def detect_intent_audio(agent, session_id, audio_file_path, language_code): """Returns the result of detect intent with an audio file as input. Using the same `session_id` between requests allows continuation of the conversation.""" session_client = SessionsClient() session_path = f"{agent}/sessions/{session_id}" print(f"Session path: {session_path}\n") input_audio_config = audio_config.InputAudioConfig( audio_encoding=audio_config.AudioEncoding.AUDIO_ENCODING_LINEAR_16, sample_rate_hertz=24000, ) with open(audio_file_path, "rb") as audio_file: input_audio = audio_file.read() audio_input = session.AudioInput(config=input_audio_config, audio=input_audio) query_input = session.QueryInput(audio=audio_input, language_code=language_code) request = session.DetectIntentRequest(session=session_path, query_input=query_input) response = session_client.detect_intent(request=request) print("=" * 20) print(f"Query text: {response.query_result.transcript}") response_messages = [ " ".join(msg.text.text) for msg in response.query_result.response_messages ] print(f"Response text: {' '.join(response_messages)}\n")
def detect_intent_texts(agent, session_id, text, language_code): """Returns the result of detect intent with texts as inputs. Using the same `session_id` between requests allows continuation of the conversation.""" session_path = f"{agent}/sessions/{session_id}" print(f"Session path: {session_path}\n") client_options = None agent_components = AgentsClient.parse_agent_path(agent) location_id = agent_components["location"] if location_id != "global": api_endpoint = f"{location_id}-dialogflow.googleapis.com:443" print(f"API Endpoint: {api_endpoint}\n") client_options = {"api_endpoint": api_endpoint} session_client = SessionsClient(client_options=client_options) text_input = session.TextInput(text=text) query_input = session.QueryInput(text=text_input, language_code=language_code) request = session.DetectIntentRequest(session=session_path, query_input=query_input) response = session_client.detect_intent(request=request) print("=" * 20) print(f"Query text: {response.query_result.text}") response_messages = [ " ".join(msg.text.text) for msg in response.query_result.response_messages ] print(f"Response text: {' '.join(response_messages)}\n") return response
def discord_response(user, message_contents): """Returns the result of detect intent with texts as inputs. Using the same `session_id` between requests allows continuation of the conversation.""" session_path = f"{agent}/sessions/{session_id}" #print(f"Session path: {session_path}\n") client_options = None agent_components = AgentsClient.parse_agent_path(agent) location_id = agent_components["location"] if location_id != "global": api_endpoint = f"{location_id}-dialogflow.googleapis.com:443" print(f"API Endpoint: {api_endpoint}\n") client_options = {"api_endpoint": api_endpoint} session_client = SessionsClient(client_options=client_options) input_string = message_contents image_float = analyze_sentiment(user, input_string) text_input = session.TextInput(text=input_string) query_input = session.QueryInput(text=text_input, language_code=language_code) request = session.DetectIntentRequest( session=session_path, query_input=query_input ) response = session_client.detect_intent(request=request) #print("=" * 20) #print(f"Query text: {response.query_result.text}") response_messages = [ " ".join(msg.text.text) for msg in response.query_result.response_messages ] return ((os.getcwd() + find_emotion_gif(image_float)), f"{' '.join(response_messages)}\n")
def request_generator(): audio_input = session.AudioInput(config=input_audio_config) query_input = session.QueryInput(audio=audio_input, language_code=language_code) voice_selection = audio_config.VoiceSelectionParams() synthesize_speech_config = audio_config.SynthesizeSpeechConfig() output_audio_config = audio_config.OutputAudioConfig() # Sets the voice name and gender voice_selection.name = "en-GB-Standard-A" voice_selection.ssml_gender = ( audio_config.SsmlVoiceGender.SSML_VOICE_GENDER_FEMALE) synthesize_speech_config.voice = voice_selection # Sets the audio encoding output_audio_config.audio_encoding = ( audio_config.OutputAudioEncoding.OUTPUT_AUDIO_ENCODING_UNSPECIFIED) output_audio_config.synthesize_speech_config = synthesize_speech_config # The first request contains the configuration. yield session.StreamingDetectIntentRequest( session=session_path, query_input=query_input, output_audio_config=output_audio_config, ) # Here we are reading small chunks of audio data from a local # audio file. In practice these chunks should come from # an audio input device. with open(audio_file_path, "rb") as audio_file: while True: chunk = audio_file.read(4096) if not chunk: break # The later requests contains audio data. audio_input = session.AudioInput(audio=chunk) query_input = session.QueryInput(audio=audio_input) yield session.StreamingDetectIntentRequest( query_input=query_input)
def request_generator(): audio_input = session.AudioInput(config=input_audio_config) query_input = session.QueryInput(audio=audio_input, language_code=language_code) # The first request contains the configuration. yield session.StreamingDetectIntentRequest(session=session_path, query_input=query_input) # Here we are reading small chunks of audio data from a local # audio file. In practice these chunks should come from # an audio input device. with open(audio_file_path, "rb") as audio_file: while True: chunk = audio_file.read(4096) if not chunk: break # The later requests contains audio data. audio_input = session.AudioInput(audio=chunk) query_input = session.QueryInput(audio=audio_input) yield session.StreamingDetectIntentRequest( query_input=query_input)
def detect_intent(user): #, agent, session_id, language_code """Returns the result of detect intent with texts as inputs. Using the same `session_id` between requests allows continuation of the conversation.""" session_path = f"{agent}/sessions/{session_id}" print(f"Session path: {session_path}\n") client_options = None agent_components = AgentsClient.parse_agent_path(agent) location_id = agent_components["location"] if location_id != "global": api_endpoint = f"{location_id}-dialogflow.googleapis.com:443" print(f"API Endpoint: {api_endpoint}\n") client_options = {"api_endpoint": api_endpoint} session_client = SessionsClient(client_options=client_options) input_string = input("Enter your prompt for bitberg") while(input_string != 'close'): image_float = analyze_sentiment(user, input_string) text_input = session.TextInput(text=input_string) query_input = session.QueryInput(text=text_input, language_code=language_code) request = session.DetectIntentRequest( session=session_path, query_input=query_input ) response = session_client.detect_intent(request=request) #display image somehow # # ### display_gif(find_emotion_gif(image_float)) # # if -1.0 < image_float < -0.5: __display_gif('angry') #display angry elif image_float < 0.0: __display_gif('sad') #display sad elif image_float < 0.5: __display_gif('bored') #display bored else: __display_gif('happy') #display happy print("=" * 20) print(f"Query text: {response.query_result.text}") response_messages = [ " ".join(msg.text.text) for msg in response.query_result.response_messages ] print(f"Response text: {' '.join(response_messages)}\n") input_string = input()
def detect_intent_audio(agent, session_id, audio_file_path, language_code): """Returns the result of detect intent with an audio file as input. Using the same `session_id` between requests allows continuation of the conversation.""" session_path = f"{agent}/sessions/{session_id}" print(f"Session path: {session_path}\n") client_options = None agent_components = AgentsClient.parse_agent_path(agent) location_id = agent_components["location"] if location_id != "global": api_endpoint = f"{location_id}-dialogflow.googleapis.com:443" print(f"API Endpoint: {api_endpoint}\n") client_options = {"api_endpoint": api_endpoint} session_client = SessionsClient(client_options=client_options) input_audio_config = audio_config.InputAudioConfig( audio_encoding=audio_config.AudioEncoding.AUDIO_ENCODING_LINEAR_16, sample_rate_hertz=24000, ) with open(audio_file_path, "rb") as audio_file: input_audio = audio_file.read() audio_input = session.AudioInput(config=input_audio_config, audio=input_audio) query_input = session.QueryInput(audio=audio_input, language_code=language_code) request = session.DetectIntentRequest(session=session_path, query_input=query_input) response = session_client.detect_intent(request=request) print("=" * 20) print(f"Query text: {response.query_result.transcript}") response_messages = [ " ".join(msg.text.text) for msg in response.query_result.response_messages ] print(f"Response text: {' '.join(response_messages)}\n")
def detect_intent_text(agent, session_id, text, language_code): """Returns the result of detect intent with texts as inputs. Using the same `session_id` between requests allows continuation of the conversation.""" session_path = f"{agent}/sessions/{session_id}" client_options = None agent_components = AgentsClient.parse_agent_path(agent) location_id = agent_components["location"] if location_id != "global": api_endpoint = f"{location_id}-dialogflow.googleapis.com:443" client_options = {"api_endpoint": api_endpoint} session_client = SessionsClient(client_options=client_options) text_input = session.TextInput(text=text) query_input = session.QueryInput(text=text_input, language_code=language_code) my_request = session.DetectIntentRequest( session=session_path, query_input=query_input ) response = session_client.detect_intent(request=my_request) serializable_messages = [proto.Message.to_dict(message) for message in \ response.query_result.response_messages] return json.dumps({'messages':serializable_messages})
def detect_intent_texts(agent, session_id, texts, language_code): """Returns the result of detect intent with texts as inputs. Using the same `session_id` between requests allows continuation of the conversation.""" session_client = SessionsClient() session_path = f"{agent}/sessions/{session_id}" print(f"Session path: {session_path}\n") for text in texts: text_input = session.TextInput(text=text) query_input = session.QueryInput(text=text_input, language_code=language_code) request = session.DetectIntentRequest(session=session_path, query_input=query_input) response = session_client.detect_intent(request=request) print("=" * 20) print(f"Query text: {response.query_result.text}") response_messages = [ " ".join(msg.text.text) for msg in response.query_result.response_messages ] print(f"Response text: {' '.join(response_messages)}\n")