【5G入门】MCS调制编码方案简介


目录

    • 参考资料:
  • 1. MCS简介
    • MCS是什么
    • 如何选择MCS
    • 有哪些MCS可供选择
    • 如何配置MCS
      • 示例

参考资料:

链接: 5G NR Modulation and Coding Scheme – Modulation and Code Rate.

1. MCS简介

MCS是什么

MCS(Modulation and Coding Scheme,即调制编码方案)定义了一个RE(Resource Element,资源单位1)可以承载的有效比特数。一共有0-31号种MCS方案,其中29-31号做保留。MCS索引越高,可承载的有效比特数越高。

1 RE是资源分配的最小单位,把时域上一个常规OFDM符号周期和频域上一个子载波组成的资源称为一个资源单位.

具体来说,MCS定义了两个部分,调制方案(Modulation)码率(Code Rate)

调制方案:5G NR支持可选的调制方案包括QPSK, 16 QAM, 64 QAM 以及 256 QAM。 使用 QPSK,每个 RE 可以传输 2 位信息,使用 16QAM 可以传输 4 位,使用 64QAM 可以传输 6 位,使用 256QAM 可以传输 8 位。

码率:即为有用比特与总传输比特之间的比率(有用+冗余比特),用来度量物理层添加的冗余。冗余比特用于前向纠错 (FEC)。从另一个角度,码率可以被认为是物理层顶部的信息比特数与物理层底部映射到PDSCH的比特数之间的比值。 编码率越低代表增加的冗余越多。

如何选择MCS

选择哪一个MCS 取决于无线链路的质量。质量越好,MCS 越高,一个符号中可以传输的有用比特越多,而信号质量差则只能选择索引低的MCS,意味着一个符号中可以传输的有用数据越少。

具体地,gNB根据误块率(Block Error Rate ,BLER)进行MCS的选择。通常定义一个等于 10% 的 BLER 阈值,gNB 使用链路自适应算法分配MCS,使得在不同的无线电条件下保持 BLER 不超过阈值。

有哪些MCS可供选择

3GPP 规范 38.214给PDSCH2提供了如下三张表格( 64 QAM 表、256 QAM 表和低频谱效率 64 QAM 表),供gNB选择。

1 PDSCH:物理下行共享信道,用于传输下行业务数据和系统消息

选择每个表的情况具体如下所示:

  • 64 QAM 表:当gNB或UE不支持256 QAM或信道较差,256 QAM表解码不成功且gNB需要使用 QPSK 阶调制时,可以使用 64 QAM 表
  • 256 QAM 表:信道状态较好、且设备支持256 QAM
  • 低频谱效率 (Low SE) 64 QAM 表:适用于需要可靠数据传输的应用,例如URLLC类别的应用程序。 本表MCS通过降低的编码率、增加信道编码冗余提高信道的可靠性,因而频谱效率较低。
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    表中第一列为MCS索引号,可看出29-31是保留的。第二列是调制阶数,代表采用哪种调制方式,Qm=2,代表使用22=4,即QPSK;Qm=4,代表使用24=16,即16 QAM。第三列代表目标码率,是在选择本行调制方式和对应冗余度之后期望达到的码率(注:本目标码率和最终的数据效率还是有区别的)。最后一列是频谱效率,代表选择本种MCS时的频率效率。表中目标码率与频谱效率成正比,频谱效率越高,目标码率也越高。

如何配置MCS

MCS由gNB基于链路自适应算法决定。决定之后,gNB使用DCI向UE提供选定的MCS信息。
具体来说,选择哪个MCS表由RRC信令(IE)和物理层信令(RNTI)决定。
RRC信令配置PDSCH-Config和SPS-Config的mcs-Table参数选择MCS表。此信令用于半静态配置,但也可以使用 RRC信令进一步修改。
物理层通过动态选择RNTI (例如在C-RNTI和MCS-C-RNTI之间切换)影响MCS表的选择。

示例

一个UE已配置参数 PDSCH-Config,mcs-Table = ‘qam256’,并分配了一个MCS-C-RNTI和传统的C-RNTI。
如果UE接收到使用C-RNTI的DCI 1_1信令,UE选择256 QAM MCS表;
如果同一UE接收到使用C-RNTI的DCT 1_0信令,则UE选择64 QAM MCS表;
如果同一UE使用MCS-C-RNTI的DCI 1_1或1_0信令,则UE将选择低 SE 表。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/508473.shtml

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

相关文章

caffe初体验

caffe是一个深度学习的框架, 具体我也不太清楚, 可以自行百度吧, 我也是刚刚知道有这么一个框架, 才疏学浅啊. 在安装完caffe, 我的第一个想法就是, 别管他是个啥东西, 总得先让我运行一些看一看吧. 刚好, 官方就准备了一些数据, 供我们运行一下看一看使用. 因为我是通过dock…

【安全】进阶的Mosquitto:搭建一个安全的MQTT服务

目录一、基础版Mosquitto安装及运行Mosquitto安装Mosquitto运行二、基础安全版Mosquitto安装及运行(需要输入密码)Mosquitto安装Mosquitto配置Mosquitto测试效果三、安全版Mosquitto安装及运行Mosquitto安装TLS安装Mosquitto配置Mosquitto测试效果注意一…

PHP 循环引用的问题

问题 为了引出问题, 先来看下面一段代码: <?php $arr [a, b,c, d, ];foreach ($arr as &$each){echo $each; } echo PHP_EOL; foreach ($arr as $each){echo $each; }这段代码很简单, 输出数组的元素两次, 感觉会输出两次 abcd? 不好意思, 输出结果如下:  是不是感…

揭开HTTPS的神秘面纱

在说HTTP前&#xff0c;一定要先介绍一下HTTP&#xff0c;这家伙应该不用过多说明了&#xff0c;大家每天都在用&#xff0c;每一次HTTP请求&#xff0c;都是一次TCP连接。遗憾的是&#xff0c;请求的内容在TCP报文中是明文传输的&#xff0c;任何人截取到请求都可以读取其中的…

递归函数两种方式的区别

概述 递归函数都不陌生&#xff0c;比如计算n的阶乘&#xff1a; function f($n){if($n < 1) return 1;return $n * f($n-1); } 当然&#xff0c;有人可能会这么写&#xff1a; function f($n, $result){if($n < 1) return $result;return f($n-1, $n*$result); } 上…

Trie树

概述 在Google中随意搜索&#xff0c;如下所示&#xff1a; 他会自动显示相关的搜索&#xff0c;不知道有没有想过这个功能是如何实现的呢&#xff1f;面对海量的数据&#xff0c;它怎么能在我输入的同时&#xff0c;如此快速的检索到相关内容呢&#xff1f;当我查找资料后&am…

Python元组是什么

引出 在使用Python过程中&#xff0c;列表、集合和字典是比较常用的数据结构。 列表简单说就是数组&#xff0c;不对&#xff0c;它就是数组 集合就是去重的元素结构&#xff0c;和JAVA中的set一样 字典就是一个key-value的键值对&#xff0c;和JAVA中的HashTable一样 但是…

B+树

引言 时隔一年&#xff0c;我又想起当初看数据库时&#xff0c;看到的B树&#xff0c;就是数据库的索引使用的数据结构。再整理一下&#xff0c;看看自己没有忘记很多吧。 概述 B树之前&#xff0c;先来看一下二叉查找树&#xff08;1,2,3,4,5,6,7&#xff09; 恩&#xff0…

Python导入运行的当前模块报错

引言 今天遇到了一个奇怪的现象&#xff0c;简单举个栗子&#xff1a; 文件结构如下&#xff1a; 其中tt.py文件中定义了一个方法&#xff1a; def tt():print(tt) 我现在要在test.py中使用tt(), 代码如下&#xff1a; from test.tt import tt ​ if __name__ __main__:t…

Python中的+=

引出 今天在运行之前写的一个Python脚本时&#xff0c;发生了一个奇怪的现象&#xff08;我怎么老遇到奇怪的现象&#xff5e;&#xff5e;&#xff09;。当时的代码大概长这样&#xff1a; a [1, 2, 3] b [4, 5, 6] # ...一大段逻辑 c a c b # ...一大段逻辑 # 在这里&a…

js new Date 创建时间默认是8点

起因 最近在写一个页面&#xff0c;需要用到时间控制。然后我通过new Date()传入日期字符串创建了一个对象&#xff0c;并与当前时间做时间戳比较&#xff0c;结果12点刚过&#xff0c;就出问题了。举个栗子&#xff1a; // 假设当前时间是2019年12月22日0点20分 new Date(20…

Ubuntu14升级MySQL

最近需要将测试环境的MySQL从5.6升级到5.7. 我就自己先虚拟机搭了一个Ubuntu14进行模拟升级, 不得了 开始了各种踩坑记录 方案一 此方案可以跳过, 全是坑. 搜索 Ubuntu14 MySQL升级5.7, 出现很多结果 查看后发现处理方法全都一样, 既然大家都是这么升级的, 肯定么得问题. …

微信朋友圈技术实现设想

前提 微信朋友圈是我们每天都在用的功能, 但是如果让你来实现一个微信朋友圈, 你会如何做呢? 我来简单设想一下. 实现功能 发朋友圈评论动态查看朋友圈(只能查看好友的)查看评论(只能查看共同好友的) 是不是看着很简单? 也没有几个功能嘛. so easy. 开始实现 数据库选用…

redis的多路复用是什么鬼

有没有人和我一样, 自打知道了redis, 就一直听说什么redis单线程, 使用了多路复用等等. 天真的我以为多路复用是redis实现的技术. 今天才发现, 我被自己骗了, 多路复用是系统来实现的. 对不起自己的专业了. 为了引出多路复用, 我来大胆设想一下技术的发展路程. 前提 一个应用…

WebSocket小叙

概述 刚看到WeSocket的时候&#xff0c;我以为是HTTP相关&#xff0c;但是在前两天搭了一个简单的Client之后, 我发现这不就是TCP长连接么? 建立连接->通信->断开连接. 直到今天, 我在调试的时候, 发现发出了HTTP请求, 我想, 事情可能不是我想的那样. 先来简单描述一下…

PHP实现RPC(简版)

概述 RPC这个东西是什么? 第一次听说他, 还要在它的前边加个G, 当时我以为GRPC是一项技术, 后来才知道, 并不是这样. GRPC只是RPC的谷歌实现. 谷歌搜了一下, RPC就是一种: 远程函数调用, 看到这里, 我已经等不及了, 不往下看了, 先自己实现一个. 如果只给你这样一个概念, 如…

GC算法-复制算法

概述 复制算法就是将内存空间二等分, 每次只使用其中一块. 当执行GC时, 讲A部分的所有活动对象集体移到B中, 就可以讲A全部释放. 画个图就是: ​ 在执行GC前, 内存长这样: ​ 当执行GC后, 内存就变成这样了: 还记得标记清除算法的问题是什么吗? 内存碎片化严重. 现在好了, …

GC算法-标记压缩算法

概述 还记得标记清除和复制算法的问题么? 堆使用效率低和碎片化问题. 那么有没有能够利用整个堆, 有没有内存碎片化问题的算法呢? 这就是标记压缩算法了. 简单来说, 标记压缩算法就是将堆中的所有活动对象整体向左移, 将对象间的空隙消除. 在GC执行前的内存: GC执行后的内…

PHP usort 函数底层排序

引出 最近在一个项目中, 需要对一个数组的顺序进行调整, 允许手动将某一个元素提到数组的开头位置. 在这里, 使用了PHP中的usort函数进行了数组的排序, 代码大致如下: usort($arr, function ($a, $b){// 这里添加了 order 字段, 默认为0, 将order大的提到前边return $b[order…

密钥交换算法: 迪菲-赫尔曼算法

概述 迪菲-赫尔曼算法用于通信双方交换密钥. 还记得之前介绍HTTPS协议的时候, 提到需要先通过对方公钥来进行密钥的交换, 然后再通过密钥对通信内容进行加密. 迪菲-赫尔曼算法就是用于交换密钥的. . 此算法与非对称加密算法不同哦. OK, 一起来看看吧. 引入 在正式介绍迪菲-…