当前位置: 首页 > article >正文

(4)MATLAB生成CRC校验码

文章目录

  • 前言
  • 6. 使用MATLAB生成CRC校验码
    • 6.1 使用MATLAB库函数实现CRC
    • 6.2 不用库函数,按校验原理实现CRC
  • 总结


前言

承接前面几篇文章介绍的CRC校验码原理,本文给出CRC校验码的MATLAB仿真代码。


6. 使用MATLAB生成CRC校验码

6.1 使用MATLAB库函数实现CRC

代码如下(示例):

% 本文件以实例形式说明CRC校验码的生成原理。
% 使用CRC8生成多项式 x^8 + x^2 + x + 1对原始信息序列进行CRC8校验编码,
% 得到8为CRC码,附加到原始信息序列后面,形成发送比特序列。
poly = [1 0 0 0 0 0 1 1 1];         % 生成多项式
n = length(poly) - 1;
 
% 原始信息序列
msg = [1 1 0 1 0 0 1 1];
 
msg_length = length(msg);
 
% 消息比特序列左移8位
msg1 = [msg zeros(1, n)];
 
% 使用多项式除法求CRC校验码,q为商,r为余数
[q,r] = deconv(msg1, poly);
 
% 余数模2处理
r = mod(abs(r),2);
 
% CRC校验码
crc = r(msg_length+1:end);
 
% 将CRC校验码附加到原始信息序列后面
msg_and_crc = [msg, crc];

6.2 不用库函数,按校验原理实现CRC

代码如下(示例):

% 输入数据
data_width = 8;                 % 数据位宽。进行CRC校验的源数据按字节排列
data_num = 4;                   % 数据个数。进行CRC校验的源数据包含的字节数
msg0 = randi(2,data_width,data_num) - 1;         % 生成源数据

crc = [0 0 0 0 0 0 0 0]';         % crc初值
length = data_num;                % 输入数据个数。输入数据按字节格式存储
cnt = 1;                          % 输入数据索引
 
msg = msg0;                       % CRC输入的原始信息序列
 
% CRC8生成多项式 x^8 + x^2 + x + 1
poly = [0 0 0 0 0 1 1 1];         % 省略最高位
 
while length > 0
    crc = xor(crc,msg(:,cnt));
    
    for C = 1:8
        if  0 ~= crc(1)
            crc_shift = [crc(2:8);0];
            crc = xor(crc_shift , poly');
        else
            crc = [crc(2:8);0];
        end
    end
    
    cnt = cnt + 1;
    length = length - 1;
end
 
% 将CRC校验码附加到原始信息序列后面
msg_and_crc_2 = [msg, crc];         % 每列代表一个字节

总结

暂无后加。
后续介绍奇偶校验码和汉明码等。



http://www.kler.cn/news/336105.html

相关文章:

  • Unity各个操作功能+基本游戏物体创建与编辑+Unity场景概念及文件导入导出
  • Vue3-TS-Lodash:理解Lodash / 常用方法积累
  • 银行数字化转型导师坚鹏:2025年银行开门红绩效管理方法及案例
  • 家庭厨房的蟑螂消灭治理方法
  • 【机器学习-无监督学习】概率图模型
  • 毕业设计项目——基于transformer的中文医疗领域命名实体识别(论文/代码)
  • class 029 重要排序算法的总结
  • 数据分布过于集中 怎么办,python 人工智能 ,数据分析,机器学习pytorch tensorflow ,
  • 【C++】二叉搜索树+变身 = 红黑树
  • Python的几个高级特性
  • 谷粒商城のRabbitMQ基础篇
  • 制作离线版Koczkatamas工具包
  • 洛谷 P11045 [蓝桥杯 2024 省 Java B] 最优分组
  • Linux 系统 nvm 管理node无法使用
  • python爬虫 - 初识requests模块
  • 民锋金融:稳健发展的战略与未来展望
  • 代码随想录Day 62|Floyd 算法精讲、A \* 算法精讲 (A star算法),题目:97. 小明逛公园、127. 骑士的攻击
  • 关于BSV区块链覆盖网络的常见问题解答(下篇)
  • CRM如何和ERP融合,才能打破信息孤岛效应。
  • vite学习教程05、vite+vue2构建本地 SVG 图标