8.6 KiB
Text to speech - အတု IoT စက်ပစ္စည်း
ဒီသင်ခန်းစာအပိုင်းမှာ သင်သည် စကားကို အသံအဖြစ် ပြောင်းလဲရန် speech service ကို အသုံးပြု၍ ကုဒ်ရေးမည်။
စကားကို အသံအဖြစ် ပြောင်းလဲခြင်း
မကြာသေးမီ သင်ခန်းစာတွင် စကားကို အသံအဖြစ် ပြောင်းလဲရန် အသုံးပြုခဲ့သော speech services SDK ကို အသံကို ပြန်လည် စကားအဖြစ် ပြောင်းလဲရန် အသုံးပြုနိုင်သည်။ အသံတောင်းဆိုရာတွင် အသံဖန်တီးရန် အသုံးပြုမည့် အသံကို သတ်မှတ်ပေးရန် လိုအပ်သည်။
အသံဖန်တီးနိုင်သော အသံများသည် ဘာသာစကားတစ်ခုစီအတွက် မတူကွဲပြားပြီး speech services SDK မှ ဘာသာစကားတစ်ခုစီအတွက် ထောက်ပံ့ထားသော အသံများစာရင်းကို ရယူနိုင်သည်။
လုပ်ငန်း - စကားကို အသံအဖြစ် ပြောင်းလဲခြင်း
-
smart-timer
project ကို VS Code တွင် ဖွင့်ပြီး terminal တွင် virtual environment ကို load လုပ်ထားပါ။ -
azure.cognitiveservices.speech
package မှSpeechSynthesizer
ကို ရှိပြီးသား imports တွင် ထည့်သွင်းပါ။from azure.cognitiveservices.speech import SpeechConfig, SpeechRecognizer, SpeechSynthesizer
-
say
function အပေါ်တွင် speech synthesizer အတွက် အသုံးပြုမည့် speech configuration ကို ဖန်တီးပါ။speech_config = SpeechConfig(subscription=speech_api_key, region=location) speech_config.speech_synthesis_language = language speech_synthesizer = SpeechSynthesizer(speech_config=speech_config)
ဒါဟာ recognizer မှ အသုံးပြုခဲ့သော API key, location နှင့် language တူညီသည်။
-
ဒီအောက်တွင် အသံတစ်ခုကို ရယူပြီး speech config တွင် သတ်မှတ်ရန် အောက်ပါကုဒ်ကို ထည့်ပါ။
voices = speech_synthesizer.get_voices_async().get().voices first_voice = next(x for x in voices if x.locale.lower() == language.lower()) speech_config.speech_synthesis_voice_name = first_voice.short_name
ဒါဟာ ရရှိနိုင်သော အသံများစာရင်းအားလုံးကို ရယူပြီး အသုံးပြုနေသော ဘာသာစကားနှင့် ကိုက်ညီသော ပထမဆုံးအသံကို ရှာဖွေသည်။
💁 Microsoft Docs တွင် Language and voice support documentation မှ ထောက်ပံ့ထားသော အသံများစာရင်းအားလုံးကို ရယူနိုင်သည်။ သင်တစ်ခုခုကို သတ်မှတ်ထားသော အသံကို အသုံးပြုလိုပါက ဒီ function ကို ဖယ်ရှားပြီး documentation မှ voice name ကို hard code လုပ်နိုင်သည်။ ဥပမာ:
speech_config.speech_synthesis_voice_name = 'hi-IN-SwaraNeural'
-
say
function ၏ အကြောင်းအရာများကို SSML ဖန်တီးရန် update လုပ်ပါ။ssml = f'<speak version=\'1.0\' xml:lang=\'{language}\'>' ssml += f'<voice xml:lang=\'{language}\' name=\'{first_voice.short_name}\'>' ssml += text ssml += '</voice>' ssml += '</speak>'
-
ဒီအောက်တွင် speech recognition ကို ရပ်ထားပြီး SSML ကို ပြောဆိုပါ၊ ပြီးလျှင် recognition ကို ပြန်စတင်ပါ။
recognizer.stop_continuous_recognition() speech_synthesizer.speak_ssml(ssml) recognizer.start_continuous_recognition()
စကားပြောနေစဉ် timer စတင်ခြင်းကို အသံထွက်မပြုရန် recognition ကို ရပ်ထားသည်။ ဒါဟာ LUIS သို့ ပို့ပေးပြီး အသစ်သော timer တစ်ခုကို သတ်မှတ်ရန် တောင်းဆိုမှုအဖြစ် အလွဲသတ်မှတ်ခြင်းကို ရှောင်ရှားရန်ဖြစ်သည်။
💁 recognition ရပ်ထားခြင်းနှင့် ပြန်စတင်ခြင်းကို comment ထည့်ပြီး စမ်းသပ်နိုင်သည်။ timer တစ်ခုကို သတ်မှတ်ပြီး သင်တွေ့ရမည်မှာ timer စတင်ခြင်းကို အသံထွက်ပြောဆိုပြီး အသစ်သော timer တစ်ခုကို သတ်မှတ်ခြင်းဖြစ်သည်။ ဒါဟာ အသံထွက်ပြောဆိုမှုများနှင့် timer အသစ်များကို အဆုံးမရှိအတိုင်း ဆက်လက်လုပ်ဆောင်သွားမည်။
-
app ကို run လုပ်ပြီး function app ကိုလည်း run လုပ်ထားပါ။ timer များကို သတ်မှတ်ပြီး သင်၏ timer သတ်မှတ်ပြီးကြောင်း အသံထွက်ပြောဆိုမှုကို ကြားရမည်။ timer ပြီးဆုံးသောအခါ အသံထွက်ပြောဆိုမှုတစ်ခုကိုလည်း ကြားရမည်။
💁 ဒီကုဒ်ကို code-spoken-response/virtual-iot-device folder တွင် ရှာနိုင်သည်။
😀 သင်၏ timer program အောင်မြင်ခဲ့ပါပြီ!
အကြောင်းကြားချက်:
ဤစာရွက်စာတမ်းကို AI ဘာသာပြန်ဝန်ဆောင်မှု Co-op Translator ကို အသုံးပြု၍ ဘာသာပြန်ထားပါသည်။ ကျွန်ုပ်တို့သည် တိကျမှုအတွက် ကြိုးစားနေသော်လည်း၊ အလိုအလျောက် ဘာသာပြန်မှုများတွင် အမှားများ သို့မဟုတ် မတိကျမှုများ ပါဝင်နိုင်သည်ကို သတိပြုပါ။ မူရင်းဘာသာစကားဖြင့် ရေးသားထားသော စာရွက်စာတမ်းကို အာဏာတရ အရင်းအမြစ်အဖြစ် ရှုလေ့လာသင့်ပါသည်။ အရေးကြီးသော အချက်အလက်များအတွက် လူက ဘာသာပြန်မှု ဝန်ဆောင်မှုကို အသုံးပြုရန် အကြံပြုပါသည်။ ဤဘာသာပြန်မှုကို အသုံးပြုခြင်းမှ ဖြစ်ပေါ်လာသော အလွဲအလွတ်များ သို့မဟုတ် အနားယူမှုများအတွက် ကျွန်ုပ်တို့သည် တာဝန်မယူပါ။