You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
IoT-For-Beginners/translations/bn/6-consumer/lessons/3-spoken-feedback/wio-terminal-set-timer.md

301 lines
17 KiB

<!--
CO_OP_TRANSLATOR_METADATA:
{
"original_hash": "012b69d57d898d670adf61304f42a137",
"translation_date": "2025-08-27T13:50:49+00:00",
"source_file": "6-consumer/lessons/3-spoken-feedback/wio-terminal-set-timer.md",
"language_code": "bn"
}
-->
# টাইমার সেট করুন - Wio Terminal
এই পাঠের এই অংশে, আপনি আপনার সার্ভারলেস কোড কল করবেন বক্তৃতা বুঝতে এবং ফলাফলের উপর ভিত্তি করে আপনার Wio Terminal-এ একটি টাইমার সেট করবেন।
## টাইমার সেট করুন
বক্তৃতা থেকে টেক্সটে রূপান্তরিত হওয়া টেক্সটটি আপনার সার্ভারলেস কোডে পাঠাতে হবে যাতে এটি LUIS দ্বারা প্রক্রিয়াকৃত হয় এবং টাইমারের জন্য সেকেন্ডের সংখ্যা ফেরত পাওয়া যায়। এই সেকেন্ডের সংখ্যা টাইমার সেট করতে ব্যবহার করা যেতে পারে।
মাইক্রোকন্ট্রোলারগুলোতে সাধারণত Arduino-তে মাল্টিপল থ্রেডের জন্য নেটিভ সাপোর্ট থাকে না, তাই Python বা অন্যান্য উচ্চ-স্তরের ভাষায় কোডিং করার সময় যেমন স্ট্যান্ডার্ড টাইমার ক্লাস পাওয়া যায়, তেমনটি এখানে নেই। এর পরিবর্তে, আপনি টাইমার লাইব্রেরি ব্যবহার করতে পারেন যা `loop` ফাংশনে অতিবাহিত সময় পরিমাপ করে কাজ করে এবং সময় শেষ হলে ফাংশন কল করে।
### কাজ - টেক্সটটি সার্ভারলেস ফাংশনে পাঠান
1. যদি এটি ইতিমধ্যে খোলা না থাকে, তাহলে VS Code-এ `smart-timer` প্রজেক্টটি খুলুন।
1. `config.h` হেডার ফাইলটি খুলুন এবং আপনার ফাংশন অ্যাপের URL যোগ করুন:
```cpp
const char *TEXT_TO_TIMER_FUNCTION_URL = "<URL>";
```
`<URL>`-এর জায়গায় আপনার ফাংশন অ্যাপের URL বসান, যা আপনি আগের পাঠের শেষ ধাপে পেয়েছিলেন, যা আপনার লোকাল মেশিনের IP ঠিকানার দিকে নির্দেশ করে যেখানে ফাংশন অ্যাপটি চলছে।
1. `src` ফোল্ডারে একটি নতুন ফাইল তৈরি করুন যার নাম হবে `language_understanding.h`। এটি একটি ক্লাস সংজ্ঞায়িত করতে ব্যবহৃত হবে যা স্বীকৃত বক্তৃতাকে আপনার ফাংশন অ্যাপে পাঠাবে এবং LUIS ব্যবহার করে সেকেন্ডে রূপান্তর করবে।
1. এই ফাইলের শীর্ষে নিম্নলিখিত কোড যোগ করুন:
```cpp
#pragma once
#include <Arduino.h>
#include <ArduinoJson.h>
#include <HTTPClient.h>
#include <WiFiClient.h>
#include "config.h"
```
এটি প্রয়োজনীয় কিছু হেডার ফাইল অন্তর্ভুক্ত করে।
1. `LanguageUnderstanding` নামে একটি ক্লাস সংজ্ঞায়িত করুন এবং এই ক্লাসের একটি ইনস্ট্যান্স ঘোষণা করুন:
```cpp
class LanguageUnderstanding
{
public:
private:
};
LanguageUnderstanding languageUnderstanding;
```
1. আপনার ফাংশন অ্যাপ কল করতে, একটি WiFi ক্লায়েন্ট ঘোষণা করতে হবে। ক্লাসের `private` সেকশনে নিম্নলিখিত কোড যোগ করুন:
```cpp
WiFiClient _client;
```
1. `public` সেকশনে, `GetTimerDuration` নামে একটি মেথড ঘোষণা করুন যা ফাংশন অ্যাপ কল করবে:
```cpp
int GetTimerDuration(String text)
{
}
```
1. `GetTimerDuration` মেথডে, ফাংশন অ্যাপে পাঠানোর জন্য JSON তৈরি করতে নিম্নলিখিত কোড যোগ করুন:
```cpp
DynamicJsonDocument doc(1024);
doc["text"] = text;
String body;
serializeJson(doc, body);
```
এটি `GetTimerDuration` মেথডে পাঠানো টেক্সটকে নিম্নলিখিত JSON-এ রূপান্তর করে:
```json
{
"text" : "<text>"
}
```
যেখানে `<text>` হলো ফাংশনে পাঠানো টেক্সট।
1. এর নিচে, ফাংশন অ্যাপ কল করার জন্য নিম্নলিখিত কোড যোগ করুন:
```cpp
HTTPClient httpClient;
httpClient.begin(_client, TEXT_TO_TIMER_FUNCTION_URL);
int httpResponseCode = httpClient.POST(body);
```
এটি একটি POST রিকোয়েস্ট তৈরি করে, JSON বডি পাঠায় এবং রেসপন্স কোড পায়।
1. এর নিচে নিম্নলিখিত কোড যোগ করুন:
```cpp
int seconds = 0;
if (httpResponseCode == 200)
{
String result = httpClient.getString();
Serial.println(result);
DynamicJsonDocument doc(1024);
deserializeJson(doc, result.c_str());
JsonObject obj = doc.as<JsonObject>();
seconds = obj["seconds"].as<int>();
}
else
{
Serial.print("Failed to understand text - error ");
Serial.println(httpResponseCode);
}
```
এই কোডটি রেসপন্স কোড চেক করে। যদি এটি 200 (সফল) হয়, তাহলে টাইমারের জন্য সেকেন্ডের সংখ্যা রেসপন্স বডি থেকে পাওয়া যায়। অন্যথায় একটি ত্রুটি সিরিয়াল মনিটরে পাঠানো হয় এবং সেকেন্ডের সংখ্যা 0 সেট করা হয়।
1. এই মেথডের শেষে নিম্নলিখিত কোড যোগ করুন যা HTTP সংযোগ বন্ধ করে এবং সেকেন্ডের সংখ্যা রিটার্ন করে:
```cpp
httpClient.end();
return seconds;
```
1. `main.cpp` ফাইলে এই নতুন হেডারটি অন্তর্ভুক্ত করুন:
```cpp
#include "speech_to_text.h"
```
1. `processAudio` ফাংশনের শেষে, `GetTimerDuration` মেথড কল করুন টাইমারের সময়কাল পেতে:
```cpp
int total_seconds = languageUnderstanding.GetTimerDuration(text);
```
এটি `SpeechToText` ক্লাস থেকে প্রাপ্ত টেক্সটকে টাইমারের সেকেন্ডের সংখ্যায় রূপান্তর করে।
### কাজ - টাইমার সেট করুন
সেকেন্ডের সংখ্যা টাইমার সেট করতে ব্যবহার করা যেতে পারে।
1. `platformio.ini` ফাইলে নিম্নলিখিত লাইব্রেরি ডিপেনডেন্সি যোগ করুন একটি টাইমার সেট করার জন্য:
```ini
contrem/arduino-timer @ 2.3.0
```
1. `main.cpp` ফাইলে এই লাইব্রেরির জন্য একটি ইনক্লুড ডিরেক্টিভ যোগ করুন:
```cpp
#include <arduino-timer.h>
```
1. `processAudio` ফাংশনের উপরে নিম্নলিখিত কোড যোগ করুন:
```cpp
auto timer = timer_create_default();
```
এই কোডটি একটি `timer` নামে টাইমার ঘোষণা করে।
1. এর নিচে নিম্নলিখিত কোড যোগ করুন:
```cpp
void say(String text)
{
Serial.print("Saying ");
Serial.println(text);
}
```
এই `say` ফাংশনটি ভবিষ্যতে টেক্সটকে বক্তৃতায় রূপান্তর করবে, তবে আপাতত এটি সিরিয়াল মনিটরে পাঠানো টেক্সট লিখবে।
1. `say` ফাংশনের নিচে নিম্নলিখিত কোড যোগ করুন:
```cpp
bool timerExpired(void *announcement)
{
say((char *)announcement);
return false;
}
```
এটি একটি কলব্যাক ফাংশন যা টাইমার শেষ হলে কল করা হবে। এটি একটি বার্তা পাস করে যা টাইমার শেষ হলে বলা হবে। টাইমার পুনরাবৃত্তি করতে পারে, এবং এই কলব্যাকের রিটার্ন ভ্যালু দ্বারা এটি নিয়ন্ত্রণ করা যায় - এটি `false` রিটার্ন করে, যা টাইমারকে পুনরায় চালাতে না বলে।
1. `processAudio` ফাংশনের শেষে নিম্নলিখিত কোড যোগ করুন:
```cpp
if (total_seconds == 0)
{
return;
}
int minutes = total_seconds / 60;
int seconds = total_seconds % 60;
```
এই কোডটি মোট সেকেন্ডের সংখ্যা চেক করে, এবং যদি এটি 0 হয়, তাহলে ফাংশন কল থেকে রিটার্ন করে যাতে কোনো টাইমার সেট না হয়। এটি মোট সেকেন্ডের সংখ্যাকে মিনিট এবং সেকেন্ডে রূপান্তর করে।
1. এর নিচে, টাইমার শুরু হলে বলার জন্য একটি বার্তা তৈরি করতে নিম্নলিখিত কোড যোগ করুন:
```cpp
String begin_message;
if (minutes > 0)
{
begin_message += minutes;
begin_message += " minute ";
}
if (seconds > 0)
{
begin_message += seconds;
begin_message += " second ";
}
begin_message += "timer started.";
```
1. এর নিচে, টাইমার শেষ হলে বলার জন্য অনুরূপ কোড যোগ করুন:
```cpp
String end_message("Times up on your ");
if (minutes > 0)
{
end_message += minutes;
end_message += " minute ";
}
if (seconds > 0)
{
end_message += seconds;
end_message += " second ";
}
end_message += "timer.";
```
1. এর পরে, টাইমার শুরু হওয়ার বার্তা বলুন:
```cpp
say(begin_message);
```
1. এই ফাংশনের শেষে, টাইমার শুরু করুন:
```cpp
timer.in(total_seconds * 1000, timerExpired, (void *)(end_message.c_str()));
```
এটি টাইমার ট্রিগার করে। টাইমারটি মিলিসেকেন্ড ব্যবহার করে সেট করা হয়, তাই মোট সেকেন্ডের সংখ্যা 1,000 দ্বারা গুণ করা হয় মিলিসেকেন্ডে রূপান্তর করতে। `timerExpired` ফাংশনটি কলব্যাক হিসাবে পাস করা হয়, এবং `end_message` কলব্যাকের কাছে পাস করার জন্য একটি আর্গুমেন্ট হিসাবে পাস করা হয়। এই কলব্যাক শুধুমাত্র `void *` আর্গুমেন্ট গ্রহণ করে, তাই স্ট্রিংটি উপযুক্তভাবে রূপান্তরিত হয়।
1. অবশেষে, টাইমারকে *টিক* করতে হবে, এবং এটি `loop` ফাংশনের শেষে নিম্নলিখিত কোড যোগ করে করা হয়:
```cpp
timer.tick();
```
1. এই কোডটি বিল্ড করুন, এটি আপনার Wio Terminal-এ আপলোড করুন এবং সিরিয়াল মনিটরের মাধ্যমে এটি পরীক্ষা করুন। একবার আপনি সিরিয়াল মনিটরে `Ready` দেখতে পেলে, C বোতামটি চাপুন (বাম দিকে, পাওয়ার সুইচের সবচেয়ে কাছের বোতাম), এবং কথা বলুন। 4 সেকেন্ডের অডিও ধারণ করা হবে, টেক্সটে রূপান্তরিত হবে, তারপর আপনার ফাংশন অ্যাপে পাঠানো হবে, এবং একটি টাইমার সেট করা হবে। নিশ্চিত করুন যে আপনার ফাংশন অ্যাপ লোকালভাবে চলছে।
আপনি দেখতে পাবেন কখন টাইমার শুরু হয় এবং কখন শেষ হয়।
```output
--- Available filters and text transformations: colorize, debug, default, direct, hexlify, log2file, nocontrol, printable, send_on_enter, time
--- More details at http://bit.ly/pio-monitor-filters
--- Miniterm on /dev/cu.usbmodem1101 9600,8,N,1 ---
--- Quit: Ctrl+C | Menu: Ctrl+T | Help: Ctrl+T followed by Ctrl+H ---
Connecting to WiFi..
Connected!
Got access token.
Ready.
Starting recording...
Finished recording
Sending speech...
Speech sent!
{"RecognitionStatus":"Success","DisplayText":"Set a 2 minute and 27 second timer.","Offset":4700000,"Duration":35300000}
Set a 2 minute and 27 second timer.
{"seconds": 147}
2 minute 27 second timer started.
Times up on your 2 minute 27 second timer.
```
> 💁 আপনি এই কোডটি [code-timer/wio-terminal](../../../../../6-consumer/lessons/3-spoken-feedback/code-timer/wio-terminal) ফোল্ডারে খুঁজে পেতে পারেন।
😀 আপনার টাইমার প্রোগ্রাম সফল হয়েছে!
---
**অস্বীকৃতি**:
এই নথিটি AI অনুবাদ পরিষেবা [Co-op Translator](https://github.com/Azure/co-op-translator) ব্যবহার করে অনুবাদ করা হয়েছে। আমরা যথাসম্ভব সঠিক অনুবাদের চেষ্টা করি, তবে অনুগ্রহ করে মনে রাখবেন যে স্বয়ংক্রিয় অনুবাদে ত্রুটি বা অসঙ্গতি থাকতে পারে। নথিটির মূল ভাষায় থাকা সংস্করণটিকেই প্রামাণিক উৎস হিসেবে বিবেচনা করা উচিত। গুরুত্বপূর্ণ তথ্যের জন্য, পেশাদার মানব অনুবাদ ব্যবহার করার পরামর্শ দেওয়া হচ্ছে। এই অনুবাদ ব্যবহারের ফলে সৃষ্ট কোনো ভুল বোঝাবুঝি বা ভুল ব্যাখ্যার জন্য আমরা দায়ী নই।