Rizz / run.py
aliabid94's picture
aliabid94 HF staff
Upload folder using huggingface_hub
08d94c4 verified
import api
import gradio as gr
import random
with gr.Blocks() as demo:
with gr.Column() as setup_col:
gr.HTML("<h1 style='text-align: center; margin-top: 1em; font-size: 2em;'>Rizz++</h1>")
gr.Markdown("Rizz++ simulates conversations you might have when approaching someone you're interested in, helping you develop your skills. \nRandomly generate a scenario involving...")
with gr.Row():
approach_girl = gr.Button("Approaching a Girl")
approach_boy = gr.Button("Approaching a Boy")
gr.Markdown("...or enter your own scenario:")
with gr.Group():
custom_scenario = gr.Textbox(lines=3, label="Scenario", placeholder="There's a cute girl in my boxing class I want to talk to.")
scenario_btn = gr.Button("Submit Scenario")
with gr.Column(visible=False) as convo_col:
chat = gr.Chatbot()
recording = gr.Audio(label="Your Line", sources="microphone", type="filepath")
with gr.Group():
with gr.Row():
help_btn = gr.Button("Help Me", scale=0)
suggestion = gr.Textbox(container=False, placeholder="Stuck? Let Rizz++ suggest your next line!")
@gr.on([approach_boy.click, approach_girl.click, scenario_btn.click], outputs=[setup_col, convo_col])
def start_convo():
return {
setup_col: gr.Column(visible=False),
convo_col: gr.Column(visible=True)
}
scenario = gr.State()
personality = gr.State(lambda: random.choice(["shy", "confident", "awkward", "charming", "rude"]))
interested = gr.State(lambda: random.choice([True, False]))
SCENARIO_LINE = "The scenario is: **{}** \n\n Record your opening line below!"
def start_chat(scenario):
return [[SCENARIO_LINE.format(scenario), None]]
approach_boy.click(lambda: api.generate_scenario("boy"), outputs=scenario).then(start_chat, scenario, chat)
approach_girl.click(lambda: api.generate_scenario("girl"), outputs=scenario).then(start_chat, scenario, chat)
scenario_btn.click(lambda x: x, custom_scenario, scenario).then(start_chat, scenario, chat)
def transcribe(recording, chat):
user_message = api.transcribe_audio(recording)
chat.append([user_message, None])
return chat
def respond(scenario, chat, personality, interested):
response = api.generate_response(scenario, chat[1:], personality, interested)
chat[-1][1] = response
return chat
recording.stop_recording(transcribe, inputs=[recording, chat], outputs=[chat]
).then(respond, inputs=[scenario, chat, personality, interested], outputs=[chat]
).then(lambda: None, outputs=[recording])
help_btn.click(lambda scenario, chat: api.suggest_next_line(scenario, chat[1:]), inputs=[scenario, chat], outputs=[suggestion])
demo.launch()