Spaces:
Build error
Build error
File size: 2,706 Bytes
b0c4baa 397d198 b0c4baa 397d198 b0c4baa 397d198 b0c4baa 397d198 82555d7 397d198 82555d7 397d198 82555d7 397d198 82555d7 397d198 82555d7 397d198 82555d7 397d198 |
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 |
import json
import random
import speech_recognition as sr
import edge_tts
import asyncio
import tempfile
# Load the food menu from menu.json
with open("menu.json") as f:
food_menu = json.load(f)
# Function to get food suggestions based on user input
def get_food_suggestion(food_type, filter_type):
if food_type in food_menu:
return random.choice(food_menu[food_type].get(filter_type, []))
return "No suggestion available"
# Speech-to-Text function
def recognize_speech_from_mic():
recognizer = sr.Recognizer()
with sr.Microphone() as source:
print("Say something!")
audio = recognizer.listen(source)
try:
return recognizer.recognize_google(audio) # Use Google Speech Recognition
except sr.UnknownValueError:
return "Sorry I didn't catch that"
except sr.RequestError:
return "Sorry, I'm having trouble reaching the service"
# Text-to-Speech function
async def text_to_speech(text):
communicate = edge_tts.Communicate(text, "en-US-AriaNeural", rate="0%", pitch="0Hz")
with tempfile.NamedTemporaryFile(delete=False, suffix=".mp3") as tmp_file:
tmp_path = tmp_file.name
await communicate.save(tmp_path)
return tmp_path
# AI Food Ordering Assistant Function
async def food_order_assistant(audio_input, food_type):
# Greeting and introduction
greeting_text = "Welcome to the restaurant! What would you like to order today? Are you looking for Vegan, Halal, or Guilt-Free options?"
audio_path = await text_to_speech(greeting_text)
# Recognize customer's preference (Vegan, Halal, Guilt-Free)
dietary_preference = recognize_speech_from_mic().lower()
if dietary_preference not in ["vegan", "halal", "guilt-free"]:
dietary_preference = "vegan" # Default to Vegan if unrecognized
# Get food suggestion based on preference
suggestion = get_food_suggestion(food_type, dietary_preference)
suggestion_text = f"I suggest you try {suggestion}. Does that sound good?"
suggestion_audio = await text_to_speech(suggestion_text)
# Wait for customer confirmation
confirmation = recognize_speech_from_mic().lower()
if "yes" in confirmation:
confirmation_text = f"Your order for {suggestion} has been confirmed. Sending the order to the kitchen."
confirmation_audio = await text_to_speech(confirmation_text)
# Simulate sending order to kitchen
return confirmation_audio, f"Confirmed order: {suggestion}"
else:
cancellation_text = "Okay, let's try again."
cancellation_audio = await text_to_speech(cancellation_text)
return cancellation_audio, "Order not confirmed"
|