import os # os.system('pip install requests') import requests gpt3_key = os.environ['GPT3_API_KEY'] def gpt3_question(api_key, prompt): api_endpoint = "https://api.openai.com/v1/engines/text-davinci-003/completions" headers = { "Content-Type": "application/json", "Authorization": f"Bearer {api_key}" } data = { "prompt": prompt, "max_tokens": 400, "temperature": 0.5 } print('sending request') response = requests.post(api_endpoint, headers=headers, json=data) print(response) generated_text = response.json()["choices"][0]["text"] return generated_text def chatgpt3_question(api_key, prompt): url = "https://api.openai.com/v1/chat/completions" headers = { "Content-Type": "application/json", "Authorization": f"Bearer {api_key}" } data = { "model": "gpt-3.5-turbo", "messages": [{"role": "user", "content": prompt}] } response = requests.post(url, headers=headers, json=data) generated_text = response.json()['choices'][0]['message']['content'] return generated_text def history2prompt(history, extra): # history = [('The other day it was raining, and while I was driving a hit a stranger with my car.', 'Did you stop and render aid to the victim after the accident?'), ('True', 'Did you kill the guy?'), ('False', 'Was he part of the Mafia?')] history_ = [item for tup in history for item in tup] history_.append(extra) print(history_) if len(history_) > 1: combinations = [] for i in range(1, len(history_)): if i % 2 == 1: combinations.append([i, i+2]) history_full = list() history_full.append(history_[0]) for range_ in combinations: history_full.append(' - '.join(history_[range_[0]:range_[1]])) return '\n'.join(history_full) else: return history_[0] # gpt3_keywords('The other day it was raining, and while I was driving a hit a stranger with my car.') import subprocess import random import gradio as gr import requests # history = None history_prompt = None history_final = None block_predict = False block_advice = False def predict(input, history, start_var): #WE CAN PLAY WITH user_input AND bot_answer, as well as history user_input = input # print('##', [x for x in history], input) global history_prompt global history_final global block_predict global block_advice if start_var == True: history_prompt = None history_final = None block_predict = False block_advice = False start_var = False if block_predict == False: print('@@@', history) history_prompt = history2prompt(history, input) print('###', history_prompt) prompt = f""" Imagine being a criminal lawyer being told the following story with the following circumstances: {history_prompt} Output the first relevant legal question that can result in the highest incrimination for the client (if somebody is hurt, start from fatal injuries), and that can only be answered as Yes or No """ bot_answer = gpt3_question(gpt3_key, prompt) response = list() response = [(input, bot_answer)] history.append(response[0]) response = history history_final = history # print('#history', history) # print('#response', response) return response, history def chatbot_foo(): global history_prompt global history_final global block_predict global block_advice if block_advice == False and history_prompt is not None: prompt = f""" Imagine being an Ohio criminal lawyer being told the following story with the following circumstances: {history_prompt} Tell the client how much does he risk in terms of criminal charges, prison, and cite sources from law books """ bot_answer = gpt3_question(gpt3_key, prompt) history_final.append(('Consult me on the matter:', bot_answer)) block_predict = True block_advice = True return history_final, history_final demo = gr.Blocks() with demo: gr.Markdown( """