题主把代码粘贴一下,这样不好做和修改
matlab 本身就不快,对就行啦,本来就是仿真又不是实际应用,轻松点。Fortain比Matlab快
同二楼,把代码贴出来最好
向量化计算,MATLAB的优势是矩阵运算,所以能不写循环就不要写循环。
尽量调用系统函数,少用自己写的函数
预先申请内存,是因为如果不预分配的话,MATLAB在每次循环执行的时候都会改变数组a的大小,则每次都会去内存查找适合此大小的内存区间,然后重新分配内存。该过程不仅会造成MATLAB代码的执行速度变慢,而且很容易造成内存碎片化。
少用cell,cell的数组不需要连续的内存空间进行存储,所以需要记录每个cell单元的地址等信息,即使是空的cell单元,也会占用4个字节的存储空间。而且cell的访问是很慢的。
不管是在MATLAB还是C/C++中,都有一个准则叫:变勤拿少取为少拿多取。具体含义就是减小循环的次数,尽量在每次循环中做比较多的数据处理,不管是数据读取还是写入。因此,在编写带有嵌套循环的代码时,循环次数多的尽量在内层,少的尽量在外层。
逻辑索引比数值索引更快
赋值给类型不匹配的变量,比赋值给新定义的变量更慢。
如果要判断多个条件是否满足,尽量使用逻辑运算符 && 或者 || ,因为逻辑运算符只有在第一个逻辑条件成立的时候才会计算第二个逻辑条件[4]。
避免使用全局变量。
如果需要大段代码产生常值数据,可以考虑产生该数据,并保存在mat文件中,然后在运算中加载这些数据。
尽量使用m函数,替代m脚本。
尽量使用本地函数(local function)替代nested function。所谓本地函数,是指在同一个m文件中写了多个函数[5]。
模块化编程,尽量将长段代码分解为简单函数。长段代码中往往包含一些不常使用的代码段,分解之后可以降低处理器读取代码的时间。模块化编程可以降低首次运行时间。
避免使用eval,evalc,evalin,feval(fname),改为使用feval+函数句柄的方式。从文本间接调用函数比较耗时。
避免使用查询状态的函数,例如 inputname, which, whos, exist(var), dbstack, 这些函数比较耗时。
需大量运行且无法向量化的深度循环,考虑将之改为c语言函数。