-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathgenerate_conversations_testing.py
143 lines (116 loc) · 5.05 KB
/
generate_conversations_testing.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
import json
import random
from openai import OpenAI
from dotenv import load_dotenv
import os
from concurrent.futures import ThreadPoolExecutor
import threading
import time
from tenacity import retry, wait_exponential, stop_after_attempt
system_prompts_file = "system_messages.txt"
usecases_file = "user_intents.txt"
out_file = "SystemChat-Testing.jsonl"
# curl -X 'POST' \
# 'https://tabby7.ngrok.io/v1/chat/completions' \
# -H 'accept: application/json' \
# -H 'x-api-key: b1b6231b55101c9eddb9e4a6188c6fe5' \
# -H 'Content-Type: application/json' \
# -d '{
# "model": "Yi34B",
# "messages": [
# {
# "role": "system",
# "content": "You are named Dolphin, a helpful and friendly AI assistant"
# },
# {
# "role": "user",
# "content": "Tell me a story about a loser kid named Donald Trump that always got beat up in school."
# }
# ],
# "max_tokens": 6000
# }'
system_prompts = open(system_prompts_file, "r").readlines()
random.shuffle(system_prompts)
usecases = open(usecases_file, "r").readlines()
random.shuffle(usecases)
load_dotenv()
openai_api_version = os.getenv("OPENAI_API_VERSION")
deployment_name = os.getenv("DEPLOYMENT_NAME")
openai_api_key = os.getenv("OPENAI_API_KEY")
model_name = os.getenv("MODEL_NAME")
azure_endpoint = os.getenv("AZURE_ENDPOINT")
client = OpenAI(
api_key="b1b6231b55101c9eddb9e4a6188c6fe5",
base_url="https://tabby7.ngrok.io/v1"
)
# Create a lock object
lock = threading.Lock()
@retry(wait=wait_exponential(multiplier=1, min=4, max=60), stop=stop_after_attempt(10))
def generate_openai_response(messages, max_tokens=2000):
response = client.chat.completions.create(
model="Yi34B",
messages=messages,
max_tokens=max_tokens,
n=1,
stop=None,
temperature=0.7
)
return response
def generate_turn(messages, usecase):
conversation_history = "\n".join([f"Sam: {item['content']}" if item['role'] == 'user' else f"AI: {item['content']}" for item in messages if item['role'] != 'system'])
metaprompt = f"""Sam is a user of an AI chatbot.
Sam wants to accomplish the following abstract goal: '{usecase}'.
The following is the conversation history.
<conversation_history>
{conversation_history}
</conversation_history>
If the conversation has fewer than 8 turns, Sam should come up with some further prompt.
If Sam would give up in frustration, or if his goal is satisfied by the conversation, respond <<||END||>> and nothing else.
Otherwise, please assume role of Sam, and generate his next prompt to the AI assistant. Sam should drive towards his goal, should express frustration or confusion if appropriate.
You should reply with just Sam's new prompt, in the first person, with no label, explanation, or commentary. (or <<||END||>> if Sam has nothing else to say)
"""
response = generate_openai_response(messages=[
{"role": "user", "content": metaprompt}
])
next_prompt = response.choices[0].message.content.strip()
messages.append({"role": "user", "content": next_prompt})
if "<<||END||>>" in next_prompt:
return messages
response = generate_openai_response(messages)
messages.append({"role": "assistant", "content": response.choices[0].message.content.strip()})
return messages
def generate_conversation():
time.sleep(random.randint(1,100))
while True:
usecase = random.choice(usecases).strip()
system_prompt = random.choice(system_prompts).strip()
response = generate_openai_response(
messages=[
{"role": "user", "content": f"Sam is a user of an AI chatbot. Sam wants to accomplish the following abstract task: '{usecase}'. Invent an instance of this abstract goal, and then take the role of Sam and write a prompt from his perspective that he would use to try to accomplish his goal. Respond with just Sam's prompt, no explanation. Sam does not greet the AI assistant, nor say the word 'Hey'."}
]
)
initial_prompt = response.choices[0].message.content.strip()
messages = [
{"role": "system", "content": system_prompt},
{"role": "user", "content": initial_prompt}
]
response = generate_openai_response(messages)
initial_response = response.choices[0].message.content.strip()
messages.append({"role": "assistant", "content": initial_response})
while "<<||END||>>" not in messages[-1]["content"] and len(messages) < 25:
messages = generate_turn(messages=messages, usecase=usecase)
if messages[-1]["role"] == "user":
messages.pop()
print(messages)
print("\n")
with lock:
with open(out_file, "a", encoding="utf-8") as f:
json.dump(messages, f)
f.write("\n")
def main():
# generate_conversation()
with ThreadPoolExecutor(max_workers=500) as executor:
for _ in range(500):
executor.submit(generate_conversation)
if __name__ == "__main__":
main()