野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 16529|回复: 4

缩放字模固件库例程中有两行代码看不太明白,求大神

[复制链接]
发表于 2017-11-7 15:13:11 | 显示全部楼层 |阅读模式
5火花
        //根据源字模及目标字模大小,设定运算比例因子,左移16是为了把浮点运算转成定点运算
        unsigned int xrIntFloat_16=(in_width<<16)/out_width+1;
  unsigned int yrIntFloat_16=(in_heig<<16)/out_heig+1;
        in_width  out_width   in_heig  out_heig都是short int,看不明白这个左移16位,不就是0了吗。这两行是什么意思,求大神解释啊,万分感谢

最佳答案

查看完整内容

在32位机里,运算结果是暂存成32位的, (in_width
回复

使用道具 举报

发表于 2017-11-7 15:13:12 | 显示全部楼层
蛋白质khun 发表于 2017-11-11 11:57
多谢,可以理解说把浮点数转为定点数左移,但这里不是一个定点数嘛,这个我在研究一下吧,不过还有一个疑 ...

在32位机里,运算结果是暂存成32位的,
(in_width<<16)
我们把最后结果赋值给 unsigned int类型的变量,就不会出错,即会存储成32位,
但是如果这样操作:
in_width = (in_width<<16)
那就是你说的结果全为0的情况了
回复

使用道具 举报

发表于 2017-11-7 17:18:02 | 显示全部楼层
类似这样的东西:http://www.eepw.com.cn/article/263475.htm

这里使用的是 q16 定点运算,还是不理解的话找本大学的DSP教材来看看
回复

使用道具 举报

 楼主| 发表于 2017-11-11 11:57:54 | 显示全部楼层
flyleaf 发表于 2017-11-7 17:18
类似这样的东西:http://www.eepw.com.cn/article/263475.htm

这里使用的是 q16 定点运算,还是不理解的 ...

多谢,可以理解说把浮点数转为定点数左移,但这里不是一个定点数嘛,这个我在研究一下吧,不过还有一个疑问,如果是移个几位还可以理解,但16位的二进制左移了16位不就是16位的0吗,还是说会变成32位或者这是循环移位?实在不明白
回复

使用道具 举报

 楼主| 发表于 2017-11-13 10:20:56 | 显示全部楼层
flyleaf 发表于 2017-11-7 15:13
在32位机里,运算结果是暂存成32位的,
(in_width

好的,明白了,非常感谢
回复

使用道具 举报

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

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2024-11-23 22:25 , Processed in 0.029161 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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