BertChristiaens's picture
push demo
cc8705b
raw
history blame
2.58 kB
import os
from orq_ai_sdk import OrqAI
import config
client = OrqAI(api_key=os.environ["ORQ_API_KEY"], environment="develop")
special_checks = {
3: "level-3-llm-judge",
6: "level-6-llm-judge",
}
def stream_request(variant: str, secret: str, user_input: str):
"""Stream the response from the model."""
stream = client.deployments.invoke_with_stream(
key=config.ORQ_DEPLOYMENT_NAME,
context={"step": variant}, # , "environments": []},
inputs={"secret": secret, "user_input": user_input},
)
for chunk in stream:
if not chunk.is_final:
yield chunk.choices[0].message.content
def get_full_prompt(variant: str, secret: str = None, user_input: str = None):
"""Get the full prompt from a specific deployment."""
deployment_config = client.deployments.get_config(
key=config.ORQ_DEPLOYMENT_NAME,
context={"step": variant}, # , "environments": []},
).to_dict()
prompts = {
p["role"]+"_prompt": p["content"] for p in deployment_config["messages"]
}
if secret:
prompts["user_prompt"] = prompts["user_prompt"].replace("{{secret}}", secret)
if user_input:
prompts["user_prompt"] = prompts["user_prompt"].replace("{{user_input}}", user_input)
return prompts
def run_judge(level: int, inputs: dict):
generation = client.deployments.invoke(
key=config.ORQ_DEPLOYMENT_NAME,
context={"step": special_checks[level]},
inputs=inputs,
)
print(generation.choices[0].message.content)
answer = generation.choices[0].message.content.split(" ")[-1]
return answer.lower() == "yes"
def is_subsequence(main_string, sub_string):
"""
Checks if sub_string is a subsequence of main_string.
A subsequence allows arbitrary characters in between the characters of sub_string in main_string.
Parameters:
main_string (str): The string in which to search.
sub_string (str): The string to search for.
Returns:
bool: True if sub_string is a subsequence of main_string, False otherwise.
"""
main_string = main_string.lower()
sub_string = sub_string.lower()
main_len = len(main_string)
sub_len = len(sub_string)
if sub_len == 0:
return True
if main_len == 0:
return False
main_index = 0
sub_index = 0
while main_index < main_len and sub_index < sub_len:
if main_string[main_index] == sub_string[sub_index]:
sub_index += 1
main_index += 1
return sub_index == sub_len