হিয়ারিং এইড ডিভাইস (HA) ব্লুটুথ লো এনার্জি (BLE) এর উপর সংযোগ-ভিত্তিক L2CAP চ্যানেল (CoC) ব্যবহার করে Android-চালিত মোবাইল ডিভাইসগুলিতে অ্যাক্সেসযোগ্যতা উন্নত করতে পারে। CoC অডিওর একটি স্থির প্রবাহ বজায় রাখার জন্য বেশ কয়েকটি অডিও প্যাকেটের একটি ইলাস্টিক বাফার ব্যবহার করে, এমনকি প্যাকেটের ক্ষতির উপস্থিতিতেও। এই বাফার শ্রবণ সহায়ক ডিভাইসের জন্য অডিও গুণমান প্রদান করে বিলম্বের খরচে।
CoC এর ডিজাইন ব্লুটুথ কোর স্পেসিফিকেশন সংস্করণ 5 (BT) উল্লেখ করে। মূল স্পেসিফিকেশনের সাথে সারিবদ্ধ থাকার জন্য, এই পৃষ্ঠার সমস্ত মাল্টি-বাইট মানগুলি ছোট-এন্ডিয়ান হিসাবে পড়া হবে।
পরিভাষা
- কেন্দ্রীয় - Android ডিভাইস যা ব্লুটুথের মাধ্যমে বিজ্ঞাপনের জন্য স্ক্যান করে।
- পেরিফেরাল - শ্রবণ যন্ত্র যা ব্লুটুথের মাধ্যমে বিজ্ঞাপনের প্যাকেট পাঠায়।
নেটওয়ার্ক টপোলজি এবং সিস্টেম আর্কিটেকচার
শ্রবণ যন্ত্রের জন্য CoC ব্যবহার করার সময়, নেটওয়ার্ক টপোলজি একটি একক কেন্দ্রীয় এবং দুটি পেরিফেরাল অনুমান করে, একটি বাম এবং একটি ডান, যেমন চিত্র 1 -এ দেখা গেছে। ব্লুটুথ অডিও সিস্টেম বাম এবং ডান পেরিফেরালগুলিকে একক অডিও সিঙ্ক হিসাবে দেখে। যদি একটি পেরিফেরাল অনুপস্থিত থাকে, একটি মনোরাল ফিট বা সংযোগ হারানোর কারণে, তাহলে কেন্দ্রীয় বাম এবং ডান অডিও চ্যানেল মিশ্রিত করে এবং বাকি পেরিফেরালে অডিও প্রেরণ করে। যদি সেন্ট্রাল উভয় পেরিফেরালের সাথে সংযোগ হারায়, তাহলে সেন্ট্রাল অডিও সিঙ্কের লিঙ্কটি হারিয়ে গেছে বলে বিবেচনা করে। এই ক্ষেত্রে, কেন্দ্রীয় রুট অডিও অন্য আউটপুট.
চিত্র 1. CoC ওভার BLE ব্যবহার করে অ্যান্ড্রয়েড মোবাইল ডিভাইসের সাথে শ্রবণযন্ত্র যুক্ত করার জন্য টপোলজি
যখন সেন্ট্রাল পেরিফেরালে অডিও ডেটা স্ট্রিমিং না করে এবং একটি BLE সংযোগ বজায় রাখতে পারে, তখন কেন্দ্রীয় পেরিফেরাল থেকে সংযোগ বিচ্ছিন্ন করা উচিত নয়। সংযোগ বজায় রাখা পেরিফেরালে থাকা GATT সার্ভারের সাথে ডেটা যোগাযোগের অনুমতি দেয়।
শ্রবণ যন্ত্র জোড়া এবং সংযোগ করার সময়, কেন্দ্রীয় করবে:
- পেয়ার করা আরও সাম্প্রতিক বাম এবং ডান পেরিফেরালগুলির উপর নজর রাখুন।
- অনুমান করুন পেরিফেরালগুলি ব্যবহার করা হচ্ছে যদি একটি বৈধ জোড়া বিদ্যমান থাকে। সংযোগ বিচ্ছিন্ন হয়ে গেলে কেন্দ্র সংযুক্ত ডিভাইসের সাথে সংযোগ বা পুনরায় সংযোগ করার চেষ্টা করবে।
- অনুমান করুন যে পেয়ারিং মুছে ফেলা হলে পেরিফেরালগুলি আর ব্যবহার করা হয় না।
উপরের ক্ষেত্রে, পেয়ারিং বলতে বোঝায় OS-তে প্রদত্ত UUID এবং বাম/ডান মনোনীতদের সাথে শ্রবণযন্ত্রের একটি সেট নিবন্ধন করার ক্রিয়া, ব্লুটুথ পেয়ারিং প্রক্রিয়া নয়।
সিস্টেমের প্রয়োজনীয়তা
একটি ভাল ব্যবহারকারীর অভিজ্ঞতার জন্য CoC সঠিকভাবে প্রয়োগ করতে, কেন্দ্রীয় এবং পেরিফেরাল ডিভাইসগুলিতে ব্লুটুথ সিস্টেমগুলি করবে:
- একটি অনুগত BT 4.2 বা উচ্চতর নিয়ামক প্রয়োগ করুন। LE নিরাপদ সংযোগগুলি অত্যন্ত সুপারিশ করা হয়।
- অডিও প্যাকেট ফরম্যাট এবং টাইমিং -এ বর্ণিত পরামিতিগুলির সাথে কমপক্ষে 2টি যুগপত LE লিঙ্কের কেন্দ্রীয় সমর্থন রয়েছে৷
- অডিও প্যাকেট ফরম্যাট এবং টাইমিং- এ বর্ণিত পরামিতিগুলির সাথে কমপক্ষে 1 LE লিঙ্কের পেরিফেরাল সমর্থন রয়েছে৷
- একটি LE ক্রেডিট ভিত্তিক প্রবাহ নিয়ন্ত্রণ আছে [BT Vol 3, Part A, Sec 10.1]। ডিভাইসগুলি CoC-তে কমপক্ষে 167 বাইটের একটি MTU এবং MPS আকার সমর্থন করবে এবং 8 প্যাকেট পর্যন্ত বাফার করতে সক্ষম হবে।
- কমপক্ষে 167 বাইটের পেলোড সহ একটি LE ডেটা দৈর্ঘ্যের এক্সটেনশন [BT Vol 6, Part B, Sec 5.1.9] আছে৷
- কেন্দ্রীয় ডিভাইসটি HCI LE সংযোগ আপডেট কমান্ড সমর্থন করে এবং অ-শূন্য
maximum_CE_Length
এবংminimum_CE_Length
পরামিতি মেনে চলে। - অডিও প্যাকেট ফরম্যাট এবং টাইমিং- এ সংযোগের ব্যবধান এবং পেলোডের আকার সহ দুটি ভিন্ন পেরিফেরালগুলিতে দুটি LE CoC সংযোগের জন্য কেন্দ্রীয়কে ডেটা থ্রুপুট বজায় রাখতে হবে।
- পেরিফেরালকে
LL_LENGTH_REQ
বাLL_LENGTH_RSP
ফ্রেমেMaxRxOctets
এবংMaxRxTime
প্যারামিটারগুলিকে এই স্পেসিফিকেশনগুলির জন্য প্রয়োজনীয় ক্ষুদ্রতম প্রয়োজনীয় মানগুলি হিসাবে সেট করতে দিন। ফ্রেম পাওয়ার জন্য প্রয়োজনীয় সময়ের পরিমাণ গণনা করার সময় এটি কেন্দ্রীয়কে তার সময় নির্ধারণকারীকে অপ্টিমাইজ করতে দেয়।
এটি দৃঢ়ভাবে সুপারিশ করা হয় যে কেন্দ্রীয় এবং পেরিফেরাল সমর্থন 2MB PHY যেমন BT 5.0 স্পেসিফিকেশনে উল্লেখ করা হয়েছে। কেন্দ্রীয় 1M এবং 2M PHY উভয় ক্ষেত্রেই কমপক্ষে 64 kbit/s এর অডিও লিঙ্কগুলিকে সমর্থন করবে৷ BLE দীর্ঘ পরিসরের PHY ব্যবহার করা হবে না।
CoC লিঙ্ক লেয়ার এনক্রিপশন এবং ফ্রিকোয়েন্সি হপিংয়ের জন্য স্ট্যান্ডার্ড ব্লুটুথ প্রক্রিয়া ব্যবহার করে।
আশা গ্যাট পরিষেবা
একটি পেরিফেরাল নীচে বর্ণিত অডিও স্ট্রিমিং ফর হিয়ারিং এইড (ASHA) GATT সার্ভার পরিষেবা বাস্তবায়ন করবে। পেরিফেরাল এই পরিষেবাটির বিজ্ঞাপন দেবে যখন সাধারণ আবিষ্কারযোগ্য মোডে কেন্দ্রীয় একটি অডিও সিঙ্ককে চিনতে দেয়। যেকোনো LE অডিও স্ট্রিমিং অপারেশনের জন্য এনক্রিপশন প্রয়োজন। BLE অডিও স্ট্রিমিং নিম্নলিখিত বৈশিষ্ট্যগুলি নিয়ে গঠিত:
চারিত্রিক | বৈশিষ্ট্য | বর্ণনা |
---|---|---|
ReadOnlyProperties | পড়ুন | ReadOnlyProperties দেখুন। |
অডিও কন্ট্রোলপয়েন্ট | প্রতিক্রিয়া ছাড়াই লিখুন এবং লিখুন | অডিও স্ট্রিম জন্য নিয়ন্ত্রণ পয়েন্ট. অডিও কন্ট্রোলপয়েন্ট দেখুন। |
অডিও স্ট্যাটাস পয়েন্ট | পড়ুন/বিজ্ঞাপন করুন | অডিও কন্ট্রোল পয়েন্টের জন্য স্ট্যাটাস রিপোর্ট ক্ষেত্র। অডিও স্ট্যাটাসপয়েন্ট দেখুন। |
আয়তন | প্রতিক্রিয়া ছাড়াই লিখুন | -128 এবং 0-এর মধ্যে বাইট স্ট্রীম করা অডিও সিগন্যালে প্রয়োগ করার জন্য টেনশনের পরিমাণ নির্দেশ করে, -48 dB থেকে 0 dB পর্যন্ত। সেটিং -128 সম্পূর্ণরূপে নিঃশব্দ হিসাবে ব্যাখ্যা করা হবে, অর্থাৎ সর্বনিম্ন অ-নিঃশব্দ ভলিউম স্তর হল -127 যা -47.625 dB ক্ষয়করণের সমতুল্য। 0 সেটিং এ, স্ট্রিম করা একটি রেল-টু-রেল সাইন টোন শ্রবণ যন্ত্রে একটি 100 dBSPL ইনপুট সমতুল্য প্রতিনিধিত্ব করবে। কেন্দ্রীয় নামমাত্র পূর্ণ স্কেলে স্ট্রিম করবে এবং পেরিফেরালে পছন্দসই উপস্থাপনা স্তর সেট করতে এই পরিবর্তনশীলটি ব্যবহার করবে। |
LE_PSM_OUT | পড়ুন | অডিও চ্যানেল সংযোগ করার জন্য PSM ব্যবহার করুন। গতিশীল পরিসর থেকে বাছাই করতে হবে [বিটি ভলিউম 3, পার্ট এ, সেক 4.22] |
পরিষেবা এবং বৈশিষ্ট্যগুলিতে নির্ধারিত UUID:
পরিষেবা UUID : {0xFDF0}
চারিত্রিক | UUID |
---|---|
ReadOnlyProperties | {6333651e-c481-4a3e-9169-7c902aad37bb} |
অডিও কন্ট্রোলপয়েন্ট | {f0d4de7e-4a88-476c-9d9f-1937b0996cc0} |
অডিও স্ট্যাটাস | {38663f1a-e711-4cac-b641-326b56404837} |
আয়তন | {00e4ca9e-ab14-41e4-8823-f9e70c7e91df} |
LE_PSM_OUT | {2d410339-82b6-42aa-b34e-e2e01df8cc1a} |
ASHA GATT পরিষেবার পাশাপাশি, পেরিফেরালটি ডিভাইস ইনফরমেশন সার্ভিসকেও প্রয়োগ করবে যাতে সেন্ট্রালকে পেরিফেরালের নির্মাতার নাম এবং ডিভাইসের নাম সনাক্ত করতে দেয়।
ReadOnlyProperties
ReadOnlyProperties এর নিম্নলিখিত মান রয়েছে:
বাইট | বর্ণনা |
---|---|
0 | সংস্করণ - 0x01 হতে হবে |
1 | ডিভাইস সক্ষমতা দেখুন। |
2-9 | HiSyncId দেখুন। |
10 | ফিচারম্যাপ দেখুন । |
11-12 | রেন্ডার বিলম্ব। এই সময়, মিলিসেকেন্ডে, যখন পেরিফেরাল একটি অডিও ফ্রেম পায় থেকে পেরিফেরাল আউটপুট রেন্ডার না করা পর্যন্ত। এই বাইটগুলি অডিওর সাথে সিঙ্ক্রোনাইজ করতে একটি ভিডিও বিলম্ব করতে ব্যবহার করা যেতে পারে। |
13-14 | ভবিষ্যতে ব্যবহারের জন্য সংরক্ষিত. শূন্য থেকে শুরু করুন। |
15-16 | সমর্থিত কোডেক আইডি । এটি সমর্থিত কোডেক আইডিগুলির একটি বিটমাস্ক। একটি বিট অবস্থানে একটি 1 একটি সমর্থিত কোডেক অনুরূপ. উদাহরণস্বরূপ, 0x0002 নির্দেশ করে যে 16 kHz এ G.722 সমর্থিত। অন্যান্য সমস্ত বিট 0 এ সেট করা হবে। |
ডিভাইস সক্ষমতা
বিট | বর্ণনা |
---|---|
0 | ডিভাইস সাইড (0: বাম, 1: ডান) |
1 | ডিভাইসটি স্বতন্ত্র কিনা তা নির্দেশ করে এবং মনো ডেটা গ্রহণ করে, অথবা যদি ডিভাইসটি একটি সেটের অংশ হয় (0: monaural, 1: binaural) |
2 | ডিভাইস CSIS সমর্থন করে (0: সমর্থিত নয়, 1: সমর্থিত) |
3-7 | সংরক্ষিত (0 তে সেট) |
হাইসিঙ্কআইডি
এই ক্ষেত্রটি অবশ্যই সমস্ত বাইনোরাল ডিভাইসের জন্য অনন্য হতে হবে তবে এটি বাম এবং ডান সেটের জন্য একই হতে হবে।
বাইট | বর্ণনা |
---|---|
0-1 | প্রস্তুতকারকের আইডি। এটি BTSIG দ্বারা নির্ধারিত কোম্পানি শনাক্তকারী । |
2-7 | হিয়ারিং এইড সেট সনাক্তকারী অনন্য আইডি। এই আইডিটি অবশ্যই বাম এবং ডান উভয় পেরিফেরালে একই সেট করতে হবে। |
ফিচারম্যাপ
বিট | বর্ণনা |
---|---|
0 | LE CoC অডিও আউটপুট স্ট্রিমিং সমর্থিত (হ্যাঁ/না)। |
1-7 | সংরক্ষিত (0 তে সেট)। |
কোডেক আইডি
যদি বিট সেট করা হয়, তাহলে সেই নির্দিষ্ট কোডেক হল সমর্থন।
আইডি/বিট নম্বর | কোডেক এবং নমুনা হার | প্রয়োজনীয় বিটরেট | ফ্রেম সময় | কেন্দ্রীয় (C) বা পেরিফেরাল (P) এ বাধ্যতামূলক |
---|---|---|---|---|
0 | সংরক্ষিত | সংরক্ষিত | সংরক্ষিত | সংরক্ষিত |
1 | G.722 @ 16 kHz | 64 kbit/s | পরিবর্তনশীল | সি এবং পি |
2-15 সংরক্ষিত। 0 এছাড়াও সংরক্ষিত. |
অডিও কন্ট্রোলপয়েন্ট
যখন LE CoC বন্ধ থাকে তখন এই নিয়ন্ত্রণ পয়েন্টটি ব্যবহার করা যাবে না। পদ্ধতির বর্ণনার জন্য একটি অডিও স্ট্রিম শুরু এবং বন্ধ করা দেখুন।
অপকোড | যুক্তি | GATT উপ-প্রক্রিয়া | বর্ণনা |
---|---|---|---|
1 «Start» |
| প্রতিক্রিয়া সহ লিখুন, এবং AudioStatusPoint বৈশিষ্ট্যের মাধ্যমে একটি অতিরিক্ত স্থিতি বিজ্ঞপ্তি আশা করুন। | পেরিফেরালকে কোডেক রিসেট করতে এবং ফ্রেম 0 এর প্লেব্যাক শুরু করার নির্দেশ দেয়। কোডেক ক্ষেত্রটি এই প্লেব্যাকের জন্য ব্যবহার করার জন্য কোডেক আইডি নির্দেশ করে। উদাহরণস্বরূপ, কোডেক ক্ষেত্রটি 16k Hz এ G.722 এর জন্য "1"। অডিও টাইপ বিট ক্ষেত্রটি স্ট্রীমে উপস্থিত অডিও প্রকার(গুলি) নির্দেশ করে:
একটি «Stop» অপকোড পাওয়ার আগে পেরিফেরাল সংযোগ আপডেটের জন্য অনুরোধ করবে না। |
2 «Stop» | কোনোটিই নয় | প্রতিক্রিয়া সহ লিখুন, এবং AudioStatusPoint বৈশিষ্ট্যের মাধ্যমে একটি অতিরিক্ত স্থিতি বিজ্ঞপ্তি আশা করুন। | পেরিফেরালকে অডিও রেন্ডারিং বন্ধ করার নির্দেশ দেয়। আবার অডিও রেন্ডার করার জন্য এই স্টপের পরে একটি নতুন অডিও সেটআপ ক্রম শুরু করা উচিত৷ |
3 «Status» |
| প্রতিক্রিয়া ছাড়াই লিখুন | সংযুক্ত পেরিফেরালকে অবহিত করে যে অন্য পেরিফেরালটিতে একটি স্থিতি আপডেট রয়েছে৷ সংযুক্ত ক্ষেত্র আপডেটের ধরন নির্দেশ করে:
|
অডিও স্ট্যাটাস পয়েন্ট
অডিও কন্ট্রোল পয়েন্টের জন্য স্ট্যাটাস রিপোর্ট ক্ষেত্র
অপকোডস | বর্ণনা |
---|---|
0 | স্ট্যাটাস ঠিক আছে |
-1 | অজানা আদেশ |
-2 | অবৈধ পরামিতি |
আশা GATT পরিষেবার বিজ্ঞাপন
পরিষেবা UUID অবশ্যই বিজ্ঞাপনের প্যাকেটে থাকতে হবে। বিজ্ঞাপন বা স্ক্যান প্রতিক্রিয়া ফ্রেমে, পেরিফেরালগুলির একটি পরিষেবা ডেটা থাকতে হবে:
বাইট অফসেট | নাম | বর্ণনা |
---|---|---|
0 | AD দৈর্ঘ্য | >= 0x09 |
1 | AD প্রকার | 0x16 (পরিষেবা ডেটা - 16-বিট UUID) |
2-3 | পরিষেবা UUID | 0xFDF0 (লিটল-এন্ডিয়ান) দ্রষ্টব্য: এটি একটি অস্থায়ী আইডি। |
4 | প্রোটোকল সংস্করণ | 0x01 |
5 | সামর্থ্য |
|
6-9 | HiSyncID কাটা | HiSyncId- এর চারটি সবচেয়ে উল্লেখযোগ্য বাইট। এই বাইটগুলি আইডির সবচেয়ে র্যান্ডম অংশ হওয়া উচিত। |
পেরিফেরালগুলিতে অবশ্যই একটি সম্পূর্ণ স্থানীয় নামের ডেটা টাইপ থাকতে হবে যা হিয়ারিং এইডের নাম নির্দেশ করে। এই নামটি মোবাইল ডিভাইসের ইউজার ইন্টারফেসে ব্যবহার করা হবে যাতে ব্যবহারকারী সঠিক ডিভাইসটি নির্বাচন করতে পারে। নামটি বাম বা ডান চ্যানেল নির্দেশ করবে না যেহেতু এই তথ্যটি ডিভাইস ক্যাপাবিলিটিসে প্রদান করা হয়েছে৷
যদি পেরিফেরালগুলি নাম এবং আশা পরিষেবার ডেটা টাইপগুলিকে একই ফ্রেমের প্রকারে (ADV বা SCAN RESP) রাখে, তবে দুটি ডেটা প্রকার ("সম্পূর্ণ স্থানীয় নাম" এবং "আশা পরিষেবার জন্য পরিষেবা ডেটা") একই ফ্রেমে উপস্থিত হবে৷ এটি মোবাইল ডিভাইস স্ক্যানারকে একই স্ক্যান ফলাফলে উভয় ডেটা পেতে দেয়।
প্রাথমিক পেয়ারিংয়ের সময়, এটি গুরুত্বপূর্ণ যে পেরিফেরালগুলি যথেষ্ট দ্রুত গতিতে বিজ্ঞাপন দেয় যাতে মোবাইল ডিভাইস দ্রুত পেরিফেরালগুলি আবিষ্কার করতে পারে এবং তাদের সাথে বন্ধন করতে পারে৷
বাম এবং ডান পেরিফেরাল ডিভাইস সিঙ্ক্রোনাইজ করুন
অ্যান্ড্রয়েড মোবাইল ডিভাইসে ব্লুটুথের সাথে কাজ করার জন্য, পেরিফেরাল ডিভাইসগুলি তাদের সিঙ্ক্রোনাইজ করা নিশ্চিত করার জন্য দায়ী৷ বাম এবং ডান পেরিফেরাল ডিভাইসে প্লেব্যাক সময়মতো সিঙ্ক্রোনাইজ করা প্রয়োজন। উভয় পেরিফেরাল ডিভাইস একই সময়ে উত্স থেকে অডিও নমুনা প্লে ব্যাক করা আবশ্যক.
পেরিফেরাল ডিভাইসগুলি অডিও পেলোডের প্রতিটি প্যাকেটে পূর্বে লেখা একটি সিকোয়েন্স নম্বর ব্যবহার করে তাদের সময় সিঙ্ক্রোনাইজ করতে পারে। কেন্দ্রীয় গ্যারান্টি দেয় যে প্রতিটি পেরিফেরালে একই সময়ে চালানো অডিও প্যাকেটগুলির একই ক্রম নম্বর রয়েছে৷ প্রতিটি অডিও প্যাকেটের পরে ক্রম সংখ্যা এক দ্বারা বৃদ্ধি পায়। প্রতিটি ক্রম সংখ্যা 8-বিট দীর্ঘ, তাই 256 টি অডিও প্যাকেটের পরে ক্রম সংখ্যা পুনরাবৃত্তি হবে। যেহেতু প্রতিটি সংযোগের জন্য প্রতিটি অডিও প্যাকেটের আকার এবং নমুনার হার স্থির করা হয়েছে, তাই দুটি পেরিফেরাল আপেক্ষিক খেলার সময় বের করতে পারে। অডিও প্যাকেট সম্পর্কে আরও তথ্যের জন্য, অডিও প্যাকেট বিন্যাস এবং সময় দেখুন।
যখন সিঙ্ক্রোনাইজেশনের প্রয়োজন হতে পারে তখন বাইনোরাল ডিভাইসগুলিতে ট্রিগার প্রদান করে কেন্দ্রীয় সহায়তা করে। এই ট্রিগারগুলি প্রতিটি পেরিফেরালকে তার জোড়াযুক্ত পেরিফেরাল ডিভাইসের অবস্থা সম্পর্কে অবহিত করে যখনই কোনও অপারেশন হয় যা সিঙ্ক্রোনাইজেশনকে প্রভাবিত করতে পারে। ট্রিগারগুলি হল:
- অডিওকন্ট্রোলপয়েন্টের
«Start»
কমান্ডের অংশ হিসাবে, বাইনোরাল ডিভাইসগুলির অন্য দিকের বর্তমান সংযোগের অবস্থা দেওয়া হয়েছে। - যখনই একটি পেরিফেরালে একটি সংযোগ, সংযোগ বিচ্ছিন্ন, বা সংযোগ পরামিতি আপডেট অপারেশন হয়, অডিও কন্ট্রোলপয়েন্টের
«Status»
কমান্ডটি বাইনোরাল ডিভাইসগুলির অন্য দিকে পাঠানো হয়।
অডিও প্যাকেট বিন্যাস এবং সময়
প্যাকেটে অডিও ফ্রেম (নমুনার ব্লক) প্যাক করা শ্রবণ যন্ত্রটিকে লিঙ্ক লেয়ার টাইমিং অ্যাঙ্কর থেকে সময় বের করতে দেয়। বাস্তবায়ন সহজ করতে:
- একটি অডিও ফ্রেম সর্বদা সময়ের সাথে সংযোগের ব্যবধানের সাথে মেলে। উদাহরণস্বরূপ, যদি সংযোগের ব্যবধান 20ms হয় এবং নমুনার হার 16 kHz হয়, তাহলে অডিও ফ্রেমে 320টি নমুনা থাকতে হবে।
- ফ্রেমের সময় বা সংযোগের ব্যবধান নির্বিশেষে একটি ফ্রেমে সর্বদা একটি পূর্ণসংখ্যার নমুনা রাখার জন্য সিস্টেমে নমুনার হারগুলি 8kHz এর গুণে সীমাবদ্ধ।
- একটি সিকোয়েন্স বাইট অডিও ফ্রেমের আগে থাকবে। সিকোয়েন্স বাইটটি র্যাপ-এরাউন্ডের সাথে গণনা করা হবে এবং পেরিফেরালকে বাফারের অমিল বা আন্ডারফ্লো সনাক্ত করতে অনুমতি দেবে।
- একটি অডিও ফ্রেম সর্বদা একটি একক LE প্যাকেটে ফিট করা উচিত। অডিও ফ্রেম একটি পৃথক L2CAP প্যাকেট হিসাবে পাঠানো হবে। LE LL PDU এর আকার হবে:
অডিও পেলোড সাইজ + 1 (সিকোয়েন্স কাউন্টার) + 6 (L2CAP হেডারের জন্য 4, SDU-এর জন্য 2) - একটি সংযোগ ইভেন্ট সর্বদা যথেষ্ট বড় হওয়া উচিত যাতে 2টি অডিও প্যাকেট এবং 2টি খালি প্যাকেট থাকে যাতে একটি ACK পুনরায় ট্রান্সমিশনের জন্য ব্যান্ডউইথ সংরক্ষণ করতে পারে৷ মনে রাখবেন অডিও প্যাকেট কেন্দ্রীয় ব্লুটুথ কন্ট্রোলার দ্বারা খণ্ডিত হতে পারে। পেরিফেরাল অবশ্যই প্রতি সংযোগ ইভেন্টে 2টির বেশি খণ্ডিত অডিও প্যাকেট গ্রহণ করতে সক্ষম হবে।
কেন্দ্রীয়কে কিছু নমনীয়তা দিতে, G.722 প্যাকেটের দৈর্ঘ্য নির্দিষ্ট করা নেই। G.722 প্যাকেটের দৈর্ঘ্য কেন্দ্রীয়ভাবে সেট করা সংযোগের ব্যবধানের উপর ভিত্তি করে পরিবর্তিত হতে পারে।
G.722 আউটপুট অক্টেট ফরম্যাট Rec-এর উল্লেখ করে। ITU-T G.722 (09/2012) বিভাগ 1.4.4 "মাল্টিপ্লেক্সার"
একটি পেরিফেরাল সমর্থন করে এমন সমস্ত কোডেকগুলির জন্য, পেরিফেরালটি নীচের সংযোগ পরামিতিগুলিকে সমর্থন করবে৷ এটি কনফিগারেশনের একটি অ-সম্পূর্ণ তালিকা যা কেন্দ্রীয় প্রয়োগ করতে পারে।
কোডেক | বিটরেট | সংযোগের ব্যবধান | CE দৈর্ঘ্য (1M/2M PHY) | অডিও পেলোড আকার |
---|---|---|---|---|
G.722 @ 16 kHz | 64 kbit/s | 20 ms | 5000/3750 আমাদের | 160 বাইট |
একটি অডিও স্ট্রিম শুরু করুন এবং বন্ধ করুন
একটি অডিও স্ট্রিম শুরু করার আগে, কেন্দ্রীয় পেরিফেরালগুলি জিজ্ঞাসা করে এবং একটি সাধারণ হর কোডেক স্থাপন করে। তারপরে স্ট্রিম সেটআপ নিম্নলিখিত ক্রমটির মাধ্যমে এগিয়ে যায়:
- PSM, এবং ঐচ্ছিকভাবে, RenderDelay পড়া হয়। এই মানগুলি কেন্দ্রীয় দ্বারা ক্যাশে করা যেতে পারে।
- CoC L2CAP চ্যানেল খোলা হয়েছে - পেরিফেরাল প্রাথমিকভাবে 8টি ক্রেডিট প্রদান করবে।
- নির্বাচিত কোডেকের জন্য প্রয়োজনীয় প্যারামিটারগুলিতে লিঙ্কটি স্যুইচ করতে একটি সংযোগ আপডেট জারি করা হয়। কেন্দ্রীয় পূর্ববর্তী ধাপে CoC সংযোগের আগে এই সংযোগ আপডেট করতে পারে।
- কেন্দ্রীয় এবং পেরিফেরাল হোস্ট উভয়ই আপডেট সম্পূর্ণ ইভেন্টের জন্য অপেক্ষা করে।
- অডিও এনকোডার রিস্টার্ট করুন, এবং প্যাকেট সিকোয়েন্স কাউন্ট রিসেট করুন 0। প্রাসঙ্গিক প্যারামিটার সহ একটি
«Start»
কমান্ড অডিও কন্ট্রোলপয়েন্টে জারি করা হয়। কেন্দ্রীয় স্ট্রিমিংয়ের আগে পেরিফেরাল থেকে পূর্বের«Start»
কমান্ডের একটি সফল স্থিতি বিজ্ঞপ্তির জন্য অপেক্ষা করে। এই অপেক্ষা তার অডিও প্লেব্যাক পাইপলাইন প্রস্তুত করার জন্য পেরিফেরাল সময় দেয়। অডিও স্ট্রিমিংয়ের সময়, প্রতিলিপিটি প্রতিটি সংযোগ ইভেন্টে উপলব্ধ হওয়া উচিত যদিও বর্তমান প্রতিরূপ লেটেন্সি অ-শূন্য হতে পারে। - পেরিফেরাল তার অভ্যন্তরীণ সারি (ক্রম নম্বর 0) থেকে প্রথম অডিও প্যাকেট নেয় এবং এটি চালায়।
কেন্দ্রীয় অডিও স্ট্রীম বন্ধ করতে «Stop» কমান্ড জারি করে। এই কমান্ডের পরে, প্রতিটি সংযোগ ইভেন্টে পেরিফেরাল উপলব্ধ হওয়ার প্রয়োজন নেই। অডিও স্ট্রিমিং পুনঃসূচনা করতে, উপরের ক্রমটি অনুসরণ করুন, ধাপ 5 থেকে শুরু করে। যখন কেন্দ্রীয় অডিও স্ট্রিমিং না করে, তখনও এটি GATT পরিষেবাগুলির জন্য একটি LE সংযোগ বজায় রাখা উচিত।
পেরিফেরাল কেন্দ্রীয় একটি সংযোগ আপডেট জারি করবে না. শক্তি সঞ্চয় করতে, কেন্দ্রীয় পেরিফেরালের সাথে একটি সংযোগ আপডেট ইস্যু করতে পারে যখন এটি অডিও স্ট্রিমিং না হয়।