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

Matlab在编码中增加CRC和交织功能

定义CRC生成和检验的类(包括函数)

我们在MATLAB中定义一个类(class),包含了CRC生成函数和检验函数(囊括了常用的CRC多项式)

classdef CRCpropertiesCRCbit_LenpolynomialCRCgenCRCdetendmethodsfunction obj = CRC(CRCbit_Len) %(polynomial)obj.CRCbit_Len = CRCbit_Len;switch CRCbit_Lencase 0obj.polynomial = [0];case 1obj.polynomial = [1 1];case 2obj.polynomial = [1 1 1];case 3obj.polynomial = [1 1 1 1];case 4obj.polynomial = [1 0 0 1 1]; % x^4 + x + 1case 5obj.polynomial = [1 0 0 1 0 1];case 6obj.polynomial = [1 0 0 0 0 1 1];  %1000001case 7obj.polynomial = [1 0 0 0 1 1 1 1];case 8obj.polynomial = [1 0 0 1 1 0 0 0 1];case 9obj.polynomial = [1 0 0 0 1 0 0 0 0 1];case 10obj.polynomial = [1 0 0 0 0 1 0 0 0 1 1];case 11obj.polynomial = [1 0 0 0 0 0 0 1 0 0 0 1];case 12obj.polynomial = [1 0 0 1 0 0 0 0 0 0 0 1 1];case 13obj.polynomial = [1 0 0 0 1 0 0 0 0 0 0 0 1 1]; case 14obj.polynomial = [1 0 0 0 0 1 0 1 0 0 0 0 0 1 1];case 15obj.polynomial = [1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 1];case 16obj.polynomial = [1 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1];case 24obj.polynomial = [1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1];otherwisedisp(["Please add the corresponding polynomial in binary form."]);endobj.CRCgen = crc.generator('Polynomial', obj.polynomial, ...'InitialState', zeros(1, obj.CRCbit_Len), ...'FinalXOR', zeros(1, obj.CRCbit_Len));obj.CRCdet = crc.detector('Polynomial', obj.polynomial, ...'InitialState', zeros(1, obj.CRCbit_Len), ...'FinalXOR', zeros(1, obj.CRCbit_Len));end% generate CRCfunction crcencoded_data = encode(obj, data)crcencoded_data = generate(obj.CRCgen, data); % SourceCoding_Len x No_Active_Usersend% detect CRCfunction [crcdecoded_data, error_detected] = decode(obj, received_data)[crcdecoded_data, error_detected] = detect(obj.CRCdet, received_data); endend
end

程序示例(包含交织和解交织功能)

clc; clear all;
rng('default');
warning('off');K0 = 12;   % information bits
K_crc = 4; % crc bits length
N = 16;    % coded length (omit here)
% Rate = (K0 + K_crc) / N;Ka = 10; % packet number% Preporcessing:
% interleaver and de-interleaver related: for row vector
interleaver_IDs = randperm(N);
[~, de_interleaver_IDs] = sort(interleaver_IDs);
interlv_func = @(Bits)  Bits(:, interleaver_IDs);  % Bits could be a matrix with size (packet_num x FEC_Len) 
de_interlv_func = @(interlv_Bits) interlv_Bits(:, de_interleaver_IDs);% invoke CRC class
CRC = CRC(K_crc);% Transmission
% information bits
u0 = randi([0, 1], K0, Ka);
% append CRC
u  = CRC.encode(u0); % (K0 + K_crc) x Ka
% interleaving
inlv_bits = interlv_func(encodedBits);% omit encoding process and receiver procedure% de-interleaving
deinlv_bits = de_interlv_func(inlv_bits );
http://www.lryc.cn/news/151915.html

相关文章:

  • Css 设置从上到下的渐变色: 0到70%为yellow,然后线性地变成透明。
  • git在windows上安装
  • 快速上手GIT命令,现学也能登堂入室
  • 二进制安全虚拟机Protostar靶场 安装,基础知识讲解,破解STACK ZERO
  • python实现的一些方法,可以直接拿来用的那种
  • 通过HTTP进行并发的数据抓取
  • 《论文阅读21》Equivariant Multi-View Networks
  • 【数据结构】| 并查集及其优化实现
  • 最新ChatGPT程序源码+AI系统+详细图文部署教程/支持GPT4.0/支持Midjourney绘画/Prompt知识库
  • 自动驾驶和辅助驾驶系统的概念性架构(一)
  • 【两周学会FPGA】从0到1学习紫光同创FPGA开发|盘古PGL22G开发板学习之数码管静态显示(四)
  • 【洛谷】P3853 路标设置
  • 探索图像数据中的隐藏信息:语义实体识别和关系抽取的奇妙之旅
  • Gradle问题处理
  • 架构:C4 Model
  • 数据结构学习系列之顺序表的两种修改方式
  • React:props说明
  • Can‘t connect to local MySQL server through socket ‘/tmp/mysql.sock‘
  • C++的单例模式
  • Spring Boot 中 Nacos 配置中心使用实战
  • 学生管理系统VueAjax版本
  • 迭代器模式简介
  • 四方定理c++题解
  • ZDH-权限模块
  • 漏洞修复:在应用程序中发现不必要的 Http 响应头
  • 什么是mkp勒索病毒,中了mkp勒索病毒怎么办?勒索病毒解密数据恢复
  • db2迁移至oracle
  • webpack学习使用
  • 按钮控件之2---QComboBox 复选按钮/复选框控件
  • 【数据分享】2006-2021年我国省份级别的燃气相关指标(免费获取\20多项指标)