精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

常用的數據差錯控制技術(1)-重復校驗

電子設計 ? 來源: 電子設計 ? 作者: 電子設計 ? 2020-10-30 11:55 ? 次閱讀

大家好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給大家講的是嵌入式里數據差錯控制技術 - 重復校驗。

嵌入式應用里,除了最核心的數據處理外,我們還會經常和數據傳輸打交道。數據傳輸需要硬件傳輸接口的支持,串行接口由于占用引腳少的優點目前應用比并行接口廣泛,常用的串行接口種類非常多,比如 UART,SPI,I2C,USB 等,在使用這些接口傳輸數據時避不可免會遇到一個問題,如果傳輸過程中遇到未知硬件干擾發生 bit 錯誤怎么辦?

痞子衡今天給大家講的就是數據傳輸過程中用于差錯檢測的最簡單的方法,即重復校驗法。

一、重復校驗法基本原理

1.1 校驗依據

重復校驗法的校驗依據就是判斷重復傳輸的 q 組 n bits 二進制數據是否一致。

1.2 重復校驗位

為了實現重復校驗,就是不斷重復傳輸這組 n bits 原始數據 q 次即可,一次校驗的 q*n bits 數據塊中,僅有 n bits 數據是原始有效數據,校驗位就是那些重復的(q-1)*n bits 數據。是不是覺得簡單又粗暴?

1.3 校驗方法

假設原始數據塊是 X[n-1:0]共 n bits,重復次數為 q(q 一般為奇數),按重復傳輸方式,可分為兩個子類:

按 bit 重復:發送數據序列為,q 個 X0(X0X0...),q 個 X1(X1X1...)...,q 個 Xn-1(Xn-1Xn-1...)


按 block 重復:發送數據序列為,第 1 個 X[n-1:0],第 2 個 X[n-1:0]...,第 q 個 X[n-1:0]。

接受端收到數據后,逐次比較 q 個重復位,如完全一致,則認為沒有錯差;如不一致,則存在錯誤 bit。如需糾錯的話,原理也很簡單,判斷 q 個重復位里哪種數據位出現的次數多(這里解釋了 q 為何應是奇數)則為原始正確數據位。

1.4 C 代碼實現

實際中按 block 重復校驗法應用比較多,此處示例代碼以此為例:

安裝包:codeblocks-17.12mingw-setup.exe
集成環境:CodeBlocks 17.12 rev 11256
編譯器:GNU GCC 5.1.0
調試器:GNU gdb (GDB) 7.9.1

// repetition_code.c
//////////////////////////////////////////////////////////
#include
#include

/*!
* @brief 處理按 block 重復的數據塊
*
* @param src, 待處理的數據塊 .
* @param dest, 處理完成的原始數據 .
* @param lenInBytes, 待處理的數據塊長度 .
* @param repeatTimes, 數據重復次數(假定為奇數).
* @retval 0, 數據無錯誤位 .
* @retval 1, 數據有錯誤位且已糾正 .
*/
uint32_t verify_correct_repetition_block(uint8_t *src,
uint8_t *dest,
uint32_t lenInBytes,
uint32_t repeatTimes)
{
assert(repeatTimes % 2);
assert(!(lenInBytes % repeatTimes));

uint32_t result = 0;
uint32_t blockBytes = lenInBytes / repeatTimes;

// 遍歷一個 block 長度里每個 byte
for (uint32_t i = 0; i < blockBytes; i++)
{
// 遍歷當前 byte 的每個 bit
uint8_t correctByte = 0;
for (uint32_t j = 0; j < 8; j++)
{
// 遍歷當前 byte 的所有重復 byte
uint32_t bit1Count = 0;
for (uint32_t k = 0; k < repeatTimes; k++)
{
// 記錄所有重復 byte 中當前 bit 為 1 的個數
uint8_t countByte = *(src + i + k * blockBytes);
bit1Count += (countByte & (0x1u << j)) >> j;
}
// 當 bit1 出現半數則將當前 bit 認定為 1
if (bit1Count > (repeatTimes / 2))
{
correctByte |= 0x1u << j;
}
// 首次發現錯誤 bit 時,置位 result
if ((!result) && (bit1Count !=0) && bit1Count != repeatTimes)
{
result = 1;
}
}
// 將校驗后的 byte 存入 dest
*(dest + i) = correctByte;
}

return result;
}

// main.c
//////////////////////////////////////////////////////////
#include "repetition_code.h"
#include
#include

int main(void)
{
uint8_t src[3][4] = {{0x32, 0x33, 0x04, 0x08},
{0x32, 0x83, 0x04, 0xd8},
{0x31, 0x33, 0x04, 0xe8}};
uint8_t dest[4];
uint32_t result = verify_correct_repetition_block((uint8_t *)src, dest, sizeof(src), sizeof(src) / sizeof(src[0]));

printf("result = %d/n", result);
for (uint32_t i = 0; i < sizeof(dest); i++)
{
printf("dest[%d] = 0x%x/n", i, dest[i]);
}
return 0;
}

1.5 行業應用

實際上本文所講的單純的重復校驗法行業因為效率的原因,行業里較少應用,其改進版的實現 RA Codes 應用在了 FlexRay 協議里。

二、重復校驗法失效分析

重復校驗實現非常簡單,具有比較理想的檢錯能力,但效率太低,并未得到廣泛使用。即便犧牲了效率,但重復校驗法也存在如下 2 個缺陷,導致其檢錯糾錯并不可靠:

當重復 bit 全部發生錯誤時,會被誤認為沒有錯誤 bit 發生。


當錯誤 bit 出現概率大于原始 bit 時,在糾錯時會認定錯誤 bit 是原始 bit。

有沒有其他比重復校驗法更高效的檢錯方法?痞子衡在下篇會繼續聊。

至此,嵌入式里數據差錯控制技術之重復校驗痞子衡便介紹完畢了,掌聲在哪里~~~

審核編輯 黃昊宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 控制技術
    +關注

    關注

    3

    文章

    342

    瀏覽量

    33145
收藏 人收藏

    評論

    相關推薦

    基于GPU器件行為的創新分布式功能安全機制為智能駕駛保駕護航

    在鎖步和重復校驗兩種常見的功能安全機制之外,全球領先的GPU IP廠商Imagination帶來一種全新的、高性價比的分布式功能安全機制。
    的頭像 發表于 10-11 13:14 ?197次閱讀
    基于GPU器件行為的創新分布式功能安全機制為智能駕駛保駕護航

    AS3933 與SI3933 技術對比資料

    的完美匹配,極大地簡化了天線調諧。三大PCB例圖:Si3933 支持以下喚醒規則: 1、僅頻率檢測(不需向量校驗); 2、單向量校驗,包括 16 位的向量和 32 位的向量; 3、雙向量校驗
    發表于 08-30 14:56

    重復接地的作用與實施

    ,施工單位需要確保配電線路的零干線以及分支線的末端都接地,并且在零干線上每隔1公里進行一次接地。對于接地點超過50米遠的配電線路,在用戶接入點的零線也應進行重復接地,且重復接地電阻應控制
    的頭像 發表于 08-15 11:23 ?702次閱讀

    請問ESP-NOW對數據的完整性和一致性有校驗嗎?

    當使用ESP-NOW時,傳遞的數據在傳輸層有對數據包的完整性(比如對面傳給我的字節數和我收到的字節數是否相同)有底層校驗嗎? 還有這個數據包是否經過了CRC等
    發表于 06-17 06:55

    工業控制常用總線技術有哪些

    。以下是一些常用的工業控制機總線技術: RS-232 :這是一種傳統的串行通信總線,主要用于短距離通信。它支持全雙工通信,數據傳輸速率可達115.2 kbps。 RS-485 :RS-
    的頭像 發表于 06-16 14:52 ?1045次閱讀

    帶奇偶校驗發生器/校驗器和3態輸出的16位收發器ABT16657數據

    電子發燒友網站提供《帶奇偶校驗發生器/校驗器和3態輸出的16位收發器ABT16657數據表.pdf》資料免費下載
    發表于 05-30 09:45 ?0次下載
    帶奇偶<b class='flag-5'>校驗</b>發生器/<b class='flag-5'>校驗</b>器和3態輸出的16位收發器ABT16657<b class='flag-5'>數據</b>表

    帶奇偶校驗發生器/校驗器和3態輸出的八進制收發器SN74F657數據

    電子發燒友網站提供《帶奇偶校驗發生器/校驗器和3態輸出的八進制收發器SN74F657數據表.pdf》資料免費下載
    發表于 05-29 09:44 ?0次下載
    帶奇偶<b class='flag-5'>校驗</b>發生器/<b class='flag-5'>校驗</b>器和3態輸出的八進制收發器SN74F657<b class='flag-5'>數據</b>表

    鴻蒙原生應用元服務-訪問控制(權限)開發校驗環節

    一、場景介紹 應用在提供對外功能服務接口時,可以根據接口涉數據的敏感程度或所涉能力的安全威脅影響,在系統定義的權限列表中權限定義列表選擇合適的權限限制當前接口的開放范圍,對接口訪問者進行權限校驗
    發表于 04-22 17:52

    淺析MCU通信、存儲常用的簡單校驗算法

    UART有一個奇偶校驗,CAN通信有CRC校驗。Modbus、MAVlink、USB等通信協議也有校驗信息。
    的頭像 發表于 03-07 10:56 ?476次閱讀
    淺析MCU通信、存儲<b class='flag-5'>常用</b>的簡單<b class='flag-5'>校驗</b>算法

    9位奇偶校驗發生器/校驗器74HC280-Q100; 74HCT280-Q100數據手冊

    電子發燒友網站提供《9位奇偶校驗發生器/校驗器74HC280-Q100; 74HCT280-Q100數據手冊.pdf》資料免費下載
    發表于 01-18 15:20 ?0次下載
    9位奇偶<b class='flag-5'>校驗</b>發生器/<b class='flag-5'>校驗</b>器74HC280-Q100; 74HCT280-Q100<b class='flag-5'>數據</b>手冊

    ITC6813 REG1的電壓數據為0xffff,而且PEC校驗錯誤怎么解決?

    讀取電壓寄存器,只能讀到REG2-6的電壓數據,REG1的電壓數據為0xffff,而且PEC校驗錯誤,各位有遇到這種問題嗎?幫忙看看,謝謝
    發表于 01-04 06:37

    簡述循環冗余碼crc校驗方法的工作原理

    循環冗余碼(CRC)校驗是一種常用的錯誤檢測和糾正方法,廣泛應用于通信和存儲設備中,用于確定數據在傳輸或存儲過程中是否出現錯誤。 CRC校驗方法的工作原理可以分為以下幾個步驟:
    的頭像 發表于 12-20 11:27 ?1175次閱讀

    彈簧管壓力表的校驗方法

    彈簧管壓力表是一種常用于測量壓力的儀器,在工業生產和實驗室實驗中廣泛應用。為了保證彈簧管壓力表的準確性和可靠性,需要定期進行校驗。本文將詳細介紹彈簧管壓力表的校驗方法,包括校驗的步驟、
    的頭像 發表于 12-07 16:34 ?2705次閱讀

    AD2S1205 SO輸出的校驗位是對哪部分數據進行校驗

    Hi, SO輸出的校驗位是對哪部分數據進行校驗; 看手冊應該是對數據部分校驗即DB15-DB4; 但是通過這樣
    發表于 12-05 07:27

    差錯控制技術詳解

    一只按序列行進的隊伍,你該通過什么方法來檢查隊伍是否發生變動,有沒有少人,有沒有多人,有沒有插隊。本篇將介紹各種方法教你花式排隊,也就是信道編碼
    的頭像 發表于 11-27 10:05 ?465次閱讀
    <b class='flag-5'>差錯</b><b class='flag-5'>控制</b><b class='flag-5'>技術</b>詳解