|
import streamlit as st |
|
import chatbot_bedrock as demo_chat |
|
from transformers import AutoModelForCausalLM, AutoTokenizer |
|
|
|
st.title("Hi, I am Chatbot Philio :mermaid:") |
|
st.write("I am your hotel booking assistant for today.") |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
model = demo_chat.get_Model() |
|
|
|
|
|
with st.container(): |
|
st.markdown('<div class="scrollable-div">', unsafe_allow_html=True) |
|
|
|
if 'memory' not in st.session_state: |
|
st.write("Memory is initilizing ...") |
|
st.session_state.memory = demo_chat.demo_miny_memory(model) |
|
|
|
|
|
if 'chat_history' not in st.session_state: |
|
st.session_state.chat_history = [ ] |
|
|
|
if 'model' not in st.session_state: |
|
st.session_state.model = model |
|
|
|
|
|
for message in st.session_state.chat_history: |
|
with st.chat_message(message["role"]): |
|
st.write(message["content"]) |
|
|
|
|
|
input_text = st.chat_input(placeholder="Here you can chat with Llamma 2 model.") |
|
|
|
if input_text: |
|
with st.chat_message("user"): |
|
st.write(input_text) |
|
st.session_state.chat_history.append({"role" : "user", "content" : input_text}) |
|
|
|
chat_response = demo_chat.demo_chain(input_text=input_text, memory=st.session_state.memory, model= st.session_state.model) |
|
first_answer = chat_response.split("Human")[0] |
|
|
|
with st.chat_message("assistant"): |
|
st.write(first_answer) |
|
st.session_state.chat_history.append({"role": "assistant", "content": first_answer}) |
|
st.markdown('</div>', unsafe_allow_html=True) |