【5G NR】【一文读懂系列】移动通讯中使用的信道编解码技术-卷积码原理

本文主要是介绍【5G NR】【一文读懂系列】移动通讯中使用的信道编解码技术-卷积码原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、引言

二、卷积编码的发展历史

2.1 卷积码的起源

2.2 主要发展阶段

2.3 重要里程碑

三、卷积编码的基本概念

3.1 基本定义

3.2 编码器框图

3.3 编码多项式

3.4 网格图(Trellis)描述

四、MATLAB示例


一、引言

卷积编码,作为数字通信领域中的一项关键技术,自其诞生以来便受到广泛关注。卷积编码是一种纠错编码方法,它通过引入冗余信息来提高数据传输的可靠性。本文旨在全面介绍卷积编码的基本概念、原理、应用场景、优缺点等方面,并结合具体案例进行分析,以期为读者提供一个清晰、深入的卷积编码知识体系。

二、卷积编码的发展历史

2.1 卷积码的起源

卷积码,作为一种前向纠错编码技术,其历史可以追溯到20世纪50年代。当时,通信领域的研究者们正在探索如何在有限的带宽和信噪比条件下,提高数据传输的可靠性。卷积码的出现,为这一挑战提供了一种有效的解决方案。

2.2 主要发展阶段

  1. 早期研究阶段:在20世纪50年代末到60年代初,卷积码的概念开始形成并得到初步研究。研究者们开始探索卷积码的基本原理和性能特点,为其后续的应用奠定了基础。
  2. 理论成熟阶段:随着研究的深入,卷积码的理论体系逐渐成熟。在这一阶段,研究者们提出了卷积码的代数表示方法、状态转移图等关键理论工具,为卷积码的工程应用提供了理论基础。
  3. 工程应用阶段:从20世纪70年代开始,卷积码开始广泛应用于各种通信系统中。特别是在卫星通信、移动通信等领域,卷积码因其强大的纠错能力和较高的编码效率而备受青睐。

2.3 重要里程碑

  1. 1972年:Viterbi算法的出现为卷积码的高效解码提供了可能。Viterbi算法是一种最大似然解码算法,它能够在多项式时间内找到最可能的原始信息序列,从而大大提高了卷积码的解码效率。
  2. 1980年代:随着移动通信的快速发展,卷积码成为了第一代和第二代移动通信系统(如GSM)中的关键技术之一。在这一阶段,卷积码的优化和改进持续进行,以提高其在不同信道条件下的性能。
  3. 1990年代:随着第三代移动通信系统(如3G、4G)的兴起,卷积码逐渐被更为先进的编码技术(如Turbo码和LDPC码)所取代。然而,卷积码在某些特定场景(如深空通信、水下通信等)中仍具有重要地位。

三、卷积编码的基本概念

3.1 基本定义

卷积码将k个信息比特编成n个比特,特别适合以串行形式进行传输,时延小。

将卷积码记作(n,k,N)。一般来说,卷积码的k和n是比较小的整数。

  • 码率仍定义为k/n。
  • 卷积码是将k个比特的信息段编成n个比特的码组,其编码生成的监督码元不止和k个比特的信息段有关,还和前面的m=(N-1)个信息段有关。可知,一个监督码元同时和前m个比特以及当前输入的一个比特信息有关,即监督着N=m+1个比特,我们将N成为约束度,所有监督码元的长度nN称为约束长度。

综上,k即为卷积码的输入路数(多路输入要进行串并转换),n为输出比特个数,m为移位寄存器的位数(用于保存所需的前几个比特),N=m+1。

3.2 编码器框图

(n,k,N)=(3,1,3)卷积码编码器框图如下:

输入和输出的关系式:

(n,k,N)=(3,1,3)卷积码编码器框图如下:

输入和输出的关系式:

卷积编码的生成多项式是描述卷积编码器内部状态转移和输出码字生成的一组多项式。这些多项式通常表示为 (g(D)),其中 (D) 是一个延迟算子,表示数据在编码器中的延迟。生成多项式用于确定编码器的状态转移和输出码字的生成规则。

3.3 编码多项式

上面的编码器多项式如下:

假设输入序列x[k]=[1101],其多项式: ​​ 。则输出序列y[n]:

 

运算符号为位异或运算。

可以得到对应输入4个比特的输出数据为:[111,110,010,100];

根据上面的编码器图和输入输出关系式,可以看出来,卷积编码是一种前向纠错编码技术,其核心思想是将待传输的信息序列与特定的编码函数进行卷积运算,生成包含冗余信息的编码序列。卷积编码的主要参数包括约束长度(N)、编码速率(k/n)和生成多项式等,这些参数决定了编码的性能和特点。

3.4 网格图(Trellis)描述

卷积码的网格图表示如下:

网格图显示了时序的变化,可以更为清晰的显示出编码的过程。例如当输入(1101)时,假设移位寄存器的初始状态为a状态,则编码输出如红线所示。

四、MATLAB示例

以下是一个简单的MATLAB脚本示例,演示了如何实现一个(n,k,N)=(3,1,3) 的卷积编码器:

function encoded_data = convolutionalEncoder(input_data, K, g)  % 参数:  % input_data - 输入数据比特流 (1xN vector)  % K - 约束长度 (寄存器数量 + 1)  % g - 生成多项式的矩阵形式 (Gx(K-1) matrix, G是输出数量)  % 输出:  % encoded_data - 编码后的数据比特流 (1x(3*N) vector for R=1/3)  N = length(input_data); % 输入数据的长度  G = size(g, 1); % 输出数量 (对于R=1/3, G应为3)  % 初始化寄存器状态和输出数据  register = zeros(1, K-1);  encoded_data = zeros(1, N*G);  % 对输入数据进行卷积编码  for i = 1:N  % 构造当前寄存器的内容(包括新输入比特)  register_with_input = [input_data(i) register];  % 对每个生成多项式计算输出比特  for j = 1:G  % 提取对应的生成多项式  generator = g(j, :);  % 计算异或和  output_bit = mod(sum(generator .* register_with_input), 2);  % 将输出比特添加到编码后的数据中  encoded_data((i-1)*G + j) = output_bit;  end  % 更新寄存器状态  register = register_with_input(1:end-1);  end  
end  % 示例使用  
% 定义生成多项式 (通常为八进制或十六进制形式, 这里转换为二进制)  
% 例如: g1 = [1 1 1], g2 = [1 0 1], g3 = [1 1 0] (八进制)  g_binary = [1 0 0;1 0 1;1 1 1];% 设置约束长度 (K=4 对于上述生成多项式)  
K = 3;  % 输入数据比特流  
input_data = [1 1 0 1 ];  % 进行卷积编码  
encoded_data = convolutionalEncoder(input_data, K, g_binary);  % 显示编码后的数据  
disp('Encoded Data:');  
disp(encoded_data);

上面的程序已经通过调试,运行结果如下:

输入:

% 输入数据比特流

input_data = [1 1 0 1 ];

% 输出数据比特流

Encoded Data = [1 1 1 1 1 0 0 1 0 1 0 0];

大家可以试着运行一下,有问题可以留言。欢迎大家在评论区探讨。

这篇关于【5G NR】【一文读懂系列】移动通讯中使用的信道编解码技术-卷积码原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/694870

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma