单片机/MCU论坛
登录
直播中
陈飞
7年用户
1173经验值
私信
关注
[问答]
如何使用STM模块测量函数的执行时间?
开启该帖子的消息推送
STM
我想问你如何使用 STM 模块测量函数的执行时间。
是否有可能通过BSP.H库的now () 函数为两个类型为ifx_
ti
ckTimer的变量(分别为起始变量和停止变量分配分笔数)来通过BSP默认计时器对其进行测量?
另外,要在执行期间获取这些值,是必须通过调试还是可以通过 printf 打印出来? 我试过 printf 但无法打印出值(我已经包含了 stdio.h 图书馆)
回帖
(1)
李燕
2024-1-22 17:13:44
您可以使用STM模块来测量函数的执行时间。使用BSP.H库的now()函数为起始和停止变量分配时间戳,并计算它们之间的差值,即函数的执行时间。
以下是一个使用STM模块测量函数执行时间的示例代码:
```C
#include
#include
int main() {
ifx_tickTimer start, stop;
// 获取起始时间戳
start = now();
// 执行需要测量的函数
// ...
// 获取停止时间戳
stop = now();
// 计算执行时间
float executionTime = (stop - start) / HAL_GetTickFreq();
// 打印执行时间
printf("执行时间: %.3f 秒n", executionTime);
return 0;
}
```
在上面的代码中,我们使用了`ifx_tickTimer`类型的变量`start`和`stop`来保存起始和停止时间戳。然后,通过计算两者之间的差值并除以时钟频率,我们可以得到函数的执行时间。最后,我们使用`printf`函数打印出执行时间。
请确保通过BSP.H库的功能启用了STM模块,并在硬件上启用了STM计时器。另外,您还需要确保在调试模式下运行代码,因为在非调试模式下,printf函数可能无法正常工作。
您可以使用STM模块来测量函数的执行时间。使用BSP.H库的now()函数为起始和停止变量分配时间戳,并计算它们之间的差值,即函数的执行时间。
以下是一个使用STM模块测量函数执行时间的示例代码:
```C
#include
#include
int main() {
ifx_tickTimer start, stop;
// 获取起始时间戳
start = now();
// 执行需要测量的函数
// ...
// 获取停止时间戳
stop = now();
// 计算执行时间
float executionTime = (stop - start) / HAL_GetTickFreq();
// 打印执行时间
printf("执行时间: %.3f 秒n", executionTime);
return 0;
}
```
在上面的代码中,我们使用了`ifx_tickTimer`类型的变量`start`和`stop`来保存起始和停止时间戳。然后,通过计算两者之间的差值并除以时钟频率,我们可以得到函数的执行时间。最后,我们使用`printf`函数打印出执行时间。
请确保通过BSP.H库的功能启用了STM模块,并在硬件上启用了STM计时器。另外,您还需要确保在调试模式下运行代码,因为在非调试模式下,printf函数可能无法正常工作。
举报
更多回帖
rotate(-90deg);
回复
相关问答
STM
如何在microblaze上
测量
C代码的
执行时间
?
2019-10-30
3840
RTThread Studio该如何查看代码
执行时间
2022-09-20
813
请问如何确定单片机中断
函数
的
执行时间
?
2023-10-07
333
如何测试CC2640某一段代码的
执行时间
?
2016-04-06
2814
如何在Keil中观察程序的
执行时间
?
2023-10-15
308
嵌套循环
执行时间
计算
2015-12-30
3432
请问C2000中寻址结构体或者共同体需要的
执行时间
长吗?
2018-06-14
2033
在顶点5上
测量
的
执行时间
是多少?
2020-06-12
1047
请问eval_perf是怎么把每个layer的
执行时间
打印出来的
2022-05-31
1588
请问spartan3e的
执行时间
是什么
2019-01-25
2077
发帖
登录/注册
20万+
工程师都在用,
免费
PCB检查工具
无需安装、支持浏览器和手机在线查看、实时共享
查看
点击登录
登录更多精彩功能!
首页
论坛版块
小组
免费开发板试用
ebook
直播
搜索
登录
×
20
完善资料,
赚取积分