当前位置: 首页 > news >正文

长春网站设计制作磁力搜索引擎哪个好

长春网站设计制作,磁力搜索引擎哪个好,sem是什么职业岗位,阿里云服务器如何配置多网站FPGA: RS译码仿真过程 在上一篇中记录了在FPGA中利用RS编码IP核完成信道编码的仿真过程,这篇记录利用译码IP核进行RS解码的仿真过程,带有程序和结果。 1. 开始准备 在进行解码的过程时,同时利用上一篇中的MATLAB仿真程序和编码过程&#x…

FPGA: RS译码仿真过程

在上一篇中记录了在FPGA中利用RS编码IP核完成信道编码的仿真过程,这篇记录利用译码IP核进行RS解码的仿真过程,带有程序和结果。

1. 开始准备

在进行解码的过程时,同时利用上一篇中的MATLAB仿真程序和编码过程,IP核的下载是同样的地址。解码过程中的参数设置正好对应编码的过程。对0-15的自然数通过RS编码得到的数据进行解码,其中m=4,n=15,k=3,ploy=19

2. RS译码IP核

RS译码IP核全名Reed-Solomon Decoder,具体细节可以参照PDF技术文档,首先看IP核参数设置。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R32PpUta-1692190030739)(1.png “rs解码IP核设置1”)]

已经通过RS编码IP核完成了编码的仿真过程,并且通过MATLAB对比对结果进行了验证,所以这个第一个页码的参数直接参照如图设置就可以,与编码是一一对应的,没有什么需要特别的说明。
在下面的Variable Check Symbol Options不需要勾选。

在这里插入图片描述

在第二个参数设置界面,都不需要勾选,勾选的话译码输出的结果会带有校验的数据。

在这里插入图片描述

在第三个参数设置界面中,把Reset选项勾选上。

在这里插入图片描述

完成这个IP核的设置。

补充

为了方便利用仿真过程中的译码过程,在之前完成编码过程后添加了一个fifo方便进行数据处理和信号控制,其中的fifoIP核的参数设置为如下。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

这个fifo根据需要设置即可,主要是为了编码之后的数据和译码过程使用控制方便。

3. 代码编写

译码过程是在编码基础上添加的,编码过程的参数没有变化,对0-15的数据进行编码,然后再进行译码,在编码和译码过程中间有一个fifo,其中fifo的读控制信号利用empty信号和译码IP的s_ready信号,fifo的写信号编码信号的输出valid信号。详细的逻辑看代码。

代码如下rs_test.v

`timescale 1ns / 1psmodule rs_test(input clk,          //时钟input rst_n         // 复位  高电平复位
//    input [7:0] data_in,  // 输入的待编码数据
//    output [7:0] dataout      // 输出的解码数据);wire rs_encode_input_tready;  // 编码输入准备信号
reg rs_encode_input_tvalid_reg;  // 编码输入有效信号
reg rs_encode_input_tready_reg;
wire rs_encode_input_tlast;
reg rs_encode_input_tlast_reg;
wire[7:0] rs_encode_data;
wire rs_encode_output_tvalid;
wire rs_encode_output_tlast;
wire rs_enocde_output_tready;
reg rs_enocde_output_tready_reg;parameter K = 3;   //  对应MATLAB仿真中的k和n的值,这个在IP核设置中已经有体现
parameter N = 4;   //
parameter L = 15;  // 编码之后的数据长度reg [3:0] datain_num; // 每一组编码的原始数据个数
reg [5:0] dataout_num;  //输出编码数据的个数wire fifo_full; // fifo 满信号// 设计输入数据
reg [3:0] datain;
always@(posedge clk)beginif(~rst_n)begindatain <= 4'b0;rs_encode_input_tready_reg <= 1'b0;rs_encode_input_tvalid_reg <= 1'b0;rs_encode_input_tlast_reg <= 1'b0;rs_enocde_output_tready_reg <= 1'b0;datain_num <= 4'b0;endelse beginrs_encode_input_tready_reg <= rs_encode_input_tready;if(fifo_full==1'b1)beginrs_encode_input_tvalid_reg <= 1'b0;endelse beginrs_encode_input_tvalid_reg <= 1'b1;endif(rs_encode_input_tready == 1'b1 && rs_encode_input_tvalid_reg == 1'b1)begin // 在ready 和valid信号都有效的时候才开始编码数据,可以在这里计数编码的个数。datain <= datain + 4'b1;datain_num <= 4'b1 + datain_num;rs_enocde_output_tready_reg <= 1'b1;endelse beginendend
end// 根据每一组编码的组数来确定数据顺序 控制最后一个tlast信号。
always@(posedge clk)beginif(~rst_n)beginrs_encode_input_tlast_reg <= 1'b0; // 这个信号是需要在一组中的最后一个数据时候信号处于高电平 和k的大小对应endelse beginif(datain_num >= K)beginrs_encode_input_tlast_reg <= 1'b1;endelse beginrs_encode_input_tlast_reg <= 1'b0;  //然后重新置零endend
endwire [3:0] data_in;
assign data_in = datain;rs_encoder_0 rs_encoder_0_ins (   //latency 5clk.aclk(clk),                                                      // input wire aclk.aresetn(rst_n),                                                // input wire aresetn.s_axis_input_tdata(data_in),                          // input wire [7 : 0] s_axis_input_tdata.s_axis_input_tvalid(rs_encode_input_tvalid_reg),                        // input wire s_axis_input_tvalid.s_axis_input_tready(rs_encode_input_tready),                        // output wire s_axis_input_tready.s_axis_input_tlast(rs_encode_input_tlast_reg),                          // input wire s_axis_input_tlast.m_axis_output_tdata(rs_encode_data),                        // output wire [7 : 0] m_axis_output_tdata.m_axis_output_tvalid(rs_encode_output_tvalid),                      // output wire m_axis_output_tvalid.m_axis_output_tready(rs_enocde_output_tready_reg),                      // input wire m_axis_output_tready.m_axis_output_tlast(rs_encode_output_tlast)                       // output wire m_axis_output_tlast
);// 通过编码模块输出的valid信号和ready信号来记录输出数据的个数
always@(posedge clk)beginif(~rst_n)begindataout_num <= 6'b0;endelse beginif(rs_encode_output_tvalid==1'b1 && rs_enocde_output_tready_reg==1'b1)begindataout_num <= dataout_num + 6'b1;if(dataout_num >= 6'd15)begindataout_num <= 6'b0;endendelse beginendend
end// rs 译码过程
// 在编码之后的数据添加一个fifo  方便管理valid信号和ready信号,减少耦合同时可以比配位宽
wire fifo_empty;
wire fifo_rd_en;wire[3:0] fifo_data;
reg fifo_flag;  // 这个是用来标致第一次从fifo中读取数据的过程wire [7:0] rs_decode_data_temp;
wire [3:0] rs_decode_data;
//in
wire rs_decode_data_s_ready;
wire rs_decode_data_s_valid;
reg rs_decode_data_s_valid_reg;  // 去掉fifo 输出的一个时钟延迟
reg rs_decode_data_s_tlast_reg;
assign fifo_rd_en = rs_decode_data_s_ready && (!fifo_empty);
// out
wire rs_decode_data_m_valid;
wire rs_decode_data_m_tlast;
wire rs_decode_data_m_ready;
// stat
wire [7:0] rs_decode_stat_data;
//wire rs_decode_stat_ready;
wire rs_decode_stat_valid;always@(posedge clk)beginif(~rst_n)beginfifo_flag <= 1'b0;endelse beginif(fifo_rd_en==1'b1)beginfifo_flag <= 1'b1;endend
endalways@(posedge clk)beginif(~rst_n)beginrs_decode_data_s_valid_reg <= 1'b0;endelse beginrs_decode_data_s_valid_reg <= fifo_rd_en;end
endfifo_generator_0 fifo_ins( // 这个输出有1clk延迟.clk(clk),      // input wire clk.srst(~rst_n),    // input wire srst.din(rs_encode_data[3:0]),      // input wire [3 : 0] din.wr_en(rs_encode_output_tvalid),  // input wire wr_en.rd_en(fifo_rd_en),  // input wire rd_en.dout(fifo_data),    // output wire [3 : 0] dout  .full(fifo_full),    // output wire full.empty(fifo_empty)  // output wire empty
);
// 输入编码中的有效信号
assign rs_decode_data_s_valid = (fifo_flag==1'b1)?fifo_rd_en:rs_decode_data_s_valid_reg; // 在第一次读取的时候 信号跟随reg信号,之后跟随en信号
reg[5:0] decode_num;
always@(posedge clk)beginif(~rst_n)begindecode_num = 6'b1;endelse beginif(rs_decode_data_s_valid==1'b1)begindecode_num <= decode_num + 6'b1;if(decode_num >= 6'd14)begindecode_num <= 6'b0;endendend
end
// 控制tlast信号
always@(posedge clk)beginif(~rst_n)beginrs_decode_data_s_tlast_reg <= 1'b0;endelse begin //当解码输入进入的数据为一组时,拉高tlast信号;if(decode_num >= 6'd14)beginrs_decode_data_s_tlast_reg <= 1'b1;endelse beginrs_decode_data_s_tlast_reg <= 1'b0;endend
endrs_decoder_0 rs_decoder_0_ins (.aclk(clk),                                                      // input wire aclk.aresetn(rst_n),                                                // input wire aresetn.s_axis_input_tdata(fifo_data),                          // input wire [7 : 0] s_axis_input_tdata.s_axis_input_tvalid(rs_decode_data_s_valid),                        // input wire s_axis_input_tvalid.s_axis_input_tlast(rs_decode_data_s_tlast_reg),                          // input wire s_axis_input_tlast.s_axis_input_tready(rs_decode_data_s_ready),                        // output wire s_axis_input_tready.m_axis_output_tdata(rs_decode_data_temp),                        // output wire [7 : 0] m_axis_output_tdata.m_axis_output_tvalid(rs_decode_data_m_valid),                      // output wire m_axis_output_tvalid.m_axis_output_tready(1'b1),                      // input wire m_axis_output_tready.m_axis_output_tlast(rs_decode_data_m_tlast),                        // output wire m_axis_output_tlast.m_axis_stat_tdata(rs_decode_stat_data),                            // output wire [7 : 0] m_axis_stat_tdata.m_axis_stat_tvalid(rs_decode_stat_valid),                          // output wire m_axis_stat_tvalid.m_axis_stat_tready(1'b1)                          // input wire m_axis_stat_tready
);assign rs_decode_data = rs_decode_data_temp[3:0];endmodule

4. 仿真测试

测试程序的testbench文件和之前保持一致,只需要把实例化的模块名字更改即可。

`timescale 1ns / 1ps
module rs_tb();reg l_clk;
reg rst_n;rs_test rs_test_ins(.clk(l_clk),          //时钟.rst_n(rst_n)         // 复位  高电平复位);
initial l_clk = 1;
always #5 l_clk= !l_clk;  //15.625   initial beginrst_n <= 0;#40;rst_n <= 1;#320;//#50000000;#320;
//    $stop;
end
endmodule

然后进入仿真过程,对照时序查看结果。

在这里插入图片描述

首先看试验大图,其中的蓝色线是解码之后的数据,从数据结果中可以看出每个数据间隔3,正好是编码之前的结果,拉开蓝色线就可以看到具体的数值。因为译码也是存在延时的,所以看起来数据会滞后,蓝色数据线的m_valid信号对应输出数据有效信号。

这里面有需要注意的地方,首先看仿真结果的前面部分。

在这里插入图片描述

这是fifo_rd_en有效的第一段,由于有1个clk的时钟延迟,所以把有效信号rs_decode_data_s_valid信号需要延迟一个clk,然后看接下来的fifo_rd_en第二个周期,需要把rs_decode_data_s_valid信号和fifo_rd_en信号对齐,否则会丢一个数据,后面的和第二个周期相同,只有第一个需要延迟一个周期,这个在程序中通过fifo_flag判断是不是第一个周期。

在这里插入图片描述

至此完成了译码的过程。


文章转载自:
http://disconnected.yqsq.cn
http://doura.yqsq.cn
http://satanize.yqsq.cn
http://crapoid.yqsq.cn
http://kbp.yqsq.cn
http://mestiza.yqsq.cn
http://rhetorical.yqsq.cn
http://cerebellum.yqsq.cn
http://thigmotropism.yqsq.cn
http://neutron.yqsq.cn
http://elaborately.yqsq.cn
http://expediency.yqsq.cn
http://timbul.yqsq.cn
http://girlish.yqsq.cn
http://fley.yqsq.cn
http://overbusy.yqsq.cn
http://interocular.yqsq.cn
http://inauguration.yqsq.cn
http://hangar.yqsq.cn
http://tammerfors.yqsq.cn
http://czarevna.yqsq.cn
http://infold.yqsq.cn
http://indigestible.yqsq.cn
http://reconvey.yqsq.cn
http://pharmic.yqsq.cn
http://voila.yqsq.cn
http://nonpartizan.yqsq.cn
http://sandcastle.yqsq.cn
http://banbury.yqsq.cn
http://thysanuran.yqsq.cn
http://shigellosis.yqsq.cn
http://panhellenic.yqsq.cn
http://gynoecium.yqsq.cn
http://pantologic.yqsq.cn
http://cantala.yqsq.cn
http://royalties.yqsq.cn
http://inviolability.yqsq.cn
http://ampersand.yqsq.cn
http://wuchang.yqsq.cn
http://boreen.yqsq.cn
http://supranatural.yqsq.cn
http://misspelt.yqsq.cn
http://deckhead.yqsq.cn
http://unman.yqsq.cn
http://chlormadinone.yqsq.cn
http://russellite.yqsq.cn
http://denary.yqsq.cn
http://beatage.yqsq.cn
http://thitherwards.yqsq.cn
http://neutralization.yqsq.cn
http://necrose.yqsq.cn
http://fenestrated.yqsq.cn
http://dee.yqsq.cn
http://pleurodont.yqsq.cn
http://manutius.yqsq.cn
http://solan.yqsq.cn
http://noodlework.yqsq.cn
http://faustine.yqsq.cn
http://hopelessly.yqsq.cn
http://autoinjector.yqsq.cn
http://avaluative.yqsq.cn
http://pincette.yqsq.cn
http://malwa.yqsq.cn
http://manent.yqsq.cn
http://osmund.yqsq.cn
http://sugarbush.yqsq.cn
http://reformulation.yqsq.cn
http://barabbas.yqsq.cn
http://neronian.yqsq.cn
http://buskined.yqsq.cn
http://skull.yqsq.cn
http://gadgetize.yqsq.cn
http://shrubby.yqsq.cn
http://bandung.yqsq.cn
http://goby.yqsq.cn
http://sociologically.yqsq.cn
http://bergamot.yqsq.cn
http://gin.yqsq.cn
http://devolute.yqsq.cn
http://somniloquism.yqsq.cn
http://picaroon.yqsq.cn
http://dysphonia.yqsq.cn
http://coccus.yqsq.cn
http://adcraft.yqsq.cn
http://chaser.yqsq.cn
http://equiaxed.yqsq.cn
http://coldly.yqsq.cn
http://bastardization.yqsq.cn
http://heavenliness.yqsq.cn
http://prevenance.yqsq.cn
http://accruement.yqsq.cn
http://heliologist.yqsq.cn
http://watchtower.yqsq.cn
http://remorsefully.yqsq.cn
http://evenhanded.yqsq.cn
http://quant.yqsq.cn
http://grillroom.yqsq.cn
http://gallows.yqsq.cn
http://sarcocarcinoma.yqsq.cn
http://vermicelli.yqsq.cn
http://www.dt0577.cn/news/64333.html

相关文章:

  • 广州网站建设信科网络百度文库官网登录入口
  • 做网站属于广告费吗全网搜索软件
  • 进一步加强政府网站内容建设网络广告一般是怎么收费
  • 福州高端网站建设武汉seo管理
  • 网站建设推广合同书高级seo招聘
  • 网站域名选择软件开发流程
  • 人力资源做网站的好处网站怎么优化推荐
  • 有没有做海报的网站推荐深圳网络推广收费标准
  • 报名小程序怎么制作百度seo排名优化软件分类
  • 成都网站建设公司哪家好大数据营销的案例
  • 镇江网站建设策划餐饮营销引流都有什么方法
  • 网站优化潍坊网络公司取什么名字好
  • 一个人做网站网站里的友情链接
  • 建站平台哪个最好最简单的网页制作
  • wordpress打赏积分常用的关键词优化策略有哪些
  • 湖南网站建设公司舆情监测系统
  • 创建购物网站石家庄seo代理商
  • 舟山建设技术学校网站免费crm网站不用下载的软件
  • 南通教育平台网站建设跨境电商平台推广
  • seo快速优化报价aso优化软件
  • 网站服务内容 备案网站数据统计工具
  • 网站推广的方法ppt长尾关键词爱站
  • 怎么修改自己网站内容天津seo数据监控
  • 手机网站进不去怎么解决天津的网络优化公司排名
  • 网站关键字语法网络推广外包
  • 目前流行的网站开发工具惠州网络推广
  • 延安免费做网站公司推广百度百科
  • 做阿里巴巴网站多少钱百度广告点击软件源码
  • 公司网站怎么做才高大上主流网站关键词排名
  • 一站式做网站哪家好app推广文案