Vous êtes sur la page 1sur 6

CHAPITRE 3: Compléments d’algèbre linéaire et bilinéaire

LES OUTILS DU PACKAGE LINALG:

Le package linalg contient plus d'une centaine d'outils en algèbre linéaire :

O with(linalg);
BlockDiagonal, GramSchmidt, JordanBlock, LUdecomp, QRdecomp, Wronskian, addcol, (1)
addrow, adj, adjoint, angle, augment, backsub, band, basis, bezout, blockmatrix, charmat,
charpoly, cholesky, col, coldim, colspace, colspan, companion, concat, cond, copyinto,
crossprod, curl, definite, delcols, delrows, det, diag, diverge, dotprod, eigenvals,
eigenvalues, eigenvectors, eigenvects, entermatrix, equal, exponential, extend, ffgausselim,
fibonacci, forwardsub, frobenius, gausselim, gaussjord, geneqns, genmatrix, grad,
hadamard, hermite, hessian, hilbert, htranspose, ihermite, indexfunc, innerprod, intbasis,
inverse, ismith, issimilar, iszero, jacobian, jordan, kernel, laplacian, leastsqrs, linsolve,
matadd, matrix, minor, minpoly, mulcol, mulrow, multiply, norm, normalize, nullspace,
orthog, permanent, pivot, potential, randmatrix, randvector, rank, ratform, row, rowdim,
rowspace, rowspan, rref, scalarmul, singularvals, smith, stackmatrix, submatrix, subvector,
sumbasis, swapcol, swaprow, sylvester, toeplitz, trace, transpose, vandermonde, vecpotent,
vectdim, vector, wronskian
Les fonctions matrix et vector permettent de définir respectivement une matrice (tableau
rectangulaire d'objets) ou un vecteur (tableau d'objets à une seule ligne) :

Définition d'une matrice 2x4 :


O P:=matrix([[s,t,u,v],[w,x,y,z]]);M:=matrix(2,2); print(M);N:=
matrix([[a,b],[c,d]]);
s t u v
P :=
w x y z
M := array 1 ..2, 1 ..2,
M1, 1 M1, 2
M2, 1 M2, 2

a b
N := (2)
c d

Définition d'un vecteur-ligne d'ordre 4 et d'une matrice-colonne d'ordre 3:


O V:=vector([a,b,c,d]);
MAPLE TSI Spé 2009/2010 (3)
1/6
V := a b c d (3)

O C:=matrix([[1],[2],[3]]);
1
C := 2 (4)
3

Une matrice a le type matrix , un vecteur a le type vector.


Opérations sur les matrices:
A la place de la fonction evalm, on peut utiliser les outils spécifiques du package linalg:
Multiplication de vecteurs ou de matrices de dimensions compatibles avec multiply
O multiply(M,N);
M1, 1 a CM1, 2 c M1, 1 b CM1, 2 d
(5)
M2, 1 a CM2, 2 c M2, 1 b CM2, 2 d

Calcul de la matrice inverse,lorsque N est inversible, avec inverse


O inverse(N);
d b
K
a d Kb c a d Kb c
(6)
c a
K
a d Kb c a d Kb c

Multiplication par un scalaire λ avec scalarmul


O scalarmul(P,lambda);
λs λt λu λv
(7)
λw λx λy λz

Test d'égalité de deux matrices avec equal


O equal(M,N);
false (8)
Etude d'une matrice:
Déterminant et trace d'une matrice carrée (somme des éléments diagonaux):
O N:=matrix([[1,2],[4,-3]]);det(N);trace(N);
1 2
N := (9)
4 K3
K11
K2
Rang d'une matrice:
O rank(N);
2 (10)

MAPLE TSI Spé 2009/2010 2/6


kernel(A); ou nullspace(A); détermine une base du noyau de A
colspace(A); détermine une base du sous-espace engendré par les vecteurs-colonnes de A
rowspace(A); détermine une base du sous-espace engendré par les vecteurs-lignes de A
O A:=matrix([[2,-2],[-1,1]]);kernel(A);
2 K2
A :=
K1 1

1 1 (11)

O colspace(A);
1
1 K (12)
2

O rowspace(A);
1 K1 (13)

Matrice caractéristique: λ IKA , polynôme caractéristique de A: det λ IKA .


O charmat(A,lambda);
λ K2 2
(14)
1 λ K1

O charpoly(A,lambda),minpoly(A,lambda);
2 2
λ K3 λ, λ K3 λ (15)
Valeurs propres de A (ce sont les racines du polynôme caractéristique):
O eigenvals(A);
0, 3 (16)
Un vecteur propre associé à la valeur propre λ est un vecteur X non nul tel que A X = λ X .
O eigenvects(A);
0, 1, 1 1 , 3, 1, K2 1 (17)

Le résultat affiché signifie que λ = 0 est une valeur propre d'ordre 1 de vecteur propre associé
X = 1, 1 et que λ = 3 est une valeur propre d'ordre 1 de vecteur propre associé X = K2, 1 .
Modification d'une matrice:
O print(P);
s t u v
(18)
w x y z

row(P,k) permet d'extraire la k-ième ligne de la matrice P. Le résultat est un vecteur et col(P,k) permet
d'extraire la k-ième colonne de la matrice P. Le résultat est un vecteur.
O row(P,2),col(P,3);
w x y z , u y (19)

MAPLE TSI Spé 2009/2010 3/6


rowdim(P) et coldim(P) retournent le nombre de lignes et de colonnes de la matrice P.
O rowdim(P),coldim(P);
2, 4 (20)
augment(M1,M2,...,Mn) permet de concaténer horizontalement les n matrices M1,M2,...,Mn:
O augment(A,P);
2 K2 s t u v
(21)
K1 1 w x y z

stackmatrix(M1,M2,...,Mn) permet de concaténer verticalement les n matrices M1,M2,...,Mn:


O stackmatrix(A,N);
2 K2
K1 1
(22)
1 2
4 K3

copyinto(M,N,m,n) : copie M dans N , l'élément M[1,1] étant copié en N[m,n] :


O copyinto(N,P,1,2);
s 1 2 v
(23)
w 4 K3 z

swapcol(M,m,n) et swaprow(M,m,n) permettent d'échanger les colonnes (ou les lignes) m et n de la


matrice M:
O swaprow(A,1,2);
K1 1
(24)
2 K2

transpose(M) permet de transposer la matrice M:


O print(M);transpose(M);
M1, 1 M1, 2
(25)
M2, 1 M2, 2

M1, 1 M2, 1

M1, 2 M2, 2

addcol(M,m,n,k) ou addrow(M,m,n,k) rendent une matrice obtenue par l'opération col n := col n + k *
col m (respectivement lig n := lig n + k * lig m) :
O print(N);addcol(N,1,2,mu);
1 2
(26)
4 K3

MAPLE TSI Spé 2009/2010 4/6


1 µC2
4 4 µK3

Matrices particulières:
O vandermonde([a,b,c,d]);
1 a a2 a3
1 b b2 b3
(27)
2 3
1 c c c
2 3
1 d d d

O JordanBlock(expr,4);
expr 1 0 0
0 expr 1 0
(28)
0 0 expr 1
0 0 0 expr

LES OUTILS DU PACKAGE LinearAlgebra:


A partir de la version 7, existe dans Maple un nouveau package LinearAlgebra avec des outils
similaires à ceux du package linalg et destiné à supplanter l'ancien. En voici les fonctions:
O with(LinearAlgebra):
On définit une matrice A dont on calcule le déterminant, la matrice et le polynôme caractéristique, ainsi
que les valeurs propres et vecteurs propres associés:
O A:=Matrix([[1,-1,-1],[-2,2,3],[2,-2,-3]]);
Determinant(A);CharacteristicMatrix(A,lambda);
factor(CharacteristicPolynomial(A,lambda));MinimalPolynomial(A,
lambda);
Eigenvalues(A);Eigenvectors(A);TridiagonalForm(A);

1 K1 K1
A := K2 2 3
2 K2 K3
0

λ K1 1 1
2 λ K2 K3
K2 2 λ C3

λ λ K1 λ C1
3
λ Kλ
MAPLE TSI Spé 2009/2010 5/6
0
1
K1

K1 0 1 1
1 , K1 K1 1
0 1 1 0

Error, (in LinearAlgebra:-TridiagonalForm) Matrix must be


floating-point symmetric or complex floating-point hermitian
O

MAPLE TSI Spé 2009/2010 6/6

Vous aimerez peut-être aussi