Borrar filtros
Borrar filtros

Using structures as input of the model with parallel computing

2 visualizaciones (últimos 30 días)
Hi everyone,
I'm currently using structure of constants as an input of simulink blocks in my model. The only way I was able to do that was using bus objects. The settings for my model are defined in file which I call in my main.
Here comes the problem : I'm trying to use the parallel computing toolbox. I get this error message when I try to load my model: The symbol 'HD_bus' resolved to a bus object in the model workspace; Bus objects should only be created in the base workspace
Is there any way to go around this particular issue
Cheers Alex

Respuesta aceptada

Kaustubha Govind
Kaustubha Govind el 13 de Abr. de 2012
I wonder if you could assign the Simulink.Bus object in the base workspace in the parfor loop, as discussed here: http://blogs.mathworks.com/seth/2010/10/17/parallel-computing-with-simulink-running-thousands-of-simulations/#11
  6 comentarios
Kaustubha Govind
Kaustubha Govind el 19 de Abr. de 2012
Blocks like (Embedded) MATLAB Function, Stateflow and Model Reference (in modes other than Normal) will try to generate code into the slprj folder in order to produce a MEX-file that is used for faster simulation. I'm guessing that suppressed "SLSF diagnostic" was about a stale splrj.
Kaustubha Govind
Kaustubha Govind el 19 de Abr. de 2012
Btw, Guy's suggested solution might be safer to use if you happen to be changing non-tunable parameters within the parfor loop.

Iniciar sesión para comentar.

Más respuestas (3)

Alexandre
Alexandre el 12 de Abr. de 2012
Thanks for the reply TAB. The problem is I think I have to define my properties in the model workspace as I am using parrallel computing with a parfor loop. If I let the bus in the base workspace matlab throw a transparency error. Anyone as an idea ? Cheers Alex

Alexandre
Alexandre el 13 de Abr. de 2012
Can anyone help on this topic ?

Guy Rouleau
Guy Rouleau el 16 de Abr. de 2012
I recommend using pctRunOnAll to initialize all the workers once before starting the for loop.
About your error, look at the doc page "Running Parallel Simulations":
and go to the subsection "A Model with Stateflow, MATLAB Function Block, or Model Block". There you will see an example showing how to run each worker in different tmp folder to avoid conflicts when models mus generate a mex-file.

Categorías

Más información sobre Simulink Functions en Help Center y File Exchange.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by