查看单个帖子
旧 2019-12-14, 20:13   #1
poster
高级会员
 
注册日期: 2019-11-21
帖子: 3,006
声望力: 66
poster 正向着好的方向发展
帖子 MATLAB中的几个时间计数器

我有一个程序正在运行一个循环,我想有两个时间计数器,一个用于循环,它将告诉我循环的一次迭代的日志是如何记录的,以及整个程序的一次。据我所知, tic和toc仅能运行一次。



回答:

您只熟悉以下tic toc语法:

tic; someCode; elapsed = toc; 但是还有另一种语法:

start = tic; someCode; elapsed = toc(start); 第二种语法可以进行相同的时间测量,但是允许您选择同时运行多个秒表计时器。您将tic的输出分配给变量tStart,然后在调用toc时使用相同的变量。 MATLAB测量tic及其相关toc命令之间经过的时间,并以秒为单位显示经过的时间。使用此语法,您可以计时多个并发操作的时间,包括嵌套操作的时间( tic toc的matlab文档 )。

这是在您的情况下使用它的方法。假设这是您的代码:

for i = 1:M someCode; end 像这样插入tic和toc:

startLoop = tic; for i = 1:N startIteration = tic; someCode; endIteration = toc(startIteration); end endLoop = toc(startLoop); 您还可以使用上述语法创建一个向量,其第ith个元素是第i个迭代的时间度量。像这样:

startLoop = tic; for i = 1:N startIteration(i) = tic; someCode; endIteration(i) = toc(startIteration(i)); end endLoop = toc(startLoop);

更多&回答...
poster 当前离线   回复时引用此帖