初 末 2022-03-31 15:21 采纳率: 75.7%
浏览 49
已结题

数字下变频时低通滤波不成功?

    做了一个简易的数字下变频模块,用DDS分别生成2Mhz与3Mhz的正弦波输出分别设为16位宽的

din,s_oc,两波混频,然后通过低通滤波器滤除混频产生的5Mhz正弦波,但是滤出波形全输出不对?

img


这是我的代码。
module hunp(
input clk,
output signed [15:0] din ,
output signed [15:0] s_oc ,
output signed [31:0] mult ,
output signed [55:0] fir_1
);
wire m_axis_phase_tdata1;
wire m_axis_phase_tdata2;
wire fir_1;
dds_compiler_0 dds1 (
.aclk(clk), // input wire aclk
.m_axis_data_tvalid(), // output wire m_axis_data_tvalid
.m_axis_data_tdata(din), // output wire [15 : 0] m_axis_data_tdata
.m_axis_phase_tvalid(), // output wire m_axis_phase_tvalid
.m_axis_phase_tdata(m_axis_phase_tdata1) // output wire [31 : 0] m_axis_phase_tdata
);
dds_compiler_1 dds2 (
.aclk(clk), // input wire aclk
.m_axis_data_tvalid(), // output wire m_axis_data_tvalid
.m_axis_data_tdata(s_oc), // output wire [15 : 0] m_axis_data_tdata
.m_axis_phase_tvalid(), // output wire m_axis_phase_tvalid
.m_axis_phase_tdata(m_axis_phase_tdata2) // output wire [31 : 0] m_axis_phase_tdata
);
mult_gen_0 mult0 (
.CLK(clk), // input wire CLK
.A(din), // input wire [15 : 0] A
.B(s_oc), // input wire [15 : 0] B
.P(mult) // output wire [31 : 0] P
);
fir_compiler_0 your_instance_name (
.aclk(clk), // input wire aclk
.s_axis_data_tvalid(1), // input wire s_axis_data_tvalid
.s_axis_data_tready(), // output wire s_axis_data_tready
.s_axis_data_tdata(mult), // input wire [31 : 0] s_axis_data_tdata
.m_axis_data_tvalid( ), // output wire m_axis_data_tvalid
.m_axis_data_tdata(fir_1) // output wire [55 : 0] m_axis_data_tdata
);
endmodule
验证代码如下:
module tb();
reg clk;
wire signed [15:0] din;
wire signed [15:0] s_oc;
wire signed [31:0] mult;
wire signed [55:0] fir_1;
hunp hunp1(
.clk(clk),
.din (din ),
.s_oc (s_oc ),
.mult (mult ),
.fir_1 (fir_1)
);
initial
begin
clk = 0;
end
//产生10MHz时钟信号
always
begin
#10 clk = ~clk;
end
endmodule
望博学多才的各位批评指正。

  • 写回答

1条回答 默认 最新

  • 老皮芽子 2022-03-31 16:51
    关注

    代码看不出问题
    把 DDS,FIR IP 的设置贴出来,明天上班我帮你在电脑上跑跑看

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 4月9日
  • 已采纳回答 4月1日
  • 创建了问题 3月31日

悬赏问题

  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊
  • ¥15 安装svn网络有问题怎么办