Return values of function vs. assignin
2 次查看(过去 30 天)
显示 更早的评论
Hi,
I'm writing a MATLAB function that sets some variables for a Simulink simulation of a planar robot.
A bunch of values are to be set in the workspace, around 20. However, about half of them should be of no interest for the end user, because they are internal variables of the simulation (variables for Simulink switches, for handling errors in the simulation, etc.). Also, they have to be saved in the workspace with the name that's used in the Simulink model.
Because of this, I was thinking about storing these values not by return values of the function, but by using the assignin function. This way, they could be stored with the right names in the workspace and the end user could ignore them.
Do you think it would be appropriate or just confusing and smell of bad design?
Thank you.
LT
4 个评论
Stephen23
2019-8-17
Bad design.
In similar situations I have put all those extra bit-and-pieces into one structure, and passed that as an (undocumented) output argument (right after all the documented ones).
John D'Errico
2019-8-17
I do agree with the comments by others. If you have many parameters to return, just stuff them into a struct. The idea of using assignin for the purpose is a terrible design choice, IMHO.
采纳的回答
Nikhil Sonavane
2019-8-20
I understand that you wish to set some parameters in the workspace before you execute your model but don’t wish the end user to do it every time. I suggest you use Callbacks instead of a function. You may refer to the following documentation for more information about callbacks-
0 个评论
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Simulink Functions 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!