SymPy - Mathématiques symboliques en Python
Aperçu
SymPy est une bibliothèque Python pour les mathématiques symboliques qui permet le calcul exact en utilisant des symboles mathématiques plutôt que des approximations numériques. Cette compétence fournit des conseils complets pour effectuer l'algèbre symbolique, le calcul, l'algèbre linéaire, la résolution d'équations, les calculs de physique et la génération de code avec SymPy.
Quand utiliser cette compétence
Utilisez cette compétence pour :
- Résoudre des équations symboliquement (algébriques, différentielles, systèmes d'équations)
- Effectuer des opérations de calcul (dérivées, intégrales, limites, séries)
- Manipuler et simplifier des expressions algébriques
- Travailler avec des matrices et de l'algèbre linéaire symboliquement
- Effectuer des calculs de physique (mécanique, mécanique quantique, analyse vectorielle)
- Calculs de théorie des nombres (nombres premiers, factorisation, arithmétique modulaire)
- Calculs géométriques (géométrie 2D/3D, géométrie analytique)
- Convertir des expressions mathématiques en code exécutable (Python, C, Fortran)
- Générer des résultats LaTeX ou d'autres sorties formatées
- Avoir besoin de résultats mathématiques exacts (par exemple,
sqrt(2)et non1.414...)
Capacités principales
1. Bases du calcul symbolique
Créer des symboles et des expressions :
from sympy import symbols, Symbol
x, y, z = symbols('x y z')
expr = x**2 + 2*x + 1
# Avec des hypothèses
x = symbols('x', real=True, positive=True)
n = symbols('n', integer=True)
Simplification et manipulation :
from sympy import simplify, expand, factor, cancel
simplify(sin(x)**2 + cos(x)**2) # Retourne 1
expand((x + 1)**3) # x**3 + 3*x**2 + 3*x + 1
factor(x**2 - 1) # (x - 1)*(x + 1)
Pour les bases détaillées : Voir references/core-capabilities.md
2. Calcul
Dérivées :
from sympy import diff
diff(x**2, x) # 2*x
diff(x**4, x, 3) # 24*x (dérivée troisième)
diff(x**2*y**3, x, y) # 6*x*y**2 (dérivées partielles)
Intégrales :
from sympy import integrate, oo
integrate(x**2, x) # x**3/3 (indéfinie)
integrate(x**2, (x, 0, 1)) # 1/3 (définie)
integrate(exp(-x), (x, 0, oo)) # 1 (impropre)
Limites et séries :
from sympy import limit, series
limit(sin(x)/x, x, 0) # 1
series(exp(x), x, 0, 6) # 1 + x + x**2/2 + x**3/6 + x**4/24 + x**5/120 + O(x**6)
Pour les opérations de calcul détaillées : Voir references/core-capabilities.md
3. Résolution d'équations
Équations algébriques :
from sympy import solveset, solve, Eq
solveset(x**2 - 4, x) # {-2, 2}
solve(Eq(x**2, 4), x) # [-2, 2]
Systèmes d'équations :
from sympy import linsolve, nonlinsolve
linsolve([x + y - 2, x - y], x, y) # {(1, 1)} (linéaire)
nonlinsolve([x**2 + y - 2, x + y**2 - 3], x, y) # (non-linéaire)
Équations différentielles :
from sympy import Function, dsolve, Derivative
f = symbols('f', cls=Function)
dsolve(Derivative(f(x), x) - f(x), f(x)) # Eq(f(x), C1*exp(x))
Pour les méthodes de résolution détaillées : Voir references/core-capabilities.md
4. Matrices et algèbre linéaire
Création et opérations sur des matrices :
from sympy import Matrix, eye, zeros
M = Matrix([[1, 2], [3, 4]])
M_inv = M**-1 # Inverse
M.det() # Déterminant
M.T # Transposée
Valeurs propres et vecteurs propres :
eigenvals = M.eigenvals() # {valeur_propre: multiplicité}
eigenvects = M.eigenvects() # [(val_propre, mult, [vecteurs_propres])]
P, D = M.diagonalize() # M = P*D*P^-1
Résoudre des systèmes linéaires :
A = Matrix([[1, 2], [3, 4]])
b = Matrix([5, 6])
x = A.solve(b) # Résoudre Ax = b
Pour l'algèbre linéaire complète : Voir references/matrices-linear-algebra.md
5. Physique et mécanique
Mécanique classique :
from sympy.physics.mechanics import dynamicsymbols, LagrangesMethod
from sympy import symbols
# Définir le système
q = dynamicsymbols('q')
m, g, l = symbols('m g l')
# Lagrangien (T - V)
L = m*(l*q.diff())**2/2 - m*g*l*(1 - cos(q))
# Appliquer la méthode de Lagrange
LM = LagrangesMethod(L, [q])
Analyse vectorielle :
from sympy.physics.vector import ReferenceFrame, dot, cross
N = ReferenceFrame('N')
v1 = 3*N.x + 4*N.y
v2 = 1*N.x + 2*N.z
dot(v1, v2) # Produit scalaire
cross(v1, v2) # Produit vectoriel
Mécanique quantique :
from sympy.physics.quantum import Ket, Bra, Commutator
psi = Ket('psi')
A = Operator('A')
comm = Commutator(A, B).doit()
Pour les capacités de physique détaillées : Voir references/physics-mechanics.md
6. Mathématiques avancées
La compétence inclut un support complet pour :
- Géométrie : Géométrie analytique 2D/3D, points, lignes, cercles, polygones, transformations
- Théorie des nombres : Nombres premiers, factorisation, PGCD/PPCM, arithmétique modulaire, équations diophantiennes
- Combinatoire : Permutations, combinaisons, partitions, théorie des groupes
- Logique et ensembles : Logique booléenne, théorie des ensembles, ensembles finis et infinis
- Statistiques : Distributions de probabilité, variables aléatoires, espérance, variance
- Fonctions spéciales : Gamma, Bessel, polynômes orthogonaux, fonctions hypergéométriques
- Polynômes : Algèbre polynomiale, racines, factorisation, bases de Groebner
Pour les sujets avancés détaillés : Voir references/advanced-topics.md
7. Génération de code et sortie
Convertir en fonctions exécutables :
from sympy import lambdify
import numpy as np
expr = x**2 + 2*x + 1
f = lambdify(x, expr, 'numpy') # Créer une fonction NumPy
x_vals = np.linspace(0, 10, 100)
y_vals = f(x_vals) # Évaluation numérique rapide
Générer du code C/Fortran :
from sympy.utilities.codegen import codegen
[(c_name, c_code), (h_name, h_header)] = codegen(
('my_func', expr), 'C'
)
Sortie LaTeX :
from sympy import latex
latex_str = latex(expr) # Convertir en LaTeX pour les documents
Pour la génération de code complète : Voir references/code-generation-printing.md
Travailler avec SymPy : bonnes pratiques
1. Toujours définir les symboles en premier
from sympy import symbols
x, y, z = symbols('x y z')
# Maintenant x, y, z peuvent être utilisés dans des expressions
2. Utiliser les hypothèses pour une meilleure simplification
x = symbols('x', positive=True, real=True)
sqrt(x**2) # Retourne x (pas Abs(x)) grâce à l'hypothèse positive
Hypothèses courantes : real, positive, negative, integer, rational, complex, even, odd
3. Utiliser l'arithmétique exacte
from sympy import Rational, S
# Correct (exact) :
expr = Rational(1, 2) * x
expr = S(1)/2 * x
# Incorrect (virgule flottante) :
expr = 0.5 * x # Crée une valeur approximative
4. Évaluation numérique quand nécessaire
from sympy import pi, sqrt
result = sqrt(8) + pi
result.evalf() # 5.96371554103586
result.evalf(50) # 50 chiffres de précision
5. Convertir en NumPy pour les performances
# Lent pour de nombreuses évaluations :
for x_val in range(1000):
result = expr.subs(x, x_val).evalf()
# Rapide :
f = lambdify(x, expr, 'numpy')
results = f(np.arange(1000))
6. Utiliser les solveurs appropriés
solveset: Équations algébriques (principale)linsolve: Systèmes linéairesnonlinsolve: Systèmes non-linéairesdsolve: Équations différentiellessolve: Usage général (hérité, mais flexible)
Structure des fichiers de référence
Cette compétence utilise des fichiers de référence modulaires pour différentes capacités :
-
core-capabilities.md: Symboles, algèbre, calcul, simplification, résolution d'équations- Charger quand : Calcul symbolique basique, calcul, ou résolution d'équations
-
matrices-linear-algebra.md: Opérations matricielles, valeurs propres, systèmes linéaires- Charger quand : Travail avec des matrices ou des problèmes d'algèbre linéaire
-
physics-mechanics.md: Mécanique classique, mécanique quantique, vecteurs, unités- Charger quand : Calculs de physique ou problèmes de mécanique
-
advanced-topics.md: Géométrie, théorie des nombres, combinatoire, logique, statistiques- Charger quand : Sujets mathématiques avancés au-delà de l'algèbre et du calcul basiques
-
code-generation-printing.md: Lambdify, codegen, sortie LaTeX, impression- Charger quand : Convertir des expressions en code ou générer une sortie formatée
Motifs de cas d'usage courants
Motif 1 : Résoudre et vérifier
from sympy import symbols, solve, simplify
x = symbols('x')
# Résoudre l'équation
equation = x**2 - 5*x + 6
solutions = solve(equation, x) # [2, 3]
# Vérifier les solutions
for sol in solutions:
result = simplify(equation.subs(x, sol))
assert result == 0
Motif 2 : Pipeline symbolique vers numérique
# 1. Définir le problème symbolique
x, y = symbols('x y')
expr = sin(x) + cos(y)
# 2. Manipuler symboliquement
simplified = simplify(expr)
derivative = diff(simplified, x)
# 3. Convertir en fonction numérique
f = lambdify((x, y), derivative, 'numpy')
# 4. Évaluer numériquement
results = f(x_data, y_data)
Motif 3 : Documenter les résultats mathématiques
# Calculer le résultat symboliquement
integral_expr = Integral(x**2, (x, 0, 1))
result = integral_expr.doit()
# Générer la documentation
print(f"LaTeX: {latex(integral_expr)} = {latex(result)}")
print(f"Pretty: {pretty(integral_expr)} = {pretty(result)}")
print(f"Numerical: {result.evalf()}")
Intégration avec les workflows scientifiques
Avec NumPy
import numpy as np
from sympy import symbols, lambdify
x = symbols('x')
expr = x**2 + 2*x + 1
f = lambdify(x, expr, 'numpy')
x_array = np.linspace(-5, 5, 100)
y_array = f(x_array)
Avec Matplotlib
import matplotlib.pyplot as plt
import numpy as np
from sympy import symbols, lambdify, sin
x = symbols('x')
expr = sin(x) / x
f = lambdify(x, expr, 'numpy')
x_vals = np.linspace(-10, 10, 1000)
y_vals = f(x_vals)
plt.plot(x_vals, y_vals)
plt.show()
Avec SciPy
from scipy.optimize import fsolve
from sympy import symbols, lambdify
# Définir l'équation symboliquement
x = symbols('x')
equation = x**3 - 2*x - 5
# Convertir en fonction numérique
f = lambdify(x, equation, 'numpy')
# Résoudre numériquement avec une estimation initiale
solution = fsolve(f, 2)
Référence rapide : fonctions les plus courantes
# Symboles
from sympy import symbols, Symbol
x, y = symbols('x y')
# Opérations basiques
from sympy import simplify, expand, factor, collect, cancel
from sympy import sqrt, exp, log, sin, cos, tan, pi, E, I, oo
# Calcul
from sympy import diff, integrate, limit, series, Derivative, Integral
# Résolution
from sympy import solve, solveset, linsolve, nonlinsolve, dsolve
# Matrices
from sympy import Matrix, eye, zeros, ones, diag
# Logique et ensembles
from sympy import And, Or, Not, Implies, FiniteSet, Interval, Union
# Sortie
from sympy import latex, pprint, lambdify, init_printing
# Utilitaires
from sympy import evalf, N, nsimplify
Exemples de démarrage
Exemple 1 : Résoudre une équation quadratique
from sympy import symbols, solve, sqrt
x = symbols('x')
solution = solve(x**2 - 5*x + 6, x)
# [2, 3]
Exemple 2 : Calculer une dérivée
from sympy import symbols, diff, sin
x = symbols('x')
f = sin(x**2)
df_dx = diff(f, x)
# 2*x*cos(x**2)
Exemple 3 : Évaluer une intégrale
from sympy import symbols, integrate, exp
x = symbols('x')
integral = integrate(x * exp(-x**2), (x, 0, oo))
# 1/2
Exemple 4 : Valeurs propres d'une matrice
from sympy import Matrix
M = Matrix([[1, 2], [2, 1]])
eigenvals = M.eigenvals()
# {3: 1, -1: 1}
Exemple 5 : Générer une fonction Python
from sympy import symbols, lambdify
import numpy as np
x = symbols('x')
expr = x**2 + 2*x + 1
f = lambdify(x, expr, 'numpy')
f(np.array([1, 2, 3]))
# array([ 4, 9, 16])
Résolution des problèmes courants
-
"NameError: name 'x' is not defined"
- Solution : Toujours définir les symboles en utilisant
symbols()avant utilisation
- Solution : Toujours définir les symboles en utilisant
-
Résultats numériques inattendus
- Problème : Utiliser des nombres en virgule flottante comme
0.5au lieu deRational(1, 2) - Solution : Utiliser
Rational()ouS()pour l'arithmétique exacte
- Problème : Utiliser des nombres en virgule flottante comme
-
Performance lente dans les boucles
- Problème : Utiliser
subs()etevalf()à répétition - Solution : Utiliser
lambdify()pour créer une fonction numérique rapide
- Problème : Utiliser
-
"Can't solve this equation"
- Essayer différents solveurs :
solve,solveset,nsolve(numérique) - Vérifier si l'équation est résoluble algébriquement
- Utiliser des méthodes numériques s'il n'existe pas de solution fermée
- Essayer différents solveurs :
-
La simplification ne fonctionne pas comme prévu
- Essayer différentes fonctions de simplification :
simplify,factor,expand,trigsimp - Ajouter des hypothèses aux symboles (par exemple,
positive=True) - Utiliser
simplify(expr, force=True)pour une simplification agressive
- Essayer différentes fonctions de simplification :
Ressources supplémentaires
- Documentation officielle : https://docs.sympy.org/
- Tutoriel : https://docs.sympy.org/latest/tutorials/intro-tutorial/index.html
- Référence API : https://docs.sympy.org/latest/reference/index.html
- Exemples : https://github.com/sympy/sympy/tree/master/examples