有符号和无符号相加(vivo)

描述如下代码,实现加法;
C = A + B;
A是21bit无符号数;
B是18位有符号数;
如何实现才能保证正确得到一个不溢出的有符号数C;

module unsign_sign(
     input  wire             [20:0]A,
     input  wire   signed    [17:0]B,
    
     output wire   signed    [22:0]C
);

assign C =$signed({1'b0, A})+$signed({{4{B[17]}}, B});

endmodule

注意点:

  1. 位宽的无符号与有符号数的加法运算,需要将其位宽对补齐后运算
  2. 无符号数和任何书相加都是无符号数,所以需要强制转换
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值