百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

32个实用matlab编程技巧

liuian 2024-12-12 13:25 43 浏览


今天给大家介绍一些matlab编程小技巧,希望对大家学习matlab有所帮助。

1、能用矩阵计算的就用矩阵计算,不能用矩阵计算的想方设法也要往矩阵计算上靠。

2、少用循环,尤其是避免多重循环嵌套,尽量用向量化的运算来代替循环操作。在必须使用多重循环的情况下,若各层循环执行的次数不同,则在循环的外层执行循环次数少的,内层执行循环次数多的。

3、在定义数组变量时先预定义数组的大小能大大提高计算效率。

4、对于多核CPU,使用parfor比用for更节约时间。

5、定义循环变量时,尽量不要使用i和j,因为i和j是matlab预留的虚数单位。

6、在m文件前面使用clear,close,clc等命令可以释放内存、清理窗口。

7、对于三角函数计算,在系统默认函数前后面加"d"是直接进行角度计算,这里"d"代表"degree",例如sind(30) = 0.5,效果与sin(30*pi/180)一样,其他的有cosd、tand等。

8、在程序运行结束后,使用clearvars可以清掉不需要的变量而保留结果变量,例如,clearvars -except varA varB,意思是清除变量空间中除了变量varA,varB以外的所有变量。

9、使用Ctrl+C可以终止正在运行的程序。

10、doc + 函数名,直接打开相应函数的matlab帮助文档。help + 函数名,在命令窗口中显示相应函数的帮助信息。

11、在M脚本编辑器或在命令窗口中按"Tab"键可以补全函数名或变量名。

12、选中代码按"Ctrl + R"键是一键注释代码,选中代码按"Ctrl + T"键是一键取消注释。

13、选中代码按"Ctrl + I"键是一键智能对齐代码。

14、在进行绘图操作时,多使用figure命令,其作用是新建一个空的绘图窗口,接下的绘图命令可以将图绘制在它里面,而不会覆盖其他绘图窗口。

15、在命令窗口输入edit或open+函数名可以快速打开m文件。

16、元胞数组可以存储不同类型和大小的数据。

17、使用单精度 single替代双精度 double可以节约内存开销。

18、matlab 输入? (埃,Angstrom),示例: xlabel(' length(\AA)','interpreter','latex').

19、在matlab中显示上下标,上标用'^',下标用'_'.

20、在matlab中输入希腊字母及特殊字符,采用'\+字母或字符读音',如: α \alpha.

21、成对符如括号、引号等的自动补全,matlab脚本编辑器本身不带成对符自动补全的自动补全功能,不过可以通过输入法设置就可以实现自动补全功能。如手心输入法,打开“设置”,在“按键”下找到“智能符号设置”,勾选自动补全成对符,在编辑脚本打开此输入法即可。

22、通过mat2cell命令可以方便快捷地将大矩阵划分成一个个矩阵,通过使用cellfun命令可以快速对各个小矩阵进行各种处理。

23、对于安装了支持GPU计算的计算机,可以通过gpuArray来快速使用GPU进行计算。当然对于数据量较小时,gpuArray的效率也不是太高,gpuArray.函数名可以调用一些内置的函数进行GPU计算,如果gpuArray.zeros(100,100)可以在GPU中生成100*100大小的0方阵。

24、计算完成后,使用save()函数将数据保存成本地mat文件,常用格式为 ① save('filename', 'var1', 'var2', ...):保存指定的变量在 filename 指定的文件中、② save matname var1 var2 ......。

25、使用tic和toc命令可以获取程序运行所花时间。也可以与if判断语句相结合通过判断运行时间来终端程序运行。示例:

for k = 1:1000

tic;

tmp = rand(k);

tm = toc;

% tmp语句运行时间超过0.001时程序就会跳出循环。

if tm > 0.001

break;

end

end

26、对多矩阵求和(sum)、平均值(mean)、最大值(max)等时,可以用冒号(:)符来直接取所有元素,而不是用这些命令嵌套。示例:x = rand(3,4,2,2),对x求和。使用嵌套的话要用四次sum,即sum(sum(sum(sum(x)))),而用冒号表达式则只需用一次,即sum(x(:))。这样不仅使代码简洁,运行效率也会有所提高。

27、常用向量化函数 —— accumarray、arrayfun 、bsxfun 、cellfun 、spfun 、structfun等。

28、通过delete命令可以实现m自毁功能,例如一个名为test.m的m文件,在程序结尾添加delete('test.m'); 程序运行完成后将自动删除自身。

29、关于matlab中矩阵大小的计算函数,length函数计算矩阵最大维的大小;size函数计算各维的大小;numel函数计算矩阵中元素的总个数,如numel(A(:))。

30、程序调试神器命令 —— dbstop if error,添加此命令到程序中,程序运行中如果遇到错误将自动停止在错误处,对快速查找程序错误非常有帮助。

31、end命令的妙用,end除了作为自定义函数和控制流函数的终止标识符外,还能作为数组的末尾索引,如下:

A = rand(1,10); % A(10)和A(end), A(8)和A(end-2)是等价的。

32、路径和文件相关的函数,也是很多初学的小伙伴常疑惑的问题,下面就来整理一下与路径文件相关的命令:

pwd       % 获取当前工作路径
dir       % 列出当前文件夹中的文件和文件夹
ls        % 列出当前中文件夹内容 
cd        % 打开指定文件mkdir     % 创建新文件夹
rmdir     % 删除文件夹copyfile  % 复制文件或文件夹
movefile  % 移动或重命名文件或文件夹
delete    % 删除文件或对象

相关推荐

HR必备Excel函数:4个与日期相关的计算函数。

提到日期函数,很多人首先会想到“today”,它可以显示当天的日期,并且每次打开表格时都会自动更新。但是,对于前天、昨天、明天和后天的日期,就不能用yesterday或者tomorrow等这些英文了,...

这篇文章有点长,但可以让你十分钟玩转Excel的时间函数

日期与时间函数——TODAY、NOW、YEAR、MONTH、DAY!如何用WORKDAY函数查询距离某天的第20个工作日是哪一天?如何用NETWORKDAYS函数查询员工工作了多少个工作日?如何用WE...

Excel2020年日历套装,表格设计,农历显示,查阅套打轻松应用

Hello大家好,我是帮帮。今天跟大家分享一组Excel2020年日历套装,表格设计,自带农历控件,查阅套打轻松应用。有个好消息!为了方便大家更快的掌握技巧,寻找捷径。请大家点击文章末尾的“了解更多”...

巧用NETWORKDAYS函数计算两个日期之间工作日的天数

带有日期的单元格是我们日常使用EXCEL的时候经常见到的,有的时候我们需要求出两个日期之间间隔的天数,可以直接用结束日期减去开始日期即可,这是个非常简单的减法公式。不过这个单纯的减法公式会默认去掉开始...

Excel按工作日、休息日进行汇总

1、按周六日/其它时间汇总为了区分一周的周六日和其它时间,可以使用WEEKDAY函数,把WEEKDAY函数的第2个参数指定为2,如WEEKDAY(A3,2),则周一返回1,周二返回2,…,周六返回...

如何计算每月应出勤天数,如有法定假期和调休,如何计算

本文介绍如何计算每月的应出勤天数。第一部分介绍正常双休制下计算应出勤天数;第二部份介绍当月有法定假期和调休的情况下计算应出勤天数。一、计算正常双休制的应出勤天数如下图所示,要求计算各员工2021年3月...

《Excel一键生成工作日历:让会议排期更轻松!》

每当需要安排会议时,总要翻看日历确认工作日,再逐个标注会议时间,既耗时又容易出错。今天教大家用Excel快速生成工作日历表,让会议排期变得简单高效!一、快速生成日历框架创建基础日期:在A1单元格输入月...

如何计算指定日期区间内,有多少工作日和休息日?

大家好,今天咱们要解决的问题是如何计算给定的一段日期内,正常工作日有多少天,放假时间有多少天?比如咱们要计算2025年3月份工作日一共有多少天,又有多少天放假,如下图所示:通过肉眼我们可以数清楚,20...

如何如何在表格中自动突出显示双休日?

现在不少人喜欢用Excel来制作备忘录或安排工作事项。在表格中输入日期后,可以使用条件格式突出显示双休日,避免在休息日安排了工作。具体方法是这样的:第1步:选择要设置条件格式的日期单元格区域;在“开始...

excel函数技巧:networkdays.intl判断节假日

如图,想知道6月的每一天是否是节假日,公式如下:=NETWORKDAYS.INTL(A2,A2,1,$E$2:$E$28)这个函数既可以判断当前日期(一参=二参)是否是周末及工作日(三参、四参)还可得...

仅需3步,让考勤表根据实际休息日,自动地填充颜色

Hello,大家好,之前跟大家分享了我们如何让考勤表根据单休与双休自动的填充颜色,最近有粉丝问到:能不能让考勤表根据实际的休息日自动的填充颜色呢?可以是可以,只不过因为牵扯到假期调休,我们每年的休息日...

5步搞定动态考勤表!标记节假日、调休日?Excel自动变色!

今天教你用「动态考勤表」一招解决所有问题!只需输入月份,自动变色、自动更新节假日,从此告别加班,效率翻倍!动态考勤表的优势:自动变色:节假日、双休日一键标记,颜色分明。一表多用:修改月份即可...

一起用python做个炫酷音乐播放器,想听啥随便搜

前言前段时间写的Python自制一款炫酷音乐播放器,有不少小伙伴私信我,对播放器提了不少改进建议,让我完善播放器的功能。今天音乐播放器2.0版本完成了,大家一起来看看是如何用python自制一款炫酷的...

用Python做个“冰墩墩雪容融”桌面部件(好玩又有趣)

桌面太单调?今天就带大家,一起用Python的PyQt5开发一个有趣的自定义桌面动画挂件,看看实现的动画挂件效果!下面,我们开始介绍这个自定义桌面动画挂件的制作过程。一、核心功能设计实现将动态图gif...

Python串口调试助手源码分享

以下是一个基于Python和PyQt5实现的串口调试助手示例,包含核心功能实现代码:pythonimportsysimportserialfromPyQt5.QtCoreimportQTim...