共1条
1/1 1 跳转至页
关于程序的优化,或提高运算速度的建议

我的算法刚开始也运行的比较慢,后来我做了如下的工作以后,速度就不是什么问
题了,仅供大家参考,呵呵。
1。对程序本身的优化,主要是从本身的结构上重新进行了改进,比如,变量不再
轻易的声明成double了,函数尽量少用,语句要精练。循环尤其要注意,一定要精确到
对循环次数的控制。
2。优化级数的处理,现在是 -o3。这样对c语言的程序优化效果很好,不过要注意
对一些变量的处理,如果是一些不愿意让它优化的变量,一定要用volatile定义。
3。cmd文件的编制,主要是对coff文件中各个section的定位。如果把cpu经常访问
的section如果定义到了片外,速度就是会很慢的。这步是比较重要的,如果对section
有什么疑问,可以多看看 Assembly language tools user's guide,里面关于coff文件
和各种cmd文件的编写说的很明白。
对于一些必须放到片外的段,可以进行如下的处理:
如果是.far文件必须放到EMIF空间,不要一下子就都放进去,建议把这个段再细分,
建立子段,把访问少的数据放到一个子段中,然后放到片外,把访问多的数据放到片内
的一个子段中。
了算法本身以外,还有这么几点
1.尽量利用DSP的并行处理资源,比如SIMD指令,双套寄存器,多条总线等等
2.利用流水,特别是循环里的语句
3.打开循环,其实也是在循环里应用第一,二条的具体操作,当然不是全部打
开,而是提取前缀后缀出来,错开循环体内的语句,使其能够应用上1,2条所
述的内容
我的一点粗浅理解,欢迎大牛指正
关键词: 关于 程序 优化 提高 运算 速度 建议
共1条
1/1 1 跳转至页
回复
打赏帖 | |
---|---|
C语言函数宏的三种封装方式被打赏50分 | |
【STM32F769】记一次由于开启D-Cache之后DMA数据传输出错的问题查找与解决被打赏35分 | |
嵌入式LinuxC语言程序调试和宏使用技巧被打赏50分 | |
让代码中包含最新的编译时间信息被打赏50分 | |
【分享开发笔记,赚取电动螺丝刀】STM32F769LVGL优化显示被打赏26分 | |
rtthread硬件加密--2crc加密分析被打赏10分 | |
【分享开发笔记,赚取电动螺丝刀】STM32F769驱动ST7789以及显示优化被打赏36分 | |
【分享开发笔记,赚取电动螺丝刀】S32K146 PAL模拟I2C驱动适配被打赏23分 | |
我想要一部加热台+电源硬件设计规范被打赏16分 | |
我想要一部加热台+LED背光驱动芯片RT9293知识被打赏18分 |