semantrix / pistas.py
Javierss
Add files
e2b757a
raw
history blame contribute delete
No virus
8.15 kB
import json
import os
import random
import openai
from sentence_transformers import util
from transformers import pipeline
openai.api_key = os.getenv("OPENAI_API_KEY")
def hint(secret, n, model, last_pista, lang, Config):
pista = ""
# Pistas avanzadas
if n >= 3:
j = random.randint(0, 2)
while j == last_pista:
j = random.randint(0, 2)
if j == 0:
response = openai.chat.completions.create(
model="gpt-3.5-turbo",
messages=[
{
"role": "user",
"content": Config.hint_0_0 # type: ignore
+ secret
+ Config.hint_0_1 # type: ignore
+ secret
+ Config.hint_0_2, # type: ignore
}
],
temperature=1,
max_tokens=256,
top_p=1,
frequency_penalty=0.5,
presence_penalty=0,
)
output = str(response.choices[0].message.content)
output = output.replace('"', "").replace("'", "")
if lang == 0:
output = ireplace("la " + secret, "La palabra secreta", output)
output = ireplace("las " + secret, "La palabra secreta", output)
output = ireplace("el " + secret, "La palabra secreta", output)
output = ireplace("los " + secret, "La palabra secreta", output)
output = ireplace("un " + secret, "La palabra secreta", output)
output = ireplace("una " + secret, "La palabra secreta", output)
output = ireplace("unos " + secret, "La palabra secreta", output)
output = ireplace("unas " + secret, "La palabra secreta", output)
elif lang == 1:
output = ireplace("the " + secret, "The secret word", output)
output = ireplace("a " + secret, "The secret word", output)
pista += Config.hint_0_3 + output # type: ignore
last_pista = 0
elif j == 1:
response = openai.chat.completions.create(
model="gpt-3.5-turbo",
messages=[
{
"role": "user",
"content": Config.hint_1_0 + secret + Config.hint_1_1, # type: ignore
}
],
temperature=1,
max_tokens=256,
top_p=1,
frequency_penalty=0,
presence_penalty=0,
)
output = str(response.choices[0].message.content)
pista += Config.hint_1_2 + output # type: ignore
last_pista = 1
elif j == 2:
response = openai.chat.completions.create(
model="gpt-3.5-turbo",
messages=[
{
"role": "user",
"content": Config.hint_2_0 + secret + Config.hint_2_1, # type: ignore
}
],
temperature=1,
max_tokens=256,
top_p=1,
frequency_penalty=0,
presence_penalty=0,
)
output = str(response.choices[0].message.content)
pista += Config.hint_2_2 + output # type: ignore
last_pista = 2
# Pistas iniciales
else:
j = random.randint(3, 4)
while j == last_pista:
j = random.randint(3, 4)
if j == 3:
words = []
response = openai.chat.completions.create(
model="gpt-3.5-turbo",
messages=[
{
"role": "user",
"content": Config.hint_3_0, # type: ignore
}
],
temperature=1.25,
max_tokens=256,
top_p=1,
frequency_penalty=0,
presence_penalty=0,
)
output = str(response.choices[0].message.content)
output = (output.replace(" ", "").replace(".", "")).lower()
words.extend(output.strip().split(","))
response = openai.chat.completions.create(
model="gpt-3.5-turbo",
messages=[
{
"role": "user",
"content": Config.hint_3_1 # type: ignore
+ secret
+ Config.hint_3_2, # type: ignore
}
],
temperature=1.1,
max_tokens=256,
top_p=1,
frequency_penalty=0,
presence_penalty=0,
)
output = str(response.choices[0].message.content)
output = (output.replace(".", "")).lower()
words.append(output) # type: ignore
random.shuffle(words)
sentences1 = [secret, secret, secret, secret]
sentences2 = words
embeddings1 = model.encode(sentences1, convert_to_tensor=True)
embeddings2 = model.encode(sentences2, convert_to_tensor=True)
cosine_scores = util.cos_sim(embeddings1, embeddings2)
scores = cosine_scores[0].tolist()
sum_scores = sum(scores)
normalized_scores = [round(score * 100 / sum_scores, 1) for score in scores]
pista += Config.hint_3_3 # type: ignore
for i in range(len(words)):
pista += (
words[i]
+ (" ") * (15 - len(words[i]))
+ "|"
+ ("🟩") * round(normalized_scores[i] * 0.5)
+ " "
+ str(normalized_scores[i])
+ "%\n"
)
last_pista = 3
elif j == 4:
response = openai.chat.completions.create(
model="gpt-3.5-turbo",
messages=[
{
"role": "user",
"content": Config.hint_4_0 # type: ignore
+ secret
+ Config.hint_4_1, # type: ignore
}
],
temperature=1,
max_tokens=256,
top_p=1,
frequency_penalty=0,
presence_penalty=0,
)
film_title = str(response.choices[0].message.content).replace('"', "")
response = openai.chat.completions.create(
model="gpt-3.5-turbo",
messages=[
{
"role": "user",
"content": Config.hint_4_2 # type: ignore
+ film_title
+ Config.hint_4_3, # type: ignore
}
],
temperature=1,
max_tokens=256,
top_p=1,
frequency_penalty=0,
presence_penalty=0,
)
output = str(response.choices[0].message.content)
pista += Config.hint_4_4 + film_title + "\n" + output # type: ignore
last_pista = 4
return pista, n + 1, last_pista
def curiosity(secret, Config):
response = openai.chat.completions.create(
model="gpt-3.5-turbo",
messages=[
{
"role": "user",
"content": Config.curiosity + secret + '".',
}
],
temperature=1,
max_tokens=256,
top_p=1,
frequency_penalty=0,
presence_penalty=0,
)
output = str(response.choices[0].message.content)
return output
def ireplace(old, new, text):
idx = 0
while idx < len(text):
index_l = text.lower().find(old.lower(), idx)
if index_l == -1:
return text
text = text[:index_l] + new + text[index_l + len(old) :]
idx = index_l + len(new)
return text