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.mzph.cn/news/63086.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

高教社杯数模竞赛特辑论文篇-2012年D题:机器人避障问题(附获奖论文及MATLAB代码实现)

目录 摘要 一、问题重述 二、问题分析 2.1 求取最短路径的分析 2.2 最短时间路径的分析 <

UE5打完包后,启动程序不能全屏

最近看到ue5的打包程序后不能默认自动全屏&#xff0c;效果如下&#xff0c;发现并不是全屏的&#xff0c;而且就算点击放大也不是全屏 解决办法&#xff1a;设置如下之后在打包就可以了 但是会一直打印错误的日志&#xff0c;不过这个不影响使用

JS -RSA 明文加密--用户密码加密

1 配置文件引入 加密包 package.json "jsencrypt": "^3.0.0-rc.1",2 加密公钥配置 import { JSEncrypt } from jsencrypt import request from "/utils/request";const RSA_PUBLIC_KEY "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCJVol0cJ…

解决SpringBoot项目war部署到tomcat下无法Nacos中注册服务问题

问题说明 怎么解决Spring Boot项目部署到tomcat下无法Nacos中注册服务问题"&#xff0c;希望能够解决您遇到有关问题。 在使用Nacos作为注册中心的Spring Boot项目&#xff0c;以war包形式部署到服务器上&#xff0c;启动项目发现该服务无法在Nacos中注册。 分析 …

芯片开发之难如何破解?龙智诚邀您前往DR IP-SoC China 2023 Day

2023年9月6日&#xff08;周三&#xff09;&#xff0c;龙智即将亮相D&R IP-SoC China 2023 Day&#xff0c;呈现集成了Perforce与Atlassian产品的芯片开发解决方案&#xff0c;助力企业更好、更快地进行芯片开发。 龙智资深顾问、技术支持部门负责人李培将带来主题演讲—…

(数字图像处理MATLAB+Python)第十一章图像描述与分析-第三、四节:几何表述和形状描述

文章目录 一&#xff1a;几何描述&#xff08;1&#xff09;像素间几何关系A&#xff1a;邻接与连通B&#xff1a;距离 &#xff08;2&#xff09;像素间几何特征A&#xff1a;位置B&#xff1a;方向C&#xff1a;尺寸 &#xff08;3&#xff09;程序 二&#xff1a;形状描述&a…

python元组的不可变性和应用场景

Python元组是一种不可变的数据类型&#xff0c;也就是说一旦创建后&#xff0c;其元素无法被修改、添加或删除。元组使用圆括号来表示&#xff0c;元素之间使用逗号进行分隔。 以下是创建和访问元组的方法和语法&#xff1a; 创建元组&#xff1a; 使用圆括号直接创建&#xff…

yolov5自定义模型训练三

经过11个小时cpu训练完如下 在runs/train/expx里存放训练的结果&#xff0c; 测试是否可以检测ok 网上找的这张识别效果不是很好&#xff0c;通过加大训练次数和数据集的话精度可以提升。 训练后的权重也可以用视频源来识别&#xff0c; python detect.py --source 0 # webca…

Fiddler Response私人订制

在客户端接口的测试中&#xff0c;我们经常会需要模拟各种返回状态或者特定的返回值&#xff0c;常见的是用Fiddler模拟各种请求返回值场景&#xff0c;如重定向AutoResponder、请求拦截修改再下发等等。小编在近期的测试中遇到的一些特殊的请求返回模拟的测试场景&#xff0c;…

docker作业

目录 1、使用mysql:5.6和 owncloud 镜像&#xff0c;构建一个个人网盘。 1.1启动镜像 1.2启动cloud镜像 1.3浏览器访问 ​编辑 2、安装搭建私有仓库 Harbor 2.1下载docker-compose 2.2 磁盘挂载&#xff0c;保存harbor 2.3 修改配置文件 2.4安装 2.5浏览器访问 2.6 新…

MybatisPlus(2)

前言&#x1f36d; ❤️❤️❤️SSM专栏更新中&#xff0c;各位大佬觉得写得不错&#xff0c;支持一下&#xff0c;感谢了&#xff01;❤️❤️❤️ Spring Spring MVC MyBatis_冷兮雪的博客-CSDN博客 上篇我们简单介绍了MybatisPlus的方便之处&#xff0c;这篇来深入了解Myb…

代码随想录算法训练营第二十四天|理论基础 77. 组合

理论基础 其实在讲解二叉树的时候&#xff0c;就给大家介绍过回溯&#xff0c;这次正式开启回溯算法&#xff0c;大家可以先看视频&#xff0c;对回溯算法有一个整体的了解。 题目链接/文章讲解&#xff1a;代码随想录 视频讲解&#xff1a;带你学透回溯算法&#xff08;理论篇…

Maven之高版本的 lombok 和 tomcat 7 插件冲突问题

高版本的 lombok 和 tomcat 7 插件冲突问题 在开发期间&#xff0c;当我们使用 tomcat7-maven-plugin 来作为运行环境运行我们项目使&#xff0c;如果我们项目中使用了 1.16.20 及以上版本的 lombok 包&#xff0c;项目启动时会报错&#xff1a; for annotations org.apache.…

使用代理服务器和pip安装软件包

在开着代理服务器的情况下&#xff0c;直接pip install 软件包名会出现如下错误&#xff0c; WARNING: Retrying (Retry(total4, connectNone, readNone, redirectNone, statusNone)) after connection broken by SSLError(SSLZeroReturnError(6, TLS/SSL connection has been…

设计模式--代理模式(Proxy Pattern)

一、什么是代理模式&#xff08;Proxy Pattern&#xff09; 代理模式&#xff08;Proxy Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许一个对象&#xff08;代理&#xff09;充当另一个对象&#xff08;真实对象&#xff09;的接口&#xff0c;以控制对该对象的…

GNSS全球卫星导航系统(频段)

在地球表面或近地空间的任何地点&#xff0c;为用户提供全天候的三维坐标、速度和时间信息的空基无线电导航定位系统。 系统卫星导航频段信号频率全球 北斗 &#xff08;中国&#xff09; 低频段B2a1176.45 MHz低频段B2b1207.14 MHz低频段B3I1268.52 MHz高频段B1I1561.098MHz高…

UG\NX CAM二次开发 获取工序的状态 UF_OPER_ask_status

文章作者:代工 来源网站:NX CAM二次开发专栏 简介: UG\NX CAM二次开发 获取工序的状态 效果: 代码: void MyClass::do_it() {int count=0;tag_t * objects;UF_UI_ONT_ask_selected_nodes(&count, &objects);for (int i=0; i<count; i++){tag_t operTa…

智能工厂移动式作业轻薄加固三防平板数据采集终端

在这个高度自动化和数字化的环境中&#xff0c;数据采集变得尤为重要。为了满足这个需求&#xff0c;工业三防平板数据采集终端应运而生。工业三防平板数据采集终端采用了轻量级高强度镁合金材质&#xff0c;这使得它在保持轻薄的同时具有更强的坚固性。这种材质还具有耐磨防损…

java脚手架搭建:如何使用Java脚手架来构建应用程序

Java脚手架搭建的步骤&#xff1a;创建Maven项目&#xff1a;使用maven--webapp创建一个Maven项目&#xff0c;并在pom.xml中添加所需的依赖。 Java脚手架搭建的步骤&#xff1a; 1. 创建Maven项目&#xff1a;使用maven-archetype-webapp创建一个Maven项目&#xff0c;并在p…

Linux安装ffmpeg

1 下载yasm wget http://www.tortall.net/projects/yasm/releases/yasm-1.3.0.tar.gz tar -zxvf yasm-1.3.0.tar.gz cd yasm-1.3.0 ./configure make && make install2 下载ffmpeg wget http://ffmpeg.org/releases/ffmpeg-3.1.3.tar.bz2 tar jxvf ffmpeg-3.1.3.tar.…