OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4749|回复: 6

[XILINX] 请教一下,Verilog如何写查表程序?

[复制链接]

17

主题

53

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
264
金钱
264
注册时间
2019-3-26
在线时间
105 小时
发表于 2021-11-3 15:16:55 | 显示全部楼层 |阅读模式
10金钱
简单得比如8选1数据选择:
case(data)
8'd1:***;
8‘d2:***;
...
8‘d8:***;
endcase

但是如果需要在两百多个数据中选择一个呢?用case这种就太麻烦了,有没有其他写法呀?

我目前通过$readmemh将源数据读取到了一个数组中,需求是输入一个数字找它在这个数组中的下标,请问要怎么写呀?用for或者while一个个对比,我担心影响时序和占用面积。

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

10

主题

3229

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8074
金钱
8074
注册时间
2020-5-11
在线时间
3574 小时
发表于 2021-11-3 15:44:31 | 显示全部楼层
本帖最后由 LcwSwust 于 2021-11-3 16:10 编辑

我没深入学习,而且很久没写Verilog程序,大多忘了。
我觉得可以用for循环,比如数组有200个元素,用for循环相当于生成200个比较器,并行运行,应当不会影响时序。看看这样可以不:
  1. y<=-1;
  2. for(i=0;i<SIZE;i=i+1)
  3. begin
  4. if(buf[i]==x)
  5.   y<=i;  
  6. end
复制代码



修改一下代码



专治疑难杂症
回复

使用道具 举报

17

主题

53

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
264
金钱
264
注册时间
2019-3-26
在线时间
105 小时
 楼主| 发表于 2021-11-3 16:02:40 | 显示全部楼层
经过正点原子客服的指点,可以用计数器
回复

使用道具 举报

10

主题

3229

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8074
金钱
8074
注册时间
2020-5-11
在线时间
3574 小时
发表于 2021-11-3 16:12:03 | 显示全部楼层
Xinmx 发表于 2021-11-3 16:02
经过正点原子客服的指点,可以用计数器

哦,那么200个元素是否可能需要200个周期才能得出结果?
专治疑难杂症
回复

使用道具 举报

17

主题

53

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
264
金钱
264
注册时间
2019-3-26
在线时间
105 小时
 楼主| 发表于 2021-11-3 17:01:33 | 显示全部楼层
LcwSwust 发表于 2021-11-3 16:12
哦,那么200个元素是否可能需要200个周期才能得出结果?

嗯嗯,是这样的,等于说拿时间换面积。我是新手,看网上说的时序电路不建议用for,0.0,起始我也不太懂哈哈
回复

使用道具 举报

17

主题

53

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
264
金钱
264
注册时间
2019-3-26
在线时间
105 小时
 楼主| 发表于 2021-11-3 17:03:11 | 显示全部楼层
LcwSwust 发表于 2021-11-3 16:12
哦,那么200个元素是否可能需要200个周期才能得出结果?

我这个项目做完用for也尝试一下
回复

使用道具 举报

23

主题

72

帖子

0

精华

高级会员

Rank: 4

积分
735
金钱
735
注册时间
2015-7-9
在线时间
135 小时
发表于 2021-11-8 21:52:03 | 显示全部楼层
case难写为何不用编程列出代码呢
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-10-3 22:16

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表