• 【转】CRC校验


    原文链接 http://blog.chinaunix.net/uid-26435987-id-3164528.html

    CRC (英文全称Cyclical Redundancy Check), 循环冗余码校验

    校验原理:
    1、循环校验码(CRC码):
    是数据通信领域中最常用的一种差错校验码,其特征是信息字段校验字段的长度可以任意选定。
     
    2、生成CRC码的基本原理:
    任意一个由二进制位串组成的代码都可以和一个系数仅为‘0’和‘1’取值的多项式一一对应。
    例如:代码1010111对应的多项式为x6+x4+x2+x+1,而多项式为x5+x3+x2+x+1对应的代码101111。
     
    3、CRC码集选择的原则:
    若设码字长度为N,信息字段为K位,校验字段为R位(N=K+R),则对于CRC码集中的任一码字,存在且仅存在一个R次多项式g(x),使得
                     V(x)=A(x)g(x)=xRm(x)+r(x);
    其中:    m(x)为K次信息多项式, r(x)为R-1次校验多项式,
             g(x)称为生成多项式:g(x)=g0+g1x+ g2x2+...+g(R-1)x(R-1)+gRxR
    发送方通过指定的g(x)产生CRC码字,接收方则通过该g(x)来验证收到的CRC码字。 
     
    4、CRC校验码软件生成方法
        借助于多项式除法,其余数为校验字段。
    例如:信息字段代码为: 1011001;对应的K=6次信息多项式m(x)=x6+x4+x3+1 
          假设生成多项式为:g(x)=x4+x3+1;则对应g(x)的代码为: 11001
          x4m(x)=x10+x8+x7+x4 对应的代码记为:10110010000;
    采用多项式除法(注意下图):  得余数为: 1010     (即校验字段为:1010)
    发送方:发出的传输字段为:  1 0 1 1 0 0 1 1 0 1 0
                              信息字段       校验字段
    接收方:使用相同的生成码进行校验:接收到的字段/生成码(模2除法)如果能够除尽,则正确。
     
    “模2除”的演示图片:
  • 相关阅读:
    shiro
    leetcode696 C++ 36ms 计算二进制子串
    leetcode557 C++ 56ms 反转字符串中的每个单词
    leetcode657 C++ 16ms 判断回环
    leetcode709 C++ 4ms 转换成小写字母
    leetcode141 C++ 8ms 环形链表
    leetcode160 C++ 32ms 相交链表
    leetcode234 C++ 28ms 回文链表
    leetcode203 C++ 28ms 删除链表中满足条件的节点
    leetcode83 C++ 12ms 删除有序链表中的重复元素
  • 原文地址:https://www.cnblogs.com/ihongyan/p/4853313.html
Copyright © 2020-2023  润新知