完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
|
FPGA求取极大值是要先定义一个二维数组(比如reg [15:0] signal [0:511]),然后将输入的数据存进去再进行处理么?
我的思路是采用状态机,状态1时进行数据的写入,完成状态1后进入状态0进行极大值的求取,逐个将每个值都与左右两边的值进行比较,如果signal[i+1]>signal[i]&&signal[i+1]>signal[i+2]的话就把该值所在地址i+1输出,有没有别的更好的思路什么的? 再就是最后编译得到的结果FPGA占用的资源太大,用的Cyclone IV E total logic elements达到了87%,是因为处理的数据太多的原因还是算法太过麻烦的缘故呢?有没有更好的解决办法?多谢了!! |
|
相关推荐
1个回答
|
|
|
module detection(clk,data_in,fnum);
input clk; input [15:0]data_in; output fnum; reg [15:0]fnum; reg [15:0] signal [0:511]; reg [9:0]i; reg state,next_state=1; //初始化状态为1,准备往二维数组中写数据 initial begin //$readmemh("memory.txt", signal); i<=0; fnum<=0; end always@(posedge clk) //时钟上升沿i加一 begin if(i!=511) begin i<=i+1; end else begin i<=0; end state<=next_state; end always@(state,i) begin case(state) 1'b1: begin if(i==255) next_state=1'b0; //状态为1时,当i加到255时下一个状态变为0 else next_state=1'b1; end 1'b0: begin //状态为0时,当i加到255时下一个状态变为1 if(i==511) next_state=1'b1; else next_state=1'b0; end endcase end always@(posedge clk) begin case(next_state) 1'b1: //状态为1时,往二维数组里写数据; begin signal <= data_in; end 1'b0: //状态为0时,选取数组里极大值所在的地址 begin if(signal[i+1]>signal&&signal[i+1]>signal[i+2]) begin fnum<=i+1; end else begin fnum<=0; end end endcase end endmodule 这个是自己写的代码,仿真出来的结果,fnum一直为0,而且耗费的FPGA资源很多。 |
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
NVMe高速传输之摆脱XDMA设计50:主要功能测试结果与分析2 nvmePCIe高速存储
252 浏览 0 评论
NVMe高速传输之摆脱XDMA设计49:主要功能测试结果与分析1
1501 浏览 0 评论
907 浏览 0 评论
855 浏览 0 评论
658 浏览 0 评论
4427 浏览 63 评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-2 10:25 , Processed in 0.717570 second(s), Total 72, Slave 55 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
12614