সর্বাধিক গুরুত্বপূর্ণ বিট

testwiki থেকে
imported>KanikBot কর্তৃক ০৮:৩৯, ৪ জুলাই ২০২৩ তারিখে সংশোধিত সংস্করণ (ইংরেজি উইকিপিডিয়া ও উইকিউপাত্তের তথ্যের ভিত্তিতে বট কর্তৃক বিষয়শ্রেণী যোগ)
(পরিবর্তন) ← পূর্বের সংস্করণ | সর্বশেষ সংস্করণ (পরিবর্তন) | পরবর্তী সংস্করণ → (পরিবর্তন)
পরিভ্রমণে চলুন অনুসন্ধানে চলুন

কম্পিউটিং-এর পরিভাষায় সর্বাধিক গুরুত্বপূর্ণ বিট (টেমপ্লেট:Lang-en) হচ্ছে কোন বাইনারি সংখ্যার সর্বোচ্চ অবস্থান মানের বিট। অর্থাৎ বাম দিক থেকে প্রথম অশূন্য বিট। যেহেতু সংখ্যার অবস্থানমাত্রিক চিহ্নপদ্ধতিতে বা ‘পজিশনাল নোটেশনে’ সবচেয়ে বেশি মানের অঙ্ককে সবচেয়ে বাম দিকে লেখা হয়, সেহেতু সর্বাধিক গুরুত্বপূর্ণ বিটকে অনেক সময় “লেফ্‌ট মোস্ট বিট” বা “সর্ববামের বিট”-ও বলা হয়।

এক বা দুইয়ের পূরক চিহ্নপদ্ধতিতে সর্বাধিক গুরুত্বপূর্ণ বিট দ্বারা সংখ্যার ধনাত্মকতা বা ঋণাত্মকতা প্রকাশিত হয়। যেখানে নির্দিষ্ট দৈর্ঘের বিট স্ট্রিংএর এমএসবি ‘’1’’ হওয়ার অর্থ সংখ্যাটি ঋণাত্মক এবং ‘’0’’ হবার অর্থ সংখ্যাটি ধনাত্মক।

ইংরেজিতে এমএসবি দ্বারা অনেক সময় মোস্ট সিগনিফিকেন্ট বাইটও বোঝানো হয়। বিটের মত এখানেও সর্বচ্চ অবস্থান মানের বাইট কেই ‘এম এস বি’ বলা হয়। ইংরেজি তে লেখার সময় এক্ষেত্রে বড় হরফে (MSB) লেখা হয়।

মোস্ট সিগনিফিকেন্ট বিট্‌স (বহুবচনে) বলতে সেইসব বিটের সেট কে বোঝায় যারা অবস্থান গত ভাবে এমএসবি’র সব চেয়ে কাছাকাছি।

১৪৯ এর চিহ্নহীন বাইনারি প্রকাশ, যেখানে এমএসবি কে হাইলাইট করা হয়েছে। একটি ৮ বিট বাইনারি সংখ্যার এমএসবি দারা ডেসিমেল ১২৮ প্রকাশিত হয়। সব ধরনের বাইনারি সংখ্যাতেই এলএসবি’র মান ১

প্রচলিত পদ্ধতি

একটি বাইনারি সংখ্যার মধ্যকার বিটগুলিকে নির্দেশ করার জন্য প্রত্যেকটা বিটকে সাধারণত অবস্থান সূচক একটা সংখ্যা দেওয়া হয়। এই সংখ্যাগুলি শুন্য থেকে শুরুকরে ঐ বাইনারি সংখ্যার বিট সংখ্যার চেয়ে এক কম পর্যন্ত হয়। এই সংখ্যা সূচকের ক্রম বাম বা ডান যেকোন দিক থেকে শুরু হতে পারে (ব্যবহারিক প্রসঙ্গ নির্ভর)। একারণে বিভ্রান্তি এড়ানোর জন্য ‘এমএসবিকে সাধারণত ‘প্রথম বিট’ বা ‘শেষ বিট’ এভাবে না বলে ‘উচ্চমাত্রার বিট’ বলা হয়।

ট্রান্সমিশন

802.5 এবং FDDI, স্টান্ডার্ড অনুসারে মোস্ট সিগনিফিকেন্ট বিট কে প্রথমে ট্রান্সমিট করা হয়।[১]

একটি ইন্টিজার সংখ্যার মোস্ট সিগনিফিকেন্ট অশুন্য বিটের অবস্থান নির্ণয়

নিম্নে সি প্রোগ্রামিং ভাষায় একটা ৩২ বিট ইন্টিজারের অশুন্য এমএসবি নির্ণয়ের অ্যালগরিদম দেওয়া হল [] এখানে ওপারেটর '>>' ‘আনসাইন্ড রাইট শিফট’ অপারেশন নির্দেশ করে।

/**
 * Returns the most significant bit position of n from 0 to 31.
 * -1 is returned if n is 0.
 */
int mostSignificantBitPosition(unsigned int n) {
  int pos = 0;
  int tmp;
  tmp = n >> 16;
  if (tmp != 0) { n = tmp; pos = pos + 16; }
  tmp = n >> 8;
  if (tmp != 0) { n = tmp; pos = pos + 8; }
  tmp = n >> 4;
  if (tmp != 0) { n = tmp; pos = pos + 4; }
  tmp = n >> 2;
  if (tmp != 0) { n = tmp; pos = pos + 2; }
  tmp = n >> 1;
  if (tmp != 0) { n = tmp; pos = pos + 1; }
  return pos + n - 1;
}
// C# code to return the index of the MSB. MSB(0)=0
public static int MostSignificantBit (UInt32 n)				
{
     int b = 0;
     if (0 != (n & (~0u << (1 << 4)))) { b |= (1 << 4); n >>= (1 << 4); }
     if (0 != (n & (~0u << (1 << 3)))) { b |= (1 << 3); n >>= (1 << 3); }
     if (0 != (n & (~0u << (1 << 2)))) { b |= (1 << 2); n >>= (1 << 2); }
     if (0 != (n & (~0u << (1 << 1)))) { b |= (1 << 1); n >>= (1 << 1); }
     if (0 != (n & (~0u << (1 << 0)))) { b |= (1 << 0); }
     return b;
}
// C# code to return the index of the MSB. MSB(0)=0
public static int MostSignificantBit(UInt64 n)
{
     int b = 0;
     if (0 != (n & (~0uL << (1 << 5)))) { b |= (1 << 5); n >>= (1 << 5); }
     if (0 != (n & (~0uL << (1 << 4)))) { b |= (1 << 4); n >>= (1 << 4); }
     if (0 != (n & (~0uL << (1 << 3)))) { b |= (1 << 3); n >>= (1 << 3); }
     if (0 != (n & (~0uL << (1 << 2)))) { b |= (1 << 2); n >>= (1 << 2); }
     if (0 != (n & (~0uL << (1 << 1)))) { b |= (1 << 1); n >>= (1 << 1); }
     if (0 != (n & (~0uL << (1 << 0)))) { b |= (1 << 0); }
     return b;
}

যেসব কম্পিউটার ভাষা ইন্টারপ্রেটারের মাধ্যমে কাজ করে (যেমন পাইথন), সেসব ক্ষেত্রে এধরনের বিট অপারেশনের চেয়ে log2 অপারেশনটি অনেক বেশি কার্যকর, দ্রুত এবং সংক্ষিপ্ত। নিম্নে এমএসবি নির্ণয়ে পাইথন ব্যবহারের একটা পদ্ধতি দেখান হল,

from math import log
def msb_pos(n):
    return int(log(n, 2))

জাভা ভার্সন ১.৫ থেকে টেমপ্লেট:Javadoc:SE এবংটেমপ্লেট:Javadoc:SE নামক দুইটি ‘মেথড’ পাওয়া যায় যারা যথাক্রমে ৩২-বিট এবং ৬৪-বিট ইন্টিজার সংখ্যার ‘লিডিং জিরো’ বা সংখ্যার বামের শুন্য সংখ্যা নির্ণয় করে। যেসংখ্যাটা সলে (ইন্টিজার সংখ্যার বিট সংখ্যা) - ১ - (এমএসবি এর অবস্থান মান বা পজিশন) এর সমান।

তথ্যসূত্র

টেমপ্লেট:সূত্র তালিকা

আরো দেখুন