(4)MATLAB生成CRC校验码

文章目录

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

前言

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


6. 使用MATLAB生成CRC校验码

6.1 使用MATLAB库函数实现CRC

代码如下(示例):

c 复制代码
% 本文件以实例形式说明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

代码如下(示例):

c 复制代码
% 输入数据
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];         % 每列代表一个字节

总结

暂无后加。

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


相关推荐
用户712122751261 天前
MATLAB 自动化 Excel 转 SLDD 数据字典完整方案(适配自定义 THBPackage 存储类)
matlab
CSharp精选营2 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
ZhengEnCi2 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi2 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
刘马想放假5 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠6 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦13 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
LDR00614 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术14 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
码云数智-园园14 天前
C++20 Modules 模块详解
java·开发语言·spring