Labfans是一个针对大学生、工程师和科研工作者的技术社区。 | 论坛首页 | 联系我们(Contact Us) |
![]() |
|
![]() |
#1 |
高级会员
注册日期: 2019-11-21
帖子: 3,006
声望力: 66 ![]() |
![]()
我有一个程序正在运行一个循环,我想有两个时间计数器,一个用于循环,它将告诉我循环的一次迭代的日志是如何记录的,以及整个程序的一次。据我所知, 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); 更多&回答... |
![]() |
![]() |