欲对AD采样数据进行求平均值滤波。
思路是这样的:
采样255次数据,对255次数据求平均.
其中求平均值是这样写的:
if(cnt == 8'd255)
begin
for(i=8'd0;i<8'd255;i= i+1'b1)
sum <= sum+databuf[i];//阻塞赋值
dataout <= sum/255;
end
发现数据会从0到255跳变。
之后改成这样的:
if(cnt == 8'd255)
begin
for(i=8'd0;i<8'd255;i= i+1'b1)
sum = sum+databuf[i];非阻塞赋值
dataout <= sum/255;
end
这时,数据跳变的更快了,而且显示的是错误的结果。完全达不到滤波效果。
想问问,Verilog里边求平均值,怎么求?
整个机算是这样的:
//对数据进行滤波
//方法:求平均值
reg [7:0] databuf1;
reg [7:0] dataout;
reg [7:0] databuf[254:0];//定义一段内存
reg [15:0] sum;
integer i;
reg [7:0] cnt;
always @(posedge convert,negedge sys_rstn)
begin
if(!sys_rstn)
begin
sum<=0;
cnt <= 8'b0;
for(i=8'd0;i<8'd255;i= i+1'b1)
begin
databuf[i] = 7'b0;
end
end
else
begin
databuf[cnt] <= read_data;
cnt <= cnt+1'b1;
if(cnt == 8'd255)
begin
for(i=8'd0;i<8'd255;i= i+1'b1)
sum = sum+databuf[i];
dataout <= sum/255;
end
end
end
有奖活动 | |
---|---|
【EEPW电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
“我踩过的那些坑”主题活动——第001期 | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
【我踩过的那些坑】calloc和malloc错误使用导致跑飞问题排查被打赏50分 | |
多组DCTODC电源方案被打赏50分 | |
【我踩过的那些坑】STM32cubeMX软件的使用过程中的“坑”被打赏50分 | |
新手必看!C语言精华知识:表驱动法被打赏50分 | |
【我踩过的那些坑】杜绑线问题被打赏50分 | |
【我踩过的那些坑】STM32的硬件通讯调试过程的“坑”被打赏50分 | |
【我踩过的那些坑】晶振使用的问题被打赏100分 | |
【我踩过的那些坑】电感选型错误导致的处理器连接不上被打赏50分 | |
【我踩过的那些坑】工作那些年踩过的记忆深刻的坑被打赏10分 | |
【我踩过的那些坑】DRC使用位置错误导致的问题被打赏100分 |