weixin_53090316 2021-04-20 20:37 采纳率: 0%
浏览 474
已结题

如何设计一个信号纠错器并在MATLAB中完成运行?

大神看看有没有会的,能做出来价格好说,可以后续追加金额。

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样本。 

  •  点赞
  •  
  •  
  • 收藏
  • 复制链接分享
  •  
  • 收起

 

  • 写回答

1条回答 默认 最新

  • SoftwareTeacher 《编程之美》作者 2021-04-25 18:35
    关注

    你好, 能否把这个大问题细化为几个小问题, 这样MatLab 的专家可以来回答一个小问题, 而不要面对一个巨大复杂的问题。 

    评论

报告相同问题?

悬赏问题

  • ¥20 SQL server表计算问题
  • ¥15 C# P/Invoke的效率问题
  • ¥20 thinkphp适配人大金仓问题
  • ¥20 Oracle替换.dbf文件后无法连接,如何解决?(相关搜索:数据库|死循环)
  • ¥15 数据库数据成问号了,前台查询正常,数据库查询是?号
  • ¥15 算法使用了tf-idf,用手肘图确定k值确定不了,第四轮廓系数又太小才有0.006088746097507285,如何解决?(相关搜索:数据处理)
  • ¥15 彩灯控制电路,会的加我QQ1482956179
  • ¥200 相机拍直接转存到电脑上 立拍立穿无线局域网传
  • ¥15 (关键词-电路设计)
  • ¥15 如何解决MIPS计算是否溢出