快速业务通道

Vdsp(bf561)中的浮点运算(11):fract16与float的转换

作者 佚名技术 来源 程序设计 浏览 发布时间 2012-06-29
nt passing.
*
* Code Size:
*
*       38 bytes
*
* Registers Used:
*
*       R0 - the input argument and result
*       R1 - various
*       R2 - various
*
* (c) Copyright 2006 Analog Devices, Inc.  All rights reserved.
*     $Revision: 1.2 $
*
***************************************************************************/

这个转换过程需要24个cycle。

1.3 fract16常量赋值

vdsp虽然没有将fract16当成内置类型,但是对于常量,编译器还是网开一面,使用r16或者r32后缀,编译器会自动将这个常量正确转换为fract16类型,如

fract16 r = 0.2r16;

编译器自动计算r的值为0x1999。

1.4 不幸的事件

由于fract16不是内置类型,编译器将不会自动完成两种类型之间的转换,如果不小心写上:

float r;
fract16 r1 = 0.2r16;
r = r1;

那么很不幸,r的值不是期望的0.2,而是6553!

Fract的其它运算也一样,务必通过函数调用来完成。

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号