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/ne/6-consumer/lessons/2-language-understanding
co-op-translator[bot] 9508c7b48a
🌐 Update translations via Co-op Translator (#545)
4 weeks ago
..
README.md 🌐 Update translations via Co-op Translator (#545) 4 weeks ago
assignment.md 🌐 Update translations via Co-op Translator (#545) 4 weeks ago

README.md

भाषा बुझ्ने

यस पाठको स्केच नोटको झलक

स्केच नोट नित्या नरसिम्हन द्वारा। ठूलो संस्करण हेर्नका लागि तस्बिरमा क्लिक गर्नुहोस्।

पाठ अघि क्विज

पाठ अघि क्विज

परिचय

अघिल्लो पाठमा तपाईंले आवाजलाई पाठमा रूपान्तरण गर्नुभयो। स्मार्ट टाइमर प्रोग्राम गर्नका लागि, तपाईंको कोडले के भनिएको थियो भन्ने कुरा बुझ्न आवश्यक छ। तपाईंले प्रयोगकर्ताले "३ मिनेटको टाइमर सेट गर्नुहोस्" जस्तो निश्चित वाक्यांश बोल्नेछ भनेर मान्न सक्नुहुन्छ, र त्यस अभिव्यक्तिलाई विश्लेषण गरेर टाइमर कति समयको लागि सेट गर्नुपर्ने हो भन्ने जानकारी निकाल्न सक्नुहुन्छ। तर, यो प्रयोगकर्तामैत्री हुँदैन। यदि प्रयोगकर्ताले "३ मिनेटको लागि टाइमर सेट गर्नुहोस्" भने भने, तपाईं वा मैले यसको अर्थ बुझ्न सक्छौं, तर तपाईंको कोडले बुझ्दैन, किनभने यो निश्चित वाक्यांशको अपेक्षा गरिरहेको हुन्छ।

यही ठाउँमा भाषा बुझ्ने क्षमताको आवश्यकता पर्छ। एआई मोडेलहरूको प्रयोग गरेर पाठलाई व्याख्या गर्न र आवश्यक विवरणहरू फिर्ता गर्न सकिन्छ। उदाहरणका लागि, "३ मिनेटको टाइमर सेट गर्नुहोस्" र "टाइमर ३ मिनेटको लागि सेट गर्नुहोस्" दुबैलाई बुझेर टाइमर ३ मिनेटको लागि चाहिएको छ भन्ने कुरा निकाल्न सकिन्छ।

यस पाठमा तपाईं भाषा बुझ्ने मोडेलहरू, तिनीहरू कसरी बनाउने, प्रशिक्षण दिने, र कोडबाट कसरी प्रयोग गर्ने भन्ने कुरा सिक्नुहुनेछ।

यस पाठमा हामी निम्न विषयहरू समेट्नेछौं:

भाषा बुझ्ने

मानिसहरूले हजारौं वर्षदेखि भाषा प्रयोग गरेर संवाद गर्दै आएका छन्। हामी शब्द, ध्वनि, वा क्रियाहरू प्रयोग गरेर संवाद गर्छौं र के भनिएको छ भन्ने कुरा बुझ्छौं। यसमा शब्द, ध्वनि वा क्रियाको अर्थ मात्र होइन, तिनको सन्दर्भ पनि बुझिन्छ। हामी इमानदारी र व्यंग्य बुझ्छौं, जसले गर्दा एउटै शब्दले हाम्रो स्वरको लयअनुसार फरक अर्थ दिन सक्छ।

हालै तपाईंले गरेका केही संवादहरूको बारेमा सोच्नुहोस्। ती संवादको कति हिस्सा कम्प्युटरका लागि बुझ्न गाह्रो हुन सक्छ किनभने त्यसले सन्दर्भ आवश्यक पर्छ?

भाषा बुझ्ने, जसलाई प्राकृतिक-भाषा बुझ्ने पनि भनिन्छ, कृत्रिम बुद्धिमत्ताको एउटा क्षेत्र हो जसलाई प्राकृतिक-भाषा प्रशोधन (NLP) भनिन्छ। यसले पढ्ने क्षमतासँग सम्बन्धित छ, जसले शब्द वा वाक्यको विवरण बुझ्न प्रयास गर्दछ। यदि तपाईंले एलेक्सा वा सिरी जस्ता आवाज सहायक प्रयोग गर्नुभएको छ भने, तपाईंले भाषा बुझ्ने सेवाहरू प्रयोग गर्नुभएको छ। यी सेवाहरू "एलेक्सा, टेलर स्विफ्टको नयाँ एल्बम बजाउनुहोस्" लाई मेरो छोरीलाई उनको मनपर्ने गीतमा नाच्न लगाउने सेवामा रूपान्तरण गर्छन्।

💁 कम्प्युटरहरूले धेरै प्रगति गरे पनि, पाठलाई वास्तवमै बुझ्न अझै धेरै टाढा छन्। जब हामी कम्प्युटरसँग भाषा बुझ्ने कुरा गर्छौं, हामी मानव संवाद जत्तिकै उन्नत कुरा बुझाउँदैनौं। यसको सट्टा, हामी केही शब्दहरू लिने र मुख्य विवरणहरू निकाल्ने कुरा बुझाउँछौं।

मानिसका रूपमा, हामी भाषा बिना सोच्ने स्वाभाविक रूपमा बुझ्छौं। यदि मैले अर्को मानिसलाई "टेलर स्विफ्टको नयाँ एल्बम बजाउनुहोस्" भने भने, उनीहरूले मेरो मतलब तुरुन्तै बुझ्नेछन्। तर कम्प्युटरका लागि यो कठिन हुन्छ। यसले शब्दहरूलाई आवाजबाट पाठमा रूपान्तरण गर्नुपर्नेछ र निम्न जानकारीहरू निकाल्नुपर्नेछ:

  • संगीत बजाउनुपर्नेछ
  • संगीत कलाकार टेलर स्विफ्टको हो
  • संगीत एउटा एल्बम हो, जसमा धेरै ट्र्याकहरू छन्
  • टेलर स्विफ्टका धेरै एल्बमहरू छन्, त्यसैले तिनीहरूलाई कालानुक्रमिक रूपमा क्रमबद्ध गर्नुपर्नेछ र सबैभन्दा नयाँ प्रकाशित एल्बम चाहिएको हो

तपाईंले अनुरोध गर्दा बोलेका केही वाक्यहरूको बारेमा सोच्नुहोस्, जस्तै कफी अर्डर गर्नु वा परिवारका सदस्यलाई केही दिन भन्नु। ती वाक्यलाई कम्प्युटरले बुझ्न आवश्यक पर्ने जानकारीका टुक्राहरूमा विभाजन गर्न प्रयास गर्नुहोस्।

भाषा बुझ्ने मोडेलहरू एआई मोडेलहरू हुन् जसलाई भाषाबाट निश्चित विवरणहरू निकाल्न प्रशिक्षण दिइन्छ। यी मोडेलहरूलाई स्थानान्तरण शिक्षाको प्रयोग गरेर विशिष्ट कार्यहरूको लागि प्रशिक्षण दिइन्छ, ठीक त्यस्तै जसरी तपाईंले कस्टम भिजन मोडेललाई सानो छविहरूको सेट प्रयोग गरेर प्रशिक्षण दिनुभएको थियो। तपाईंले एउटा मोडेल लिन सक्नुहुन्छ, त्यसपछि तपाईंले बुझ्न चाहेको पाठ प्रयोग गरेर यसलाई प्रशिक्षण दिन सक्नुहुन्छ।

भाषा बुझ्ने मोडेल बनाउने

LUIS लोगो

तपाईं LUIS (भाषा बुझ्ने सेवा) प्रयोग गरेर भाषा बुझ्ने मोडेलहरू बनाउन सक्नुहुन्छ। यो माइक्रोसफ्टको कग्निटिभ सेवाहरूको हिस्सा हो।

कार्य - लेखन स्रोत बनाउनुहोस्

LUIS प्रयोग गर्नका लागि, तपाईंले लेखन स्रोत बनाउनु आवश्यक छ।

  1. आफ्नो smart-timer स्रोत समूहमा लेखन स्रोत बनाउन निम्न आदेश प्रयोग गर्नुहोस्:

    az cognitiveservices account create --name smart-timer-luis-authoring \
                                        --resource-group smart-timer \
                                        --kind LUIS.Authoring \
                                        --sku F0 \
                                        --yes \
                                        --location <location>
    

    <location> लाई स्रोत समूह बनाउँदा प्रयोग गरिएको स्थानले प्रतिस्थापन गर्नुहोस्।

    ⚠️ LUIS सबै क्षेत्रहरूमा उपलब्ध छैन, त्यसैले यदि तपाईंले निम्न त्रुटि पाउनुभयो भने:

    InvalidApiSetId: The account type 'LUIS.Authoring' is either invalid or unavailable in given region.
    

    अर्को क्षेत्र छनोट गर्नुहोस्।

    यसले निःशुल्क-स्तरको LUIS लेखन स्रोत बनाउनेछ।

कार्य - भाषा बुझ्ने एप बनाउनुहोस्

  1. आफ्नो ब्राउजरमा luis.ai पोर्टल खोल्नुहोस् र Azure प्रयोग गर्नुभएको खाताबाट साइन इन गर्नुहोस्।

  2. संवादमा दिइएका निर्देशनहरू पालना गरेर आफ्नो Azure सदस्यता चयन गर्नुहोस्, त्यसपछि तपाईंले भर्खरै बनाएको smart-timer-luis-authoring स्रोत चयन गर्नुहोस्।

  3. Conversation apps सूचीबाट, नयाँ एप बनाउन New app बटन चयन गर्नुहोस्। नयाँ एपलाई smart-timer नाम दिनुहोस् र Culture आफ्नो भाषामा सेट गर्नुहोस्।

    💁 भविष्यवाणी स्रोतको लागि एउटा फिल्ड छ। तपाईं भविष्यवाणीका लागि छुट्टै स्रोत बनाउन सक्नुहुन्छ, तर निःशुल्क लेखन स्रोतले महिनामा १, भविष्यवाणीहरू अनुमति दिन्छ, जुन विकासका लागि पर्याप्त हुनुपर्छ, त्यसैले यसलाई खाली छोड्न सक्नुहुन्छ।

  4. एप बनाइसकेपछि देखिने गाइड पढ्नुहोस् जसले भाषा बुझ्ने मोडेललाई प्रशिक्षण दिनका लागि आवश्यक चरणहरूको बारेमा जानकारी दिन्छ। गाइड पढिसकेपछि यसलाई बन्द गर्नुहोस्।

इरादा र इकाइहरू

भाषा बुझ्ने इरादा (intents) र इकाइहरू (entities) वरिपरि आधारित छ। इरादा भनेको शब्दहरूको उद्देश्य हो, जस्तै संगीत बजाउनु, टाइमर सेट गर्नु, वा खाना अर्डर गर्नु। इकाइहरू भनेको इरादाले केलाई जनाउँछ भन्ने हो, जस्तै एल्बम, टाइमरको अवधि, वा खानाको प्रकार। मोडेलले व्याख्या गर्ने प्रत्येक वाक्यमा कम्तिमा एउटा इरादा र वैकल्पिक रूपमा एक वा बढी इकाइहरू हुनुपर्छ।

केही उदाहरणहरू:

वाक्य इरादा इकाइहरू
"टेलर स्विफ्टको नयाँ एल्बम बजाउनुहोस्" संगीत बजाउनु टेलर स्विफ्टको नयाँ एल्बम
"३ मिनेटको टाइमर सेट गर्नुहोस्" टाइमर सेट गर्नु ३ मिनेट
"मेरो टाइमर रद्द गर्नुहोस्" टाइमर रद्द गर्नु कुनै पनि छैन
"३ ठूला अनानास पिज्जा र एउटा क्यesar सलाद अर्डर गर्नुहोस्" खाना अर्डर गर्नु ३ ठूला अनानास पिज्जा, क्यesar सलाद

तपाईंले पहिले सोचेका वाक्यहरूको बारेमा सोच्नुहोस्। ती वाक्यमा इरादा र कुनै इकाइहरू के हुनेछन्?

LUIS प्रशिक्षण गर्नका लागि, पहिले तपाईंले इकाइहरू सेट गर्नुहुन्छ। यी निश्चित शब्दहरूको सूची हुन सक्छ, वा पाठबाट सिक्न सकिन्छ। उदाहरणका लागि, तपाईं आफ्नो मेनुबाट उपलब्ध खानाको निश्चित सूची प्रदान गर्न सक्नुहुन्छ, प्रत्येक शब्दका भिन्नताहरू (वा पर्यायवाचीहरू) सहित, जस्तै बैंगनअउबर्जिन

टाइमर सेट गर्नका लागि, तपाईंले समयको इकाइ (मिनेट वा सेकेन्ड) र समयको संख्या (जस्तै ३ मिनेट) का लागि दुई इकाइहरू थप्न सक्नुहुन्छ।

कार्य - भाषा बुझ्ने मोडेलमा इकाइहरू थप्नुहोस्

LUIS पोर्टलमा इकाइहरू थप्नका लागि, Microsoft Docs मा Quickstart: Build your app in LUIS portal बाट निर्देशनहरू पालना गर्नुहोस्।

...

  1. Azure Resources सेक्सनबाट Authoring Resource चयन गर्नुहोस्, र Primary KeyEndpoint URL प्रतिलिपि गर्नुहोस्।

  2. आफ्नो कमाण्ड प्रम्प्ट वा टर्मिनलमा निम्न curl कमाण्ड चलाउनुहोस्:

    curl "<endpoint url>/luis/prediction/v3.0/apps/<app id>/slots/staging/predict" \
          --request GET \
          --get \
          --data "subscription-key=<primary key>" \
          --data "verbose=false" \
          --data "show-all-intents=true" \
          --data-urlencode "query=<sentence>"
    

    <endpoint url> लाई Azure Resources सेक्सनबाट प्राप्त Endpoint URL सँग बदल्नुहोस्।

    <app id> लाई Settings सेक्सनबाट प्राप्त App ID सँग बदल्नुहोस्।

    <primary key> लाई Azure Resources सेक्सनबाट प्राप्त Primary Key सँग बदल्नुहोस्।

    <sentence> लाई तपाईँले परीक्षण गर्न चाहेको वाक्य सँग बदल्नुहोस्।

  3. यो कलको आउटपुट JSON डकुमेन्ट हुनेछ जसले क्वेरी, शीर्ष intent, र प्रकार अनुसार टुक्रिएको entities को सूची विवरण दिन्छ।

    {
        "query": "set a timer for 45 minutes and 12 seconds",
        "prediction": {
            "topIntent": "set timer",
            "intents": {
                "set timer": {
                    "score": 0.97031575
                },
                "None": {
                    "score": 0.02205793
                }
            },
            "entities": {
                "number": [
                    45,
                    12
                ],
                "time-unit": [
                    [
                        "minute"
                    ],
                    [
                        "second"
                    ]
                ]
            }
        }
    }
    

    माथिको JSON set a timer for 45 minutes and 12 seconds क्वेरीबाट आएको हो:

    • set timer शीर्ष intent थियो जसको सम्भाव्यता 97% थियो।
    • दुई number entities पत्ता लागे, 4512
    • दुई time-unit entities पत्ता लागे, minutesecond

भाषा बुझ्ने मोडेल प्रयोग गर्नुहोस्

एकपटक प्रकाशित भएपछि, LUIS मोडेललाई कोडबाट कल गर्न सकिन्छ। अघिल्लो पाठहरूमा, तपाईंले IoT Hub प्रयोग गरेर क्लाउड सेवाहरू सँग संचार गर्न, टेलिमेट्री पठाउन र कमाण्डहरू सुन्न प्रयोग गर्नुभएको थियो। यो धेरै असिंक्रोनस हुन्छ - एकपटक टेलिमेट्री पठाएपछि तपाईंको कोडले प्रतिक्रिया कुर्दैन, र यदि क्लाउड सेवा डाउन छ भने, तपाईंलाई थाहा हुँदैन।

स्मार्ट टाइमरको लागि, हामी तुरुन्त प्रतिक्रिया चाहन्छौं ताकि हामी प्रयोगकर्तालाई टाइमर सेट भएको जानकारी दिन सकौं, वा क्लाउड सेवाहरू उपलब्ध नभएको चेतावनी दिन सकौं। यसका लागि, हाम्रो IoT उपकरणले IoT Hub मा निर्भर नगरी वेब Endpoint सिधै कल गर्नेछ।

IoT उपकरणबाट LUIS कल गर्ने सट्टा, तपाईंले HTTP ट्रिगर जस्तो फरक प्रकारको ट्रिगरको साथ serverless कोड प्रयोग गर्न सक्नुहुन्छ। यसले तपाईंको function app लाई REST अनुरोधहरू सुन्न र तिनीहरूलाई प्रतिक्रिया दिन अनुमति दिन्छ। यो function तपाईंको उपकरणले कल गर्न सक्ने REST Endpoint हुनेछ।

💁 यद्यपि तपाईंले IoT उपकरणबाट सिधै LUIS कल गर्न सक्नुहुन्छ, serverless कोड जस्तो केही प्रयोग गर्नु राम्रो हुन्छ। यसरी जब तपाईंले कल गर्ने LUIS एप परिवर्तन गर्न चाहनुहुन्छ, उदाहरणका लागि जब तपाईंले राम्रो मोडेल प्रशिक्षण गर्नुहुन्छ वा फरक भाषामा मोडेल प्रशिक्षण गर्नुहुन्छ, तपाईंले केवल आफ्नो क्लाउड कोड अपडेट गर्नुपर्छ, हजारौं वा लाखौं IoT उपकरणहरूमा कोड पुनः-डिप्लोय गर्न आवश्यक पर्दैन।

कार्य - serverless functions app सिर्जना गर्नुहोस्

  1. smart-timer-trigger नामको Azure Functions app सिर्जना गर्नुहोस्, र यसलाई VS Code मा खोल्नुहोस्।

  2. यस एपमा speech-trigger नामको HTTP ट्रिगर थप्नुहोस्, निम्न कमाण्ड प्रयोग गरेर VS Code टर्मिनल भित्र:

    func new --name text-to-timer --template "HTTP trigger"
    

    यसले text-to-timer नामको HTTP ट्रिगर सिर्जना गर्नेछ।

  3. Functions app चलाएर HTTP ट्रिगर परीक्षण गर्नुहोस्। जब यो चल्छ, तपाईं आउटपुटमा Endpoint सूची देख्नुहुनेछ:

    Functions:
    
            text-to-timer: [GET,POST] http://localhost:7071/api/text-to-timer
    

    यसलाई http://localhost:7071/api/text-to-timer URL आफ्नो ब्राउजरमा लोड गरेर परीक्षण गर्नुहोस्।

    This HTTP triggered function executed successfully. Pass a name in the query string or in the request body for a personalized response.
    

कार्य - भाषा बुझ्ने मोडेल प्रयोग गर्नुहोस्

  1. LUIS को लागि SDK Pip प्याकेज मार्फत उपलब्ध छ। requirements.txt फाइलमा निम्न लाइन थप्नुहोस् ताकि यस प्याकेजमा निर्भरता थप्न सकियोस्:

    azure-cognitiveservices-language-luis
    
  2. सुनिश्चित गर्नुहोस् कि VS Code टर्मिनलमा भर्चुअल वातावरण सक्रिय छ, र Pip प्याकेजहरू स्थापना गर्न निम्न कमाण्ड चलाउनुहोस्:

    pip install -r requirements.txt
    

    💁 यदि त्रुटिहरू आउँछ भने, तपाईंले निम्न कमाण्ड प्रयोग गरेर pip अपग्रेड गर्न आवश्यक हुन सक्छ:

    pip install --upgrade pip
    
  3. MANAGE ट्याबको LUIS पोर्टलबाट आफ्नो LUIS API Key, Endpoint URL, र App ID को लागि local.settings.json फाइलमा नयाँ प्रविष्टिहरू थप्नुहोस्:

    "LUIS_KEY": "<primary key>",
    "LUIS_ENDPOINT_URL": "<endpoint url>",
    "LUIS_APP_ID": "<app id>"
    

    <endpoint url> लाई MANAGE ट्याबको Azure Resources सेक्सनबाट प्राप्त Endpoint URL सँग बदल्नुहोस्। यो https://<location>.api.cognitive.microsoft.com/ हुनेछ।

    <app id> लाई MANAGE ट्याबको Settings सेक्सनबाट प्राप्त App ID सँग बदल्नुहोस्।

    <primary key> लाई MANAGE ट्याबको Azure Resources सेक्सनबाट प्राप्त Primary Key सँग बदल्नुहोस्।

  4. __init__.py फाइलमा निम्न imports थप्नुहोस्:

    import json
    import os
    from azure.cognitiveservices.language.luis.runtime import LUISRuntimeClient
    from msrest.authentication import CognitiveServicesCredentials
    

    यसले केही सिस्टम लाइब्रेरीहरू, साथै LUIS सँग अन्तरक्रिया गर्न लाइब्रेरीहरू आयात गर्दछ।

  5. main मेथडको सामग्री हटाउनुहोस्, र निम्न कोड थप्नुहोस्:

    luis_key = os.environ['LUIS_KEY']
    endpoint_url = os.environ['LUIS_ENDPOINT_URL']
    app_id = os.environ['LUIS_APP_ID']
    
    credentials = CognitiveServicesCredentials(luis_key)
    client = LUISRuntimeClient(endpoint=endpoint_url, credentials=credentials)
    

    यसले तपाईंले local.settings.json फाइलमा थप्नुभएको मानहरू लोड गर्दछ, तपाईंको API key सँग credentials object सिर्जना गर्दछ, त्यसपछि LUIS app सँग अन्तरक्रिया गर्न LUIS client object सिर्जना गर्दछ।

  6. यो HTTP ट्रिगर JSON को रूपमा बुझ्नको लागि पाठ पास गरेर कल गरिनेछ, पाठ text नामको प्रोपर्टीमा हुनेछ। HTTP अनुरोधको body बाट मान निकाल्न र कन्सोलमा लग गर्न निम्न कोड main फंक्शनमा थप्नुहोस्:

    req_body = req.get_json()
    text = req_body['text']
    logging.info(f'Request - {text}')
    
  7. LUIS मा भविष्यवाणी अनुरोध पठाएर भविष्यवाणीहरू माग गरिन्छ - भविष्यवाणी गर्न पाठ समावेश भएको JSON डकुमेन्ट। निम्न कोड प्रयोग गरेर यो सिर्जना गर्नुहोस्:

    prediction_request = { 'query' : text }
    
  8. यो अनुरोध LUIS मा पठाउन सकिन्छ, तपाईंको एप प्रकाशित गरिएको staging slot प्रयोग गरेर:

    prediction_response = client.prediction.get_slot_prediction(app_id, 'Staging', prediction_request)
    
  9. भविष्यवाणी प्रतिक्रिया शीर्ष intent समावेश गर्दछ - सबैभन्दा उच्च भविष्यवाणी स्कोर भएको intent, साथै entities। यदि शीर्ष intent set timer हो भने, entities बाट टाइमरको लागि आवश्यक समय पढ्न सकिन्छ:

    if prediction_response.prediction.top_intent == 'set timer':
        numbers = prediction_response.prediction.entities['number']
        time_units = prediction_response.prediction.entities['time unit']
        total_seconds = 0
    

    number entities संख्याहरूको array हुनेछ। उदाहरणका लागि, यदि तपाईंले "Set a four minute 17 second timer." भने, भने number array मा 2 integers - 4 र 17 हुनेछ।

    time unit entities string को array को array हुनेछ, प्रत्येक समय इकाई array भित्र string को array को रूपमा। उदाहरणका लागि, यदि तपाईंले "Set a four minute 17 second timer." भने, भने time unit array मा 2 array हुनेछ जसमा प्रत्येकमा एकल मान हुनेछ - ['minute']['second']

    "Set a four minute 17 second timer." को लागि यी entities को JSON संस्करण:

    {
        "number": [4, 17],
        "time unit": [
            ["minute"],
            ["second"]
        ]
    }
    

    यस कोडले टाइमरको कुल समय सेकेन्डमा परिभाषित गर्दछ। यो entities बाट मानहरूद्वारा भरिनेछ।

  10. Entities लिंक गरिएको छैनन्, तर हामी तिनीहरूबारे केही अनुमान गर्न सक्छौं। तिनीहरू बोलेको क्रममा हुनेछन्, त्यसैले array मा स्थिति प्रयोग गरेर कुन संख्या कुन समय इकाईसँग मेल खान्छ निर्धारण गर्न सकिन्छ। उदाहरणका लागि:

    • "Set a 30 second timer" - यसमा एक संख्या, 30, र एक समय इकाई, second हुनेछ, त्यसैले एकल संख्या एकल समय इकाईसँग मेल खानेछ।
    • "Set a 2 minute and 30 second timer" - यसमा दुई संख्या, 230, र दुई समय इकाई, minutesecond हुनेछ, त्यसैले पहिलो संख्या पहिलो समय इकाईको लागि हुनेछ (2 minutes), र दोस्रो संख्या दोस्रो समय इकाईको लागि (30 seconds)।

    निम्न कोडले संख्या entities मा वस्तुहरूको गणना प्राप्त गर्दछ, र array को पहिलो वस्तु निकाल्न प्रयोग गर्दछ, त्यसपछि दोस्रो र यस्तै। यो if ब्लक भित्र थप्नुहोस्।

    for i in range(0, len(numbers)):
        number = numbers[i]
        time_unit = time_units[i][0]
    

    "Set a four minute 17 second timer." को लागि, यो दुई पटक लूप हुनेछ, निम्न मानहरू दिनेछ:

    लूप गणना number time_unit
    0 4 minute
    1 17 second
  11. यस लूप भित्र, संख्या र समय इकाई प्रयोग गरेर टाइमरको कुल समय गणना गर्नुहोस्, प्रत्येक मिनेटको लागि 60 सेकेन्ड थप्दै, र कुनै पनि सेकेन्डको लागि सेकेन्डको संख्या।

    if time_unit == 'minute':
        total_seconds += number * 60
    else:
        total_seconds += number
    
  12. Entities को लूप बाहिर, टाइमरको कुल समय लग गर्नुहोस्:

    logging.info(f'Timer required for {total_seconds} seconds')
    
  13. सेकेन्डको संख्या HTTP प्रतिक्रिया रूपमा फंक्शनबाट फर्काउन आवश्यक छ। if ब्लकको अन्त्यमा निम्न थप्नुहोस्:

    payload = {
        'seconds': total_seconds
    }
    return func.HttpResponse(json.dumps(payload), status_code=200)
    

    यस कोडले टाइमरको कुल सेकेन्डको संख्या समावेश भएको payload सिर्जना गर्दछ, यसलाई JSON string मा रूपान्तरण गर्दछ र HTTP परिणामको रूपमा 200 स्थिति कोडको साथ फर्काउँछ, जसको अर्थ कल सफल भयो।

  14. अन्ततः, if ब्लक बाहिर, intent चिन्हित नभएको अवस्थामा त्रुटि कोड फर्काएर ह्यान्डल गर्नुहोस्:

    return func.HttpResponse(status_code=404)
    

    404 not found को स्थिति कोड हो।

  15. Functions app चलाउनुहोस् र curl प्रयोग गरेर परीक्षण गर्नुहोस्।

    curl --request POST 'http://localhost:7071/api/text-to-timer' \
         --header 'Content-Type: application/json' \
         --include \
         --data '{"text":"<text>"}'
    

    <text> लाई तपाईंको अनुरोधको पाठसँग बदल्नुहोस्, उदाहरणका लागि set a 2 minutes 27 second timer

    तपाईं functions app बाट निम्न आउटपुट देख्नुहुनेछ:

    Functions:
    
            text-to-timer: [GET,POST] http://localhost:7071/api/text-to-timer
    
    For detailed output, run func with --verbose flag.
    [2021-06-26T19:45:14.502Z] Worker process started and initialized.
    [2021-06-26T19:45:19.338Z] Host lock lease acquired by instance ID '000000000000000000000000951CAE4E'.
    [2021-06-26T19:45:52.059Z] Executing 'Functions.text-to-timer' (Reason='This function was programmatically called via the host APIs.', Id=f68bfb90-30e4-47a5-99da-126b66218e81)
    [2021-06-26T19:45:53.577Z] Timer required for 147 seconds
    [2021-06-26T19:45:53.746Z] Executed 'Functions.text-to-timer' (Succeeded, Id=f68bfb90-30e4-47a5-99da-126b66218e81, Duration=1750ms)
    

    curl को कलले निम्न फर्काउनेछ:

    HTTP/1.1 200 OK
    Date: Tue, 29 Jun 2021 01:14:11 GMT
    Content-Type: text/plain; charset=utf-8
    Server: Kestrel
    Transfer-Encoding: chunked
    
    {"seconds": 147}
    

    टाइमरको सेकेन्डको संख्या "seconds" मानमा हुनेछ।

💁 तपाईं यो कोड code/functions फोल्डरमा पाउन सक्नुहुन्छ।

कार्य - आफ्नो फंक्शनलाई IoT उपकरणमा उपलब्ध गराउनुहोस्

  1. तपाईंको IoT उपकरणले तपाईंको REST Endpoint कल गर्न, यसलाई URL थाहा हुन आवश्यक छ। जब तपाईंले यसलाई पहिले पहुँच गर्नुभयो, तपाईंले localhost प्रयोग गर्नुभयो, जुन तपाईंको स्थानीय मेसिनमा REST Endpoint पहुँच गर्न शोर्टकट हो। तपाईंको IoT उपकरणलाई पहुँच दिन, तपाईंले क्लाउडमा प्रकाशित गर्नुपर्छ, वा स्थानीय रूपमा पहुँच गर्न आफ्नो IP ठेगाना प्राप्त गर्नुपर्छ।

    ⚠️ यदि तपाईं Wio Terminal प्रयोग गर्दै हुनुहुन्छ भने, functions app स्थानीय रूपमा चलाउनु सजिलो हुन्छ, किनकि त्यहाँ लाइब्रेरीहरूमा निर्भरता हुनेछ जसले तपाईंले पहिले जस्तै functions app डिप्लोय गर्न सक्नुहुन्न। functions app स्थानीय रूपमा चलाउनुहोस् र आफ्नो कम्प्युटरको IP ठेगाना प्रयोग गरेर पहुँच गर्नुहोस्। यदि तपाईं क्लाउडमा डिप्लोय गर्न चाहनुहुन्छ भने, यसलाई कसरी गर्ने जानकारी पछि पाठमा प्रदान गरिनेछ।

    • Functions app प्रकाशित गर्नुहोस् - आफ्नो functions app क्लाउडमा प्रकाशित गर्न अघिल्लो पाठहरूमा निर्देशनहरू पालना गर्नुहोस्। एकपटक प्रकाशित भएपछि, URL https://<APP_NAME>.azurewebsites.net/api/text-to-timer हुनेछ, जहाँ <APP_NAME> तपाईंको functions app को नाम हुनेछ। सुनिश्चित गर्नुहोस् कि तपाईंले आफ्नो स्थानीय सेटिङहरू पनि प्रकाशित गर्नुभएको छ।

      HTTP ट्रिगरको साथ काम गर्दा, तिनीहरू डिफल्ट रूपमा function app key द्वारा सुरक्षित हुन्छन्। यो key प्राप्त गर्न निम्न कमाण्ड चलाउनुहोस्:

      az functionapp keys list --resource-group smart-timer \
                               --name <APP_NAME>                               
      

      functionKeys सेक्सनबाट default प्रविष्टिको मान प्रतिलिपि गर्नुहोस्।

      {
        "functionKeys": {
          "default": "sQO1LQaeK9N1qYD6SXeb/TctCmwQEkToLJU6Dw8TthNeUH8VA45hlA=="
        },
        "masterKey": "RSKOAIlyvvQEQt9dfpabJT018scaLpQu9p1poHIMCxx5LYrIQZyQ/g==",
        "systemKeys": {}
      }
      

      यो key URL मा query parameter को रूपमा थप्न आवश्यक हुनेछ, त्यसैले अन्तिम URL https://<APP_NAME>.azurewebsites.net/api/text-to-timer?code=<FUNCTION_KEY> हुनेछ, जहाँ <APP_NAME> तपाईंको functions app को नाम हुनेछ, र <FUNCTION_KEY> तपाईंको डिफल्ट function key हुनेछ।

      💁 तपाईं HTTP ट्रिगरको authorization प्रकार function.json फाइलको authlevel सेटिङ प्रयोग गरेर परिवर्तन गर्न सक्नुहुन्छ। तपाईं यसबारे थप जानकारी Microsoft docs मा Azure Functions HTTP trigger को कन्फिगरेसन सेक्सन मा पढ्न सक्नुहुन्छ।

    • Functions app स्थानीय रूपमा चलाउनुहोस्, र IP ठेगाना प्रयोग गरेर पहुँच गर्नुहोस् - तपाईं आफ्नो कम्प्युटरको स्थानीय नेटवर्कमा IP ठेगाना प्राप्त गर्न सक्नुहुन्छ, र त्यसलाई URL निर्माण गर्न प्रयोग गर्न सक्नुहुन्छ।

      आफ्नो IP ठेगाना पत्ता लगाउनुहोस्:

      एकपटक तपाईंले आफ्नो IP ठेगाना प्राप्त गर्नुभयो भने, तपाईं functions लाई http:// मा पहुँच गर्न सक्नुहुन्छ।

:7071/api/text-to-timer, जहाँ <IP_ADDRESS>तपाईंको IP ठेगाना हुनेछ, उदाहरणका लागिhttp://192.168.1.10:7071/api/text-to-timer`।

  > 💁 ध्यान दिनुहोस् कि यसले पोर्ट 7071 प्रयोग गर्दछ, त्यसैले IP ठेगानापछि `:7071` राख्न आवश्यक छ।

  > 💁 यो केवल तब काम गर्नेछ जब तपाईंको IoT उपकरण तपाईंको कम्प्युटरको समान नेटवर्कमा हो।
  1. curl प्रयोग गरेर endpoint परीक्षण गर्नुहोस्।

🚀 चुनौती

एउटा कुरा अनुरोध गर्न धेरै तरिकाहरू छन्, जस्तै टाइमर सेट गर्नु। यसलाई अनुरोध गर्ने विभिन्न तरिकाहरू सोच्नुहोस्, र तिनीहरूलाई तपाईंको LUIS एपमा उदाहरणको रूपमा प्रयोग गर्नुहोस्। यी तरिकाहरू परीक्षण गर्नुहोस्, हेर्नको लागि कि तपाईंको मोडेलले टाइमर अनुरोध गर्ने विभिन्न तरिकाहरूलाई कत्तिको राम्रोसँग सम्हाल्न सक्छ।

व्याख्यानपछिको प्रश्नोत्तर

व्याख्यानपछिको प्रश्नोत्तर

समीक्षा र आत्म अध्ययन

असाइनमेन्ट

टाइमर रद्द गर्नुहोस्


अस्वीकरण:
यो दस्तावेज़ AI अनुवाद सेवा Co-op Translator प्रयोग गरेर अनुवाद गरिएको छ। हामी यथार्थताको लागि प्रयास गर्छौं, तर कृपया ध्यान दिनुहोस् कि स्वचालित अनुवादहरूमा त्रुटि वा अशुद्धता हुन सक्छ। यसको मूल भाषा मा रहेको मूल दस्तावेज़लाई आधिकारिक स्रोत मानिनुपर्छ। महत्वपूर्ण जानकारीको लागि, व्यावसायिक मानव अनुवाद सिफारिस गरिन्छ। यस अनुवादको प्रयोगबाट उत्पन्न हुने कुनै पनि गलतफहमी वा गलत व्याख्याको लागि हामी जिम्मेवार हुने छैनौं।