Matlab从安装到入门再到初级


下面是已安装好的Matlab界面,各模块窗口可以在布局中勾选:

写程序点新建脚本创建:

比如说写一个a=1

点保存命名文件时,如果是名称是英文,那么可以直接点上方绿色运行按钮运行,但不支持中文名称

但是可以选中程序右键点执行所选内容

运行后,右边工作区会保存结果至名称为a的矩阵中,双击可以打开矩阵

下面命令窗口也会打印出执行的命令和结果

如果是循环程序,每次打印出结果肯定会延长运行时间,因此可以在命令行后加上分号,这样就不会打印出结果了,如果想看结果,运行结束后可以在工作区找到相应矩阵查看。

如果是要批量清楚工作区变量矩阵,可以在命令窗口输入clear

右下方命令历史记录窗口会记录下当前运行的代码,但还是建议及时保存文件

下面这个按钮可以切换文件夹

当前文件夹又称运行目录,目录下的自定义函数优先被调用,如果是调用不在运行目录下的自定函数,会报错提示未找到该函数,网上别人写的程序直接拿来用会经常遇见这种问题。

除了自定义函数,如果是要导入函数工具箱,可以先将压缩包解压,再点击主页设置路径,点添加并包含子文件夹,Matlab自带的都是基本的运算函数,比如在运行优化算法时,缺少相应函数,可以通过这个方法导入。

Matlab脚本文件,可以简单分为两种,一个是可以直接运行的(下图第二个),一个是不可直接运行,只能用于调用的(下图第一个)

第二个文件就是上面介绍过的a=1,然后也可以多写点代码

第一个文件则使用function文件建立

自定义函数名称为fun,其中的fun也是脚本文件名称,两者名称必须一致,c是输入,b是输出,该函数实现的是将c值赋给b,例如:

矩阵的行数和列数可以通过size函数返回,用法[n,m]=size(x),length这个函数则是返回矩阵行数和列数其中最大的一个,用法n=length(x)

矩阵的转置,用单引号

有些时候也会改变矩阵的维度

函数创建与调用


在Matlab中使用function函数构建自定义函数时,需要保存为m文件进行调用:

   

写好函数后点击保存

在主程序中,可以直接调用当前运行目录中的自定义函数:

在命令窗口处可以看见输出结果

matlab中创建矩阵比较简单,可以直接x=[0:0.2:2]生成0到2间隔为0.2的数列

disp是常用的打印函数,等同于python中的print

matlab中自带了很多数学函数,使用起来比较方便,代码简单,并且右方的工作区间可以双击查看运算过程数据。

循环语句


在进行列表或矩阵计算时,常常会用到循环语句将项目调用出来进行计算,然后在储存于列表或矩阵中或者打印,一般循环会用到while和for,当使用while时,需要通过计数来协助完成循环,for循环则相对来说简单一点,但如果是要知道满足某个条件时才终止循环这种情况,while更为实用。

4.1 while循环

例如将列表words中每个项目加上"!"打印出来:

words = [“hello”, “world”, “spam”, “eggs”];

counter = 1;

max_index = length(words);

while counter <= max_index

word=words(counter);

disp(word + “!”)

counter = counter + 1;

end

%结果:

hello!

world!

spam!

eggs!

4.2 for循环

将上述while循环语句更改为for循环语句:

words = [“hello”, “world”, “spam”, “eggs”];

for i=1:length(words)

word=words(i);

disp(word + “!”)

end

4.3 拓展

sum从0,1,…,n累加,直到sum>20时终止循环并打印sum

sum=0;

n=0;

while sum<=20

sum = sum+n;

n = n+1;

end

disp(sum)

sum = 0;

n = 0;

for i=1:10

sum = sum+n;

n=n+1;

if sum>20

break;

end

end

disp(sum)

%结果:

21

parfor循环并行计算


5.1 简介

parfor循环是Matlab并行计算工具箱(Parallel Computing Toolboxl)用于并行计算单循环的工具,并行度与CPU核心数有关

软件界面左下角start开启,启动约十几秒

出现这个图标就表示已经开启并行池

开启前可以先对Parallel Preference预设pool数量,电脑多少核心这里就填多少,填多了也没用,下面是并行工具运行时间,默认30分钟

可以多设置一些时长,不需要并行计算时可以点击关闭

5.2 何时使用parfor

1、如果您有一个慢for循环,parfor循环可能很有用。如果您有以下情况,请考虑parfor:

  • 一些循环需要很长时间。在这种情况下,worker可以同时执行循环内的计算。确保循环次数超过工作进程数,否则,不会调用所有的核进行运算。
  • 简单计算的许多循环,如蒙特卡罗模拟或参数扫描。parfor将循环划分为多个组,以便每个worker执行循环总次数的一部分。

2、如果您有以下情况,parfor循环可能没有用处:

  • 运行矢量化的代码,例如x=0     for i=100     x=x+1     end,执行并行计算时,work1负责第1、5、11次循环,work2执行2、6、12次循环,由于各works同时开始工作,work2开始计算时,第1次迭代也就是work1还未执行完第一个计算,work同样的基于x=0开始进行x=x+1,因此将导致结果x(1)=x(2)。
  • 执行所需时间较短的循环,由于需要时间将计算同步给其他workers,因此采用并行计算反而程序运行时间更多。

3、当循环中的迭代依赖于其他迭代的结果时,不能使用parfor循环。每个迭代必须独立于所有其他迭代。

举几个案例解释上述条件:

(1)普通单核计算

ticn = 20;

A = 500;

a = zeros(n);

for i = 1:n

a(i) = max(abs(eig(rand(A))));

endtoc

历时18. 765742秒.

(2)并行四核计算

ticn = 200;

A = 500;

a = zeros(n);

for i = 1:n

a(i) = max(abs(eig(rand(A))));

endtoc

历时6. 358251秒

那么针对于仿真模拟或者是优化算法中的循环该怎么用,上文也说到了不能对循环中有矢量计算的采用并行方式

(1)单核计算

ticn = 20;

A = 500;

a = zeros(n);

for i = 1:n

b=0;

for j = 1:n

b=b+1;

a(i,j) = max(abs(eig(rand(A))))+1;

end

end

toc

历时39. 582394秒

(2)并行四核计算

可见内循环有一个矢量代码b=b+1,但对于外循环是不受影响的,因此可以将外循环改为parfor,反之如果外循环有矢量代码,内循环没有,就把内循环改为parfor,但不能在parfor循环内使用parfor循环。

ticn = 20;

A = 500;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注:Python)

发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**

[外链图片转存中…(img-zDZWbiFO-1713597599772)]

[外链图片转存中…(img-FyzklNxk-1713597599773)]

[外链图片转存中…(img-sTDJAjOw-1713597599774)]

[外链图片转存中…(img-2hlZMgCM-1713597599775)]

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注:Python)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值