Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

Cours 2

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 11

Université de Skikda 20 août 55

Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02


Cours : Langage Par : Z.Mansouri

MATLAB

Chapitre II : Les vecteurs et les matrices

Matlab était conçu à l’origine pour permettre aux mathématiciens, scientifiques et


ingénieurs d‘utiliser facilement les mécanismes de l’algèbre linéaire. Par conséquent,
l’utilisation des vecteurs et des matrices est très intuitif et commode en Matlab.

1. Les vecteurs :

Un vecteur est une liste ordonnée d’éléments. Si les éléments sont arrangés
horizontalement on dit que le vecteur est un vecteur ligne, par contre si les éléments sont
arrangés verticalement on dit que c’est un vecteur colonne.

Pour créer un vecteur ligne il suffit d’écrire la liste de ses composants entre crochets [et]
et de les séparés par des espaces ou des virgules comme suit :

>> V = [ 5 , 2 , 13 , -6 ] % Création d’un vecteur ligne V


V =
5 2 13 -6

>> U = [ 4 -2 1 ] % Création d’un vecteur ligne U


U =
4 -2 1

Pour créer un vecteur colonne il est possible d’utiliser une des méthodes suivantes :
1. écrire les composants du vecteur entre crochets [et] et de les séparés par des
points-virgules (;) comme suit :
>> U = [ 4 ; -2 ; 1 ] % Création d’un vecteur colonne U
U =
4
-2
1

2. écrire verticalement le vecteur :


>> U = [
4
-2
1
]
U =

4
-2
1

1
Université de Skikda 20 août 55
Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02
Cours : Langage Par : Z.Mansouri

3. calculer le transposé d’un vecteur ligne :


>> U = [ 4 -2 1 ]' % Création d’un vecteur colonne U
U =
4
-2
1

Si les composants d’un vecteur X sont ordonnés avec des valeurs consécutives, nous
pouvons le noter avec la notation suivante :

X = premier_élément : dernier_élément (Les crochets sont facultatifs dans ce cas)

Par exemple :
>> X = 1:8 % on peut aussi écrire colon(1,8)
X =
1 2 3 4 5 6 7 8
>> X = [1:8]
X =
1 2 3 4 5 6 7 8

Si les composants d’un vecteur X sont ordonnés avec des valeurs consécutives mais avec un
pas (d’incrémentation/décrémentation) différente de 1, nous pouvons spécifier le pas avec
la notation :

X = premier_élément : le_pas : dernier_élément (Les crochets sont facultatifs)

Par exemple :
>> X = [0:2:10] % le vecteur X contient les nombres pairs < 12
X =
0 2 4 6 8 10
>> X = [-4:2:6] % on peut aussi écrire colon(-4,2,6)
X =
-4 -2 0 2 4 6
>> X = 0:0.2:1 % on peut aussi écrire colon(0,0.2,1)
X =
0 0.2000 0.4000 0.6000 0.8000 1.0000

On peut écrire des expressions plus complexes comme :


>> V = [ 1:2:5 , -2:2:1 ]
V =
1 3 5 -2 0
>> A = [1 2 3]
A =
1 2 3
>> B = [A, 4, 5, 6]
B =
1 2 3 4 5 6

2
Université de Skikda 20 août 55
Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02
Cours : Langage Par : Z.Mansouri

1.1 Référencement et accès aux éléments d’un vecteur :

L’accès aux éléments d’un vecteur se fait en utilisant la syntaxe générale suivante :

nom_vecteur ( positions )
positions : peut être un simple
numéro, ou une liste de numéro
Les parenthèses (et) sont utilisées ici (pour la consultation). (un vecteur de positions)
Les crochets [et] sont utilisés uniquement pendant la création.

Exemples :

>> V = [5, -1, 13, -6, 7] % création du vecteur V qui contient 5 éléments
V =
5 -1 13 -6 7

eme
>> V(3) % la 3 position
ans =
13

>> V(2:4) % de la deuxième position jusqu'au quatrième


ans =
-1 13 -6

eme ere
>> V(4:-2:1) % de la 4 pos jusqu'à la 1 avec le pas = -2
ans =
-6 -1

eme
>> V(3:end) % de la 3 position jusqu'à la dernière
ans =
13 -6 7

ere eme eme


>> V([1,3,4]) % la 1 , la 3 et la 4 position uniquement
ans =
5 13 -6

>> V(1) = 8 % donner la valeur 8 au premier élément


V =
8 -1 13 -6 7

>> V(6) = -3 % ajouter un sixième élément avec la valeur -3


V =
8 -1 13 -6 7 -3

>> V(9) = 5 % ajouter un neuvième élément avec la valeur 5


V =
8 -1 13 -6 7 -3 0 0 5

3
Université de Skikda 20 août 55
Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02
Cours : Langage Par : Z.Mansouri
>> V(2) = [] % Supprimer le deuxième élément
V =
8 13 -6 7 -3 0 0 5

eme eme
>> V(3:5) = [] % Supprimer du 3 jusqu’au 5 élément
V =
8 13 0 0 5

1.2 Les opérations élément-par-élément pour les vecteurs :

Avec deux vecteurs 𝑢 �⃗ et 𝑣⃗, il est possible de réaliser des calcules élément par élément en
utilisant les opérations suivantes :
Exemple avec :
L’opération Signification >> u = [-2, 6, 1] ;
>> v = [ 3, -1, 4] ;
>> u+2
ans =
0 8 3
+ Addition des vecteurs >> u+v
ans =
1 5 5
>> u-2
ans =
-4 4 -1
- Soustraction des vecteurs >> u-v
ans =
-5 7 -3
>> u*2
ans =
-4 12 2
>> u.*2
.* Multiplication élément par élément ans =
-4 12 2
>> u.*v
ans =
-6 -6 4
>> u/2
ans =
-1.0000 3.0000 0.5000
>> u./2
./ Division élément par élément ans =
-1.0000 3.0000 0.5000
>> u./v
ans =
-0.6667 -6.0000 0.2500
>> u.^2
ans =
4 36 1
.^ Puissance élément par élément >> u.^v
ans =
-8.0000 0.1667 1.0000

L’écriture d’une expression tel que : u^2 génère une erreur car cette expression réfère a une
multiplication de matrices (u*u doit être réécrite u*u' ou u'*u pour être valide).

4
Université de Skikda 20 août 55
Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02
Cours : Langage Par : Z.Mansouri

1.3 La fonction linspace :


La création d’un vecteur dont les composants sont ordonnés par intervalle régulier et avec
un nombre d’éléments bien déterminé peut se réaliser avec la fonction :
linspace (début, fin, nombre d’éléments).
Le pas d’incrémentation est calculé automatiquement par Matlab selon la formule :
𝑓𝑖𝑛 − 𝑑𝑒𝑏𝑢𝑡
𝑙𝑒 𝑝𝑎𝑠 =
𝑛𝑜𝑚𝑏𝑟𝑒 𝑑 ′ é𝑙é𝑚𝑒𝑛𝑡𝑠 − 1
Par exemple :
>> X = linspace(1,10,4) % un vecteur de quatre élément de 1 à 10
X =
1 4 7 10

>> Y = linspace(13,40,4) % un vecteur de quatre élément de 13 à 40


Y =
13 22 31 40

La taille d’un vecteur (le nombre de ses composants) peut être obtenue avec la fonction
length comme suit :
>> length(X) % la taille du vecteur X
ans =
4

2. Les matrices :

Une matrice est un tableau rectangulaire d’éléments (bidimensionnels). Les vecteurs sont
des matrices avec une seule ligne ou une seule colonne (monodimensionnels).
Pour insérer une matrice, il faut respecter les règles suivantes :
• Les éléments doivent être mises entre des crochets [ et ]
• Les espaces ou les virgules sont utilisés pour séparer les éléments dans la même ligne
• Un point-virgule (ou la touche entrer) est utilisé pour séparer les lignes

Pour illustrer cela, considérant la matrice suivante :


1 2 3 4
𝐴 = �5 6 7 8�
9 10 11 12

Cette matrice pout être écrite en Matlab avec une des syntaxes suivantes :
>> A = [1,2,3,4 ; 5,6,7,8 ; 9,10,11,12] ;

>> A = [1 2 3 4 ; 5 6 7 8 ; 9 10 11 12] ;

>> A = [1,2,3,4
5,6,7,8
9,10,11,12] ;
>> A=[[1;5;9] , [2;6;10] , [3;7;11] , [4;8;12]] ;

5
Université de Skikda 20 août 55
Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02
Cours : Langage Par : Z.Mansouri

Le nombre d’éléments dans chaque ligne (nombre de colonnes) doit être identique dans
toutes les lignes de la matrice, sinon une erreur sera signalée par Matlab. Par exemple :
>> X = [1 2 ; 4 5 6]
Error using vertcat
CAT arguments dimensions are not consistent.

Une matrice peut être générée par des vecteurs comme le montre les exemples suivants :

>> x = 1:4 % création d’un vecteur x


x =
1 2 3 4
>> y = 5:5:20 % création d’un vecteur y
y =
5 10 15 20
>> z = 4:4:16 % création d’un vecteur z
z =
4 8 12 16

>> A = [x ; y ; z] % A est formée par les vecteurs lignes x, y et z


A =
1 2 3 4
5 10 15 20
4 8 12 16

>> B = [x' y' z'] % B est formée par les vecteurs colonnes x, y et z
B =
1 5 4
2 10 8
3 15 12
4 20 16

>> C = [x ; x] % C est formée par le même vecteur ligne x 2 fois


C =
1 2 3 4
1 2 3 4

2.1 Référencement et accès aux éléments d’une matrice :

L’accès aux éléments d’une matrice se fait en utilisant la syntaxe générale suivante :

nom_matrice ( positions_lignes , positions_colonnes )

positions : peut être un simple


Les parenthèses (et) sont utilisées ici (pour la consultation).
numéro, ou une liste de numéro
Les crochets [et] sont utilisés uniquement pendant la création.
(un vecteur de positions)

6
Université de Skikda 20 août 55
Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02
Cours : Langage Par : Z.Mansouri

Il est utile de noter les possibilités suivantes :


− L’accès à un élément de la ligne i et la colonne j se fait par : A(i,j)
− L’accès à toute la ligne numéro i se fait par : A(i,:)
− L’accès à toute la colonne numéro j se fait par : A(:,j)
Exemples :
>> A = [1,2,3,4 ; 5,6,7,8 ; 9,10,11,12] % création de la matrice A
A =
1 2 3 4
5 6 7 8
9 10 11 12

ème ème
>> A(2,3) % l’élément sur la 2 ligne à la 3 colonne
ans =
7

ère
>> A(1,:) % tous les éléments de la 1 ligne
ans =
1 2 3 4

ème
>> A(:,2) % tous les éléments de la 2 colonne
ans =
2
6
10

ème ème
>> A(2:3,:) % tous les éléments de la 2 et la 3 ligne
ans =
5 6 7 8
9 10 11 12

>> A(1:2,3:4) % La sous matrice supérieure droite de taille 2x2


ans =
3 4
7 8

>> A([1,3],[2,4]) % la sous matrice : lignes(1,3) et colonnes (2,4)


ans =
2 4
10 12

>> A(:,3) = [] % Supprimer la troisième colonne


A =
1 2 4
5 6 8
9 10 12

>> A(2,:) = [] % Supprimer la deuxième ligne


A =
1 2 4
9 10 12

7
Université de Skikda 20 août 55
Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02
Cours : Langage Par : Z.Mansouri

>> A = [A , [0;0]] % Ajouter une nouvelle colonne {ou A(:,4)=[0;0]}


A =
1 2 4 0
9 10 12 0

>> A = [A ; [1,1,1,1]] % Ajouter une nouvelle ligne {ou A(3,:)=[1,1,1,1]}


A =
1 2 4 0
9 10 12 0
1 1 1 1

Les dimensions d’une matrice peuvent être acquises en utilisant la fonction size.
Cependant, avec une matrice A de dimension m × n le résultat de cette fonction est un
vecteur de deux composants, une pour m et l’autre pour n.

>> d = size(A)
d =
3 4

Ici, la variable d contient les dimensions de la matrice A sous forme d’un vecteur. Pour
obtenir les dimensions séparément on peut utiliser la syntaxe :

>> d1 = size (A, 1) % d1 contient le nombre de ligne (m)


d1 =
3

>> d2 = size (A, 2) % d2 contient le nombre de colonne (n)


d2 =
4

2.2 Génération automatique des matrices

En Matlab, il existe des fonctions qui permettent de générer automatiquement des matrices
particulières. Dans le tableau suivant nous présentons-les plus utilisées :

La fonction Signification
zeros(n) Génère une matrice n × n avec tous les éléments = 0
zeros(m,n) Génère une matrice m × n avec tous les éléments = 0
ones(n) Génère une matrice n × n avec tous les éléments = 1
ones(m,n) Génère une matrice m × n avec tous les éléments = 1
eye(n) Génère une matrice identité de dimension n × n
magic(n) Génère une matrice magique de dimension n × n
rand(m,n) Génère une matrice de dimension m × n de valeurs aléatoires

8
Université de Skikda 20 août 55
Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02
Cours : Langage Par : Z.Mansouri

2.3 Les opérations de base sur les matrices :


L’opération Signification
+ L’addition
- La soustraction
.* La multiplication élément par élément
./ La division élément par élément
.\ La division inverse élément par élément
.^ La puissance élément par élément
* La multiplication matricielle
/ La division matricielle (A/B) = (A*B-1)
Les opérations élément par éléments sur les matrices sont les mêmes que ceux pour les
vecteurs (la seule condition nécessaire pour faire une opération élément par élément est
que les deux matrices aient les mêmes dimensions). Par contre la multiplication ou la
division des matrices requiert quelques contraintes (consulter un cours sur l’algèbre
matricielle pour plus de détail).

Exemple :
>> A=ones(2,3)
A =
1 1 1
1 1 1
>> B=zeros(3,2)
B =
0 0
0 0
0 0
>> B=B+3
B =
3 3
3 3
3 3
>> A*B
ans =
9 9
9 9
>> B=[B , [3 3 3]'] % ou bien B(:,3)=[3 3 3]’
B =
3 3 3
3 3 3
3 3 3
>> B=B(1:2,:) % ou bien B(3,:)=[]
B =
3 3 3
3 3 3
>> A=A*2
A =
2 2 2
2 2 2

9
Université de Skikda 20 août 55
Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02
Cours : Langage Par : Z.Mansouri
>> A.*B
ans =
6 6 6
6 6 6
>> A*eye(3)
ans =
2 2 2
2 2 2

2.4 Fonctions utiles pour le traitement des matrices

Voici quelques fonctions parmi les plus utilisées concernant les matrices:

La fonction L’utilité Exemple d’utilisation


>> A = [1,2;3,4] ;
>> det(A)
det Calcule de déterminant d’une matrice ans =
-2
>> inv(A)
ans =
inv Calcule l’inverse d’une matrice -2.0000 1.0000
1.5000 -0.5000
>> rank(A)
rank Calcule le rang d’une matrice ans =
2
>> trace(A)
trace Calcule la trace d’une matrice ans =
5
>> eig(A)
ans =
eig Calcule les valeurs propres -0.3723
5.3723
>> v = [-1,5,3];
>> u = [2,-2,1];
dot Calcule le produit scalaire de 2 vecteurs >> dot(u,v)
ans =
-9
>> norm(u)
norm Calcule la norme d’un vecteur ans =
3
>> cross(u,v)
cross Calcule le produit vectoriel de 2 vecteurs ans =
-11 -7 8
>> diag(A)
ans =
diag Renvoie le diagonal d’une matrice 1
4
>> V = [-5,1,3]
>> diag(V)
Crée une matrice ayant le vecteur V dans ans =
diag(V) -5 0 0
le diagonal et 0 ailleurs.
0 1 0
0 0 3

10
Université de Skikda 20 août 55
Niveau : 2eme année LMD Sciences et Techniques Chapitre N°02
Cours : Langage Par : Z.Mansouri
>> B=[1,2,3;4,5,6;7,8,9]
B =
1 2 3
4 5 6
7 8 9
>> tril(B)
ans =
1 0 0
4 5 0
7 8 9
tril Renvoie la partie triangulaire inferieure >> tril(B,-1)
ans =
0 0 0
4 0 0
7 8 0

>> tril(B,-2)
ans =
0 0 0
0 0 0
7 0 0
>> triu(B)
ans =
1 2 3
0 5 6
0 0 9
>> triu(B,-1)
ans =
triu Renvoie la partie triangulaire supérieure 1 2 3
4 5 6
0 8 9
>> triu(B,1)
ans =
0 2 3
0 0 6
0 0 0

11

Vous aimerez peut-être aussi