ThreeYear_s 2024-01-28 11:48 采纳率: 66.7%
浏览 30
已结题

FPGA Verilog 如何实现乘小数

通过这种方式实现乘一个1.几的小数

但是我发现 如果后面右移1位 这个数据本身也会变 所以加起来就不是想要的数据了

2222 + 2222 >>1 => 2222

怎么避免这样呢?

module ad16_xishu(
    input clk,
    input rst_n,
    output reg [15:0] ad_Data
);

reg [15:0] ad_Data_First=16'h22_22;

//右移>>1位=除以2  1.75的系数=>1本身+1>>1(0.5)+1>>2(0.25)
always@(posedge clk or negedge rst_n)
    if(!rst_n)begin
        ad_Data <= 16'd0;
    end
    else begin
    ad_Data <= ad_Data_First + ad_Data_First >>1;
    end
  • 写回答

1条回答 默认 最新

  • 老皮芽子 2024-01-29 09:17
    关注

    要这么写
    ad_Data <= ad_Data_First +( ad_Data_First >>1);
    注意 >> 这样的移位运算的优先级比加减法的运算优先级低

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 2月7日
  • 已采纳回答 1月30日
  • 创建了问题 1月28日

悬赏问题

  • ¥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腾讯文档收集表