Using 'solve' function in Simulink

11 ビュー (過去 30 日間)
Daniel Bronson
Daniel Bronson 2013 年 11 月 13 日
コメント済み: Mikkel 2014 年 9 月 5 日
I have a very non-linear equation that I need to solve during run-time of a Simulink simulation. I have been using the 'solve' function in normal scripts to solve for this. Unfortunately, I need this to be solved in run-time of the simulation.
I have tried to use an embedded Matlab function with the 'solve' function in the script. The problem is that it doesn't like 'syms' command used in conjunction with the 'solve' command. I have tried using the coder.extrinsic with the parameter, but it gives the error, "Undefined function or variable 'v'.... It doesn't seem to appreciate that I have declared 'v' as a syms in order for v to be solved for in the 'solve' function.
Has anyone successfully got the 'solve' function to work in a user-defined Matlab block in Simulink? I have raised this issue in front of a few dozen students at my University, and am interested in showing them a solution. Thank you!
For your ease, I have attached the simulation I am attempting to run. You can find the specific problematic block in the 'Velocity' block on the 'Top Level' file.
  1 件のコメント
Walter Roberson
Walter Roberson 2013 年 11 月 13 日
To check: would it be possible for you to do the solve() symbolically in MATLAB, and use matlabFunction() to generate parameterized MATLAB code, that you incorporate into Simulink ?

サインインしてコメントする。

採用された回答

Azzi Abdelmalek
Azzi Abdelmalek 2013 年 11 月 13 日
Try Interpreted Matlab function block, formerly called Matlab function .
  5 件のコメント
Kaustubha Govind
Kaustubha Govind 2014 年 6 月 9 日
Mikkel: Please specify the line that you are entering on the block.
Mikkel
Mikkel 2014 年 9 月 5 日
Kaustubha: I'm now entering this
eval(solve(u(2)*cos(u(3)-u(4))-u(1)*cos(x-u(4)),x))
and it is being calculated, though extremely slow! is there a way to speed this up?

サインインしてコメントする。

その他の回答 (1 件)

Walter Roberson
Walter Roberson 2013 年 11 月 14 日
If
P = .5*R*Cd*A*v^3 + Cr*M*g*v*cos(theta) + (M*g*v*sin(theta)
then
R*Cd*A/2 * v^3 + M*g*(Cr*cos(theta) + sin(theta))*v - P = 0
the solution is then
roots([R*Cd*A/2, 0, M*g*(Cr*cos(theta) + sin(theta)), -P])
Two of the roots might be imaginary.

Community Treasure Hunt

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

Start Hunting!

Translated by