-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
Copy pathMission903Solutions.py
167 lines (134 loc) · 6.85 KB
/
Mission903Solutions.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
from openai import OpenAI
import tiktoken
import json
from datetime import datetime
import os
import streamlit as st
DEFAULT_API_KEY = os.environ.get("TOGETHER_API_KEY")
DEFAULT_BASE_URL = "https://api.together.xyz/v1"
DEFAULT_MODEL = "meta-llama/Llama-3-8b-chat-hf"
DEFAULT_TEMPERATURE = 0.7
DEFAULT_MAX_TOKENS = 512
DEFAULT_TOKEN_BUDGET = 4096
class ConversationManager:
def __init__(self, api_key=None, base_url=None, model=None, history_file=None, temperature=None, max_tokens=None, token_budget=None):
if not api_key:
api_key = DEFAULT_API_KEY
if not base_url:
base_url = DEFAULT_BASE_URL
self.client = OpenAI(
api_key=api_key,
base_url=base_url
)
self.model = model if model else DEFAULT_MODEL
self.temperature = temperature if temperature else DEFAULT_TEMPERATURE
self.max_tokens = max_tokens if max_tokens else DEFAULT_MAX_TOKENS
self.token_budget = token_budget if token_budget else DEFAULT_TOKEN_BUDGET
self.system_messages = {
"sassy_assistant": "You are a sassy assistant that is fed up with answering questions.",
"angry_assistant": "You are an angry assistant that likes yelling in all caps.",
"thoughtful_assistant": "You are a thoughtful assistant, always ready to dig deeper. You ask clarifying questions to ensure understanding and approach problems with a step-by-step methodology.",
"custom": "Enter your custom system message here."
}
self.system_message = self.system_messages["sassy_assistant"] # Default persona
self.conversation_history = [{"role": "system", "content": self.system_message}]
def count_tokens(self, text):
try:
encoding = tiktoken.encoding_for_model(self.model)
except KeyError:
encoding = tiktoken.get_encoding("cl100k_base")
tokens = encoding.encode(text)
return len(tokens)
def total_tokens_used(self):
try:
return sum(self.count_tokens(message['content']) for message in self.conversation_history)
except Exception as e:
print(f"An unexpected error occurred while calculating the total tokens used: {e}")
return None
def enforce_token_budget(self):
try:
while self.total_tokens_used() > self.token_budget:
if len(self.conversation_history) <= 1:
break
self.conversation_history.pop(1)
except Exception as e:
print(f"An unexpected error occurred while enforcing the token budget: {e}")
def set_persona(self, persona):
if persona in self.system_messages:
self.system_message = self.system_messages[persona]
self.update_system_message_in_history()
else:
raise ValueError(f"Unknown persona: {persona}. Available personas are: {list(self.system_messages.keys())}")
def set_custom_system_message(self, custom_message):
if not custom_message:
raise ValueError("Custom message cannot be empty.")
self.system_messages['custom'] = custom_message
self.set_persona('custom')
def update_system_message_in_history(self):
try:
if self.conversation_history and self.conversation_history[0]["role"] == "system":
self.conversation_history[0]["content"] = self.system_message
else:
self.conversation_history.insert(0, {"role": "system", "content": self.system_message})
except Exception as e:
print(f"An unexpected error occurred while updating the system message in the conversation history: {e}")
def chat_completion(self, prompt, temperature=None, max_tokens=None, model=None):
temperature = temperature if temperature is not None else self.temperature
max_tokens = max_tokens if max_tokens is not None else self.max_tokens
model = model if model is not None else self.model
self.conversation_history.append({"role": "user", "content": prompt})
self.enforce_token_budget()
try:
response = self.client.chat.completions.create(
model=model,
messages=self.conversation_history,
temperature=temperature,
max_tokens=max_tokens,
)
except Exception as e:
print(f"An error occurred while generating a response: {e}")
return None
ai_response = response.choices[0].message.content
self.conversation_history.append({"role": "assistant", "content": ai_response})
return ai_response
def reset_conversation_history(self):
self.conversation_history = [{"role": "system", "content": self.system_message}]
### Streamlit code ###
st.title("Sassy Chatbot :face_with_rolling_eyes:")
# Sidebar
st.sidebar.header("Options")
# Initialize the ConversationManager object
if 'chat_manager' not in st.session_state:
st.session_state['chat_manager'] = ConversationManager()
chat_manager = st.session_state['chat_manager']
# Set the token budget, max tokens per message, and temperature with sliders
max_tokens_per_message = st.sidebar.slider("Max Tokens Per Message", min_value=10, max_value=500, value=50)
temperature = st.sidebar.slider("Temperature", min_value=0.0, max_value=1.0, value=0.7, step=0.01)
# Select and set system message with a selectbox
system_message = st.sidebar.selectbox("System message", ['Sassy', 'Angry', 'Thoughtful', 'Custom'])
if system_message == 'Sassy':
chat_manager.set_persona('sassy_assistant')
elif system_message == 'Angry':
chat_manager.set_persona('angry_assistant')
elif system_message == 'Thoughtful':
chat_manager.set_persona('thoughtful_assistant')
# Open text area for custom system message if "Custom" is selected
elif system_message == 'Custom':
custom_message = st.sidebar.text_area("Custom system message")
if st.sidebar.button("Set custom system message"):
chat_manager.set_custom_system_message(custom_message)
if st.sidebar.button("Reset conversation history", on_click=chat_manager.reset_conversation_history):
st.session_state['conversation_history'] = chat_manager.conversation_history
if 'conversation_history' not in st.session_state:
st.session_state['conversation_history'] = chat_manager.conversation_history
conversation_history = st.session_state['conversation_history']
# Chat input from the user
user_input = st.chat_input("Write a message")
# Call the chat manager to get a response from the AI. Uses settings from the sidebar.
if user_input:
response = chat_manager.chat_completion(user_input, temperature=temperature, max_tokens=max_tokens_per_message)
# Display the conversation history
for message in conversation_history:
if message["role"] != "system":
with st.chat_message(message["role"]):
st.write(message["content"])