ব্লুটুথ LE ব্যবহার করে হিয়ারিং এইড অডিও সাপোর্ট

সেভ করা পৃষ্ঠা গুছিয়ে রাখতে 'সংগ্রহ' ব্যবহার করুন আপনার পছন্দ অনুযায়ী কন্টেন্ট সেভ করুন ও সঠিক বিভাগে রাখুন।

হিয়ারিং এইড ডিভাইস (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 দেখুন।
অডিও কন্ট্রোলপয়েন্ট প্রতিক্রিয়া ছাড়াই লিখুন এবং লিখুন অডিও স্ট্রিম জন্য নিয়ন্ত্রণ পয়েন্ট. অডিও কন্ট্রোলপয়েন্ট দেখুন।
অডিও স্ট্যাটাসপয়েন্ট পড়ুন/বিজ্ঞাপন করুন অডিও কন্ট্রোল পয়েন্টের জন্য স্ট্যাটাস রিপোর্ট ক্ষেত্র। Opcodes হল:
  • 0 - স্ট্যাটাস ঠিক আছে
  • -1 - অজানা কমান্ড
  • -2 - অবৈধ প্যারামিটার
আয়তন প্রতিক্রিয়া ছাড়াই লিখুন -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) / বাইনরাল (1)। ডিভাইসটি স্বতন্ত্র কিনা এবং মনো ডেটা গ্রহণ করে বা ডিভাইসটি একটি সেটের অংশ কিনা তা নির্দেশ করে৷
2-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 বন্ধ থাকে তখন এই নিয়ন্ত্রণ পয়েন্টটি ব্যবহার করা যাবে না। পদ্ধতির বর্ণনার জন্য একটি অডিও স্ট্রিম শুরু এবং বন্ধ করা দেখুন।

অপকোড যুক্তি বর্ণনা
1 «Start»
  • uint8_t codec
  • uint8_t audiotype
  • int8_t volume
  • int8_t otherstate
পেরিফেরালকে কোডেক রিসেট করতে এবং ফ্রেম 0 এর প্লেব্যাক শুরু করার নির্দেশ দেয়। কোডেক ক্ষেত্রটি এই প্লেব্যাকের জন্য ব্যবহার করার জন্য কোডেক আইডি নির্দেশ করে। উদাহরণস্বরূপ, কোডেক ক্ষেত্রটি 16k Hz এ G.722 এর জন্য "1"।

অডিও টাইপ বিট ক্ষেত্রটি স্ট্রীমে উপস্থিত অডিও প্রকার(গুলি) নির্দেশ করে:
  • 0 - অজানা
  • 1 - রিংটোন
  • 2 - ফোনকল
  • 3 - মিডিয়া
অন্য রাজ্যের ক্ষেত্রটি নির্দেশ করে যে বাইনোরাল ডিভাইসগুলির অন্য দিকটি সংযুক্ত কিনা। অন্যান্য পেরিফেরাল ডিভাইস সংযুক্ত হলে ক্ষেত্রের মান 1 হয়, অন্যথায় মান 0 হয়।

একটি «Stop» অপকোড পাওয়ার আগে পেরিফেরাল সংযোগ আপডেটের জন্য অনুরোধ করবে না।
2 «Stop» কোনোটিই নয় পেরিফেরালকে অডিও রেন্ডারিং বন্ধ করার নির্দেশ দেয়। আবার অডিও রেন্ডার করার জন্য এই স্টপের পরে একটি নতুন অডিও সেটআপ ক্রম শুরু করা উচিত।
3 «Status»
  • uint8_t connected
সংযুক্ত পেরিফেরালকে অবহিত করে যে অন্য পেরিফেরালটিতে একটি স্থিতি আপডেট রয়েছে৷ সংযুক্ত ক্ষেত্র আপডেটের ধরন নির্দেশ করে:
  • 0 - অন্যান্য পেরিফেরাল সংযোগ বিচ্ছিন্ন
  • 1 - অন্যান্য পেরিফেরাল সংযুক্ত
  • 2 - উভয় সংযোগে একটি LE সংযোগ পরামিতি আপডেট হয়েছে৷

ASHA GATT পরিষেবার বিজ্ঞাপন

পরিষেবা UUID অবশ্যই বিজ্ঞাপনের প্যাকেটে থাকতে হবে। বিজ্ঞাপন বা স্ক্যান প্রতিক্রিয়া ফ্রেমে, পেরিফেরালগুলির একটি পরিষেবা ডেটা থাকতে হবে:

বাইট অফসেট নাম বর্ণনা
0 AD দৈর্ঘ্য >= 0x09
1 AD প্রকার 0x16 (পরিষেবা ডেটা - 16-বিট UUID)
2-3 পরিষেবা UUID 0xFDF0 (লিটল-এন্ডিয়ান)

দ্রষ্টব্য: এটি একটি অস্থায়ী আইডি।
4 প্রোটোকল সংস্করণ 0x01
5 সামর্থ্য
  • 0 - বাম (0) বা ডান (1) পাশ
  • 1 - একক (0) বা দ্বৈত (1) ডিভাইস।
  • 2-7 - সংরক্ষিত। এই বিট শূন্য হতে হবে.
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 বাইট

একটি অডিও স্ট্রিম শুরু এবং বন্ধ করা হচ্ছে

একটি অডিও স্ট্রিম শুরু করার আগে, কেন্দ্রীয় পেরিফেরালগুলি জিজ্ঞাসা করে এবং একটি সাধারণ হর কোডেক স্থাপন করে। তারপরে স্ট্রিম সেটআপ নিম্নলিখিত ক্রমটির মাধ্যমে এগিয়ে যায়:

  1. PSM, এবং ঐচ্ছিকভাবে, RenderDelay পড়া হয়। এই মানগুলি কেন্দ্রীয় দ্বারা ক্যাশে করা যেতে পারে।
  2. CoC L2CAP চ্যানেল খোলা হয়েছে - পেরিফেরাল প্রাথমিকভাবে 8টি ক্রেডিট প্রদান করবে।
  3. নির্বাচিত কোডেকের জন্য প্রয়োজনীয় প্যারামিটারগুলিতে লিঙ্কটি স্যুইচ করতে একটি সংযোগ আপডেট জারি করা হয়। কেন্দ্রীয় পূর্ববর্তী ধাপে CoC সংযোগের আগে এই সংযোগ আপডেট করতে পারে।
  4. কেন্দ্রীয় এবং পেরিফেরাল হোস্ট উভয়ই আপডেট সম্পূর্ণ ইভেন্টের জন্য অপেক্ষা করে।
  5. অডিও এনকোডার রিস্টার্ট করুন এবং প্যাকেট সিকোয়েন্স কাউন্ট 0 এ রিসেট করুন। প্রাসঙ্গিক প্যারামিটার সহ একটি «Start» কমান্ড অডিও কন্ট্রোল পয়েন্টে জারি করা হয়। কেন্দ্রীয় স্ট্রিমিংয়ের আগে পেরিফেরাল থেকে পূর্বের «Start» কমান্ডের একটি সফল স্থিতি বিজ্ঞপ্তির জন্য অপেক্ষা করে। এই অপেক্ষা তার অডিও প্লেব্যাক পাইপলাইন প্রস্তুত করার জন্য পেরিফেরাল সময় দেয়। অডিও স্ট্রিমিংয়ের সময়, প্রতিলিপিটি প্রতিটি সংযোগ ইভেন্টে উপলব্ধ হওয়া উচিত যদিও বর্তমান প্রতিরূপ লেটেন্সি অ-শূন্য হতে পারে।
  6. পেরিফেরাল তার অভ্যন্তরীণ সারি (ক্রম নম্বর 0) থেকে প্রথম অডিও প্যাকেট নেয় এবং এটি চালায়।

কেন্দ্রীয় অডিও স্ট্রীম বন্ধ করতে «Stop» কমান্ড জারি করে। এই কমান্ডের পরে, প্রতিটি সংযোগ ইভেন্টে পেরিফেরাল উপলব্ধ হওয়ার প্রয়োজন নেই। অডিও স্ট্রিমিং পুনঃসূচনা করতে, উপরের ক্রমটি অনুসরণ করুন, ধাপ 5 থেকে শুরু করে। যখন কেন্দ্রীয় অডিও স্ট্রিমিং না করে, তখনও এটি GATT পরিষেবাগুলির জন্য একটি LE সংযোগ বজায় রাখা উচিত।

পেরিফেরাল কেন্দ্রীয় একটি সংযোগ আপডেট জারি করবে না. শক্তি সঞ্চয় করতে, কেন্দ্রীয় পেরিফেরালের সাথে একটি সংযোগ আপডেট ইস্যু করতে পারে যখন এটি অডিও স্ট্রিমিং না হয়।