Spaces:
No application file
No application file
| import streamlit as st | |
| from transformers import AutoTokenizer, AutoModelForCausalLM | |
| from peft import PeftModel | |
| import torch | |
| repo_id = "muhammadjasim12/incometaxcassendra" | |
| st.set_page_config(page_title="Income Tax Chatbot", page_icon="ποΈ") | |
| st.title("ποΈ Income Tax AI Assistant") | |
| st.caption("Section 8.1 of Income Tax Assessment Act 1997") | |
| with st.sidebar: | |
| st.header("βοΈ Settings") | |
| max_tokens = st.slider("Max tokens", 50, 300, 200) | |
| if st.button("ποΈ Clear"): | |
| st.session_state.messages = [] | |
| st.rerun() | |
| def load_model(): | |
| tokenizer = AutoTokenizer.from_pretrained("TinyLlama/TinyLlama-1.1B-Chat-v1.0") | |
| base = AutoModelForCausalLM.from_pretrained( | |
| "TinyLlama/TinyLlama-1.1B-Chat-v1.0", | |
| torch_dtype=torch.float16, | |
| device_map="cpu" | |
| ) | |
| model = PeftModel.from_pretrained(base, repo_id) | |
| model.eval() | |
| return tokenizer, model | |
| tokenizer, model = load_model() | |
| st.success("β Model ready!") | |
| if "messages" not in st.session_state: | |
| st.session_state.messages = [] | |
| for msg in st.session_state.messages: | |
| with st.chat_message(msg["role"]): | |
| st.write(msg["content"]) | |
| if prompt := st.chat_input("Ask about Section 8.1..."): | |
| st.session_state.messages.append({"role": "user", "content": prompt}) | |
| with st.chat_message("user"): | |
| st.write(prompt) | |
| with st.chat_message("assistant"): | |
| with st.spinner("Thinking..."): | |
| formatted = f"<|system|>\nAnswer ONLY based on Section 8.1 of the Income Tax Assessment Act 1997.\n<|user|>\n{prompt}\n<|assistant|>\n" | |
| inputs = tokenizer(formatted, return_tensors="pt") | |
| with torch.no_grad(): | |
| output = model.generate(**inputs, max_new_tokens=max_tokens, do_sample=False, pad_token_id=tokenizer.eos_token_id) | |
| answer = tokenizer.decode(output[0], skip_special_tokens=True).split("<|assistant|>")[-1].strip() | |
| st.write(answer) | |
| st.session_state.messages.append({"role": "assistant", "content": answer}) |