在vdsp提供的《VisualDSP++ 5.0 C/C++ Compiler and Library Manual for Blackfin Processors Revision 5.1, August 2008》中列出了vdsp支持的所有数据类型,其中与浮点有点的类型有:
Type | Bit Size | Number Representation | sizeof returns |
double | 32 bits | 32-bit IEEE single-precision | 4 |
float | 32 bits | 32-bit IEEE single-precision | 4 |
double | 64 bits | 64-bit IEEE double-precision | 8 |
long double | 64 bits | 64-bit IEEE | 8 |
fract16 | 16 bits signed | 1.15 fract | 2 |
fract32 | 32 bits signed | 1.31 fract | 4 |
其中前4个采用了IEEE的格式,而fract则是ADI自己定义的格式。
在这里容易混淆的一点是通过project options -> compilers中的参数配置可以控制使用的double类型是32位的还是64位的,可恶的是在默认情况下,vdsp是将double当成32位来处理的,这对于某些科学计算相关的代码来说简直是一个噩梦!
当然了,由于bf561硬件本身不支持浮点运算,只能通过软件模拟来实现,所以文档中这样解释为什么默认情况下要使用32位的double:
On Blackfin processors, the float data type is 32 bits, and the double data type default size is 32 bits. This size is chosen because it is the most efficient. The 64-bit long double data type is available if more precision is needed, although this is more costly because the type exceeds the data sizes supported natively by hardware.
似乎勉强也说得过去。
但由此造成的一个问题是:如果在要使用的dlb库和调用者之间是使用不同的选项来编译的,那么将造成程序运行时不可避免的错误!
编缉推荐阅读以下文章
版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明!