J'ai un système d'équations comme suit:solution symbolique du système d'équations en utilisant sympy des solutions triviales en fonction des symboles
Ce système spécifique, je sais qu'une solution non triviale (s) existe seulement si p1 == p2, qui est
Cependant, comment puis-je déterminer cela dans le cas général en utilisant Sympy?
Pour cet exemple, ma mise en œuvre est la suivante:
from sympy import Matrix, symbols, pprint, lcm, latex
from sympy.solvers import solve_linear_system
top_matrix = Matrix.zeros(8,7)
p1 = symbols("p1")
p2 = symbols("p2")
top_matrix[0,0] = 1
top_matrix[0,1] = -1
top_matrix[1,1] = (1-p1)
top_matrix[1,2] = -1
top_matrix[2,2] = 1
top_matrix[2,4] = p2-1
top_matrix[3,1] = p1
top_matrix[3,3] = -1
top_matrix[4,3] = 1
top_matrix[4,4] = -p2
top_matrix[5,4] = 1
top_matrix[5,5] = -1
top_matrix[6,1] = -1
top_matrix[6,6] = 1
top_matrix[7,4] = -1
top_matrix[7,6] = 1
pprint(top_matrix)
vars = symbols("a1, a2, a3, a4, a5, a6, a7, a8")
print solve_linear_system(top_matrix, *vars)
Le résultat est
None
Si je mets
p2 = p1
le résultat est
{a1: -1, a5: -1, a2: -1, a6: -1, a3: p1 - 1, a4: -p1}
Existe-t-il un moyen de découvrir cette exigence automatiquement?