24小时热门版块排行榜    

查看: 2452  |  回复: 11

bbslover

金虫 (正式写手)

[交流] 【求助】一个matlab窗口占25%CPU,如何提高?已有7人参与

matlab计算时候,在任务管理器中发现占25%cpu,如何提高这个值,是matlab的计算加快呢?  我的电脑是 4 核的 CPU。
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
回帖支持 ( 显示支持度最高的前 50 名 )

xiegangmai

版主 (职业作家)

我没头衔

优秀版主优秀版主优秀版主


小木虫(金币+0.5):给个红包,谢谢回帖交流
引用回帖:
Originally posted by bbslover at 2011-03-05 09:50:59:
matlab计算时候,在任务管理器中发现占25%cpu,如何提高这个值,是matlab的计算加快呢?  我的电脑是 4 核的 CPU。

加速程序运算,需考虑多方面的因素。

首先是算法,算法的设计很重要,关系运行效率。

另外是数据矢量化处理,尽量避免循环,采用数组、矩阵计算方式。

关于并行,可参考:http://www.mathworks.com/support ... l?solution=1-372IPG

从MATLAB 7.3 (R2006b)开始,不需要用户干涉,Matlab的某些矩阵操作会自动使用多个CPU,主要是Matlab所采用的BLAS (Basic Linear Algebra Subroutines)开始支持多线程。BLAS里的操作包括矩阵乘法、求特征根等。

从MATLAB 7.4 (R2007a)开始,Matlab开始提供对某些操作的多线性支持,主要是element-wise的数值计算,比如sin(A)、A.*log(A)。

如果电脑显卡支持GPU,可以试试用GPU加速计算(CUDA_matlab,免费的),另外,Jacket也不错,可惜只有15天的试用期,就要收费。
明德厚学、求是创新
3楼2011-03-06 15:59:11
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

ghost820521

铁杆木虫 (著名写手)


小木虫(金币+0.5):给个红包,谢谢回帖交流
我也想知道结果。这个25%的意思是只有一个核在工作,如何能让所有核都同时参与运算?
下辈子一定要投胎做女人,然后嫁给一个像我这样的男人。
2楼2011-03-06 14:14:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

bbslover

金虫 (正式写手)

好的 多谢了
4楼2011-03-07 08:05:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

信彼南山

木虫 (著名写手)

★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
xiegangmai(金币+1): 谢谢应助! 2011-03-08 09:35:45
要看你的计算任务是不是允许进行分布式分解
单线程任务无法分解的情况下是不能提高的
5楼2011-03-07 17:27:06
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

bbslover

金虫 (正式写手)

引用回帖:
Originally posted by 信彼南山 at 2011-03-07 17:27:06:
要看你的计算任务是不是允许进行分布式分解
单线程任务无法分解的情况下是不能提高的

多谢了
6楼2011-03-08 09:07:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiegangmai

版主 (职业作家)

我没头衔

优秀版主优秀版主优秀版主


小木虫(金币+0.5):给个红包,谢谢回帖交流
引用回帖:
Originally posted by 信彼南山 at 2011-03-07 17:27:06:
要看你的计算任务是不是允许进行分布式分解
单线程任务无法分解的情况下是不能提高的

有多层次多粒度的并行,你说的线程并行只是其中粒度较粗的并行,还可以数据并行,也可以提升速度的。

利用 Parallel Computing Toolbox(并行计算工具箱),可在多核和多处理器计算机上使用 MATLAB 和 Simulink 来解决计算问题和数据密集型问题。并行处理结构包括并行 for 循环和代码块、分布式数组、并行数值算法,以及消息传递函数等,可以以较高的级别在 MATLAB 中执行任务及数据并行算法,而无需为特定的硬件和网络架构编写程序。这样,将串行 MATLAB 应用程序转换为 并行 MATLAB 应用程序,便几乎不需要修改代码,且不需要使用低级语言编写程序。此外,还可以在各种批处理环境中交互运行或脱机运行应用程序。

主要功能
支持数据并行和任务并行的应用程序开发
可使用 parfor(并行 for 循环)和 spmd(单程序多数据)注释代码段,用于执行数据并行和任务并行的算法
高级别的结构,如分布式数组、并行算法,以及消息传递函数,可在多个处理器上处理大型的数据集
可在一个多核桌面上本地运行八个 worker
与 MATLAB Distributed Computing Server 集成,可用于使用调度程序或任意数量 worker 的基于集群的应用程序
提供交互模式和批量执行模式

比如数据并行编程:

当你需要简单计算的多次循环迭代时,例如蒙特卡洛(Monte Carlo)模拟,parfor循环就很有用。parfor将循环迭代分组,那么每个worker执行迭代的一部分。当迭代耗时很长的时候parfor循环也是有用的,因为workers可以同时执行迭代。
当循环中有迭代依赖其他迭代的结果时不应该使用parfor循环。每个迭代都必须不依赖其他迭代。由于parfor循环内有通信消耗,当只有小数量的简单计算时使用parfor可能得不到什么好处。

for循环
CODE:
clear A
for i = 1:8
   A(i) = i;
end
A

parfor循环
CODE:
clear A
parfor i = 1:8
   A(i) = i;
end
A

明德厚学、求是创新
7楼2011-03-08 09:43:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xoxoaurora

金虫 (职业作家)

引用回帖:
Originally posted by xiegangmai at 2011-03-08 09:43:21:
有多层次多粒度的并行,你说的线程并行只是其中粒度较粗的并行,还可以数据并行,也可以提升速度的。

利用 Parallel Computing Toolbox(并行计算工具箱),可在多核和多处理器计算机上使用 MATLAB 和 Simul ...

版主强啊。膜拜
去哪里?
8楼2011-03-08 09:47:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dubo

金虫 (著名写手)

优秀版主

★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
xiegangmai(金币+1): 鼓励讨论交流! 2011-03-08 11:33:40
可以强制修改优先级,任务管理器,查看CPU,右击,设置优先级,设置为
9楼2011-03-08 11:19:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

suxl04

铁杆木虫 (正式写手)

★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
xiegangmai(金币+1): 鼓励讨论交流! 2011-03-08 11:34:43
这个问题我也遇到过。
我感觉和写的程序有关,因为同一电脑上,有些程序可以多核,有些只能单核。
GAOTEAM,PC
10楼2011-03-08 11:29:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 bbslover 的主题更新
普通表情 高级回复(可上传附件)
信息提示
请填处理意见