ThreeYear_s 2023-11-15 12:00 采纳率: 66.7%
浏览 17

fpga 怎么实现简易输出随着输入进行变化

Verilog 怎么实现简易输出随着输入进行变化

如下所示代码
assign o_ad_ch1 = o_ad_rxdone ? ad_out_a[63:48] :o_ad_ch1;

assign real_o_ad_ch1 = o_ad_ch1 +(o_ad_ch1>>1)+(o_ad_ch1>>2)+(o_ad_ch1>>3); //凑1.78左右的o_ad_ch1
问题如下:

其中o_ad_ch1 是输入,这是一个采集0-5v电压的一个实际数据,需要把他转化成标准值 大致需要乘一个1.77左右的系数,但是这个系数不是固定的,从0-5v,这个系数应该从1.76逐渐增加到1.78,如何实现这个功能呢?

  • 写回答

2条回答 默认 最新

  • 日晨难再 数字IC领域优质创作者 2023-11-15 12:13
    关注

    你写的不就是解决这个问题的代码嘛?右移一位相当于乘0.5,右移两位相当于乘0.25以此类推,这样的话,你就可以把1-2之间的这个系数分解成一个二进制小数了,然后根据这个小数对应移位就行了。
    最后是,建议写在always块里面,这样可以使用if和case等语句。

    评论

报告相同问题?

问题事件

  • 修改了问题 11月15日
  • 创建了问题 11月15日

悬赏问题

  • ¥15 is not in the mmseg::model registry。报错,模型注册表找不到自定义模块。
  • ¥15 安装quartus II18.1时弹出此error,怎么解决?
  • ¥15 keil官网下载psn序列号在哪
  • ¥15 想用adb命令做一个通话软件,播放录音
  • ¥30 Pytorch深度学习服务器跑不通问题解决?
  • ¥15 部分客户订单定位有误的问题
  • ¥15 如何在maya程序中利用python编写领子和褶裥的模型的方法
  • ¥15 Bug traq 数据包 大概什么价
  • ¥15 在anaconda上pytorch和paddle paddle下载报错
  • ¥25 自动填写QQ腾讯文档收集表