CPRI协议的理解——CPRI中的扰码

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

CPRI协议的理解——CPRI中的扰码

  • 前言
  • 8B10B线路编码下的扰码
    • 发送端
    • 接收
  • 64B66B线路编码下的扰码
    • 带有终止控制字符的控制块格式
    • 带有起始控制字符的控制块格式
    • 数据块格式


前言

CPRI中有两种情况会需要用到扰码,一种是在8B10B线路编码的速率上数据添加了扰码。一种是64B66B编码。

8B10B线路编码下的扰码

在这里插入图片描述

发送端

使用的扰码器是旁流扰码器,如图 40 所示。扰码序列是使用原语(基于 GF(2))多项式 P(X) = 1+ X28 + X31 构造的。

加扰序列ci(i=0,1,…,25616T-1)构造为:
• 初始条件由31 位向量定义(加扰器的种子:c0,…c30)。种子的选择超出了 CPRI 规范的范围。不排除所有位都等于“0”的种子,并且允许禁用加扰操作。
• 后续符号的递归定义:c(i+31) = c(i) + c(i+3) modulo 2 for i ≥ 0 c(i) 位是串行伪随机码生成器在时间序列i 中的生成位(c0 是第一个输出位)。
• 在每个位周期,移位寄存器前进一位并生成一个新位。
• **在每个超帧开始时,扰码器状态会使用种子值(c0…c30) 进行重置。**因此,ci序列周期为25616T。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
Figure 41: Scrambling of bytes #Z.X.W.Y in hyperframe Z

接收

支持协议版本 2 的接收器应能够接收由上文中描述的加扰功能对任何种子值加扰的数据。
接收机应使用控制字节 #Z.0.2 至 #Z.0.(T/8-1) 中的至少 31 位来检索发射机的加扰序列,以便生成解扰序列。
一旦完成上述操作,接收器应定期检查输入数据的解扰序列,方法是对解扰控制字节 #Z.0.2 至 #Z.0.(T/8-1) 的至少 31 位进行采样,已知为50h(见4.2.10.3.1)

64B66B线路编码下的扰码

对于 64B/66B 线路编码,使用 IEEE 802.3 [22] 中的 3 种格式,图 49-7(64B/66B 块格式)。这三种格式是:

  • 带有终止控制字符的控制块格式
  • 带有起始控制字符的控制块格式
  • 数据块格式
    10GBASE-R PCS 通过块类型字段隐式编码起始和终止控制字符。

带有终止控制字符的控制块格式

/T/ 字符将位于 64 位的最后 8 位。
/T/ 断言示例(TXC<3> = 1 & TXD<31:24> = 0xFD)在图 42 中以粗体显示。
在这里插入图片描述
由于 TxC<3:0> 不会保持为零,因此同步标头更改为“10”而不是“01”,以指示有效负载中有一个控制字符。块类型字段(0xFF)是超帧的第一个字节,位于超帧的前 64 位的前 8 位中,并与 64B/66B 线路编码方案对齐。

带有起始控制字符的控制块格式

/S/ 字符将位于 64 位的前 8 位中。
/S/ 断言示例(TXC<0> = 1 & TXD<7:0> = 0xFB)如图 43 中的粗体所示。
在这里插入图片描述
由于 TxC<3:0> 不会保持为零,因此同步标头更改为“10”而不是“01”,以指示有效负载中有一个控制字符。块类型字段 (0x78) 是超帧的第九个字节,位于超帧的第二个 64 位块的前 8 位中,并与 64B/66B 线路编码方案对齐。

数据块格式

在数据传输的情况下,数据按 8 字节包分组,对这 64 位进行加扰,并添加位序列“01”以形成 66 位序列。
64B/66B 数据块编码的示例如图 44 所示。
在这里插入图片描述

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

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

相关文章

队列 + 宽搜(BFS)

例题一 解法&#xff1a; 算法思路&#xff1a; 层序遍历即可~ 仅需多加⼀个变量&#xff0c;⽤来记录每⼀层结点的个数就好了。 例题二 解法&#xff08;层序遍历&#xff09;&#xff1a; 算法思路&#xff1a; 在正常的层序遍历过程中&#xff0c;我们是可以把⼀层的结点…

vue代办事件案例实战练习,配有答案解析

代办事件案例 该案例&#xff0c;综合了前面所学的知识&#xff0c;列入点击事件绑定&#xff0c;双向绑定&#xff0c;v-for循环语句&#xff0c;v-model双向绑定&#xff0c;以及input标签的不同type形式。 演示代码如下&#xff1a; <template > <div id"ku…

基于LangChain-Chatchat实现的RAG-本地知识库的问答应用[3]-参数配置详细版

基于LangChain-Chatchat实现的RAG-本地知识库的问答应用[3]-参数配置详细版 在开始参数配置之前,先执行以下脚本 python copy_config_example.py该脚本将会将所有config目录下的配置文件样例复制一份到config目录下,方便开发者进行配置。 接着,开发者可以根据自己的需求,对…

盲盒一番赏小程序开发,市场新活力

当下&#xff0c;年轻人的的消费水平在逐渐提升&#xff0c;对娱乐消费的需求也在提升&#xff0c;一番赏的出现&#xff0c;成功吸引了年轻人的关注&#xff0c;成为了年轻人娱乐休闲的主要方式&#xff0c;在商场中的一番赏店铺中&#xff0c;都能看到年轻人的身影。 一番赏…

手机录屏怎么操作?3个小技巧,轻松录屏

在数字化时代&#xff0c;手机录屏功能已逐渐成为我们日常生活和工作中不可或缺的工具。无论是为了记录游戏过程、制作教程&#xff0c;还是为了留存重要的视频通话&#xff0c;手机录屏都能发挥巨大的作用。本文将详细介绍手机录屏的3个功能、录屏小技巧等&#xff0c;帮助您更…

GD32 MCU启动后如何运行到main函数

GD32 MCU启动后如何运行到main函数入口&#xff1f;你是否也有这样的疑虑。在执行到main函数之前MCU干了哪些事情呢&#xff1f;下面为大家解答。 MCMCU上电后&#xff0c;首先会根据BOOT0和BOOT1的状态判断从主Flash/SRAM/ISP中启动&#xff0c;如果BOOT0为低电平&#xff0c…

白蚁监测装置:支持北斗定位

TH-BY2白蚁监测控制管理系统原理 采用白蚁喜欢吃的食物做诱饵&#xff0c;吸引白蚁取食&#xff0c;取食过程中触动报警装置。报警装置发出信号&#xff0c;通过物联网传输到监控系统&#xff0c;经过数据处理&#xff0c;监测结果呈现给用户。用户通知白蚁防治专业人员&#x…

高端品牌网站建设

随着互联网的快速发展&#xff0c;越来越多的企业开始意识到高端品牌网站建设对于企业发展的重要性。高端品牌网站建设不仅是企业形象展示的窗口&#xff0c;更是与消费者进行有效沟通和互动的桥梁。下面从设计、内容和用户体验三个方面&#xff0c;探讨高端品牌网站建设的重要…

美国犹他州立大学《Nature Geoscience》(IF=18)!揭示草本植物对土壤有机碳的重要贡献!

随着全球变暖的影响越来越显著&#xff0c;碳固定成为了一个备受关注的话题。在这个背景下&#xff0c;热带草原被认为是一个潜在的碳固定区域。然而&#xff0c;目前的研究主要关注于在热带草原中种植树木&#xff0c;以期望增加土壤有机碳含量。但是&#xff0c;热带草原中的…

当OpenHarmony遇上OpenEuler

1、 安装openEuler 虚拟机、物理机器当然都可以安装。虚拟机又可以使用WSL、或者VMWare、VirtualBox虚拟机软件&#xff0c;如果需要安装最新版本&#xff0c;建议使用后者。当前WSL只支持OpenEuler 20.03。 1.1 WSL openEuler WSL的安装都是程序员的必备技能了&#xff0c;…

干G货,性能测试基本方法和原则,

一、性能测试关键点 评估性能指标——线程tps&#xff08;可架构给&#xff09; 吞吐量qps&#xff08;可架构给&#xff09; 错误率&#xff08;可架构给&#xff09; 平均响应时间&#xff08;可架构给&#xff09;模拟线上数据量了解接口有没有缓存&#xff0c;有缓存的需要…

springboot连接多个库

一个SpringBoot项目&#xff0c;同时连接两个数据库&#xff1a;比如一个是Mysql数据库&#xff0c;一个是oracle数据库&#xff08;啥数据库都一样&#xff0c;连接两个同为oracle的数据库&#xff0c;或两个不同的数据库&#xff0c;只需要更改对应的driver-class-name和jdbc…

Compose 可组合项 - DatePicker、DatePickerDialog

一、概念 一般是以对话框的形式呼出&#xff0c;DatePickerDialog 就是对 DatePicker 的一个简单对话框封装。 Composable fun DatePicker( state: DatePickerState, modifier: Modifier Modifier, dateFormatter: DatePickerFormatter remember { DatePickerFor…

使用MySQL

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 1 下载安装MySQL MySQL是一款开源的数据库软件&#xff0c;由于其免费特性得到了全世界用户的喜爱&#xff0c;是目前使用人数最多的数据库。下面将…

Swarm 集群管理

Swarm 集群管理 简介 Docker Swarm 是 Docker 的集群管理工具。它将 Docker 主机池转变为单个虚拟 Docker 主机。 Docker Swarm 提供了标准的 Docker API&#xff0c;所有任何已经与 Docker 守护程序通信的工具都可以使用 Swarm 轻松地扩展到多个主机。 支持的工具包括但不限…

使用 Nstbrowser 管理多个帐户 - 2024 年最佳反检测浏览器

每个人一定都看过那些房间里全是窃听器的老间谍电影&#xff0c;对吧&#xff1f;现在这些电影可能看起来有点好笑&#xff0c;但互联网并没有好到哪里去&#xff01; 事实上&#xff0c;每个你打开的页面在你浏览时都在被监控&#xff01;此外&#xff0c;当你管理多个账户时…

Rust 开发搜索引擎 Quickwit 替代ES,成本降低 10 倍,查询亚秒级别!

一、Quickwit 概述 Quickwit 它是云存储上最快的搜索引擎&#xff0c;它非常适合用于可观察性的云原生搜索引擎&#xff0c;如日志、跟踪以及即将推出的指标。同时也是 Datadog、Elasticsearch、Loki 和 Tempo 的开源替代方案。 二、Quickwit 功能 全文搜索和聚合查询&#…

C++语法13 单分支结构的相关问题详解

一、奇偶数问题 要判断一个数是否是偶数&#xff0c;只要判断这个数字能不能被2整除即可。如果一个数字a除以2&#xff0c;没有余数&#xff0c;那么就是偶数&#xff1b;如果除以2有余数&#xff0c;那么就是奇数。 if(a%20) a是偶数 if(a%21) a是奇数 训练&#xff1…

LangChain-ChatGLM本地搭建|报错合集(win10)

安装过程 1. 创建虚拟环境 conda create -n langchain-chatglm python3.10 conda activate langchain-chatglm2. 部署 langchain-ChatGLM git clone https://github.com/imClumsyPanda/langchain-ChatGLMpip3 install -r requirements.txt pip3 install -U gradio pip3 inst…

05-5.4.1 树的存储结构

&#x1f44b; Hi, I’m Beast Cheng &#x1f440; I’m interested in photography, hiking, landscape… &#x1f331; I’m currently learning python, javascript, kotlin… &#x1f4eb; How to reach me --> 458290771qq.com 喜欢《数据结构》部分笔记的小伙伴可以…