 |
Apprendre Maple Site dédié au logiciel de calcul formel Maple
|
Voir le sujet précédent :: Voir le sujet suivant |
Auteur |
Message |
Erable
Inscrit le: 06 Fév 2010 Messages: 16
|
Posté le: 31 Mai 2010 12:31 Sujet du message: Puissances de matrices |
|
|
Bonjour, j’ai une matrice d’adjacence (des 0 et des 1), je cherche à partir de quelle puissance un des termes de cette matrice n’est plus nul. J’utilise donc ce petit algorithme :
Code: | LongueurCheminPlusCourt := proc (A)
local B, k;
B := A; k := 1;
while evalm(B)[1, NombreParagraphes] = 0
do B := `&*`(B, A);
k := k+1;
end do;
k;
end proc
|
Le problème, c’est que pour chaque calcul de puissance, au lieu d’utiliser la matrice déjà calculée, l’ordinateur recommence à zéro. Par exemple, s’il vient de calculer A^50, au lieu de calculer A^51 en multipliant A^50 par A, il calcule A^51 bêtement. En fait à la ligne B := `&*`(B, A); il ne calcule pas le nouveau B, il écrit juste ce que B représente, du genre :
B := `&*`(`&*`(`&*`(`&*`(`&*`(MatriceAdjacence, MatriceAdjacence), MatriceAdjacence), MatriceAdjacence), MatriceAdjacence), MatriceAdjacence)
Quelqu'un a une idée? |
|
Revenir en haut de page |
|
 |
ALS
Inscrit le: 11 Sep 2006 Messages: 647
|
Posté le: 31 Mai 2010 16:59 Sujet du message: |
|
|
Bonjour,
je pense qu'il faut remplacer 2 lignes de votre procédure comme ceci:
Code: |
LongueurCheminPlusCourt := proc (A)
local B, k;
B := evalm(A); k := 1;
while B[1, NombreParagraphes] = 0
do B := evalm(B&* A);
k := k+1;
end do;
k;
end proc:
|
Cela devrait fonctionner maintenant. |
|
Revenir en haut de page |
|
 |
Erable
Inscrit le: 06 Fév 2010 Messages: 16
|
Posté le: 31 Mai 2010 17:15 Sujet du message: |
|
|
Ok merci ça marche ! |
|
Revenir en haut de page |
|
 |
|
|
Vous ne pouvez pas poster de nouveaux sujets dans ce forum Vous ne pouvez pas répondre aux sujets dans ce forum Vous ne pouvez pas éditer vos messages dans ce forum Vous ne pouvez pas supprimer vos messages dans ce forum Vous ne pouvez pas voter dans les sondages de ce forum
|

Développé par phpBB © 2001, 2006 phpBB Group
Traduction par : phpBB-fr.com
Apprendre Maple - ©
- Alain Le Stang - Navigation optimisée pour une résolution 1024 x 768.
|