【发布时间】:2020-01-30 11:58:21
【问题描述】:
我对 MATLAB 上的并行池概念(我使用的是 2019 a 版本)和编码不熟悉。我将与您分享的这段代码可以在网上找到,我根据自己的需要做了一些修改。
问题陈述:我有一个非线性系统(罗斯勒方程),我必须绘制它的分岔图,我尝试使用 for 循环正常进行,但它的计算时间太多,我的电脑被绞死了几个次,所以我得到了一个建议,将我的代码并行池化,以解决这个问题。我试图学习如何在网上使用 MATLAB 进行并行池,但我仍然无法解决我的问题,因为仍然存在一些问题,因为我的代码中有 2 个 parfor 循环我在索引和分配方面遇到问题全局参数(请注意:此代码是为正常执行而编写的,不使用并行池)。
我在下面附上我的代码,如果我提到了很多代码行,请原谅。
clc;
a = 0.2; b = 0.2; global c;
crange = 1:0.05:90; % Range for parameter c
k = 0; tspan = 0:0.1:500; % Time interval for solving Rossler system
xmax = []; % A matrix for storing the sorted value of x1
for c = crange
f = @(t,x) [-x(2)-x(3); x(1)+a*x(2); b+x(3)*(x(1)-c)];
x0 = [1 1 0]; % initial condition for Rossler system
k = k + 1;
[t,x] = ode45(f,tspan,x0); % call ode() to solve Rossler system
count = find(t>100); % find all the t values which is >10
x = x(count,:);
j = 1;
n = length(x(:,1)); % find the length of vector x1(x in our problem)
for i=2 : n-1
% check for the min value in 1st column of sol matrix
if (x(i-1,1)+eps) < x(i,1) && x(i,1) > (x(i+1,1)+eps)
xmax(k,j)=x(i,1); % Sorting the values of x1 in increasing order
j=j+1;
end
end
% generating bifurcation map by plotting j-1 element of kth row each time
if j>1
plot(c,xmax(k,1:j-1),'k.','MarkerSize',1);
end
hold on;
index(k)=j-1;
end
xlabel('Bifuracation parameter c');
ylabel('x max');
title('Bifurcation diagram for c');
【问题讨论】:
-
你好阿基尔。这被投票关闭,因为需要提供重现问题的能力。我想您已经进行了一些调试以深入了解哪条线路出现故障。请指出故障发生在哪一行,以便更好地帮助社区为您提供帮助。
-
这里有一些问题。 1)
c不需要是全局的。 2)k = k+1特别不允许parfor循环,因为执行顺序会影响结果。 3) 你的内部for循环似乎只是对x(:,1)进行排序,为什么不使用sort? 4) 我按原样运行你的代码,只用了 150 秒,一个幼稚的并行 for 循环不太可能产生很大的不同,因为每次迭代大约需要 0.1 秒,所以开销很可能会抵消任何好处。 -
(续) 6) 我认为真正的问题是在您尝试显示绘图的循环之后,显示的点太多。我认为您可以使用不太精细的
c和tspan向量,但仍然可以获得不错的结果。 -
@David:我的问题是为我使用的代码相同的另一个系统找到结果。提到的问题很简单,因为它有一个简单的流程。我设计的那个太复杂了,肯定需要并行处理。
标签: matlab parallel-processing