Le fichier source est ${UPS_HOME}/upsvtm/demo/${UPS_LANGUAGE}/matrice2.upl.
Cet exemple utilise les instructions de l'extension d'Up ! 5GL pour Up ! Mathematical.
Pour analyser le fichier source, UpsMat.upi doit être déclaré parmi les modules importés dans le fichier ${UPS_HOME}/ini/${UPS_USER}/upsp5l.ini.
upscmp Source=matrice2.upl
matrice2 TaillePartieDecimale=36 TaillePartieEntiere=36
upssng Source=matrice2.upl TaillePartieDecimale=36 TaillePartieEntiere=36
Source Composant "Exemple d'emploi du type Matrice" Version 4.0.0;
Procedure EcrireMatrice(Libelle : Caractere, M : Matrice[?,?] De Nul Ou Decimal)
/******************************************************************************/
Variable
/******/
I : Entier;
J : Entier;
Ligne : Nul Ou Caractere;
Debut
Ecran.Ecrire(Libelle);
Ecran.Ecrire("-------------");
Pour I=0 JusquA M.NbLignes-1 Faire
Si I==0 Alors
Ligne="{{";
Sinon
Ligne=" {";
Fin Si
Pour J=0 JusquA M.NbColonnes-1 Faire
Si J!=0 Alors
Ligne+=", ";
Fin Si
Ligne+=M[I,J].VersCaractere("-&&&.&&&.&&&.&,#&&.&&&");
Fin Pour
Si I==M.NbLignes-1 Alors
Ligne+="}}";
Sinon
Ligne+="}";
Fin Si
Ecran.Ecrire(Ligne);
Fin Pour
Fin Procedure
Procedure Appliquer1(D : Nul Ou Decimal)
/**************************************/
Debut
Ecran.Ecrire(D.VersCaractere("-&&&.&&&.&&&.&,#&&"));
Fin Procedure
Procedure Appliquer2(D1 : Nul Ou Decimal, D2 : Nul Ou Decimal)
/************************************************************/
Debut
Ecran.Ecrire(D1.VersCaractere("-&&&.&&&.&&&.&,#&&")+"+"+D2.VersCaractere("-&&&.&&&.&&&.&,#&&"));
Fin Procedure
Fonction Appliquer3(D : Nul Ou Decimal) Retourner Nul Ou Decimal
/**************************************************************/
Debut
Retourner -D;
Fin Fonction
Fonction Appliquer4(D1 : Nul Ou Decimal, D2 : Nul Ou Decimal) Retourner Nul Ou Decimal
/************************************************************************************/
Debut
Retourner -(D1+D2);
Fin Fonction
Principal
/*******/
Variable
/******/
A : Matrice[3,3] De Nul Ou Decimal;
B : Matrice[3,3] De Nul Ou Decimal;
C : Nul Ou Matrice[?,?] De Nul Ou Decimal;
Q : Nul Ou Matrice[?,?] De Nul Ou Decimal;
R : Nul Ou Matrice[?,?] De Nul Ou Decimal;
P : Nul Ou Matrice[?,?] De Nul Ou Decimal;
L : Nul Ou Matrice[?,?] De Nul Ou Decimal;
D : Nul Ou Matrice[?,?] De Nul Ou Decimal;
U : Nul Ou Matrice[?,?] De Nul Ou Decimal;
V : Nul Ou Matrice[?,?] De Nul Ou Decimal;
X : Nul Ou Decimal;
Y : Nul Ou Entier;
Debut
A[0,0]=Decimal(1.0);
A[0,1]=Decimal(2.0);
A[0,2]=Decimal(3.0);
A[1,0]=Decimal(4.0);
A[1,1]=Decimal(6.0);
A[1,2]=Decimal(5.0);
A[2,0]=Decimal(7.0);
A[2,1]=Decimal(8.0);
A[2,2]=Decimal(9.0);
EcrireMatrice("A", A);
B={{Decimal(4.0), Decimal(5.0), Decimal(6.0)}, {Decimal(7.0), Decimal(8.0), Decimal(9.0)}, {Decimal(1.0), Decimal(2.0), Decimal(3.0)}};
EcrireMatrice("B", B);
Ecran.Ecrire(");
C=A+B;
EcrireMatrice("A+B", C);
C=-A;
EcrireMatrice("-A", C);
C=A-B;
EcrireMatrice("A-B", C);
C=A*B;
EcrireMatrice("A*B", C);
C=B/A;
EcrireMatrice("B/A", C);
C=A.Cloner();
EcrireMatrice("++C", ++C);
EcrireMatrice("--C", --C);
C=C^4;
EcrireMatrice("C^4", C);
Ecran.Ecrire(");
C=Decimal(2.0);
EcrireMatrice("C=2.0", C);
C+=Decimal(3.0);
EcrireMatrice("C+=3.0", C);
C-=Decimal(3.0);
EcrireMatrice("C-=3.0", C);
C*=Decimal(3.0);
EcrireMatrice("C*=3.0", C);
C/=Decimal(3.0);
EcrireMatrice("C/=3.0", C);
C^=4;
EcrireMatrice("C^=4", C);
Ecran.Ecrire(");
C=A.Copier(0, 0, 3, 3);
EcrireMatrice("Copier()", C);
C=Decimal(0.0);
C.Coller(0, 0, A);
EcrireMatrice("Coller()", C);
C=A.InsererColonne(1, Decimal(10.0));
EcrireMatrice("InsererColonne()", C);
C=A.InsererLigne(1, Decimal(10.0));
EcrireMatrice("InsererLigne()", C);
C=A.SupprimerColonne(1);
EcrireMatrice("SupprimerColonne()", C);
C=A.SupprimerLigne(1);
EcrireMatrice("SupprimerLigne()", C);
C=A.Copier(0, 0, 3, 3);
C.PermuterColonnes(0, 2);
EcrireMatrice("PermuterColonnes()", C);
C=A.Copier(0, 0, 3, 3);
C.PermuterLignes(0, 2);
EcrireMatrice("PermuterLignes()", C);
C=A.Copier(0, 0, 3, 3);
C.Transposer();
EcrireMatrice("Transposer()", C);
C=A.Copier(0, 0, 3, 3);
C.AppliquerSymetrieVerticale();
EcrireMatrice("AppliquerSymetrieVerticale()", C);
C=A.Copier(0, 0, 3, 3);
C.AppliquerSymetrieHorizontale();
EcrireMatrice("AppliquerSymetrieHorizontale()", C);
Si C.EstDiagonale() Alors
Ecran.Ecrire("EstDiagonale");
Sinon
Ecran.Ecrire("Non EstDiagonale");
Fin Si
Si C.EstTriangulaireSuperieure() Alors
Ecran.Ecrire("EstTriangulaireSuperieure");
Sinon
Ecran.Ecrire("Non EstTriangulaireSuperieure");
Fin Si
Si C.EstTriangulaireInferieure() Alors
Ecran.Ecrire("EstTriangulaireInferieure");
Sinon
Ecran.Ecrire("Non EstTriangulaireInferieure");
Fin Si
Si C.EstSymetrique() Alors
Ecran.Ecrire("EstSymetrique");
Sinon
Ecran.Ecrire("Non EstSymetrique");
Fin Si
Si C.EstAntiSymetrique() Alors
Ecran.Ecrire("EstAntiSymetrique");
Sinon
Ecran.Ecrire("Non EstAntiSymetrique");
Fin Si
Ecran.Ecrire(");
A.Appliquer(Appliquer1);
A.Appliquer(Appliquer2, B);
C=A.Appliquer(Appliquer3);
EcrireMatrice("Appliquer3()", C);
C=A.Appliquer(Appliquer4, B);
EcrireMatrice("Appliquer4()", C);
Ecran.Ecrire(");
A={{Decimal(1.0), Decimal(1.0), Decimal(2.0)}, {Decimal(1.0), Decimal(0.0), Decimal(-2.0)}, {Decimal(-1.0), Decimal(2.0), Decimal(3.0)}};
DecomposerQR(A, Q, R);
EcrireMatrice("Q", Q);
EcrireMatrice("R", R);
DecomposerPLU(A, P, L, U);
EcrireMatrice("P", P);
EcrireMatrice("L", L);
EcrireMatrice("U", U);
DecomposerPLDU(A, P, L, D, U);
EcrireMatrice("P", P);
EcrireMatrice("L", L);
EcrireMatrice("D", D);
EcrireMatrice("U", U);
A={{Decimal(1.0), Decimal(2.0), Decimal(3.0)}, {Decimal(4.0), Decimal(6.0), Decimal(5.0)}, {Decimal(7.0), Decimal(8.0), Decimal(9.0)}};
DecomposerVL(A, V, L);
EcrireMatrice("V", V);
EcrireMatrice("L", L);
C=Inv(A);
EcrireMatrice("Inv(A)", C);
X=Decimal(Det(A));
Ecran.Ecrire("Det(A)="+X.VersCaractere("-&&&.&&&.&&&.&,#&&.&&&"));
X=Decimal(Trc(A));
Ecran.Ecrire("Trc(A)="+X.VersCaractere("-&&&.&&&.&&&.&,#&&.&&&"));
Y=Rng(A);
Ecran.Ecrire("Rng(A)="+Caractere(Y));
A={{Decimal(5.0), Decimal(-4.0), Decimal(1.0)}, {Decimal(-4.0), Decimal(6.0), Decimal(-4.0)}, {Decimal(0.0), Decimal(-4.0), Decimal(5.0)}};
C=Exp(A);
EcrireMatrice("Exp(A)", C);
C=Log(A);
EcrireMatrice("Log(A)", C);
C=Racine(A);
EcrireMatrice("Racine(A)", C);
Ecran.Ecrire(");
Fin Principal