matlab 图片最多显示几张_Matlab系列之运行程序的分析

2e14b09b58a7599aecaad5460a17eb9b.gif

不知道大家对System Generator系列中的资源分析以及时序分析的功能是否还有印象,这两个分析功能会将各模块所消耗的资源以及耗时都展现出来,用于资源或时序的优化,本篇将要记录的内容也与之有点相似,使用特定的功能或者语句对程序进行分析,然后得到各函数的耗时以及被调用次数等信息,最后再根据这些信息对程序进行优化,接下来就使用MATLAB提供的这两种方法来进行程序分析,下一篇再对程序优化和程序调试做介绍。

~Show Time~

05ae242903b7554ff8025591f8df8354.gif

01

第一种方法

使用一个工具——Profiler,这个工具是MATLAB中的一个图形用户接口,可以用于分析程序运行时各个部分所消耗的时间,可以从以下几个方面提供程序运行信息:

1)避免由于疏忽造成的非必要操作。

2)替换运行较慢的算法,选择快速算法。

3)通过存储变量的方式避免重复计算。

接下来说下使用Profiler进行程序运行分析的步骤:

1)查看Profiler生成的通体报告,查找运行时间最多的函数或调用最频繁的函数。

2)查看这些函数的详细报告,查找其中运行时间最多的语句或调用最频繁的语句。

3)确定运行时间最多的函数或代码是否存在改进的可能。

4)单击界面链接,打开相应文件进行修改。

5)重复进行上述的分析、修改,直至优化出满意的结果。

Profiler的使用介绍

1)打开方式

第一个打开的地方在主页->代码->运行并计时。

4d5dfdd87a3f8d80d9d4f54e961a77a6.png

第二个打开的地方在编辑器->运行->运行并计时,要看到这个功能的前提就是需要打开一个M文件。

3746d19916f11053c76ef6bd28a45a8d.png

第三个打开方式就是直接在命令行窗口输入:profile viewer

以上的三种打开方式都可以打开一个探查器的窗口,也就是Profiler的界面,在“运行此代码”中输入需要分析的命令或表达式,然后点“启动探查”,就会开始对其进行分析。

f283ad1daaa2d2926cba916a5cb655bf.png

使用一串代码进行探查测试:

[t,y] = ode23('lotka',[0 2],[20;20])

点击开始探查后,会出现如下结果,红色框中的就是所探查的程序运行的信息名称:

67a07c9aa8b7d09bf5fcc274fea11af3.png

单击图中的蓝色字体,点的是红色框所选择的名称则会进行排序,点的是函数名称一栏中的函数,则会进入其内部观察更加详细的分析报告,这份报告中含有该函数中的每行代码的被调用次数和运行时间,以及子函数、函数列表等等,可以简单看下图的内容,此外,如果点击图中红色框里的蓝色字体,则会将此时的结果保存至新的窗口(该窗口会自动弹出),可以用于程序优化后与之对比,然后分析得到较优的结果。

6be829a0f19f1aba1af3c2e49d84f896.png

73487bf978e4e5aff41654bf94837ebe.gif注意:如果你一直点开始探查,在命令行窗口也有运行代码,但是就是没探查摘要出来,别慌,跟着下面的几张图改一下字体的预设即可解决。

8e305350e35da312452b300605dce726.png 

ad76330211c5f42101f7ddf90057d43b.png

05ae242903b7554ff8025591f8df8354.gif

02

第二种方法

这个方法可以说是更加简单易懂,直接在需要计时的部分前后放置计时函数的开始和结束即可,即:计时器的开始—tic,计时器的结束—toc。

因此使用的语法就是这样子的了:

tic

      %需计时的程序代码

toc

t=toc%将记得的时间进行保存

注:如果计时的程序过于简单,计时误差会相对比较大,大家可以自己使用该种方法,然后对比结果分析下。

c93ecd070cdfc9ed126ea98b6494b95f.gif

阅读本文共使用 129923b0971fb60fcaf2e7c87cf80d60.gif a323aa092b8817a0a45811eb525eb137.gif c0a6f39ef304c3758b64891fb4fb2312.gif bd797eecf732531be0ec0d73694bc96e.gif

b49d8f556b81c49476af1050bf67aaaa.gif

884ce8cae31bda3cf45d0d13266af7ff.gif

db0cc2b4905238920cea19c94ad0d7ae.png

b49d8f556b81c49476af1050bf67aaaa.gif

f03a6c267f50f83280b91b403d48b58d.gif

电子知识

一些电路设计与DIY作品

电子设计技巧与经验

FPGA

System Generator系列教程

算法介绍

通信协议分析

资料分享

Matlab系列记录

建设中~

b8dce0d4226b668593edaeb3a1b3101b.gif

点个赞

1a4840f535b01b7d75418c7ad5b4f7ea.gif

再走吧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值