کد خطی
در تئوری کدگذاری کانال مخابراتی ، کد خطی (به انگلیسی: Linear code)، یک کد تصحیحکننده خطاست که هر ترکیب خطی از کلمات کد (به انگلیسی: Codeword) نیز یک کلمه کد است. کدهای خطی، به کدهای بلوکی و کدهای کانولوشنال تقسیم میشوند، گرچه کدهای توربو را نیز میتوان ترکیبی از این دو دانست. کدهای خطی، کدگذاری و کدگشایی کارآمدتری نسبت به دیگر کدها دارند.[نیازمند منبع]
کدهای خطی برای تصحیح خطای روبهجلو (به انگلیسی: Forward error correction) در انتقال سمبولها (برای نمونه، بیتها) در یک کانال مخابراتی بهکار میروند تا درصورت خطا در انتقال، برخی از خطاها از سوی گیرنده تصحیح، یا دستکم، شناسایی شوند. کلمات کد در یک کد بلوک خطی، بلوکهایی از سمبولها هستند که با سمبولهای بیشتری (نسبت به سمبولهای اصلی) هنگام ارسال، کدگذاری شدهاند. یک کد خطی به طول ، بلوکهای -سمبولی را ارسال میکند.
برای نمونه، کد همینگ [7، 4، 3]، یک کد باینری بلوکی خطی است که پیامهای 4-بیتی را با کلمات کد 7-بیتی نشان میدهد؛ دو کلمه کد متمایز، حداقل در سه بیت تفاوت دارند. در نتیجه، حداکثر، دو خطا در هر کلمه کد قابل شناسایی است، درحالیکه یک خطا را میتوان تصحیح کرد. این کد، کلمه کد دارد.
تعریف و پارامترها[ویرایش]
کد خطی به طول و بُعد ، یک زیرفضای خطی با بُعد از فضای برداری است، که میدان متناهی با مؤلفه است. به چنین کدی، کد q-ary میگویند. اگر یا باشد، کد را بهترتیب، کد باینری یا کد سهتایی میگویند. بردارها در ، کلمات کد هستند. اندازه یک کد، تعداد کلمات کد، و برابر است.
وزن یک کلمه کد، تعداد عناصر غیرصفر آن است، و فاصله دو کلمه کد، فاصله همینگ آنهاست، یعنی تعداد عناصری که در آنها تفاوت دارند. فاصله کد خطی، حداقل وزن کلمات کد غیرصفر آن، یا حداقل فاصله کلمات کد متمایز است. یک کد خطی با طول ، بُعد و فاصله ، کد نامیده میشود (یا دقیقتر، کد ).
برای ، پایۀ استاندارد تعریف میشود، زیرا هر مختصات نشاندهنده یک بیت است که از راه یک کانال نویزی با احتمال خطای انتقال کمی (یک کانال متقارن باینری ) منتقل میشود. اگر پایۀ دیگری استفاده شود، این مدل نمیتواند استفاده شود و فاصله همینگ، تعداد خطاهای انتقال را آنطور که میخواهیم، تعیین نمیکند.
ماتریسهای مولد و بررسی کد[ویرایش]
به عنوان یک زیرفضای خطی از ، کد (که ممکن است بسیار بزرگ باشد) ممکن است به عنوان گسترۀ مجموعهای از کلمه کد نشان دادهشود (که به عنوان پایه در جبر خطی شناخته می شود). این کدهای پایه، اغلب در ردیفهای ماتریس که بهعنوان ماتریس مولد کد شناخته میشود، قرار میگیرند. اگر شکل ماتریس بلوکی داشتهباشد، یعنی ، که ماتریس واحد و ماتریسی است. در این حالت، ، شکل استاندارد دارد.
ماتریس ، که یک تابع خطی را نشان میدهد که هسته آن است، ماتریس بررسی (به انگلیسی: Check matrix)، یا گاهی ماتریس بررسی برابری (به انگلیسی: Parity check matrix) نامیده میشود. به طور معادل، ماتریسی است که ، هستۀ آن است. اگر یک کد با ماتریس مولد به شکل استاندارد باشد، ، یک ماتریس بررسی برای است. کد تولیدشده با ، کد دوگان نامیده میشود. میتوان نشان داد که یک ماتریس است، درحالیکه یک ماتریس است.
خطیبودن کد، تضمین میکند که دستکم فاصله همینگ کلمه کد و هر یک از کلمات کد دیگر ، مستقل از است. این از آنجا میآید که نیز یک کلمه کد از (یعنی عنصری از زیرفضای ) است و اینکه . این خواص دلالت بر آن دارد که:
به عبارت دیگر، برای یافتن حداقل فاصله کلمات کد یک کد خطی، تنها لازم است که به کلمات کد غیرصفر نگاه کرد. کلمه کد غیرصفر با کوچکترین وزن، حداقل فاصله را با کلمه کد صفر دارد و از این رو حداقل فاصله کد را تعیین میکند.
فاصله کد خطی ، با حداقل تعداد ستونهای وابسته خطی نیز برابر است.
اثبات: چون ، که معادل است ، که ، ستون ام است. با حذف مواردی که ، آنهایی از که ، وابسته خطی هستند. از این رو، حداقل تعداد ستون های وابسته خطی است. از سوی دیگر، با درنظرگرفتن حداقل مجموعه ستونهای وابسته خطی ، که مجموعه شاخص ستون است: . حال با درنظرگرفتن بردار طوریکه ، اگر : زیرا . بنابراین، ، و حداقل تعداد ستون های وابسته خطی است.
مثال: کدهای همینگ[ویرایش]
به عنوان نخستین کلاس از کدهای خطی تصحیحکننده خطا، کدهای همینگ، در سیستم های مخابراتی دیجیتال، گسترده استفاده میشوند.
برای هر عدد صحیح مثبت ، کد همینگ با نشان دادهمیشود. ازآنجاکه ، کد همینگ میتواند تنها یک بیت خطا را تصحیح کند.
مثال : کد بلوک خطی با ماتریس مولد و ماتریس بررسی برابری زیر، یک کد همینگ است.
مثال: کد آدامار[ویرایش]
کد آدامار (به انگلیسی: Hadamard code)، یک کد خطی است که میتواند بسیاری از خطاها را تصحیح کند. این کد میتواند ستونبهستون ساخته شود: ستون ام، بیت های نمایش باینری عدد صحیح است، همانطور که در مثال زیر نشان داده شدهاست. کد آدامار، دارای حداقل فاصله است و بنابراین میتواند خطا را تصحیح کند.
مثال: کد بلوک خطی با ماتریس مولد زیر، یک کد آدامار است:
.
کد آدامار، یک مورد خاص از کد رید-مالر (Reed-Muller) است. اگر ستون اول (ستون تمامصفر) را از خارج کنیم، یک کد سیمپلکس ، که کد دوگان کد همینگ است، بهدست میآید.
الگوریتم نزدیکترین همسایه[ویرایش]
پارامتر ، ارتباط نزدیکی با توانایی تصحیح خطای کد دارد. ساختار/الگوریتم زیر، این را نشان می دهد (که الگوریتم رمزگشایی نزدیکترین همسایه نامیده میشود):
ورودی: یک بردار دریافتشده در .
خروجی: یک کلمه کد در که نزدیکترین به است، اگر یافت شود.
- شروع با ، دو مرحله زیر را تکرار کن.
- هر کلمه کد را یک نقطه در فضای -بُعدی در نظر بگیر. تعداد نقاط درون توپی به شعاع (همینگ) اطراف بردار دریافتشده را، که با نشان داده میشود، بشمار.
- برای هر در ، بررسی کن آیا در است. اگر چنین بود، را به عنوان جواب الگوریتم برگردان.
- را یکی زیاد کن. اگر ، دیگر ادامه نده؛ شمارش کافیست، و هیچ جوابی پیدا نشدهاست.
میگوییم ، خطا را تصحیح میکند، اگر حداکثر یک کلمه کد در برای هر در باشد.
نماد رایج[ویرایش]
کدها، اغلب با نشان دادهمیشوند و یک کد بهطول و رتبه (یعنی کلمه کد در پایه کد، و ردیف در ماتریس مولد آن) به طور کلی با شناخته میشود. کدهای بلوکی خطی اغلب بهصورت ، که ، حداقل فاصله همینگ هر دو کلمه کد است، اشاره دارد.
نباید با که نمادی که برای نشاندادن یک کد غیرخطی به طول ، اندازه ( کلمه کد) و حداقل فاصله همینگ است، اشتباه شود.
قید سینگِلتون (به انگلیسی: Singleton bound)[ویرایش]
لِم (قید سینگِلتُون): برای هر کد خطی ، داریم .
کد که پارامترهای آن، را برآورده کند، حداکثر فاصله قابل تفکیک یا MDS نامیده میشود. چنین کدهایی، اگر یافت شوند، بهترین کدها هستند.
کدهای معادل: اگر و دو کد به طول ، و یک جایگشت در گروه متقارن که برای آن در باشد، اگر و فقط اگر، در باشد، آنگاه و ، جایگشت-معادل هستند. بهطور کلیتر، اگر ماتریس مونومیال باشد که را ایزومورفیک به بفرستد، آنگاه و معادل هستند.
لم : هر کد خطی، جایگشت-معادلِ کدی است که به شکل استاندارد است.
قضیه بونیسولی[ویرایش]
یک کد، همفاصله است، اگر، و تنها اگر، ثابت یافت شود بهطوریکه فاصله هر دو کلمه کد متمایز، باشد. ۱۹۸۴، آریگو بونیسولی، ساختار کدهای خطی تک-وزن را روی میدانهای محدود تعیین و ثابت کرد که هر کد خطی همفاصله، دنبالهای از کدهای همینگ دوگان است. [۱]
منابع[ویرایش]
لینک های خارجی[ویرایش]
- ↑ Bonisoli, A. (1984). "Every equidistant linear code is a sequence of dual Hamming codes". Ars Combinatoria. 18: 181–186.