NR HARQ (四)dynamic codebook

news2025/1/12 15:37:13

微信同步更新欢迎关注同名modem协议笔记

上篇提到type-1 HARQ-ACK codebook,即semi-static codebook,UE要为每个PDSCH候选位置生成反馈,也会包含实际没有下行传输的PDSCH,再加上配置CBG的场景,HARQ-ACK 码本中包含的无用信息会更多,开销确实很大。因而,Type-2 HARQ-ACK 码本即dynamic 码本就出现了,目前看实网中一般都用的dynamic 码本,还没有见过semi-static 码本,长话短说,下面就看下相关内容。

4448878f22604724bb168ff3d58d55f5.png

RRC层配置有参数 pdsch-HARQ-ACK-Codebook=dynamic或 pdsch-HARQ-ACK-Codebook-r16时就要采用type-2 HARQ-ACK codebook,即动态码本,目前看到log中采用的都是动态码本。如果DCI format没有带counter DAI时,UE不能用Type-2HARQ-ACK codebook 反馈HARQ-ACK info。

ca808e40a0b445b78f35d97cbe3325cb.png

UE收到下行DCI后,不管调度的是PDSCH reception或SPS PDSCH release或指示SCell dormancy,都要根据DCI field PDSCH-to-HARQ_feedback timing indicator 和K0去反馈HARQ-ACK信息。

c2f1d3aeca0e4a73b6c50fba1df7582e.png  

监听调度PDSCH reception/SPS PDSCH release/SCell dormancy DCI 的PDCCH 时机就是服务小区激活DL BWP中的一个PDCCH monitoring集合,集合中按照PDCCH monitoring occasion 开始时间按升序排列。PDCCHmonitoring occasion集合的基数就是了PDCCH monitoring occasion总数M。

82d6df6ac3414234938539d44b2ab6c7.png

DCI field DAI 中有一部分作为counter DAI 用于指示当前 PDSCH reception/SPS PDSCH release/SCell dormancy 场景已经调度的累积数量,也就是PDCCH出现的个数,即累积的对象是截至当前服务小区的当前PDCCH monitoring occasion的数量。

DAI的计数顺序是,如果UE支持type2-HARQ-ACK-Codebook即一个PDCCH monitoring occasion进行多次PDSCH调度,那首先将各个PDCCH monitoring occasion对应的PDSCH reception,按照PDSCH reception 开始时间升序排列;其次按照服务小区index升序排列,最后按照PDCCH monitoring occasion index 升序排列。如下图。

afe119cd4890492783ae1a7165e92852.png

 c340989412dd4967b779246bc35aa9e4.png 

对于R16 multi-DCI based multi-TRP的场景,有配置ackNackFeedbackMode=joint时,counter DAI要先根据相同服务小区的相同PDCCH monitoring occasion中的第一个 CORESET 进行计数,然后再根据第二个 CORESET计数。

7465844a9ab14a6fb0331f7ca5c07d09.png

total DAI表示服务小区和PDCCH monitoring occasion pair出现的总个数,即调度的PDCCH出现的个数,截至到当前PDCCH monitoring occasion,且会在每个PDCCH monitoring occasion进行更新。

对于R16 multi-DCI based multi-TRP的场景,有配置ackNackFeedbackMode=joint时,total DAI是根据{服务小区,PDCCH 监视时机}-对中的第一个 CORESET 和第二个 CORESET共同计数。

34e0b73dc8114edb919b9180c0c53aa0.png

N_DL_C-DAI 代表counter DAI 的bits数,T_D=2^N_DL_C-DAI。V_DL_C-DAI,c,m代表在服务小区c PDCCH monitoring occasion m中DCI 调度PDSCH 的数量即counter DAI的值

根据spec规定counter DAI 和total DAI 能用2bits表示,38.213 Table 9.1.3-1定义了DCI bit的取值和DAI 的对应关系。

R16中DCI 1_2中counter DAI也可以是1bit表示,因而38.213 Table 9.1.3-1A定义了DCI 1 bit的取值和DAI 的对应关系。

14d6ee40fb04497c83ed28b8795565a6.png

另外在PDCCH monitoring occasion m中所有DCI format 的total DAI所带的值是一样的。在HARQ-ACK codebook相关配置没有改变的情况下,网络侧在下发DCI 时所带的counter DAI 的bits大小应该保证是一样的。

e937108c93e74979ade6ab38b42d96bf.png 

例如上图PDCCH monitoring occasion 对应1~4,DCI DAI 对应counter DAI 和Total DAI,根据上面的描述total DAI会在每个 PDCCH monitoring occasion,每个PDCCH monitoring occasion的total DAI 的值也应该是一样的,counter DAI 用于统计已经出现的累积调度,如此UE就可以很好的掌握下行传输的基本情况,更好的做出HARQ-ACK。

type-2 HARQ-ACK codebook的生成也是一段伪代码。

0cb7256755f944928fb349b9e6c3f169.png 

UE根据DCI动态调度情况,要生成对应的HARQ-ACK info,对应的就是动态码本 其长度为O_ACK;伪代码中的m=0对应的是最早的那个PDCCH monitoring occasion,N_DL_cells对应的是服务小区的个数;j对应的是DAI 相关的参数,Vtemp和Vtemp2用于记录counter DAI和Total DAI变化的参数,0作为初始值;Vs用于记录ACK 的HARQ-ACK info。

1fb73906e54247fb93874057f705e71e.png

首先对特定的PDCCH monitoring occasion m开始进行遍历,c对应的服务小区,即代表针对特定的PDCCH monitoring occasion,还要对服务小区进行遍历,如果服务小区发生BWP切换,对应小区不做任何操作,UE直接跳到下一个服务小区。

afac7b8368b348efbd1f04760bd0db7b.png

如果遍历小区没有发生BWP切换且在PDCCH monitoring occasion n 收到PDCCH data;初始Vtemp=0,假如正常收到第一个DCI 其c-DAI=1,不可能满足第一个if,下一步Vtemp=1。下一个if 判断DCI是否有带T-DAI,如果没带Vtemp,2=c-DAI的值,有带T-DAI,则Vtemp,2=T-DAI的值。

那什么时候会满足V_DL_c-DAI,c,m<=Vtemp?正常情况下c-DAI 是2bits,即每4个值,为一轮,没有漏检时,永远不会满足V_DL_c-DAI,c,m<=Vtemp,所以漏检DCI时才可能满足第一个if;比如上一个DCI c-DAI=1,则Vtemp=1, 下一个DCI c-DAI 直接=1,说明没有收到c-DAI=2和3对应的DCI,这时候c-DAI<=Vtemp,j++,j对应漏检DCI的次数,j++一次,对应的c-DAI 4个值。

另外Vtemp 会先于Vtemp,2赋值,正常情况下Vtemp,2 是不可能小于Vtemp的,虽然有时候DCI 可能没有带T-DAI,这种情况下Vtemp,2 会赋值c-DAI的值,只能是Vtemp,2>=Vtemp, 所以如果Vtemp,2<Vtemp 则说明,有漏检DCI情况。

5e40706cdc1343bb8d69f4c88bb63d37.png

后面根据配置的场景生成对应的HARQ-ACK info,2TB传输没有带harq-ACK-SpatialBundlingPUCCH时,针对每TB生成1bit HARQ-ACK info,即对应2bits;2TB传输且带harq-ACK-SpatialBundlingPUCCH,将2TB 的HARQ-ACK进行位与操作最终生成1 bit HARQ-ACK info;其他情况,直接生成1bit HARQ-ACK info。 这里假设j=0的话,即UE一直没有漏检DCI,有序接收DCI,即这里的Vs记录的就是正常接收的TB HARQ-ACK bit 对信息。

之后继续特定PDCCH monitoring occasion 对服务小区进行遍历,小区遍历完成则换下一个PDCCH monitoring occasion 继续对服务小区进行遍历。

8827921a64554151a2c47507645951b8.png

Vtemp,2<Vtemp 说明,有漏检DCI情况,j++;如果2TB传输没有带harq-ACK-SpatialBundlingPUCCH,O_ACK=2(4*j+Vtemp,2);否则O_ACK=4*j+Vtemp,2;最后从O_ACK中去掉Vs就是要放开NACK的bit位。

上面的内容是按照counter DAI 对应2bits的情况看的,R16中DCI 1_2 中counter DAI 可能会对应1bit,因而 动态码本生成的过程还涉及以下内容。

1df9a2b806624b9784c48eb8ff350281.png

 

5d729797dea94c8a84fb00e76ebca532.png 

对于和SPS PDSCH reception复用的场景,UE生成SPS PDSCH reception 的bits后 将其级联在O_ACK末尾发送。

81e7f2c3351c437e8004b567b238f8a0.png

举个例子,假如网络侧共发送8个DCI ,maxNrofCodeWordsScheduledByDCI=2,UEmiss了DCI(3,3),则j=1,Vtemp,2=4,O_ACK=2(4*1+4)=16 bit,反馈的HARQ-ACK如上图。

82ab31cd3f16453a83ebde0e2f44acaf.png

maxNrofCodeWordsScheduledByDCI=2但是UE只有到1个TB,这时候如果有配置 harq-ACK-SpatialBundlingPUCCH,UE对第二个TB生成ack,否则生成NACK。

Type-2 HARQ-ACK codebook for CBG

在配置CBG传输时,动态码本的生成和上面的内容会有点不一样,总结着说,如果有任意一个服务小区被配置使用基于CBG的数据传输,则生成两个子码本:第一子码本为TB子码本,针对指示SPS PDSCH释放的PDCCH以及基于TB的PDSCH传输进行TB级的反馈;第二子码本为CBG子码本,针对基于CBG的PDSCH传输进行CBG级的反馈。将两个子码本按照TB子码本和CBG子码本顺序级联在一起构成最终的HARQ-ACK码本。如果多个服务小区都被配置使用基于CBG的传输且配置的CBG个数不同,则基于最大的CBG个数产生CBG子码本。配置CBG的情况的动态码本=TB 子码本+CBG 子码本,上报时TB 在前,CBG在后,两者级联在一起。下面看下spec上的描述。

b13215d764794142840ed747b5241c0b.png

根据CBG的配置情况,将小区分成两部分:配置CBG传输的小区记为N_DL,CBG_cells,没有配置CBG传输的小区(按TB发送的小区), 记为N_DL,TB_cells。 N_DL,CBG_cells+N_DL,TB_cells=N_DL_cells

生成码本的方式和前面的描述是一样的,但是有些点要注意。

0c49f5dd740f417b8ae20e98807b5f22.png

生成TB based sub-codebook时要用N_DL_cells而不是N_DL,TB_cells,例如SPS PDSCH release/SPS PDSCH reception DCI 1_1指示的SCell dormancy和虽然配置了CBG传输但是实际中仍然进行的TB传输,例如DCI 1_0,虽然配置了CBG,但是只能进行基于TB的传输,这点也是在计算TB 子码本时要用N_DL_cells原因;对于CBG子码本,要用N_DL,CBG_cells进行计算。

385dc3b5e62b4a3db5c5bb30eabae750.png

如果多个服务小区都被配置使用基于CBG的传输且配置的CBG个数不同,则基于最大的CBG个数产生CBG子码本,最大bit数由N_CBG/TB,max_HARQ-ACK,c ×N_DL_TB,c。如果某个CBG传输小区的N_CBG/TB_HARQ-ACK,c ×N_DL_TB,c小于最大值,后面不足的位用NACK补足。

这里生成子码本时,harq-ACK-SpatialBundlingPUCCH 不起作用;且两个子码本的counter DAI和Total DAI独立工作,最后上报时TB子码本在前,CBG子码本在后,两者级联在一起。对于multi-DCI based multi-TRP的场景,生成码本时要分别针对两个CORESETs都统计一次。

055d949bc4c64cafb8c3933292be652d.png

举个例子 假如有3个CC,serving cell 0进行CBG传输,maxCodeBlockGroupsPerTransportBlock=2;serving cell 1进行TB传输,serving cell 3进行CBG传输,maxCodeBlockGroupsPerTransportBlock=4;所有CC的maxNrofCodeWordsScheduledByDCI=2;上图中5个绿色部分分别生成各2bit的TB HARQ-ACK info,组成TB sub codebook;由于最大的N_CBG/TB,max_HARQ-ACK,c=4,所以CBG传输部分要生成N_CBG/TB,max_HARQ-ACK,c ×N_DL_TB,c=2×4=8 bit的码本,共3个CBG TB,共24 bits,其中橙色的CBG 由于maxCodeBlockGroupsPerTransportBlock=2,所以要用NACK 补上4bit;最后码本长度=TB subcodebook+CBG subcodebook=10+24 =34bits。

HARQ-ACK codebook 这部分还剩余3个章节,Type-2 HARQ-ACK codebook in physical uplink shared channel,Type-2 HARQ-ACK codebook grouping and HARQ-ACK retransmission和Type-3 HARQ-ACK codebook determination,这几个后面有时间再整理。

 

 

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

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

相关文章

SpringBoot系列之数据库初始化-datasource配置方式

在我们的日常业务开发过程中&#xff0c;如果有db的相关操作&#xff0c;通常我们是直接建立好对应的库表结构&#xff0c;并初始化对应的数据&#xff0c;即更常见的情况下是我们在已有表结构基础之下&#xff0c;进行开发&#xff1b; 但是当我们是以项目形式工作时&#xff…

java微信支付v3系列——3.订单创建准备操作

微信支付的下单操作分为了5种&#xff0c;分别是JSAPI、APP、H5以及Native支付及小程序支付&#xff0c;之所以将支付放在单独一个章节&#xff0c;而不是按照支付类型划分一个章节&#xff0c;是因为支付所传递的数据都是相似的&#xff0c;方便我们更好的封装。 本章节是支付…

20221222英语学习

托福词汇 sociology n.社会学 given adj.规定的&#xff0c;特定的&#xff1b;假定的 narrative n.叙述&#xff1b;记叙体&#xff0c;叙述技巧 deplore vt.悲叹&#xff0c;哀叹&#xff0c;公开谴责 despoil vt.夺取&#xff0c;掠夺&#xff1b;毁坏&#xff0c;破坏…

Kubernetes:环境搭建

文章目录1、k8s 概念1.1、基本概念1.2、基本术语2、k8s 架构2.1、k8s 节点2.2、k8s 组件2.2.1、master 组件2.2.2、node 组件3、k8s 集群安装配置3.1、docker3.2、主机环境调整3.3、安装 kube 工具3.4、Master 节点初始化3.5、node 节点初始化3.6、重置节点4、k8s 集群升级4.1、…

基于node.js网上蛋糕店系统的设计与实现(论文+项目源码)

随着互联网应用技术的突飞猛进。信息化广泛使用&#xff0c;已渗透到各行各业。作为代表的以网上购物商城为例。它极大地改变了人们的出行方式以及线上购物发生的转变。网上购物的需求也随着人们的个性化定制而变得相对复杂。用户量以及需求量在网上商城也带来了很多商家的考验…

c++primer第2章 变量和基本类型

文章目录第2章 变量和基本类型2.1 基本内置类型2.1.1 算术类型2.1.2 类型转换2.1.3 字面值常量2.2 变量2.2.1 变量定义2.2.2 变量声明与定义的关系2.2.3 标识符2.2.4 名字的作用域第Ⅰ部分 c基础 语法特征 类型 变量 语句 控制结构 函数补充&#xff1a;自定义数据类型(语言扩展…

Elasticsearch:如何减少 Elasticsearch 集群中的分片数量

在我之前的文章 “Elasticsearch&#xff1a;我的 Elasticsearch 集群中应该有多少个分片&#xff1f;” &#xff0c; 它描述了在我们实际操作中的分片数量的准则。在文章 “Elasticsearch&#xff1a;如何部署 Elasticsearch 来满足自己的要求” 讲述了如何部署 Elasticsearc…

Prometheus系列之Grafana 版本9.0.0 设置Email邮件报警实战

目录1. 配置文件conf/defaults.ini修改2. Grafana Web页面配置报警邮箱接收者3. 创建Dashboard4. 创建Alert的文件夹5. 设置Notification policies6. 添加Alert7. Alert Rule测试1. 配置文件conf/defaults.ini修改 将conf/defaults.ini的如下内容 ##########################…

变量提升,函数提升,暂时性死区,详细解析

变量的提升 JavaScript 在执行之前 会进行预解析 函数声明 函数体会被提升到当前作用域顶部 var的声明会提升 并赋值undefined 因为var会有一个变量提升&#xff0c;他的声明初始化会被提升&#xff0c;但是值不会被提升&#xff0c;所以控制台返回undefined 函数提升 这是…

CSS -- CSS3基础动画讲解

文章目录CSS 3动画1 动画的基本使用2 动画序列3 动画常用属性4 动画简写属性5 速度曲线细节CSS 3动画 动画(animation) 是CSS3中具有颠覆性的特征之一&#xff0c;可通过设置多个节点来精确控制一个或一组动画常用来实现复杂的动画效果。 相比较过渡&#xff0c;动画可以实现…

白银票据的原理和使用

白银票据的原理和使用白银票据(Silver Ticket)原理白银票据的使用服务账号是计算机名字$用来管理服务的账号 白银票据(Silver Ticket)原理 白银票据是伪造本该由TGS返回的ST(服务票据)&#xff0c;从而访问对应的服务 有server用户的hash就可以伪造出ST&#xff0c;且不经过K…

自重启伪遗传改良算法解决TSP问题(Matlab代码实现)

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f468;‍&#x1f4bb;4 Matlab代码 &#x1f4a5;1 概述 旅行商问题&#xff0c;即TSP问题&#xff08;Traveling Salesman Problem&#xff09;又译为旅行推销员问题、货郎担问题&…

Spark 3.0 - 14.ML 高斯混合聚类理论与实战

目录 一.引言 二.高斯混合模型理论 1.高斯模型 GM 2.高斯混合模型 GMM 三.高斯混合模型实践 1.数据准备 2.模型训练 3.获取多个 GM 四.总结 一.引言 前面提到的 K-means 是发现数据对应簇的硬聚类方法&#xff0c;即分配一个点其固定分配到某个簇&#xff0c;而高斯混…

三方系统集成SF(SuccessFactors),实现单点登录要点

在笔者先前的文章——《基于saml2.0的平台&#xff08;适用多种平台&#xff09;单点登录配置&#xff0c;以okta为例》中&#xff0c;详细介绍了如何把一个自开发的三方系统&#xff0c;集成到okta或者IAS平台。 经过笔者的实际工作经验&#xff0c;发现SF自己本身其实也可以…

MCU-51:初识单片机,从点亮一个灯开始

题目一、什么是单片机二、点亮一个LED灯2.1 LED原理和知识2.2 方法一2.3 方法二一、什么是单片机 单片机又称单片微控制器&#xff0c;把一整个计算机系统集成到一个芯片上&#xff0c;当于一个微型的计算机&#xff0c;和计算机相比&#xff0c;单片机只缺少了I/O设备。一块芯…

文字语义纠错技术探索与实践-张健

背景 文本语义纠错的使用场景非常广泛&#xff0c;基本上只要涉及到写作就有文本纠错的需求。书籍面市前就有独立的校对的环节来保障出版之后不出现明显的问题。在新闻中我们也时不时看到因为文字审核没到位造成大乌龙的情况&#xff0c;包括上市公司在公开文书上把“临时…

并行计算(MPI + OpenMP)

文章目录并行计算MPI&#xff08;进程级并行&#xff09;基本结构数据类型点对点通信阻塞非阻塞非连续数据打包聚合通信Communicator & Cartisen GridOpenMP&#xff08;线程级并行&#xff09;简介基本制导语句worksharing constructSectionsSingleFor临界区 & 原子操…

React 学习笔记总结(三)

文章目录1. React( v16.8 版本) 生命周期2. React( v16.8 版本) 生命周期 更新流程2.1 三个更新流程2.2 setState()的生命周期流程(对应上图2号线)2.3 forceUpdate()的生命周期流程(对应上图3号线)2.4 父组件render()渲染的生命周期流程(对应上图1号线)2.5 React( v16.8 版本)生…