Spaces:
Build error
Build error
Update actions/actions.py
Browse files- actions/actions.py +19 -51
actions/actions.py
CHANGED
|
@@ -32,13 +32,14 @@ openai.api_key = secret_value_0
|
|
| 32 |
# Provide your OpenAI API key
|
| 33 |
|
| 34 |
#model_engine="text-davinci-002"
|
| 35 |
-
def generate_openai_response(
|
| 36 |
"""Generate a response using the OpenAI API."""
|
| 37 |
|
| 38 |
-
|
| 39 |
|
|
|
|
| 40 |
#results = main_search(query)
|
| 41 |
-
results = main_search(
|
| 42 |
|
| 43 |
# Create context from the results
|
| 44 |
context = "".join([f"#{str(i)}" for i in results])[:2014] # Trim the context to 2014 characters - Modify as necessory
|
|
@@ -52,8 +53,8 @@ def generate_openai_response(conversation_data, model_engine="gpt-3.5-turbo", ma
|
|
| 52 |
#prompt_template = f"Using Relevant context:{context}\n\n and Previous User Query: {previous_user_query}\n\n Answer the next question in detail:{current_user_query}"
|
| 53 |
messages=[
|
| 54 |
{"role": "system", "content": f"You are Omdi, a helpful assistant answers Omdena questions Using Relevant context:{context}"},
|
| 55 |
-
{"role": "user", "content":
|
| 56 |
-
{"role": "user", "content":
|
| 57 |
]
|
| 58 |
# Generate a response using the OpenAI API
|
| 59 |
response = openai.ChatCompletion.create(
|
|
@@ -78,11 +79,21 @@ class GetOpenAIResponse(Action):
|
|
| 78 |
tracker: Tracker,
|
| 79 |
domain: Dict[Text, Any]) -> List[Dict[Text, Any]]:
|
| 80 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 81 |
# Use OpenAI API to generate a response
|
| 82 |
#query = tracker.latest_message.get('text')
|
| 83 |
-
|
| 84 |
-
#response = generate_openai_response(conversation_data[0])
|
| 85 |
-
response = conversation_data
|
| 86 |
|
| 87 |
# Output the generated response to user
|
| 88 |
dispatcher.utter_message(text=str(response))
|
|
@@ -228,46 +239,3 @@ class SayHelloWorld(Action):
|
|
| 228 |
# Output the generated response to user
|
| 229 |
generated_text = response.choices[0].text
|
| 230 |
dispatcher.utter_message(text=generated_text)
|
| 231 |
-
|
| 232 |
-
def extract_conversation_history(dispatcher: CollectingDispatcher, tracker: Tracker, domain: Dict[Text, Any]) -> Dict[Text, Any]:
|
| 233 |
-
conversation_history = tracker.events
|
| 234 |
-
|
| 235 |
-
user_queries = []
|
| 236 |
-
bot_responses = []
|
| 237 |
-
current_user_query = ""
|
| 238 |
-
previous_user_query = None
|
| 239 |
-
previous_bot_response = None
|
| 240 |
-
|
| 241 |
-
for event in conversation_history:
|
| 242 |
-
if event.get("event") == "user":
|
| 243 |
-
user_queries.append(event.get("text"))
|
| 244 |
-
elif event.get("event") == "bot":
|
| 245 |
-
bot_responses.append(event.get("text"))
|
| 246 |
-
|
| 247 |
-
if user_queries:
|
| 248 |
-
if len(user_queries) >= 2:
|
| 249 |
-
previous_user_query = user_queries[-2]
|
| 250 |
-
else:
|
| 251 |
-
pass
|
| 252 |
-
|
| 253 |
-
try:
|
| 254 |
-
current_user_query = user_queries[-1]
|
| 255 |
-
except:
|
| 256 |
-
pass
|
| 257 |
-
|
| 258 |
-
if bot_responses:
|
| 259 |
-
if len(bot_responses) >= 2:
|
| 260 |
-
previous_bot_response = bot_responses[-2]
|
| 261 |
-
else:
|
| 262 |
-
pass
|
| 263 |
-
else:
|
| 264 |
-
pass
|
| 265 |
-
|
| 266 |
-
conversation_data = {
|
| 267 |
-
"previous_user_query": previous_user_query,
|
| 268 |
-
"previous_bot_response": previous_bot_response,
|
| 269 |
-
"current_user_query": current_user_query
|
| 270 |
-
}
|
| 271 |
-
|
| 272 |
-
# Now you can use the conversation_data dictionary as needed.
|
| 273 |
-
return conversation_data
|
|
|
|
| 32 |
# Provide your OpenAI API key
|
| 33 |
|
| 34 |
#model_engine="text-davinci-002"
|
| 35 |
+
def generate_openai_response(user_queries, model_engine="gpt-3.5-turbo", max_tokens=256, temperature=0.5):
|
| 36 |
"""Generate a response using the OpenAI API."""
|
| 37 |
|
| 38 |
+
|
| 39 |
|
| 40 |
+
# Run the main function from search_content.py and store the results in a variable
|
| 41 |
#results = main_search(query)
|
| 42 |
+
results = main_search(user_queries[-1])
|
| 43 |
|
| 44 |
# Create context from the results
|
| 45 |
context = "".join([f"#{str(i)}" for i in results])[:2014] # Trim the context to 2014 characters - Modify as necessory
|
|
|
|
| 53 |
#prompt_template = f"Using Relevant context:{context}\n\n and Previous User Query: {previous_user_query}\n\n Answer the next question in detail:{current_user_query}"
|
| 54 |
messages=[
|
| 55 |
{"role": "system", "content": f"You are Omdi, a helpful assistant answers Omdena questions Using Relevant context:{context}"},
|
| 56 |
+
{"role": "user", "content": user_queries[-2]},
|
| 57 |
+
{"role": "user", "content": user_queries[-1]}
|
| 58 |
]
|
| 59 |
# Generate a response using the OpenAI API
|
| 60 |
response = openai.ChatCompletion.create(
|
|
|
|
| 79 |
tracker: Tracker,
|
| 80 |
domain: Dict[Text, Any]) -> List[Dict[Text, Any]]:
|
| 81 |
|
| 82 |
+
# Extract conversation data
|
| 83 |
+
conversation_history = tracker.events
|
| 84 |
+
|
| 85 |
+
user_queries = []
|
| 86 |
+
bot_responses = []
|
| 87 |
+
|
| 88 |
+
for event in conversation_history:
|
| 89 |
+
if event.get("event") == "user":
|
| 90 |
+
user_queries.append(event.get("text"))
|
| 91 |
+
elif event.get("event") == "bot":
|
| 92 |
+
bot_responses.append(event.get("text"))
|
| 93 |
+
|
| 94 |
# Use OpenAI API to generate a response
|
| 95 |
#query = tracker.latest_message.get('text')
|
| 96 |
+
response = generate_openai_response(user_queries)
|
|
|
|
|
|
|
| 97 |
|
| 98 |
# Output the generated response to user
|
| 99 |
dispatcher.utter_message(text=str(response))
|
|
|
|
| 239 |
# Output the generated response to user
|
| 240 |
generated_text = response.choices[0].text
|
| 241 |
dispatcher.utter_message(text=generated_text)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|