Best practice to pass large number of parameters to many functions?

This a programming style question. I have to solve a model for given parameters. The parameters are fixed in the beginning and they do not change during execution. These parameters need to be available to all the functions and subfunctions of the code. So far I used global variables. This is not very elegant, but it worked. But when I tried to speed up my code with using "parfor" instead of "for", then I learned that globals and parfor don't play well together.
So now I am planning to pass all the parameters to all functions as input arguments. Obviously, I don't want to write out each of them and create functions with 20-30 inputs. What is the best practice to do this? Should I use a structure?
Thanks, Andras

6 Commenti

In case somebody stumbles upon this entry, I found this utility function extremely useful. It makes packing variables into a structure, and then unpacking them very smooth and easy.
This thread is several years old, but I have a similar question. I was using structs/objects with parameters as fields/properties, but I'm now thinking of switching to saving a whole workspace instead, for a few reasons, and I'm wondering if there is a significant disadvantage that I'm overlooking. My reasons are:
1. I want to save the parameters (as well as initial conditions and other options) to file anyway to preserve for postprocessing of model trajectories. So if I used a struct, I'd have to save the struct.
2. I have a script where the user sets the parameters, and it seems simpler to be able to enter something like
sigma = 1;
rather than
params.sigma = 1;
especially when there are so many parameters to track.
Well, File I/O is likely to be slower than argument passing, which may or may not be an issue, especially if your workspace contains a lot of other stuff that you don't need. I assume this also means you'd have to pass the filename in as an argument to the function.
It works, there are just very few advantages to it in general.
Loading an entire file will generally be extremely slow compared to passing arguments around. Even if disk access is to a solid state drive, the bus speeds for a file load will be slow compared to main memory access. And to load a .mat file forces MATLAB to read and unpack the file format into memory. Avoid putting loads of .mat files into functions, if that will ever be done more than once.
If you get tired typing the variable name params, then just use p. So p.sigma costs two extra characters. If the only cost is your inconvenience of typing p.sigma, rather than a simple sigma, is that really that hard?
If you will need to use a variable a lot, then in the beginning of your function, do this once:
sigma = p.sigma;
Hi,I am new to matlab .When I tried to execute the program(I have attached 2 files),the output shows an error saying too many input arguements.Can anyone tell me what's the problem?
You would be better off opening a new thread to ask a question. I assume you are just pressing Run on your program though, in which case obviously it will not have any input arguments, which it appears to expect so you will get that error as soon as it reaches a line where one of those input arguments will be used.

Accedi per commentare.

 Risposta accettata

John D'Errico
John D'Errico il 1 Ago 2014
Modificato: John D'Errico il 1 Ago 2014
Yes. Simplest and fastest would be to use a struct as a container. That way you pass around only one argument to each function where any parameter is needed. This is not costly in terms of space or time, since MATLAB does not copy the struct into each workspace unless it is modified there.
Another option which will surely be slower but does not need you to pass in anything, is to use a function. Have the parameters defined in there as persistent variables, which you could easily set up so they are passed in initially.
Then when you want to know the value of a given parameter, query the value using the name of that parameter. Let the function do the work here. It would be slower, but requires no passed arguments at all.
You could even set up a list of prefs with setpref, which you could then query the values using getpref. Of course, this would be even slower, since I think prefs are stored on disk.

2 Commenti

Could you give an example of your explanation, please! I am new in MatLab and this is the best response but I am not familiar with structures or cantainer yet.

Accedi per commentare.

Più risposte (2)

I use structures for this sort of thing. I also usually set up functions so that they can handle input as either structure or parameter/value pairs. When appropriate, the functions will also be coded to fall back on specific default values, so I don't always have to provide all the parameters.

4 Commenti

Thank you! A clarifying question: where do the functions get the default values from? I assume you don't repeat them in all of your functions. But if they are set in the main code, then they either need to be global or passed to each of the specific functions which would defeat the purpose.
For more complex functions that require a lot of inputs, I usually use inputParser objects. They're a bit of overkill for simple functions (and I usually use a much simpler parser for those), but for something like this they're great.
As far as getting the defaults to all the subfunctions, I would set up the input parser at the beginning of your main function, where it would fill in any missing values with defaults. Store all the resulting parameters in a structure and then pass that to the subfunctions.
For example, here is an example of an input-parsing function that I use with one of the models underlying my research. It's called at the very start of a simulation, and it checks the many input variables for format, fills in defaults, and collects everything together.
Thanks again. The example function was very useful!
hi can u share the example model domain has expired

Accedi per commentare.

Nowadays I generally use classes with a regular setup of a class (or many collaborating, but one front end at least) to run the actual algorithm(s) or solve the model or whatever it is and an arguments/parameters class that I pass in.
The parameters class is always very simple, effectively just a struct, but with the added bonus that I use validateattributes in the set functions of all the parameters to ensure they are in the correct format before they get anywhere near the algorithm.
Using classes with parallel programming does require a bit of care though as I have made many mistakes with it!!

Richiesto:

il 1 Ago 2014

Commentato:

il 10 Nov 2022

Community Treasure Hunt

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

Start Hunting!

Translated by