大神看看有没有会的,能做出来价格好说,可以后续追加金额。
1.编码器和位发生器的设计实现。
2.BPSK调制器和AWGN信道的设计与实现。目前的步骤如下:位发生器->编码器->调制器-> AWGN信道。
3.调制后,需要在每个调制符号中加入AWGN样本。噪声样本需要根据信噪比(SNR)进行缩放。
4.在验收部分,按照以下步骤分别设计了三个模块:Rx:解调器-> LLR ->解码器。
5.在MATLAB中进行测试和修改,确认纠错目标是否完成,计算误码率与信噪比之间的关系
使用C ++设计卷积码编码器。 下面是bit generator的初步程序。 它需要生成1004个随机数,最后4个数字为0000。生成的数字应保存在文件中,然后将1004个数字将该数字添加到卷积码编码器的向量中。 需要具有1/2 rate和4个寄存器的卷积码编码器,并且编码器输出的编码器位还需要能够生成文档。
#include<stdio.h>
#define LEN(数组,len)[len]大小(数组)/大小(数组{0});]数组大小
int 编码器(int **gen, int n, int L, int reg_, int m, int inf_, int
inf_len, int 输出\) /* 编码器 (int **gen, int n, int reg_, int m, int
inf_, int inf_len, int 输出\) *此函数是一个卷积编码器。
*gen
是生成序列,这是一个双维数组,它是一个双维指针,*n
是每个时钟周期中编码器的位数,*L
表示
连续长度,*reg 表示
移位寄存器
,*m 表示寄存器数,*inf 表示
信息序列,*inf_len 表示 inf 长度,*l
表示输出为输出代码。
*/
[ int inf_ex [inf_len] m];
int i,j;//索引
用于 (i=0;i < inf_len = m;i=) / / 扩展信息序列以包括最后
m
位 [如果(i < inf_len) inf_ex [i] inf_i;
其他 inf_ex [i]= 0;
用于 (i=0;i < inf_len [m;i])//在扩展信息中输入位
= 对于 (j=0;j < n;j=)//输出每个时钟
周期
的 n 位 = int out_tem=0;//如果
(*(gen = L*j) = 1)//判断下一个信息位是否应
在 Mod op out_tem = inf_ex=i=
int k;
用于 (k=0;k < m;k=) /
/foreach
寄存器 = 如果 (*(gen = L*j
= k = 1) = 1) out_tem =
reg=k=///根据生成序列进行模式操作
= out_tem % = 2;//Mod 2 输出 =i*n = j = out_tem;
}
用于 (j= m - 1;j > 0;j
-) / / 寄存器移位
[reg_j] [reg] j - 1];
reg{0} = inf_ex[i];//输入信息位到寄存器中
}
返回 1;
}
main()
= int inf=1、 0、 0、1、1、0、1、1、1、1、1、1、1、1、0、0=;//
信息序列 int inf_len;//信息
长度 LEN(inf, inf_len);
int gen=2=7==1、0、1、1、0、1、1、1、1、0、1、1=;/生成序列 int n;//每个
时钟周期中编码器的位数 int L;//Constraight 长度
LEN(gen, n);
LEN(gen{0},L);
int m=L - 1;//移位寄存器数
int init_s 0, 0, 0, 0, 0, 0\;初始状态全部为零
int reg[m];///注册
int i;//索引
用于 (i=0;i < m;i=)
=reg{i}=init_s[i];
}
int output_len=(inf_len = m)*n;//输出长度,每个输入位都可以生成 n 位输出序列
int 输出=(inf_len = m)*n=;//输出
序列编码器(gen、n、L、reg、m、inf、inf_len、输出);//编码器
用于 (i=0;i < output_len;i=)
=printf("%d",
输出{i});
|
系统("暂停");
}
如果完成了编码器的实现,则下一步将是实现BPSK调制器和AWGN通道。至此的链条应如下所示:
位发生器->编码器->调制器-> AWGN通道
对于BPSK调制器,您需要将所有零编码的位映射到+1.0,将所有编码的位映射到-1.0。
0-> +1.0
1-> -1.0
调制后,您需要将AWGN样本添加到每个调制符号中。噪声样本需要根据信噪比(SNR)进行缩放。如果生成的标准偏差为1的AWGN样本,则可以使用从SNR得出的标准偏差来缩放。您需要的方程式如下:
通常,您以dB为单位输入SNRdB作为从-2到8的矢量,步长为0.5 dB。
信噪比
1. SNRdB = 10 * log10(SNR)->求解SNR
2. SNR = Rc * Eb / N0->求解N0(Eb为1,Rc为编码率,通常Rc = 1/2)
3. N0 = 2 * sigma ^ 2-解决sigma
一旦找到sigma的值,就可以乘以统一标准偏差生成的AWGN样本。
- 点赞
- 收藏
- 复制链接分享
- 收起