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/fa/6-consumer/lessons/2-language-understanding/README.md

45 KiB

درک زبان

نمای کلی درس به صورت اسکچ‌نوت

اسکچ‌نوت توسط نیتیا ناراسیمهان. برای مشاهده نسخه بزرگ‌تر روی تصویر کلیک کنید.

آزمون پیش از درس

آزمون پیش از درس

مقدمه

در درس قبلی، شما گفتار را به متن تبدیل کردید. برای اینکه بتوانید از این قابلیت برای برنامه‌ریزی یک تایمر هوشمند استفاده کنید، کد شما باید بتواند آنچه گفته شده را درک کند. شما می‌توانید فرض کنید که کاربر یک عبارت ثابت مانند "یک تایمر سه دقیقه‌ای تنظیم کن" را می‌گوید و آن عبارت را تجزیه کنید تا مدت زمان تایمر مشخص شود، اما این روش خیلی کاربرپسند نیست. اگر کاربر بگوید "یک تایمر برای سه دقیقه تنظیم کن"، شما یا من متوجه منظور او می‌شویم، اما کد شما نمی‌تواند، زیرا انتظار یک عبارت ثابت را دارد.

اینجاست که درک زبان وارد عمل می‌شود، با استفاده از مدل‌های هوش مصنوعی برای تفسیر متن و استخراج جزئیات مورد نیاز، به عنوان مثال توانایی درک هر دو عبارت "یک تایمر سه دقیقه‌ای تنظیم کن" و "یک تایمر برای سه دقیقه تنظیم کن" و فهمیدن اینکه یک تایمر برای سه دقیقه مورد نیاز است.

در این درس، شما با مدل‌های درک زبان آشنا خواهید شد، یاد خواهید گرفت چگونه آن‌ها را ایجاد، آموزش و از آن‌ها در کد خود استفاده کنید.

در این درس به موارد زیر خواهیم پرداخت:

درک زبان

انسان‌ها برای صدها هزار سال از زبان برای ارتباط استفاده کرده‌اند. ما با کلمات، صداها یا حرکات ارتباط برقرار می‌کنیم و آنچه گفته شده را درک می‌کنیم، هم معنای کلمات، صداها یا حرکات و هم زمینه آن‌ها. ما صداقت و طعنه را درک می‌کنیم، به طوری که همان کلمات بسته به لحن صدا می‌توانند معانی متفاوتی داشته باشند.

به برخی از مکالماتی که اخیراً داشته‌اید فکر کنید. چه مقدار از مکالمه برای یک کامپیوتر سخت خواهد بود که درک کند، زیرا نیاز به زمینه دارد؟

درک زبان، که به آن درک زبان طبیعی نیز گفته می‌شود، بخشی از حوزه هوش مصنوعی به نام پردازش زبان طبیعی (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 را در luis.ai در مرورگر خود باز کنید و با همان حسابی که برای Azure استفاده کرده‌اید وارد شوید.

  2. دستورالعمل‌های موجود در دیالوگ را دنبال کنید تا اشتراک Azure خود را انتخاب کنید، سپس منبع smart-timer-luis-authoring که تازه ایجاد کرده‌اید را انتخاب کنید.

  3. از لیست اپلیکیشن‌های مکالمه، دکمه اپلیکیشن جدید را انتخاب کنید تا یک اپلیکیشن جدید ایجاد کنید. اپلیکیشن جدید را smart-timer نام‌گذاری کنید و فرهنگ را به زبان خود تنظیم کنید.

    💁 یک فیلد برای منبع پیش‌بینی وجود دارد. شما می‌توانید یک منبع دوم فقط برای پیش‌بینی ایجاد کنید، اما منبع نویسندگی رایگان اجازه ۱۰۰۰ پیش‌بینی در ماه را می‌دهد که برای توسعه کافی است، بنابراین می‌توانید این فیلد را خالی بگذارید.

  4. راهنمایی که پس از ایجاد اپلیکیشن ظاهر می‌شود را بخوانید تا با مراحل لازم برای آموزش مدل درک زبان آشنا شوید. پس از اتمام، این راهنما را ببندید.

اهداف و موجودیت‌ها

درک زبان بر اساس اهداف و موجودیت‌ها است. اهداف نشان‌دهنده قصد کلمات هستند، برای مثال پخش موسیقی، تنظیم تایمر یا سفارش غذا. موجودیت‌ها نشان‌دهنده چیزی هستند که هدف به آن اشاره دارد، مانند آلبوم، مدت زمان تایمر یا نوع غذا. هر جمله‌ای که مدل تفسیر می‌کند باید حداقل یک هدف و به صورت اختیاری یک یا چند موجودیت داشته باشد.

برخی مثال‌ها:

جمله هدف موجودیت‌ها
"آخرین آلبوم تیلور سویفت را پخش کن" پخش موسیقی آخرین آلبوم تیلور سویفت
"یک تایمر سه دقیقه‌ای تنظیم کن" تنظیم تایمر سه دقیقه
"تایمر من را لغو کن" لغو تایمر هیچ
"سه پیتزای بزرگ با آناناس و یک سالاد سزار سفارش بده" سفارش غذا سه پیتزای بزرگ با آناناس، سالاد سزار

با جملاتی که قبلاً به آن‌ها فکر کرده‌اید، هدف و موجودیت‌های آن جمله چه خواهند بود؟

برای آموزش LUIS، ابتدا موجودیت‌ها را تنظیم می‌کنید. این‌ها می‌توانند یک لیست ثابت از اصطلاحات باشند یا از متن یاد گرفته شوند. برای مثال، شما می‌توانید یک لیست ثابت از غذاهای موجود در منوی خود ارائه دهید، همراه با تغییرات (یا مترادف‌ها) هر کلمه، مانند بادمجان و آبرجین به عنوان تغییرات آبرجین. LUIS همچنین موجودیت‌های از پیش ساخته شده‌ای دارد که می‌توان از آن‌ها استفاده کرد، مانند اعداد و مکان‌ها.

برای تنظیم تایمر، شما می‌توانید یک موجودیت با استفاده از موجودیت‌های عددی از پیش ساخته شده برای زمان داشته باشید و دیگری برای واحدها، مانند دقیقه و ثانیه. هر واحد می‌تواند چندین تغییر داشته باشد تا فرم‌های مفرد و جمع را پوشش دهد - مانند دقیقه و دقایق.

پس از تعریف موجودیت‌ها، شما اهداف را ایجاد می‌کنید. این‌ها بر اساس جملات نمونه‌ای که ارائه می‌دهید (که به آن‌ها عبارات گفته می‌شود) توسط مدل یاد گرفته می‌شوند. برای مثال، برای هدف تنظیم تایمر، شما ممکن است جملات زیر را ارائه دهید:

  • یک تایمر یک ثانیه‌ای تنظیم کن
  • یک تایمر برای یک دقیقه و دوازده ثانیه تنظیم کن
  • یک تایمر برای سه دقیقه تنظیم کن
  • یک تایمر نه دقیقه و سی ثانیه‌ای تنظیم کن

سپس به LUIS می‌گویید که کدام بخش‌های این جملات به موجودیت‌ها مربوط می‌شوند:

جمله "یک تایمر برای یک دقیقه و دوازده ثانیه تنظیم کن" به موجودیت‌ها تقسیم شده است

جمله یک تایمر برای یک دقیقه و دوازده ثانیه تنظیم کن هدف تنظیم تایمر دارد. همچنین دارای ۲ موجودیت با ۲ مقدار هر کدام است:

زمان واحد
1 دقیقه 1 دقیقه
12 ثانیه 12 ثانیه

برای آموزش یک مدل خوب، شما به مجموعه‌ای از جملات نمونه مختلف نیاز دارید تا روش‌های مختلفی که ممکن است کسی همان درخواست را بیان کند، پوشش دهید.

💁 همانطور که با هر مدل هوش مصنوعی، هرچه داده‌ها بیشتر و دقیق‌تر باشند، مدل بهتر خواهد بود.

به روش‌های مختلفی که ممکن است همان درخواست را بیان کنید و انتظار داشته باشید یک انسان آن را درک کند، فکر کنید.

وظیفه - افزودن موجودیت‌ها به مدل‌های درک زبان

برای تایمر، شما نیاز به افزودن ۲ موجودیت دارید - یکی برای واحد زمان (دقیقه یا ثانیه) و دیگری برای تعداد دقیقه یا ثانیه.

شما می‌توانید دستورالعمل‌های استفاده از پورتال LUIS را در مستندات شروع سریع: ساخت اپلیکیشن خود در پورتال LUIS در مستندات مایکروسافت پیدا کنید.

  1. از پورتال LUIS، تب موجودیت‌ها را انتخاب کنید و موجودیت از پیش ساخته شده عدد را با انتخاب دکمه افزودن موجودیت از پیش ساخته شده و سپس انتخاب عدد از لیست اضافه کنید.

  2. یک موجودیت جدید برای واحد زمان با استفاده از دکمه ایجاد ایجاد کنید. نام موجودیت را واحد زمان بگذارید و نوع آن را به لیست تنظیم کنید. مقادیر دقیقه و ثانیه را به لیست مقادیر نرمال شده اضافه کنید و فرم‌های مفرد و جمع را به لیست مترادف‌ها اضافه کنید. پس از افزودن هر مترادف، کلید بازگشت را فشار دهید تا به لیست اضافه شود.

    مقدار نرمال شده مترادف‌ها
    دقیقه دقیقه، دقایق
    ثانیه ثانیه، ثانیه‌ها

وظیفه - افزودن اهداف به مدل‌های درک زبان

  1. از تب اهداف، دکمه ایجاد را انتخاب کنید تا یک هدف جدید ایجاد کنید. نام این هدف را تنظیم تایمر بگذارید.

  2. در مثال‌ها، روش‌های مختلفی برای تنظیم تایمر با استفاده از دقیقه، ثانیه و ترکیب دقیقه و ثانیه وارد کنید. مثال‌ها می‌توانند شامل موارد زیر باشند:

    • یک تایمر یک ثانیه‌ای تنظیم کن
    • یک تایمر چهار دقیقه‌ای تنظیم کن
    • یک تایمر چهار دقیقه و شش ثانیه‌ای تنظیم کن
    • یک تایمر نه دقیقه و سی ثانیه‌ای تنظیم کن
    • یک تایمر برای یک دقیقه و دوازده ثانیه تنظیم کن
    • یک تایمر برای سه دقیقه تنظیم کن
    • یک تایمر برای سه دقیقه و یک ثانیه تنظیم کن
    • یک تایمر برای سه دقیقه و یک ثانیه تنظیم کن
    • یک تایمر برای یک دقیقه و یک ثانیه تنظیم کن
    • یک تایمر برای سی ثانیه تنظیم کن
    • یک تایمر برای یک ثانیه تنظیم کن

    اعداد را به صورت کلمات و عددی ترکیب کنید تا مدل یاد بگیرد هر دو را مدیریت کند.

  3. همانطور که هر مثال را وارد می‌کنید، LUIS شروع به شناسایی موجودیت‌ها می‌کند و هر موجودیتی که پیدا کند را زیرخط و برچسب‌گذاری می‌کند.

    مثال‌ها با اعداد و واحدهای زمانی که توسط LUIS زیرخط شده‌اند

وظیفه - آموزش و آزمایش مدل

  1. پس از پیکربندی موجودیت‌ها و اهداف، می‌توانید مدل را با استفاده از دکمه آموزش در منوی بالا آموزش دهید. این دکمه را انتخاب کنید و مدل باید در چند ثانیه آموزش داده شود. دکمه در حین آموزش خاکستری خواهد شد و پس از اتمام دوباره فعال خواهد شد.

  2. دکمه آزمایش را از منوی بالا انتخاب کنید تا مدل درک زبان را آزمایش کنید. متنی مانند یک تایمر برای پنج دقیقه و چهار ثانیه تنظیم کن وارد کنید و کلید بازگشت را فشار دهید. جمله در یک جعبه زیر جعبه متنی که آن را وارد کرده‌اید ظاهر خواهد شد و زیر آن هدف برتر یا هدفی که با بالاترین احتمال شناسایی شده است نمایش داده خواهد شد. این باید تنظیم تایمر باشد. نام هدف با احتمال اینکه هدف شناسایی شده درست باشد دنبال خواهد شد.

  3. گزینه بازبینی را انتخاب کنید تا تجزیه و تحلیل نتایج را مشاهده کنید. شما هدف با بالاترین امتیاز و درصد احتمال آن را خواهید دید، همراه با لیست موجودیت‌های شناسایی شده.

  4. پنل آزمایش را پس از اتمام آزمایش ببندید.

وظیفه - انتشار مدل

برای استفاده از این مدل از کد، باید آن را منتشر کنید. هنگام انتشار از LUIS، می‌توانید به یک محیط آزمایشی برای تست یا یک محیط تولید برای انتشار کامل منتشر کنید. در این درس، محیط آزمایشی کافی است.

  1. از پورتال LUIS، دکمه انتشار را از منوی بالا انتخاب کنید.

  2. مطمئن شوید که محیط آزمایشی انتخاب شده است، سپس تمام شد را انتخاب کنید. شما یک اعلان خواهید دید که اپلیکیشن منتشر شده است.

  3. می‌توانید این را با استفاده از curl آزمایش کنید. برای ساخت دستور curl، شما به سه مقدار نیاز دارید - نقطه پایانی، شناسه اپلیکیشن (App ID) و یک کلید API. این‌ها را می‌توانید از تب مدیریت که از منوی بالا قابل انتخاب است، دسترسی پیدا کنید.

    1. از بخش تنظیمات، شناسه اپلیکیشن را کپی کنید.
  4. از بخش Azure Resources، گزینه Authoring Resource را انتخاب کنید و Primary Key و Endpoint URL را کپی کنید.

  5. دستور 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> را با Endpoint URL از بخش Azure Resources جایگزین کنید.

    مقدار <app id> را با App ID از بخش Settings جایگزین کنید.

    مقدار <primary key> را با Primary Key از بخش Azure Resources جایگزین کنید.

    مقدار <sentence> را با جمله‌ای که می‌خواهید آزمایش کنید جایگزین کنید.

  6. خروجی این فراخوانی یک سند 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 به عنوان هدف اصلی با احتمال ۹۷٪ شناسایی شده است.
    • دو موجودیت number شناسایی شده‌اند: 45 و 12.
    • دو موجودیت time-unit شناسایی شده‌اند: minute و second.

استفاده از مدل درک زبان

پس از انتشار، مدل LUIS را می‌توان از طریق کد فراخوانی کرد. در درس‌های قبلی، از IoT Hub برای مدیریت ارتباط با سرویس‌های ابری، ارسال داده‌های تله‌متری و گوش دادن به دستورات استفاده کرده‌اید. این فرآیند بسیار غیرهمزمان است - وقتی داده‌های تله‌متری ارسال می‌شوند، کد شما منتظر پاسخ نمی‌ماند و اگر سرویس ابری غیرفعال باشد، متوجه نخواهید شد.

برای یک تایمر هوشمند، ما به پاسخ فوری نیاز داریم تا بتوانیم به کاربر اطلاع دهیم که تایمر تنظیم شده است یا به او هشدار دهیم که سرویس‌های ابری در دسترس نیستند. برای این کار، دستگاه IoT ما به جای تکیه بر IoT Hub، مستقیماً یک وب endpoint را فراخوانی خواهد کرد.

به جای فراخوانی مستقیم LUIS از دستگاه IoT، می‌توانید از کد بدون سرور (serverless) با یک نوع تریگر متفاوت - یک تریگر HTTP - استفاده کنید. این امکان را به برنامه تابع شما می‌دهد که به درخواست‌های REST گوش دهد و به آن‌ها پاسخ دهد. این تابع به عنوان یک endpoint REST عمل خواهد کرد که دستگاه شما می‌تواند آن را فراخوانی کند.

💁 اگرچه می‌توانید LUIS را مستقیماً از دستگاه IoT خود فراخوانی کنید، بهتر است از چیزی مانند کد بدون سرور استفاده کنید. به این ترتیب، وقتی بخواهید برنامه LUIS که فراخوانی می‌کنید را تغییر دهید - مثلاً وقتی یک مدل بهتر آموزش می‌دهید یا مدلی را به زبان دیگری آموزش می‌دهید - فقط لازم است کد ابری خود را به‌روزرسانی کنید و نیازی به استقرار مجدد کد در هزاران یا میلیون‌ها دستگاه IoT نخواهید داشت.

وظیفه - ایجاد یک برنامه توابع بدون سرور

  1. یک برنامه توابع Azure به نام smart-timer-trigger ایجاد کنید و آن را در VS Code باز کنید.

  2. یک تریگر HTTP به این برنامه اضافه کنید به نام speech-trigger با استفاده از دستور زیر در ترمینال VS Code:

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

    این دستور یک تریگر HTTP به نام text-to-timer ایجاد می‌کند.

  3. تریگر HTTP را با اجرای برنامه توابع آزمایش کنید. وقتی اجرا می‌شود، endpoint در خروجی نمایش داده می‌شود:

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

    این را با بارگذاری URL http://localhost:7071/api/text-to-timer در مرورگر خود آزمایش کنید.

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

وظیفه - استفاده از مدل درک زبان

  1. SDK برای LUIS از طریق یک بسته Pip در دسترس است. خط زیر را به فایل requirements.txt اضافه کنید تا وابستگی به این بسته اضافه شود:

    azure-cognitiveservices-language-luis
    
  2. مطمئن شوید که ترمینال VS Code محیط مجازی را فعال کرده است و دستور زیر را برای نصب بسته‌های Pip اجرا کنید:

    pip install -r requirements.txt
    

    💁 اگر با خطا مواجه شدید، ممکن است نیاز به به‌روزرسانی pip با دستور زیر داشته باشید:

    pip install --upgrade pip
    
  3. ورودی‌های جدیدی به فایل local.settings.json برای کلید API LUIS، Endpoint URL و App ID از تب MANAGE در پورتال LUIS اضافه کنید:

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

    مقدار <endpoint url> را با Endpoint URL از بخش Azure Resources در تب MANAGE جایگزین کنید. این مقدار به صورت https://<location>.api.cognitive.microsoft.com/ خواهد بود.

    مقدار <app id> را با App ID از بخش Settings در تب MANAGE جایگزین کنید.

    مقدار <primary key> را با Primary Key از بخش Azure Resources در تب MANAGE جایگزین کنید.

  4. واردات زیر را به فایل __init__.py اضافه کنید:

    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 برای برنامه LUIS شما را بارگذاری می‌کند، یک شیء اعتبارسنجی با کلید API شما ایجاد می‌کند و سپس یک شیء مشتری LUIS برای تعامل با برنامه LUIS شما ایجاد می‌کند.

  6. این تریگر HTTP با ارسال متن برای درک به صورت JSON فراخوانی خواهد شد، که متن در یک ویژگی به نام text قرار دارد. کد زیر مقدار را از بدنه درخواست HTTP استخراج کرده و آن را در کنسول ثبت می‌کند. این کد را به تابع 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 که برنامه شما به آن منتشر شده است:

    prediction_response = client.prediction.get_slot_prediction(app_id, 'Staging', prediction_request)
    
  9. پاسخ پیش‌بینی شامل هدف اصلی - هدفی با بالاترین امتیاز پیش‌بینی - همراه با موجودیت‌ها است. اگر هدف اصلی set timer باشد، موجودیت‌ها می‌توانند برای دریافت زمان مورد نیاز برای تایمر خوانده شوند:

    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 یک آرایه از اعداد خواهند بود. برای مثال، اگر بگویید "Set a four minute 17 second timer."، آرایه number شامل ۲ عدد صحیح خواهد بود - ۴ و ۱۷.

    موجودیت‌های time unit یک آرایه از آرایه‌های رشته‌ها خواهند بود، که هر واحد زمانی به صورت یک آرایه از رشته‌ها در داخل آرایه قرار دارد. برای مثال، اگر بگویید "Set a four minute 17 second timer."، آرایه time unit شامل ۲ آرایه با مقادیر تکی خواهد بود - ['minute'] و ['second'].

    نسخه JSON این موجودیت‌ها برای "Set a four minute 17 second timer." به صورت زیر است:

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

    این کد همچنین یک شمارنده برای زمان کل تایمر به ثانیه تعریف می‌کند. این مقدار با مقادیر موجودیت‌ها پر خواهد شد.

  10. موجودیت‌ها به هم مرتبط نیستند، اما می‌توانیم برخی فرضیات درباره آن‌ها داشته باشیم. آن‌ها به ترتیب گفته شده خواهند بود، بنابراین موقعیت در آرایه می‌تواند برای تعیین اینکه کدام عدد با کدام واحد زمانی مطابقت دارد استفاده شود. برای مثال:

    • "Set a 30 second timer" - این مورد یک عدد 30 و یک واحد زمانی second خواهد داشت، بنابراین عدد تکی با واحد زمانی تکی مطابقت خواهد داشت.
    • "Set a 2 minute and 30 second timer" - این مورد دو عدد 2 و 30 و دو واحد زمانی minute و second خواهد داشت، بنابراین عدد اول برای واحد زمانی اول (۲ دقیقه) و عدد دوم برای واحد زمانی دوم (۳۰ ثانیه) خواهد بود.

    کد زیر تعداد آیتم‌های موجود در موجودیت‌های عددی را دریافت می‌کند و از آن برای استخراج آیتم اول از هر آرایه، سپس آیتم دوم و به همین ترتیب استفاده می‌کند. این کد را داخل بلوک 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. داخل این حلقه، از عدد و واحد زمانی برای محاسبه زمان کل تایمر استفاده کنید، با افزودن ۶۰ ثانیه برای هر دقیقه و تعداد ثانیه‌ها برای هر ثانیه.

    if time_unit == 'minute':
        total_seconds += number * 60
    else:
        total_seconds += number
    
  12. خارج از این حلقه از میان موجودیت‌ها، زمان کل تایمر را در کنسول ثبت کنید:

    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 تبدیل می‌کند و به عنوان یک نتیجه HTTP با کد وضعیت ۲۰۰ بازمی‌گرداند، که به معنای موفقیت‌آمیز بودن فراخوانی است.

  14. در نهایت، خارج از بلوک if، اگر هدف شناسایی نشد، با بازگرداندن یک کد خطا آن را مدیریت کنید:

    return func.HttpResponse(status_code=404)
    

    کد وضعیت ۴۰۴ به معنای یافت نشد است.

  15. برنامه تابع را اجرا کنید و آن را با استفاده از 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:
    
            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 شما بتواند endpoint REST شما را فراخوانی کند، باید URL را بداند. وقتی قبلاً به آن دسترسی پیدا کردید، از localhost استفاده کردید، که یک میانبر برای دسترسی به endpointهای REST روی ماشین محلی شما است. برای اینکه دستگاه IoT شما بتواند به آن دسترسی پیدا کند، باید یا آن را در ابر منتشر کنید یا آدرس IP خود را برای دسترسی محلی دریافت کنید.

    ⚠️ اگر از Wio Terminal استفاده می‌کنید، اجرای برنامه تابع به صورت محلی آسان‌تر است، زیرا وابستگی به کتابخانه‌هایی وجود دارد که باعث می‌شود نتوانید برنامه تابع را به همان روشی که قبلاً انجام داده‌اید مستقر کنید. برنامه تابع را به صورت محلی اجرا کنید و از طریق آدرس IP کامپیوتر خود به آن دسترسی پیدا کنید. اگر می‌خواهید آن را در ابر مستقر کنید، اطلاعاتی در درس‌های بعدی در مورد نحوه انجام این کار ارائه خواهد شد.

    • برنامه توابع را منتشر کنید - دستورالعمل‌های درس‌های قبلی را برای انتشار برنامه توابع خود در ابر دنبال کنید. پس از انتشار، URL به صورت https://<APP_NAME>.azurewebsites.net/api/text-to-timer خواهد بود، که <APP_NAME> نام برنامه توابع شما خواهد بود. مطمئن شوید که تنظیمات محلی خود را نیز منتشر کنید.

      هنگام کار با تریگرهای HTTP، آن‌ها به طور پیش‌فرض با یک کلید برنامه تابع ایمن می‌شوند. برای دریافت این کلید، دستور زیر را اجرا کنید:

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

      مقدار ورودی default را از بخش functionKeys کپی کنید.

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

      این کلید باید به عنوان یک پارامتر پرس‌وجو به URL اضافه شود، بنابراین URL نهایی به صورت https://<APP_NAME>.azurewebsites.net/api/text-to-timer?code=<FUNCTION_KEY> خواهد بود، که <APP_NAME> نام برنامه توابع شما و <FUNCTION_KEY> کلید پیش‌فرض تابع شما خواهد بود.

      💁 می‌توانید نوع مجوز تریگر HTTP را با استفاده از تنظیم authlevel در فایل function.json تغییر دهید. می‌توانید اطلاعات بیشتری در مورد این موضوع در بخش پیکربندی مستندات تریگر HTTP توابع Azure در Microsoft Docs بخوانید.

    • برنامه توابع را به صورت محلی اجرا کنید و با استفاده از آدرس IP به آن دسترسی پیدا کنید - می‌توانید آدرس IP کامپیوتر خود را در شبکه محلی پیدا کنید و از آن برای ساخت URL استفاده کنید.

      آدرس IP خود را پیدا کنید:

      پس از دریافت آدرس IP، می‌توانید به تابع در http:// دسترسی پیدا کنید. <آدرس_آیپی> :7071/api/text-to-timer، که <IP_ADDRESS>آدرس IP شما خواهد بود، برای مثالhttp://192.168.1.10:7071/api/text-to-timer`.

      💁 توجه داشته باشید که این از پورت 7071 استفاده می‌کند، بنابراین بعد از آدرس IP باید :7071 را اضافه کنید.

      💁 این فقط زمانی کار می‌کند که دستگاه IoT شما در همان شبکه‌ای باشد که کامپیوتر شما قرار دارد.

  2. نقطه پایانی را با استفاده از curl آزمایش کنید.


🚀 چالش

راه‌های زیادی برای درخواست یک چیز مشابه، مانند تنظیم یک تایمر، وجود دارد. به روش‌های مختلف برای انجام این کار فکر کنید و از آنها به عنوان مثال در برنامه LUIS خود استفاده کنید. این روش‌ها را آزمایش کنید تا ببینید مدل شما چقدر می‌تواند با روش‌های مختلف درخواست تایمر سازگار شود.

آزمون پس از درس

آزمون پس از درس

مرور و مطالعه شخصی

تکلیف

لغو تایمر

سلب مسئولیت:
این سند با استفاده از سرویس ترجمه هوش مصنوعی Co-op Translator ترجمه شده است. در حالی که ما تلاش می‌کنیم دقت را حفظ کنیم، لطفاً توجه داشته باشید که ترجمه‌های خودکار ممکن است شامل خطاها یا نادرستی‌ها باشند. سند اصلی به زبان اصلی آن باید به عنوان منبع معتبر در نظر گرفته شود. برای اطلاعات حساس، توصیه می‌شود از ترجمه حرفه‌ای انسانی استفاده کنید. ما مسئولیتی در قبال سوء تفاهم‌ها یا تفسیرهای نادرست ناشی از استفاده از این ترجمه نداریم.