Difference between solve result
1 view (last 30 days)
Show older comments
Boris
on 30 Jan 2023
Commented: Walter Roberson
on 31 Jan 2023
The follows equations get me usual result:
syms x y z
solve(x+y==4,y-z==0)
But if I add true I have different one:
syms x y z
solve(x+y==4,y-z==0,true)
That is mean true as input in function solve (I try to move true from end to begin and have the same result).
0 Comments
Accepted Answer
Walter Roberson
on 30 Jan 2023
When you solve() and you do not specify the names of variables to solve for, the solve() uses symvar() and takes as many variables as there are equations. So when you passed in 3 equations, it took the first three variables from symvar(); when you pass in two equations, it took the first two variables from symvar()
Treated as a system of 3 equations, the equations are underdetermined in z. The result from solve() is similar to the case where some of the equations are inequalities. That is, the internal computation knows to return parameterized solutions and range expressions, but then the interface code that converts the internal representation to something to show to the user chooses a specific "representative" value and substitutes that.
syms x y z
internal_results = feval(symengine, 'solve', [x+y==4, y-z==0, symtrue], [x, y, z])
The general rule of thumb when MATLAB is chosing a representative value, is that if 0 is valid within the constraints of the value, then the representative value will be 0. Applying that to above, the represenative value 0 is chosen for and that leads to the [4 0 0] output that you observe.
2 Comments
Walter Roberson
on 31 Jan 2023
Minor correction: solve() does sort(symvar()) to determine the variables to solve for.
More Answers (0)
See Also
Categories
Find more on Symbolic Math Toolbox in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!