Solving Diophantine Equations in MATLAB
21 views (last 30 days)
Show older comments
MathWorks Support Team
on 15 Aug 2016
Edited: MathWorks Support Team
on 8 Oct 2022
How do I solve Diophantine Equations in MATLAB?
Accepted Answer
MathWorks Support Team
on 8 Oct 2022
Edited: MathWorks Support Team
on 8 Oct 2022
Use the “solve” function. Before using “solve”, assume that the variables in the Diophantine equation are integers to ensure “solve” returns integer solutions. For example, solve the linear Diophantine equation 1027*x + 712*y = 1;
For MATLAB R2015a and later:
syms x y integer % assume ‘x’ and ‘y’ are integers
eqn = 1027*x + 712*y == 1; % declare the equation
[xSol, ySol] = solve(eqn,[x y]) % solve for ‘x’ and ‘y’
xSol =
-165
ySol =
238
For MATLAB R2014b or before:
syms x y
assume([x y], 'integer') % assume ‘x’ and ‘y’ are integers
eqn = 1027*x + 712*y == 1; % declare the equation
[xSol, ySol] = solve(eqn,[x y]) % solve for ‘x’ and ‘y’
xSol =
-165
ySol =
238
For details on “solve”, see: https://www.mathworks.com/help/symbolic/sym.solve.html
For more information on assumptions, see: https://www.mathworks.com/help/symbolic/assumptions-for-symbolic-objects.html
0 Comments
More Answers (0)
See Also
Categories
Find more on Assumptions 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!