在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 2060|回复: 6

[讨论] 求大神指教。插值滤波器的设计有问题!

[复制链接]
发表于 2013-4-26 16:32:47 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
本帖最后由 njuptzzl 于 2013-4-26 16:58 编辑

我做插值滤波器的(分三级,第一级补偿滤波器、第二级半带滤波器两倍插值、第三级CIC滤波器8倍插值),用modelsim仿真最终结果不对!
下面是我编的cic程序。clk=4M,clk1=32M
请问我编的CIC程序有问题吗?系数是用matlab FDATOOL得到的,转换成CSD码也没错,经过halfband为什么会失真呢?系统也用simulink建模跑过。

module cic(clk,clk1,reset,halfband_out,cic_out);
    input clk,clk1;
    input reset;
    input [9:0]halfband_out;
    output [9:0]cic_out;
    reg [9:0]com_delay0[1:0];
    reg [9:0]com_delay1[1:0];
    reg [9:0]com_delay2[1:0];
    reg [9:0]com_out;
   
    reg [18:0]int_delay0;
    reg [18:0]int_delay1;
    reg [18:0]int_delay2;
   
    reg [18:0] eightbei;
    reg[2:0] count;

    //cha ling zhi
    always@(posedge clk1 or negedge reset)
    if(!reset)
    eightbei<=0;
    else if(count==3'b111)
    eightbei<={{9{com_out[9]}},com_out};
    else
    eightbei<=0;
   
    always@(posedge clk1 or negedge reset)
    if(!reset)
    count<=0;
    else if(count==3'b111)
    count<=0;
    else
    count<=count+1;
    //
      
   
   
    //梳状部分
    always@(posedge clk or negedge reset )
    if(!reset)
    begin
     com_delay0[0]<=0;
     com_delay0[1]<=0;
     com_delay1[0]<=0;
     com_delay1[1]<=0;
     com_delay2[0]<=0;
     com_delay2[1]<=0;
     com_out<=0;
    end
    else
    begin
        com_delay0[0]<=halfband_out;
        com_delay0[1]<=com_delay0[0];
        com_delay1[0]<=com_delay0[0]-com_delay0[1];
        com_delay1[1]<=com_delay1[0];
        com_delay2[0]<=com_delay1[0]-com_delay1[1];
        com_delay2[1]<=com_delay2[0];
        com_out<=com_delay2[0]-com_delay2[1];
    end
   
   
    //积分部分
    always@(posedge clk1 or negedge reset )
    if(!reset)
    begin
    int_delay0<=0;
    int_delay1<=0;
    int_delay2<=0;
   
    end
    else
    begin
        int_delay0<=int_delay0+eight_bei;
        int_delay1<=int_delay0+int_delay1;
        int_delay2<=int_delay1+int_delay2;
    end
   
    assign cic_out=int_delay2[18:9];
endmodule

经过补偿滤波器图

经过补偿滤波器图

经过halfband的图,明显失真

经过halfband的图,明显失真
 楼主| 发表于 2013-4-26 17:00:20 | 显示全部楼层
本帖最后由 njuptzzl 于 2013-4-26 18:09 编辑

自己顶一个先!坐等大神!
 楼主| 发表于 2013-4-26 21:48:10 | 显示全部楼层
大神怎么还不出现?我的问题太弱智了?!!!
发表于 2013-4-27 09:23:48 | 显示全部楼层
一看就知道你是搞codec里的东西, 将你的matlab 发给我, 帮你看看要不没办法!
 楼主| 发表于 2013-4-27 11:10:16 | 显示全部楼层
fdatool 还是simulink?
发表于 2013-5-14 18:30:29 | 显示全部楼层
回复 5# njuptzzl


    哈哈哈哈哈哈哈哈哈哈哈哈哈啊哈哈哈哈哈哈
发表于 2013-5-17 10:14:47 | 显示全部楼层
到 matlab 公司网站下sigmadelta 工具包 设计啊
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-11-15 00:48 , Processed in 0.027078 second(s), 7 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表