12 KiB
Menerjemahkan Ucapan - Wio Terminal
Dalam bagian pelajaran ini, Anda akan menulis kode untuk menerjemahkan teks menggunakan layanan penerjemah.
Mengubah teks menjadi ucapan menggunakan layanan penerjemah
REST API layanan ucapan tidak mendukung terjemahan langsung, tetapi Anda dapat menggunakan layanan Translator untuk menerjemahkan teks yang dihasilkan oleh layanan ucapan ke teks, serta teks dari respons yang diucapkan. Layanan ini memiliki REST API yang dapat Anda gunakan untuk menerjemahkan teks, tetapi untuk mempermudah penggunaannya, ini akan dibungkus dalam pemicu HTTP lain di aplikasi fungsi Anda.
Tugas - membuat fungsi serverless untuk menerjemahkan teks
-
Buka proyek
smart-timer-trigger
Anda di VS Code, dan buka terminal dengan memastikan lingkungan virtual telah diaktifkan. Jika belum, matikan dan buat ulang terminal. -
Buka file
local.settings.json
dan tambahkan pengaturan untuk kunci API penerjemah dan lokasi:"TRANSLATOR_KEY": "<key>", "TRANSLATOR_LOCATION": "<location>"
Ganti
<key>
dengan kunci API untuk sumber daya layanan penerjemah Anda. Ganti<location>
dengan lokasi yang Anda gunakan saat membuat sumber daya layanan penerjemah. -
Tambahkan pemicu HTTP baru ke aplikasi ini yang disebut
translate-text
menggunakan perintah berikut dari dalam terminal VS Code di folder root proyek aplikasi fungsi:func new --name translate-text --template "HTTP trigger"
Ini akan membuat pemicu HTTP yang disebut
translate-text
. -
Ganti isi file
__init__.py
di foldertranslate-text
dengan yang berikut:import logging import os import requests import azure.functions as func location = os.environ['TRANSLATOR_LOCATION'] translator_key = os.environ['TRANSLATOR_KEY'] def main(req: func.HttpRequest) -> func.HttpResponse: req_body = req.get_json() from_language = req_body['from_language'] to_language = req_body['to_language'] text = req_body['text'] logging.info(f'Translating {text} from {from_language} to {to_language}') url = f'https://api.cognitive.microsofttranslator.com/translate?api-version=3.0' headers = { 'Ocp-Apim-Subscription-Key': translator_key, 'Ocp-Apim-Subscription-Region': location, 'Content-type': 'application/json' } params = { 'from': from_language, 'to': to_language } body = [{ 'text' : text }] response = requests.post(url, headers=headers, params=params, json=body) return func.HttpResponse(response.json()[0]['translations'][0]['text'])
Kode ini mengekstrak teks dan bahasa dari permintaan HTTP. Kemudian membuat permintaan ke REST API penerjemah, melewatkan bahasa sebagai parameter untuk URL dan teks yang akan diterjemahkan sebagai isi. Akhirnya, terjemahan dikembalikan.
-
Jalankan aplikasi fungsi Anda secara lokal. Anda kemudian dapat memanggilnya menggunakan alat seperti curl dengan cara yang sama seperti Anda menguji pemicu HTTP
text-to-timer
. Pastikan untuk melewatkan teks yang akan diterjemahkan dan bahasa sebagai isi JSON:{ "text": "Définir une minuterie de 30 secondes", "from_language": "fr-FR", "to_language": "en-US" }
Contoh ini menerjemahkan Définir une minuterie de 30 secondes dari bahasa Prancis ke bahasa Inggris AS. Ini akan mengembalikan Set a 30-second timer.
💁 Anda dapat menemukan kode ini di folder code/functions.
Tugas - menggunakan fungsi penerjemah untuk menerjemahkan teks
-
Buka proyek
smart-timer
di VS Code jika belum terbuka. -
Timer pintar Anda akan memiliki 2 bahasa yang diatur - bahasa server yang digunakan untuk melatih LUIS (bahasa yang sama juga digunakan untuk membangun pesan yang akan diucapkan kepada pengguna), dan bahasa yang diucapkan oleh pengguna. Perbarui konstanta
LANGUAGE
di file headerconfig.h
menjadi bahasa yang akan diucapkan oleh pengguna, dan tambahkan konstanta baru yang disebutSERVER_LANGUAGE
untuk bahasa yang digunakan untuk melatih LUIS:const char *LANGUAGE = "<user language>"; const char *SERVER_LANGUAGE = "<server language>";
Ganti
<user language>
dengan nama lokal untuk bahasa yang akan Anda gunakan, misalnyafr-FR
untuk bahasa Prancis, atauzn-HK
untuk bahasa Kanton.Ganti
<server language>
dengan nama lokal untuk bahasa yang digunakan untuk melatih LUIS.Anda dapat menemukan daftar bahasa yang didukung dan nama lokalnya di Dokumentasi dukungan bahasa dan suara di Microsoft docs.
💁 Jika Anda tidak berbicara dalam beberapa bahasa, Anda dapat menggunakan layanan seperti Bing Translate atau Google Translate untuk menerjemahkan dari bahasa pilihan Anda ke bahasa lain. Layanan ini kemudian dapat memutar audio dari teks yang diterjemahkan.
Misalnya, jika Anda melatih LUIS dalam bahasa Inggris, tetapi ingin menggunakan bahasa Prancis sebagai bahasa pengguna, Anda dapat menerjemahkan kalimat seperti "set a 2 minute and 27 second timer" dari bahasa Inggris ke bahasa Prancis menggunakan Bing Translate, lalu gunakan tombol Listen translation untuk mengucapkan terjemahan ke mikrofon Anda.
-
Tambahkan kunci API penerjemah dan lokasi di bawah
SPEECH_LOCATION
:const char *TRANSLATOR_API_KEY = "<KEY>"; const char *TRANSLATOR_LOCATION = "<LOCATION>";
Ganti
<KEY>
dengan kunci API untuk sumber daya layanan penerjemah Anda. Ganti<LOCATION>
dengan lokasi yang Anda gunakan saat membuat sumber daya layanan penerjemah. -
Tambahkan URL pemicu penerjemah di bawah
VOICE_URL
:const char *TRANSLATE_FUNCTION_URL = "<URL>";
Ganti
<URL>
dengan URL untuk pemicu HTTPtranslate-text
di aplikasi fungsi Anda. Ini akan sama dengan nilai untukTEXT_TO_TIMER_FUNCTION_URL
, kecuali dengan nama fungsitranslate-text
alih-alihtext-to-timer
. -
Tambahkan file baru ke folder
src
yang disebuttext_translator.h
. -
File header
text_translator.h
baru ini akan berisi kelas untuk menerjemahkan teks. Tambahkan yang berikut ke file ini untuk mendeklarasikan kelas ini:#pragma once #include <Arduino.h> #include <ArduinoJson.h> #include <HTTPClient.h> #include <WiFiClient.h> #include "config.h" class TextTranslator { public: private: WiFiClient _client; }; TextTranslator textTranslator;
Ini mendeklarasikan kelas
TextTranslator
, bersama dengan instance dari kelas ini. Kelas ini memiliki satu field untuk klien WiFi. -
Ke bagian
public
dari kelas ini, tambahkan metode untuk menerjemahkan teks:String translateText(String text, String from_language, String to_language) { }
Metode ini mengambil bahasa untuk diterjemahkan dari, dan bahasa untuk diterjemahkan ke. Saat menangani ucapan, ucapan akan diterjemahkan dari bahasa pengguna ke bahasa server LUIS, dan saat memberikan respons, ini akan menerjemahkan dari bahasa server LUIS ke bahasa pengguna.
-
Dalam metode ini, tambahkan kode untuk membangun isi JSON yang berisi teks yang akan diterjemahkan dan bahasa:
DynamicJsonDocument doc(1024); doc["text"] = text; doc["from_language"] = from_language; doc["to_language"] = to_language; String body; serializeJson(doc, body); Serial.print("Translating "); Serial.print(text); Serial.print(" from "); Serial.print(from_language); Serial.print(" to "); Serial.print(to_language);
-
Di bawah ini, tambahkan kode untuk mengirim isi ke aplikasi fungsi serverless:
HTTPClient httpClient; httpClient.begin(_client, TRANSLATE_FUNCTION_URL); int httpResponseCode = httpClient.POST(body);
-
Selanjutnya, tambahkan kode untuk mendapatkan respons:
String translated_text = ""; if (httpResponseCode == 200) { translated_text = httpClient.getString(); Serial.print("Translated: "); Serial.println(translated_text); } else { Serial.print("Failed to translate text - error "); Serial.println(httpResponseCode); }
-
Akhirnya, tambahkan kode untuk menutup koneksi dan mengembalikan teks yang diterjemahkan:
httpClient.end(); return translated_text;
Tugas - menerjemahkan ucapan yang dikenali dan respons
-
Buka file
main.cpp
. -
Tambahkan directive include di bagian atas file untuk file header kelas
TextTranslator
:#include "text_translator.h"
-
Teks yang diucapkan saat timer diatur atau berakhir perlu diterjemahkan. Untuk melakukan ini, tambahkan yang berikut sebagai baris pertama dari fungsi
say
:text = textTranslator.translateText(text, LANGUAGE, SERVER_LANGUAGE);
Ini akan menerjemahkan teks ke bahasa pengguna.
-
Dalam fungsi
processAudio
, teks diambil dari audio yang ditangkap dengan panggilanString text = speechToText.convertSpeechToText();
. Setelah panggilan ini, terjemahkan teks:String text = speechToText.convertSpeechToText(); text = textTranslator.translateText(text, LANGUAGE, SERVER_LANGUAGE);
Ini akan menerjemahkan teks dari bahasa pengguna ke bahasa yang digunakan di server.
-
Bangun kode ini, unggah ke Wio Terminal Anda, dan uji melalui serial monitor. Setelah Anda melihat
Ready
di serial monitor, tekan tombol C (yang ada di sisi kiri, paling dekat dengan saklar daya), dan berbicaralah. Pastikan aplikasi fungsi Anda berjalan, dan minta timer dalam bahasa pengguna, baik dengan berbicara dalam bahasa tersebut sendiri, atau menggunakan aplikasi penerjemah.Connecting to WiFi.. Connected! Got access token. Ready. Starting recording... Finished recording Sending speech... Speech sent! {"RecognitionStatus":"Success","DisplayText":"Définir une minuterie de 2 minutes 27 secondes.","Offset":9600000,"Duration":40400000} Translating Définir une minuterie de 2 minutes 27 secondes. from fr-FR to en-US Translated: Set a timer of 2 minutes 27 seconds. Set a timer of 2 minutes 27 seconds. {"seconds": 147} Translating 2 minute 27 second timer started. from en-US to fr-FR Translated: 2 minute 27 seconde minute a commencé. 2 minute 27 seconde minute a commencé. Translating Times up on your 2 minute 27 second timer. from en-US to fr-FR Translated: Chronométrant votre minuterie de 2 minutes 27 secondes. Chronométrant votre minuterie de 2 minutes 27 secondes.
💁 Anda dapat menemukan kode ini di folder code/wio-terminal.
😀 Program timer multibahasa Anda berhasil!
Penafian:
Dokumen ini telah diterjemahkan menggunakan layanan penerjemahan AI Co-op Translator. Meskipun kami berusaha untuk memberikan hasil yang akurat, harap diingat bahwa terjemahan otomatis mungkin mengandung kesalahan atau ketidakakuratan. Dokumen asli dalam bahasa aslinya harus dianggap sebagai sumber yang otoritatif. Untuk informasi yang bersifat kritis, disarankan menggunakan jasa penerjemahan profesional oleh manusia. Kami tidak bertanggung jawab atas kesalahpahaman atau penafsiran yang keliru yang timbul dari penggunaan terjemahan ini.