NR 多天线传输过程 2- Scrambling -1

news2025/1/10 21:30:27

参考

《5G 无线系统设计与国际标准》

于威廉·斯托林斯的《数据与计算机通信》

《south western university--Scrambling》

《Prof. Hitesh Dholakiya-- Scrambling》

前言

       最近一次答辩,有同事问了LDPC 和 线性分组码有什么区别,当时只说出了应用场景不一样,以及原理不一样,回来细想一下: 处理的数据对象不一样,应用的场景也不一样.

        物理层编码: LDPC, Polar,Turbo 咬尾卷积码,每个Bit 可以认为一个channel,通过llr ,min-sum算法算出来的是一个概率,是一个连续值,基于概率去研究讨论编解码。

        MAC,PDCP,等层:

        译码后经过hard decison, 拿到的是0-1的离散比特流,传到MAC或者更上层. 上层处理的数据是离散的0-1比特流,概率信息已经丢失,基于最小汉明距离原理去讨论研究的.

    这两篇重点讲解一下scrambling,结合3GPP,以及数字编码了解一下为什么要scrambling.

1: 概述

2: Scrambling 简介

3: 3GPP 相关内容


一   概述

             物理层数据传输 PUSCH 和 PDSCH 经过编码和速率匹配形成码字

整个流程如下:

        

  TS38.211 里面也有详解,比如3GPP 38.211 


二  Scrambling 简介

    

2.1 意义

       1、减少连“0”或连“1”长度,保证接收机能提取到位定时信号。

       2、使加扰后的信号频谱更能适合基带传输。

       3、保密通信需要。

2.2 扰码分类

     根据收发双方LFSR同步方式的不同扰码分为:

    帧同步扰码(FrameSynchronous Scrambling,FSS)

   分布式抽样扰码(Distributed Sample Scrambling,DSS)

    和自同步扰码(Self Synchronous Scrambling,SSS)。

2.3 目的

          1  扰码的目的是抑制线路码中的长连“0” 和长连“1” ,便于从线路信号中提取时钟信号。

           2   扰码还可以将不同的终端或基站区分开来

          3,同时,扰码还有助于提高通信的保密性。

         4      加扰不改变信号的带宽,只是将来自不同信源的信号区分开来。这样,即使多个发射机使用相同的码字扩频也不会出现问题。


 


三  3GPP 相关章节

 3.1   3GPP 38.211 -6.3.1.1         Scrambling

         里面主要介绍了PUSCH Scrambling编码过程,以及相关系数

3GPP 38.211-6.3.1       Physical uplink shared channel(scrambling)

    

      交织后长度不变

     伪代码:

 

  入参:

  where x and y are tags:

          defined in [4, TS 38.212]

scrambling sequence c^{q}(i)  is given by clause 5.2.1. The scrambling sequence generator shall be initialized with

                         c_{init}=n_{RNTI}2^{15}+n_{ID}

                             

 里面mod2 作用就是模二加法,异或运算

3.2  3GPP38.212 -7.1.2             Scrambling

   里面主要结束了PBCH 编码过程。


  四    数字信号编码

        

        因为scrambling跟模拟信号Clock 同步相关。

       所以这里重点讲解一下数字信号转换模拟信号的编码过程

      这里以我们发送的一个bit流data = [0,0,1,1,0,1,0,1,1,1,0,0,1] 为例

       常用的编码方案如下:

      

     4.1  NRZ-L 不归零水平(None return to zero- level)

             0  :调制成幅度为+1的电压,

              1 : 调制成幅度为-1的电压值

                       y=1-2*x

               问题:

                      当遇到全0,全1 的比特流,因为接收方的clock 不同步,导致采样的时候出错.

             

   4.2 NRZI(Non return to zero invert) 不归零反相

          也叫差分编码 :涉及到两个电压等级

            相对收发双方时钟同步:

                        侦测到电压变化,相对维持某个电压更加容易,

             问题:

             当遇到全0 的比特流,因为接收方的clock 不同步,导致采样的时候出错.

          0 : 保持当前的电压值不变

          1:   当前的电压值反转

        data = [0,0,1,1,0,1,0,1,1,1,0,0,1] ,经过算法处理后的结果

 

     下面给出上面两种方案的代码

# -*- coding: utf-8 -*-
"""
Created on Thu Dec  8 11:26:43 2022

@author: chengxf2
"""

import numpy as np
import matplotlib.pyplot as plt
import matplotlib

def draw_voltage(data):
    
    # 将全局的字体设置为黑体
    N = len(data)
    x = np.arange(0,N)
 
    
    plt.bar(x, height=data,width=1.0,color='g',label="数字信号-voltate")
    plt.ylabel("voltate")
    plt.yticks([-1,1])
    plt.xticks(x)
    plt.legend()
    plt.show()

'''
不归零水平
0: 调制成电压值为1
1: 调制成电压值为-1
y=1-2x
'''
def NRZ_L(data):
    
    N = len(data)
    print(N)
    
    Y = []
    for x in data:
        s = 1-2*x
        Y.append(s)
    draw_voltage(Y)
    

#不归零反转
def NRZ_I(data):
    
    N = len(data)
    print(N)
    
    Y = [data[0]]
    #从-1开始
    
    prv_voltage = -1
    for i in range(N):
        
        bit = data[i]
        if 0 ==bit:
            voltage  =  prv_voltage
        else:
            voltage =  -prv_voltage
            
        Y.append(voltage)
        prv_voltage = voltage
        
   
        
        
    draw_voltage(Y)

if __name__ == "__main__":
    
    data = [0,0,1,1,0,1,0,1,1,1,0,0,1]
    

    NRZ_I(data)
    
    

     4.3 Bipolar-AMI(alternative mark inversive)

       这里涉及到三个电压等级 0,1,-1

          o :  对应的电压为0

          1: 会进行电压交替反转,

                 voltage = -pre_voltage

                 pre_voltage: 之前bit==1时候的电压值

     为什么要用这种编码方式:

     涉及到收发双方的时钟同步: 如下图 发送方发送全[1 1 1 1]的bit 流

由于接收方的时钟更发送方的并不同步,会导致最后t_5时刻再去检测出错了.

 通过AMI ,接收方可以很容易检测到voltage 变化的时候

同时根据voltage 变化的时候,进行clock 同步。

 

   问题是对全0,场景无法进行clock 同步,依然会发生错误。

# -*- coding: utf-8 -*-
"""
Created on Thu Dec  8 13:56:43 2022

@author: chengxf2
"""

import numpy as np
from pylab import *


def draw_volate(voltate):
    
   #voltate = [-1,1,1,1]
   #第一个是set_color,设置线的颜色,等价于set_c
   N = len(voltate)
   xticks = np.arange(0,N+1)
   fig = plt.figure()
   fig.suptitle('AMI 交替标记反转')
   
   line, = plt.plot(voltate,linewidth=5)
   line.set_color('g')
   
   
 
   #第二个是set_drawstyle,设置阶梯式的绘图方式,等价于set_c,效果看图
   line.set_ds('steps-mid')
    #第三个是set_linestyle,设置的是直线的类型,等价于set_ls
   #line.set_ls('--')
   
   plt.yticks([-1,0,1])
   plt.xticks(xticks)
   line.set_marker('*')
   plt.show()
   
   
def BipolarAMI():
    data = [0,0,1,1,0,1,0,1,1,1,0,0,1]
    
    Y = []
    N = len(data)
    
    pre_voltage = -1
    for i in range(N):
        bit = data[i]
        
        if 0 == bit:
            Y.append(0)
        else:
            voltage = -pre_voltage
            Y.append(voltage)
            pre_voltage = voltage
    draw_volate(Y)
            
 
 
if __name__ == "__main__":
    
    
    BipolarAMI()

4.4 pseudo ternary 编码

  跟上面相仿

 这里涉及到三个电压等级 0,1,-1

          1 : 对应的电压为0

          0: 会进行电压交替反转,

                 voltage = -pre_voltage

                 pre_voltage: 之前bit==1时候的电压值

                假设初始0的voltage 为-1

       最后两种分别为曼切斯特和差分曼切斯特编码   

 

      4.5  Machester  编码(曼切斯特编码)

        0: 电压   +1, -1的跃迁过程

        1: 电压  -1,+1的跃迁过程

      增加速率开销,提供了时钟同步信息。

   

 同样 data = [0,0,1,1,0,1,0,1,1,1,0,0,1]

      

 

    4.6 different  Machester (差分曼切斯特编码)

       主要区别在区间开始的地方

       0: 区间开始的地方有个电压转变

             [-1,1]

       1:     开始voltage 跟前面保持一致

           [volate,-voltage]过程

   

 

def  show_voltage(voltage):
        
     
        fig = plt.figure()
        fig.suptitle(' Machester ')
        N = len(voltage)
        T = 1 
        
        pre_x = 0
        pre_y = -1
        
        xticks = np.arange(N)
        
        for  i in range(N):
            v = voltage[i]
         
            
            plt.plot([pre_x,i],[pre_y,v],c='g')
            plt.plot([i,i+T],[v,v],c='g')
            
            pre_x = i+T
            pre_y = v
        plt.xticks(xticks)  
        plt.yticks([-1,0,1])
        plt.legend()
        plt.show()
    
def DfMachester():
    data = [0,0,1,1,0,1,0,1,1,1,0,0,1]
    
    Y = []
    N = len(data)
    
    pre_voltage = 1
    for i in range(N):
        bit = data[i]
        
        if 0 == bit: #[1,-1]
        
            Y.append(-pre_voltage)
            Y.append(pre_voltage)
            
        else: ##[-1,1]
            Y.append(pre_voltage)
            Y.append(-pre_voltage)
            pre_voltage = -pre_voltage
    print(Y)
    show_voltage(Y)

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

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

相关文章

Presto(OpenLookeng)之BloomFilter索引优化代码走读

一. 前言 本文计划通过走读代码来理解Presto(其实是OpenLookeng)中BloomFilter索引的建立以及Presto中利用BloomFilter索引对查询进行优化的执行流程。OpenLookeng BloomFilter索引的基本资料可以参考官网介绍:openLooKeng documentation。 二…

MacOS安装PyAudio

brew install portaudio pip install pyaudio docs:https://people.csail.mit.edu/hubert/pyaudio/docs/ pyaudio对象的open()方法: rate:取样频率channels:声道数format:取样值的量化格式 (paFloat32, paInt32, pa…

Node.js Event Loop 的三大常见理解误区和正确概念辨析

Node.js Event loop 监控器。高的 frequency 和低的持续时间是最理想的 event loop 状态。 上图显示三点半到五点半之间,event loop 的 frequency 骤降,然后 duration 居高不下。 Node.js 是一个基于事件的平台。 这意味着在 Node 中发生的一切都是对…

Windows无法读取驱动器中的光盘

一. 问题 在网上搜索了很多方法来解决下图的问题,一直失败。浪费了很多时间。后来发现,网上的方案可能恰恰是相反的思路。所以,留下个笔记吧。 二. 方法 1.打开本地服务管理器。按键盘的”WinR"组合键 打开“运行”窗口。输入“Serv…

汽车美容店会员管理系统开发步骤_分享会员系统小程序的优势

洗车店/汽车维修保养带店如何打开线上市场,获得更多目标用户呢? 除了服务的内容足够专业、优质以外,引入会员系统小程序就是关键一步。 汽修店为什么要做会员系统小程序?来看看行业现状: 1.竞争激烈:到处都…

Spring Boot与Web开发

Spring Boot与Web开发 SpringMVC快速使用 1.基于restful http接口 的CURD 2.调用rest http接口 通过RestTemplate调用 3.通过postman调用 通过MockMvc测试 4.通过swagger调用 添加依赖 添加swagger配置类 注意:访问的地址是:http://localhost:80…

【Java基础篇】基础知识易错集锦

在学习的路上,我们只记得学习新的知识,却忽略了一切新知识都是在旧知识的基础上;努力奔跑的过程中,也要记得常回头看看; 题目展示: 解析: abstract是抽象的意思,在java中&#xff0…

Python爬虫实战,requests+pyecharts模块,Python实现新冠疫情数据可视化(附源码)

前言 今天给大家介绍的是Python爬取新冠疫情数据并实现数据可视化,在这里给需要的小伙伴们代码,并且给出一点小心得。 首先是爬取之前应该尽可能伪装成浏览器而不被识别出来是爬虫,基本的是加请求头,但是这样的纯文本数据爬取的…

牛客网Mysql题目-SQL进阶篇 SQL 126-155

前言 这篇是进阶sql题目的记录,由于上一篇文章已经写将近一万字,有点长,就把剩下的再开一篇,免得总是重新发布 SQL126 平均活跃天数和月活人数 本题目要求统计,并且是多行,就需要使用group by查询 首先需…

kafka可靠性保证

1、概念 创建Topic的时候可以指定--replication-factor 3 ,表示分区的副本数,不要超过broker的数量。Leader是负责读写的节点,而其他副本则是Follower。Producer只把消息发送到Leader,Follower定期地到Leader上Pull数据。ISR是Le…

基于CNN-GRU-Attention混合神经网络的负荷预测方法(Python代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

[附源码]计算机毕业设计的家政服务平台Springboot程序

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

Linux系统(Centos7)了解DNS服务

配置与管理DNS服务器 项目导入 某高校组建了校园网,为了使校园网中的计算机简单快捷地访问本地网络及Intemet上的资源,需要在校园网中架设 DNS 务器,用来实现将域名转换成IP地址的功能。在完成该项目之前,首先应当确定网络中D…

基于多目标优化算法的电力系统分析(Matlab代码实现)

💥💥💥💞💞💞欢迎来到本博客❤️❤️❤️💥💥💥 🎉作者研究:🏅🏅🏅主要研究方向是电力系统和智能算法、机器学…

Volatile关键字的作用

专栏链接:多线程相关知识详解 编译器有优化功能,会对写好的代码进行优化,在多线程里面可能就会对代码的执行逻辑进行修改,就可能会产生bug 例如下面这个代码: import java.util.Scanner;class Counter{public static int count 0; }public class Demo {public static void …

RK3568平台开发系列讲解(系统优化篇)系统卡顿了怎么办

🚀返回专栏总目录 文章目录 一、卡顿问题分析指标二、Android 卡顿排查工具沉淀、分享、成长,让自己和他人都能有所收获!😄 📢对用户来说,内存占用高、耗费电量、耗费流量可能不容易被发现,但是用户对卡顿特别敏感,很容易直观感受到。另一方面,对于开发者来说,卡顿…

windows vs2019 编译glib2

1、安装meson pip install meson 确认是否安装成功,命令行输入: meson --version 0.60.0 2,安装ninja 先下载ninja:Releases ninja-build/ninja GitHub 加压后,把ninja.exe所在目录加入环境变量 确认是否安装成功&#xf…

英文外链怎么做效果好?

google英文外链怎么做效果好? 答案是:建设GPB外链 正确的外链建设行为追求的是高质量的外链。 对于高质量外链的定义:优质的外链是来自搜索引擎和搜索者都信任的权威网站,网站越值得信赖、越权威,链接质量就越好 网…

【ElementUI】树形控件 el-tree

目录 公共参数 基础用法 最后一层不可选择 思路一:第三层设置disable 思路二:利用样式隐藏掉第三层的选框 最后一层展示复选框 转载请注明:宾果的救星的博客_CSDN博客 公共参数 treeContent:[{name: 1,id: 1,level: 1,children: [{na…

HPPH偶联金属/小分子抑制剂/上转换纳米颗粒/点击化学/核壳磁性纳米粒子的方法

小编这里分享了科研内容HPPH偶联金属/小分子抑制剂/上转换纳米颗粒/点击化学/核壳磁性纳米粒子的方法,来看! 点击输入图片描述(最多30字) 制备光敏剂HPPH的方法: (1) 叶绿素-a的提取;(2)脱镁叶绿酸-a甲酯的制备;(3)焦…