Solving Diophantine Equations in MATLAB

21 views (last 30 days)

Accepted Answer

MathWorks Support Team
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

More Answers (0)

Products


Release

R2016a

Community Treasure Hunt

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

Start Hunting!