负数大小比较的玄机(小于等于)

 所有变量都为 reg[9:0] 的变量也就是,,正数为0--511 负数为1023--512    ,,, -1为1024-1023     -512为1024-512=512

一、第一组测试

a7=2*B_K;
 a5=-N_K;
 a6=2*(-5);
 1、if(-2<=-34 && -2>=512)a3=1;else a3=2;
 2、if((2*B_K<=-N_K && 2*B_K>=512))a4=1;else a4=2;
 3、if((2*B_K<=-N_K) && (2*B_K>=512))a5=1;else a5=2;

可以看到a7=-2;

 1、条件满足 a3=2;

 2、3、条件不买足

二、第二组测试

a7=2*B_K;
a5=-N_K;
1、if(2*B_K<=-N_K)a3=1;else a3=2;
2、if(2*B_K>=512)a6=1;else a6=2;

3、if((K==0)&& (a5>=a7) && (a7>=512))a4=1;else a4=2;

这下终于对了:

a7=1022=-2;

a5=-N_k=-34=1024-34=990;

条件1、和条件2、未成立、、、、、、、、、、

原因是:比较大小时不能直接用负数,应该有一个中间变量转换,比较的时候直接比较不进行转换;

 

 

结论::::::有负数的比较大小,应该加入中间变量作为缓存,不能直接像C语言那样直接计算比较,否则会出错

 

转载于:https://www.cnblogs.com/TFH-FPGA/archive/2012/08/06/2625681.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值