Page 501 - 3-2
P. 501

audio_interface.terminate()
            # [END audio_stream]






            def request_stream(data_stream, rate, interim_results=True):
                """Yields `StreamingRecognizeRequest`s constructed from a recording audio

                stream.
                Args:

                    data_stream: A generator that yields raw audio data to send.
                    rate: The sampling rate in hertz.

                    interim_results: Whether to return intermediate results, before the
                        transcription is finalized.

                """
                # The initial request must contain metadata about the stream, so the

                # server knows how to interpret it.
                recognition_config = cloud_speech_pb2.RecognitionConfig(

                    # There are a bunch of config options you can specify. See
                    # https://goo.gl/KPZn97 for the full list.

                    encoding='LINEAR16', # raw 16-bit signed LE samples
                    sample_rate=rate, # the rate in hertz

                    # See http://g.co/cloud/speech/docs/languages
                    # for a list of supported languages.

                    language_code='ko-KR', # a BCP-47 language tag
                )

                streaming_config = cloud_speech_pb2.StreamingRecognitionConfig(
                    interim_results=interim_results,

                    config=recognition_config,
                )



                yield cloud_speech_pb2.StreamingRecognizeRequest(

                    streaming_config=streaming_config)



                for data in data_stream:
                    # Subsequent requests can all just have the content

                    yield cloud_speech_pb2.StreamingRecognizeRequest(audio_content=data)





                                                         - 501 -
   496   497   498   499   500   501   502   503   504   505   506