0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于TMS320F2807x的IQmath的移植方法

电子设计 来源:网友电子设计发布 作者:网友电子设计发布 2021-12-28 17:43 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

由于TMS320F28x7x系列芯片内部集成了TMU(Trigonometric Math Unit)专门用于加速常用的三角函数和算术运算的执行,可以5个cycles以内得到正弦/余弦/正切等运算结果,因此TMS320F28x7x系列芯片的ROM中不再固化IQmathTables和相关三角函数。同时,在新的设计中我们更推荐用户使用TMU去处理三角函数运算。

为了兼容基于IQmath的程序的移植,本文给出了基于TMS320F2807x的IQmath的移植方法。

一.测试相关环境

测试相关的软硬件环境如下表所列:

CCS Version

7.2.0.00013

Compiler Version

TI v16.9.3.LTS

IQmath Version

V1.6.0

测试芯片型号

TMS320F28075

您可以选择任意示例工程,这里选择的工程为 adc_soc_epwm_cpu01,它的工程文件的目录为:

C:\ti\controlSUITE\device_support\F2807x\v210\F2807x_examples_Cpu1\adc_soc_epwm\cpu01

在CCS中import该工程后,右击工程,选择Properties,并打开Build Configuration下的Set Active,选择CPU1_FLASH,使程序在flash下运行。

二. 工程修改步骤

1.在新的工程中添加IQmath库文件,由于TMS320F2807x为浮点运算的芯片,所以选择IQmath_fpu32.lib这个库。

2.在新的工程中添加IQmath函数库的头文件IQmathLib.h,并在原有工程中添加以下语句:

#include "IQmathLib.h";

以上两均添加好的工程的文件列表如下:

3.由于IQmathTables不再固化在芯片的ROM中,需要将这一部分的程序拷贝到FLASH中,则要修改CMD文件,增加了IQmath和IQmathTables的内存分配。这个CMD文件在TI官方的软件包controlSUITE中已经提供,地址如下:

C:\ti\controlSUITE\device_support\F2807x\v210\F2807x_common\cmd

选择2807x_FLASH_IQMATH_lnk_cpu1.cmd,

在FLASHB和FLASHC中专门给IQmath和IQmathTables分配了空间:

4.为了保持一个工程中仅有一个CMD文件,将工程中自带的Flash_lnk.cmd删除。

右键工程文件,选择properties,在CCS Build下选择C2000 Linker,删除2807x_Generic_FLASH_lnk.cmd文件。

当然,您也可以选择修改原有的CMD文件,只要在FLASH中给IQmath和IQmathTables分配足够的空间即可。

5.移植完成以后,在程序中添加IQmath函数的测试代码。

首先在main函数前增加IQ格式的变量定义:

_iq IQresult =_IQ(1.0);

_iq IQsource;

在main函数调用IQmath库中的任意函数,这里我调用了IQsin()函数进行测试:

IQresult =_IQsin(IQsource);

通过实际debug,计算结果与预期相符。

三. TMS320F2807x Piccolo系列芯片在运算能力上的提升

1. 浮点运算单元FPU

FPU全称Float Point Unit,即浮点运算单元,是专用于浮点运算的处理器。在大多数现在的通用计算机架构中,会在CPU中集成一个或多个浮点运算器,但许多嵌入式处理器没有在硬件上支持浮点数运算。

TMS320F2807x Piccolo系列芯片使用C28x+FPU的架构,在原有的C28x定点CPU的基础上加入了一些寄存器和指令,来支持IEEE 单精度浮点数的运算。对于在定点微处理器上编写的程序,浮点C2000也完全兼容,不需要对程序做出改动。

下表给出了与定点处理器相比,浮点处理器在计算能力上的提升:

可见,与定点处理器相比,浮点处理器不但在程序编写上更加简洁,性能上也有了很大的提升,在进行除法,开方,FFT和IIR滤波等算法等指令中效率更高。

2. 三角函数运算单元TMU

与此同时,该系列芯片内部还集成了浮点三角函数运算单元TMU,它增强了C28-FPU的指令集。通过提供以单周期高效方式执行某些三角函数和算术函数的指令,减少了常见复杂函数运算的处理延迟,进一步提高了实时控制算法的性能。

带有TMU单元和没有TMU单元的CPU在一些常见函数的执行周期的对比情况如下表:

TMU可以对许多常用的实时控制算法有极大的优化,常见的有以下几种:

1.Park和Inverse Park变换;

2.空间矢量控制;

3.dq0和Inverse dq0变换;

4.FFT幅度和相位计算。

以Park变换为例,使用FPU来执行,通常需要80到100多个周期来,而集成了TMU单元的CPU仅需13个指令周期即可完成,与没有TMU相比,性能提高了85%。

因此,针对复杂且对实时控制要求高的控制算法中,相信集成了FPU和TMU的TMS320F2807x Piccolo系列芯片是您非常合适的选择。

审核编辑:何安

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式处理
    +关注

    关注

    0

    文章

    341

    浏览量

    10449
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    TMS320F28003x系列微控制器技术文档总结

    TMS320F28003xF28003x) 是 C2000™ 实时微控制器系列的成员,该系列是可扩展、超低延迟的器件,专为提高电力电子效率而设计,包括但不限于:高功率密度、高开关频率,并支持使用 GaN 和 SiC 技术。
    的头像 发表于 10-10 11:29 1050次阅读
    <b class='flag-5'>TMS320F28003x</b>系列微控制器技术文档总结

    TMS320F28003x系列微控制器数据手册的全文总结

    TMS320F28003xF28003x) 是 C2000™ 实时微控制器系列的成员,该系列是可扩展、超低延迟的器件,专为提高电力电子效率而设计,包括但不限于:高功率密度、高开关频率,并支持使用 GaN 和 SiC 技术。
    的头像 发表于 10-10 11:08 991次阅读
    <b class='flag-5'>TMS320F28003x</b>系列微控制器数据手册的全文总结

    TMS320F280034总结

    TMS320F28003xF28003x) 是 C2000™ 实时微控制器系列的成员,该系列是可扩展、超低延迟的器件,专为提高电力电子效率而设计,包括但不限于:高功率密度、高开关频率,并支持使用 GaN 和 SiC 技术。
    的头像 发表于 10-10 10:36 834次阅读
    <b class='flag-5'>TMS320F</b>280034总结

    TMS320F2800137微控制器文档全文总结

    TMS320F280013xF280013x) 是 C2000™ 实时微控制器系列的成员,该系列是可扩展、超低延迟器件,专为提高电力电子效率而设计。
    的头像 发表于 10-08 10:33 1010次阅读
    <b class='flag-5'>TMS320F</b>2800137微控制器文档全文总结

    TMS320F2800135微控制器技术文档总结

    TMS320F280013xF280013x) 是 C2000™ 实时微控制器系列的成员,该系列是可扩展、超低延迟器件,专为提高电力电子效率而设计。
    的头像 发表于 09-30 16:23 1895次阅读
    <b class='flag-5'>TMS320F</b>2800135微控制器技术文档总结

    TMS320F2800132微控制器技术文档总结

    TMS320F280013xF280013x) 是 C2000™ 实时微控制器系列的成员,该系列是可扩展、超低延迟器件,专为提高电力电子效率而设计。
    的头像 发表于 09-30 15:46 1250次阅读
    <b class='flag-5'>TMS320F</b>2800132微控制器技术文档总结

    TMS320F2800157-Q1微控制器数据手册的总结

    TMS320F280015xF280015x) 是成本优化的 C2000 实时微控制器系列的成员,该系列是可扩展的超低延迟器件,专为提高电力电子效率而设计。
    的头像 发表于 09-30 11:22 1130次阅读
    <b class='flag-5'>TMS320F</b>2800157-Q1微控制器数据手册的总结

    TMS320F2800157微控制器技术文档总结

    TMS320F280015xF280015x) 是成本优化的 C2000 实时微控制器系列的成员,该系列是可扩展的超低延迟器件,专为提高电力电子效率而设计。
    的头像 发表于 09-30 10:25 964次阅读
    <b class='flag-5'>TMS320F</b>2800157微控制器技术文档总结

    TMS320F28P55x系列微控制器技术文档总结

    TMS320F28P55xF28P55x) 是 C2000™ 实时微控制器系列的成员,该系列可扩展、超低延迟器件专为提高电力电子效率而设计,包括但不限于:高功率密度、高开关频率,并支持使用 GaN 和 SiC 技术。
    的头像 发表于 09-29 09:42 657次阅读
    ‌<b class='flag-5'>TMS320F28P55x</b>系列微控制器技术文档总结

    Texas Instruments TMS320F28P65x/TMS320F28P65x-Q1实时MCU数据手册

    Texas Instruments TMS320F28P65x/TMS320F28P65x-Q1实时微控制器(MCU)属于C2000™ 实时微控制器系列,是可扩展、超低延迟器件。C2000 MCU
    的头像 发表于 08-01 11:05 1236次阅读
    Texas Instruments <b class='flag-5'>TMS320F28P65x</b>/<b class='flag-5'>TMS320F28P65x</b>-Q1实时MCU数据手册

    Texas Instruments TMS320F28P55x/TMS320F28P55x-Q1实时MCU数据手册

    Texas Instruments TMS320F28P55x/TMS320F28P55x-Q1实时微控制器 (MCU) 属于C2000™ 实时MCU系列可扩展、超低延迟器件的一部分,设计用于提高
    的头像 发表于 07-18 13:40 726次阅读
    Texas Instruments <b class='flag-5'>TMS320F28P55x</b>/<b class='flag-5'>TMS320F28P55x</b>-Q1实时MCU数据手册

    TMS320F/C24x DSP控制器CPU和指令集参考指南

    电子发烧友网站提供《TMS320F/C24x DSP控制器CPU和指令集参考指南.pdf》资料免费下载
    发表于 12-30 16:47 2次下载
    <b class='flag-5'>TMS320F</b>/C24<b class='flag-5'>x</b> DSP控制器CPU和指令集参考指南

    TMS320C6472/TMS320TCI648X DSP通用输入/输出(GPIO)用户指南

    电子发烧友网站提供《TMS320C6472/TMS320TCI648X DSP通用输入/输出(GPIO)用户指南.pdf》资料免费下载
    发表于 12-17 16:13 0次下载
    <b class='flag-5'>TMS320</b>C6472/<b class='flag-5'>TMS320TCI648X</b> DSP通用输入/输出(GPIO)用户指南

    TMS320F280013x/15x闪存API版本 2.00.10.00

    电子发烧友网站提供《TMS320F280013x/15x闪存API版本 2.00.10.00.pdf》资料免费下载
    发表于 12-05 14:20 1次下载
    <b class='flag-5'>TMS320F280013x</b>/15<b class='flag-5'>x</b>闪存API版本 2.00.10.00

    AMC1306和tms320f28035之间如何连接?tms320f28035如何提取位流?

    您好, AMC1306M25资料上推荐使用TMS320F2807xTMS320F2837x 微控制器系列中的SDFM接口,并且使用TMS320F2807xTMS320F2837x
    发表于 12-05 06:15