RS編碼和糾錯演算法
一個n次不可約多項式,如果只能整除1+Z^2^n-1而不能整除其它1+Z^L(L<2^n-1),則這種不可約多項式就稱為本原多項式。
對於一個n次多項式,其本原多項式一般有若干個。下面將給出的一個演算法,是求解在給定任意n值及一個本原多項式的情況下,其餘本原多項式的求解方法。該演算法的意義在於提供了同一n值情況下若干個可選的本原多項式,這樣就允許在構造應用系統時有不同的選擇方案。
已知一個n級本原多項式,求解其餘的本原多項式按以下步驟進行。
(1) 首先確定n級本原多項式的個數λ(n),λ(n)即是n級本原多項式的個數。
(2) 求出小於2n-1且與2n-1互素的所有正整數,構成一個集合〔Si〕,並重新排序,使〔Si〕中元素從小到大排列。
(3) 排除〔Si〕中不適合的數
* 排除〔Si〕中形如2j(j為正整數)
* 排除〔Si〕中所有同宗的數。即從〔Si〕中從後到前搜尋,每取一個數即做2K×Si,直到大於2n-1,然後減去2n-1,用差值在〔Si〕中向前搜尋,如果有相同的數則將Si排除,否則保留。再取Si-1按同樣過程做一遍,直到S0.
* 排除〔Si〕中有倍數關係的數。即從〔Si〕中從後到前搜尋,每取一數即向前查詢一遍,最後〔Si〕中剩下的數即為本原抽樣數,其個數一定為λ(n)-1。
(4) 根據已知的一個n級本原多項式,為其設定初始狀態000…01(n個),求出其M序列{Ai}(長度為2n-1).
(5) 依次從Si中取出本原抽樣數,每取出一個抽樣數Si,即可求出一個本原多項式:以Si對{Ai}進行抽樣,就可產生長度為2n-1的另一M序列{Si}, 在{Si}中找到形如000…01(n位)的序列段{Mi},並提取包括{Mi}為前n項的2n長度的序列:
Am+0,Am+1,…,Am+n-1,
0 0 … 1
Am+n,Am+n+1,…Am+2n-1
X X … X
欲確定的Ci可用下列方程組確定;
C1=Am+n
C2=Am+n+1+C1Am+n
C3=Am+n+2+C1Am+n+1+C2Am+n
相關文章
- 校驗碼&糾錯碼
- OpenHamony 5.0.1編譯糾錯指南編譯
- 海明校驗碼檢錯和糾錯的工作原理
- 量子糾錯碼——Clifford group
- 量子糾錯碼——Stabilizer codes
- 多項式與點值的雙射 與 Reed–Solomon 編碼糾錯.
- 多分類學習及糾錯輸出碼
- 基於機器學習的糾錯系統技術 - 智慧文字糾錯 API機器學習API
- python實現查詢糾錯Python
- RS485和RS232是區別
- 3.3 編碼/解碼演算法演算法
- 語法糾錯的研究現狀
- elasticsearch拼寫糾錯之Term SuggesterElasticsearch
- 蜂窩網路TDOA定位方法的Fang演算法研究及模擬糾錯演算法
- java安全編碼指南之:字串和編碼Java字串
- 中文語法糾錯全國大賽獲獎分享:基於多輪機制的中文語法糾錯
- tokio-rs/console:非同步 Rust 偵錯程式非同步Rust
- IDEA如何設定編碼格式,字元編碼,全域性編碼和專案編碼格式Idea字元
- TTL、RS232和RS485電壓及其他的區別
- 編譯除錯Net6原始碼編譯除錯原始碼
- 演算法科普:有趣的霍夫曼編碼演算法
- MSSQL連線資料庫密碼獲取工具與原文數個錯誤糾正SQL資料庫密碼
- 透過MATLAB分別對比二進位制編碼遺傳最佳化演算法和實數編碼遺傳最佳化演算法Matlab演算法
- 錯字修改 | 佈署1箇中文文文字拼蟹糾錯模型模型
- tikv/raft-rs:在 Rust 中實現的 Raft 分散式共識演算法原始碼RaftRust分散式演算法原始碼
- Idea除錯Rocketmq原始碼編譯執行Idea除錯MQ原始碼編譯
- Qt處理中文編碼出現錯誤QT
- vim 編輯報錯導致無法正常退出和編輯
- U-net基礎入門(包括糾錯過程)
- ==和is的區別 以及編碼和解碼
- 知物由學 | “找茬”不如交給AI演算法,細說文字糾錯的多種實現途徑AI演算法
- Rust編寫的Memcached快取替代品:memc.rsRust快取
- python教程3.3:字元和編碼Python字元
- 密碼學基礎:編碼方式、訊息摘要演算法、加密演算法總結密碼學演算法加密
- Spark原始碼編譯與匯入IDEA除錯Spark原始碼編譯Idea除錯
- 用GPT-4除錯 用Claude 3編碼GPT除錯
- maven 混合編譯 java/scala 程式碼報錯(qbit)Maven編譯Java
- 某大廠面試題與解析(歡迎糾錯,優化)面試題優化