资料介绍
14.10 浮点运算
大多数的ARM处理器硬件上并不支持浮点运算。但ARM上提供了以下几个选项来实现浮点运算。
· 浮点累加协处理器FPA(Floating-Point Accelerator):ARM上提供了一组协处理器指令专门实现浮点运算。但这需要硬件支持,具体某一处理器上是否有FPA协处理器支持,可以查看ARM相关手册。
· 浮点运算仿真(FPE):使用软件仿真了FPA协处理器的执行。
· 浮点运算库(FPLib):使用ARM的浮点运算库函数实现程序中的浮点运算操作。这就意味着C编译器要把每一个浮点操作转换成一个子程序调用。C库中的子函数使用整型运算来模拟浮点操作。这些代码是用高效的汇编语言编写而成的。尽管如此,浮点运算执行起来还是要比相应整型运算慢得多。
注意Thumb指令不支持协处理器指令,所以在Thumb状态下实现浮点运算,只能调用ARM浮点运算库。
为了在ARM上高效地实现浮点运算,请遵循以下规则。
· 避免使用浮点除法运算。通常情况下,除法运算的执行速度是普通加法或乘法运算速度的1/2。在无法避免除法的情况下,尽量使除法的除数为常数。如,x=x/3.0,可将其变为x = x * (1.0/3.0)。这样除数为常数(1.0/3.0),该值在编译阶段由编译器计算。
· 使用float型代替double型。float型要比double使用更少的内存和寄存器。
· 避免使用三角函数功能。实现三角函数功能,如sin、cos,使用了大量的乘加运算,它的运算速度大约是普通乘法运算的十倍。
· 当编译器处理浮点运算操作时,由于精度的影响很多优化不能实现。比如,表达式3 * (x / 3),编译器不能判断其值和x是等价的。所以在使用浮点运算表达式时,最好先人工的做一些必要的优化。
大多数的ARM处理器硬件上并不支持浮点运算。但ARM上提供了以下几个选项来实现浮点运算。
· 浮点累加协处理器FPA(Floating-Point Accelerator):ARM上提供了一组协处理器指令专门实现浮点运算。但这需要硬件支持,具体某一处理器上是否有FPA协处理器支持,可以查看ARM相关手册。
· 浮点运算仿真(FPE):使用软件仿真了FPA协处理器的执行。
· 浮点运算库(FPLib):使用ARM的浮点运算库函数实现程序中的浮点运算操作。这就意味着C编译器要把每一个浮点操作转换成一个子程序调用。C库中的子函数使用整型运算来模拟浮点操作。这些代码是用高效的汇编语言编写而成的。尽管如此,浮点运算执行起来还是要比相应整型运算慢得多。
注意Thumb指令不支持协处理器指令,所以在Thumb状态下实现浮点运算,只能调用ARM浮点运算库。
为了在ARM上高效地实现浮点运算,请遵循以下规则。
· 避免使用浮点除法运算。通常情况下,除法运算的执行速度是普通加法或乘法运算速度的1/2。在无法避免除法的情况下,尽量使除法的除数为常数。如,x=x/3.0,可将其变为x = x * (1.0/3.0)。这样除数为常数(1.0/3.0),该值在编译阶段由编译器计算。
· 使用float型代替double型。float型要比double使用更少的内存和寄存器。
· 避免使用三角函数功能。实现三角函数功能,如sin、cos,使用了大量的乘加运算,它的运算速度大约是普通乘法运算的十倍。
· 当编译器处理浮点运算操作时,由于精度的影响很多优化不能实现。比如,表达式3 * (x / 3),编译器不能判断其值和x是等价的。所以在使用浮点运算表达式时,最好先人工的做一些必要的优化。
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- LabViEW编程之VI服务器综述 25次下载
- Windows编程之数值运算综述 5次下载
- 浮点DSP运算效率不高 10次下载
- DSP教程之DSP数值运算基础总结的详细资料说明 9次下载
- C语言教程之数据类型与运算符的详细资料说明 8次下载
- MATLAB教程之数组和矩阵的介绍及运算说明 0次下载
- 浮点运算单元的FPGA实现 8次下载
- 多核浮点非线性运算协处理器设计 0次下载
- 定点DSP C55X实现浮点相关运算解析 2次下载
- 高效的C编程之除法运算 5次下载
- C语言教程之平方和运算的问题 0次下载
- 浮点 DSP 运算效率不高 0次下载
- 定点dsp浮点运算教程
- DSP的浮点运算方法
- 浮点运算方法
- 技术干货驿站 ▏解锁C语言高效编程秘诀:深入解析运算符与优先级 1.1k次阅读
- 技术干货驿站 ▏深入理解C语言:编程高手必备,全方位解析运算符的核心技能! 1.5k次阅读
- 优秀的Verilog/FPGA开源项目-浮点运算器(FPU)介绍 6.6k次阅读
- C语言的运算符 2.1k次阅读
- FPGA浮点数转化为定点数方法 6.2k次阅读
- 如何在FPGA中正确处理浮点数运算 5.9k次阅读
- 三菱PLC浮点数运算指令 2.1w次阅读
- Altera FPGA硬核浮点DSP模块解决方案提高运算性能 4.1k次阅读
- 基于TI TMS320C6748定点/浮点DSP C674x处理器 3.8k次阅读
- 单片机浮点数的运算原理及表达方式 1.4w次阅读
- 利用FPGA技术能更方便灵活设计出浮点运算器 3.9k次阅读
- FOC之定点小数运算 7.4k次阅读
- 基于FPGA的嵌入式处理器的浮点系统 2.1k次阅读
- 快速高效的实现浮点复数矩阵分解 1.3k次阅读
- pic单片机io口控制教程之c语言编程实现 1.2w次阅读
下载排行
本周
- 1MDD品牌三极管BC807数据手册
- 3.00 MB | 次下载 | 免费
- 2MDD品牌三极管BC817数据手册
- 2.51 MB | 次下载 | 免费
- 3MDD品牌三极管D882数据手册
- 3.49 MB | 次下载 | 免费
- 4MDD品牌三极管MMBT2222A数据手册
- 3.26 MB | 次下载 | 免费
- 5MDD品牌三极管MMBTA56数据手册
- 3.09 MB | 次下载 | 免费
- 6MDD品牌三极管MMBTA92数据手册
- 2.32 MB | 次下载 | 免费
- 7STM32G474 HRTIME PWM 丢波问题分析与解决
- 1.00 MB | 次下载 | 3 积分
- 8新能源电动汽车高压线束的铜铝连接解决方案
- 2.71 MB | 次下载 | 2 积分
本月
- 1爱华AIWA HS-J202维修手册
- 3.34 MB | 37次下载 | 免费
- 2PC5502负载均流控制电路数据手册
- 1.63 MB | 23次下载 | 免费
- 3NB-IoT芯片厂商的资料说明
- 0.31 MB | 22次下载 | 1 积分
- 4H110主板CPU PWM芯片ISL95858HRZ-T核心供电电路图资料
- 0.63 MB | 6次下载 | 1 积分
- 5UWB653Pro USB口测距通信定位模块规格书
- 838.47 KB | 5次下载 | 免费
- 6技嘉H110主板IT8628E_BX IO电路图资料
- 2.61 MB | 4次下载 | 1 积分
- 7苏泊尔DCL6907(即CHK-S007)单芯片电磁炉原理图资料
- 0.04 MB | 4次下载 | 1 积分
- 8苏泊尔DCL6909(即CHK-S009)单芯片电磁炉原理图资料
- 0.08 MB | 2次下载 | 1 积分
总榜
- 1matlab软件下载入口
- 未知 | 935137次下载 | 10 积分
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420064次下载 | 10 积分
- 3Altium DXP2002下载入口
- 未知 | 233089次下载 | 10 积分
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191439次下载 | 10 积分
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183353次下载 | 10 积分
- 6labview8.5下载
- 未知 | 81602次下载 | 10 积分
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73822次下载 | 10 积分
- 8LabVIEW 8.6下载
- 未知 | 65991次下载 | 10 积分
电子发烧友App





创作
发文章
发帖
提问
发资料
发视频
上传资料赚积分
评论