I use parpool and parsim, but only 1 worker 'works' instead of 4.
10 次查看(过去 30 天)
显示 更早的评论
I have this Simulink file that runs for 3.84 s. Each 0.04 s. the data changes. I want to use parsim to make the simulation faster. I wrote the code below, but it seems that it uses only one worker (at least only one simulation appears in the manager). Is there any change I should do, or this is the correct way, because its slower than the simple sim command.
% Create a parallel pool if not already available
if isempty(gcp('nocreate'))
parpool; % Create a parallel pool
end
% Load Model & Simulation Input
model = 'zigzag_example_matlab';
Simulink.BlockDiagram.buildRapidAcceleratorTarget(model);
simIn = Simulink.SimulationInput(model);
%Simulation
tic
simout = parsim(simIn, 'TransferBaseWorkspaceVariables', 'on', 'ShowSimulationManager', 'on');
toc
2 个评论
Edric Ellis
2023-12-11
parsim allows you to run multiple simulations in parallel - you should split your data up into pieces, and then run each piece as a separate simulation.
回答(1 个)
Walter Roberson
2023-12-11
移动:Walter Roberson
2023-12-12
You appear to be building a scalar simIn
You should be constructing an array of simulation input objects
The parsim documentation has the example,
FeedTempSweep = 250:10:300;
for i = length(FeedTempSweep):-1:1
in(i) = Simulink.SimulationInput('CSTR');
in(i) = in(i).setVariable('FeedTemp0',FeedTempSweep(i));
end
out = parsim(in, 'ShowSimulationManager', 'on')
Here, 'CSTR' is the name of the model that is to be run.
Each member of the in array defines one simulation to be run. parsim() runs several of the entries in parallel.
5 个评论
Edric Ellis
2023-12-13
It does indeed sound like something isn't quite right there. Are you comparing the parsim time to something like this?
Sweep = 0.00:0.04:3.84;
for i = length(Sweep):-1:1
SampleTime = Sweep(i);
[t, y] = sim(model);
end
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Manual Performance Optimization 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!