使用 matlab 的 spmd 计算简单的三重积分给了我不正确的解决方案,对我做错了什么有什么想法吗?
Using matlab's spmd to compute simple triple integral is giving me incorrect solution, any thoughts on what I am doing wrong?
使用 matlab 的 spmd 计算简单的三重积分给出了错误的解决方案,对我做错了什么有什么想法吗?
close all; clear all; clc;
% Create a parallel pool if none exists
if isempty(gcp())
parpool();
end
nworkers = gcp().NumWorkers;
% Define the function
f = @(x,y,z) z
% Discretize the interval on the client
x = linspace(0,4,nworkers+1)
y = linspace(0,4,nworkers+1)
z = linspace(0,4,nworkers+1)
% On the workers
spmd
ainit = x(labindex())
bfin = x(labindex()+1)
cinit = y(labindex())
dfin = y(labindex()+1)
einit = z(labindex())
ffin = z(labindex()+1)
% locint = integral3(f,ainit,bfin,cinit,dfin,einit,ffin) % subinterval integration
locint = integral3(f,ainit,bfin,ainit,bfin,ainit,bfin) % subinterval integration
totalint = gplus(locint) % Add all values.
end
% Send the value back the client
totalvalue = totalint{1}
fun = @(x,y,z) z
q = integral3(fun,0,4,0,4,0,4)
q 是正确的解决方案。
这里的问题是您的 spmd
块正在划分要集成到 每个 维度的 3 维区域,而不仅仅是一个维度。您需要选择一个维度来划分积分,并仅改变该维度的限制。例如,您可以通过将 spmd
中的 integral3
调用替换为以下内容来更正问题:
spmd
...
locint = integral3(f,0,4,0,4,einit,ffin)
...
end
使用 matlab 的 spmd 计算简单的三重积分给出了错误的解决方案,对我做错了什么有什么想法吗?
close all; clear all; clc;
% Create a parallel pool if none exists
if isempty(gcp())
parpool();
end
nworkers = gcp().NumWorkers;
% Define the function
f = @(x,y,z) z
% Discretize the interval on the client
x = linspace(0,4,nworkers+1)
y = linspace(0,4,nworkers+1)
z = linspace(0,4,nworkers+1)
% On the workers
spmd
ainit = x(labindex())
bfin = x(labindex()+1)
cinit = y(labindex())
dfin = y(labindex()+1)
einit = z(labindex())
ffin = z(labindex()+1)
% locint = integral3(f,ainit,bfin,cinit,dfin,einit,ffin) % subinterval integration
locint = integral3(f,ainit,bfin,ainit,bfin,ainit,bfin) % subinterval integration
totalint = gplus(locint) % Add all values.
end
% Send the value back the client
totalvalue = totalint{1}
fun = @(x,y,z) z
q = integral3(fun,0,4,0,4,0,4)
q 是正确的解决方案。
这里的问题是您的 spmd
块正在划分要集成到 每个 维度的 3 维区域,而不仅仅是一个维度。您需要选择一个维度来划分积分,并仅改变该维度的限制。例如,您可以通过将 spmd
中的 integral3
调用替换为以下内容来更正问题:
spmd
...
locint = integral3(f,0,4,0,4,einit,ffin)
...
end