社区导航

 
查看: 2458|回复: 3

[求助] DS18B20温度值处理的VHDL程序请教

[复制链接]

11

TA的帖子

0

TA的资源

一粒金砂(初级)

Rank: 1

发表于 2018-4-12 09:59:09 | 显示全部楼层 |阅读模式


各位大神,DS18B20温度值处理成BCD数的VHDL程序中除以1600看不懂,为什么不是除以1000?
       process(temperature)
         begin
         --if(neg_flag = '0') then --温度为正数
        var4<=CONV_INTEGER(temperature)/1600;   --百位
        var3<=CONV_INTEGER(temperature)/160rem 10;   --十位
        var2<=CONV_INTEGER(temperature)/16rem 10;   --个位
         var1<=CONV_INTEGER(temperature)*10/16rem10;   --小数点后一位
         --end if;
         bcd_data(15 downto12)<=Conv_Std_Logic_Vector(var4,4);
         bcd_data(11downto8)<=Conv_Std_Logic_Vector(var3,4);
         bcd_data(7downto4)<=Conv_Std_Logic_Vector(Var2,4);
         bcd_data(3downto0)<=Conv_Std_Logic_Vector(Var1,4);
         end process;

为什么除16的倍数?既然已经用CONV_INTEGER转换成整数了,为什么不是除以10的倍数而是16的倍数?
请给解惑!

此帖出自FPGA/CPLD论坛


回复

使用道具 举报

27

TA的帖子

0

TA的资源

一粒金砂(中级)

Rank: 2

发表于 2018-4-14 09:37:19 | 显示全部楼层
消灭零回复,


回复

使用道具 举报

415

TA的帖子

1

TA的资源

一粒金砂(中级)

Rank: 2

发表于 2018-4-15 14:56:47 | 显示全部楼层
B(1111) = D(15) ,8421类型的转换啊


回复

使用道具 举报

11

TA的帖子

0

TA的资源

一粒金砂(初级)

Rank: 1

 楼主| 发表于 2018-4-20 08:33:21 | 显示全部楼层
青城山下 发表于 2018-4-15 14:56
B(1111) = D(15) ,8421类型的转换啊

我说的是这里“var4<=CONV_INTEGER(temperature)/1600;   --百位”,为什么不是除以1000,既然转换成bcd数应该除以1000,而除以1600是取出百位的16进制的系数,这里看不懂,哪位给解惑!


回复

使用道具 举报

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

本版积分规则

  • 论坛活动 E手掌握

    扫码关注
    EEWORLD 官方微信

  • EE福利  唾手可得

    扫码关注
    EE福利 唾手可得

小黑屋|手机版|Archiver|电子工程世界 ( 京ICP证 060456

GMT+8, 2018-9-20 06:05 , Processed in 0.136207 second(s), 16 queries , Gzip On, Redis On.

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