最近帮一个胖友写几句matlab代码,里面涉及到比较大的数组乘法,基本上一轮下来,耗时60min; 由于他需要不断地改变某一个值,然后跑多次,我当然不允许这个时间白白浪费掉鸭。了解到matlab也有并行计算,因为实验室是做GPU的并行计算,而MATLAB是采用CPU做计算,本着一个学习的态度,写一篇博客详细记录一下,以防万一,某一天老板突然Q我做这个事情。
回归正题
首先查看一下你的电脑CPU的核心数量,单核就算了;
任务管理器->性能->CPU
可以看到,我的内核数量是:4,就是说,最多可以开4个core ;
MAC看这里
MATLAB端的操作:
clc;clear;close;
%开启并行环境
poolobj = gcp('nocreate');% If no pool, create new one.
if isempty(poolobj)
poolsize =<