Determinant matrice

Fermé
sarah - 28 avril 2009 à 11:03
quendistu Messages postés 507 Date d'inscription lundi 3 novembre 2008 Statut Membre Dernière intervention 4 juin 2009 - 28 avril 2009 à 12:23
Bonjour,
J'aimerais calculer le déterminant d'une matrice.
J'effectue l'algorithme suivant:
def Det(mat):
" retourne le déterminant de la matrice mat"
s=0
j=0
while j<3:
B=supprimer(j,0,mat)
print B
if j%2==0:
s=s+mat[j][0]*Det(B)
else:
s=s-mat[j][0]*Det(B)
j=j+1
return s

Le probleme est que quand j'effectue la fonction supprimer alors mat perd sa ligne j et sa colonne 0 mais après il faut que je retrouve ma matrice de départ pour pouvoir supprimer sa ligne j+1 et sa colonne 0 sinon, d'une matrice 3*3 je passe a une 2*2 puis à un 1*1.
J'espere mettre fait comprendre. Merci de me donner un coup de main.(j'utilises python)

5 réponses

quendistu Messages postés 507 Date d'inscription lundi 3 novembre 2008 Statut Membre Dernière intervention 4 juin 2009 87
28 avril 2009 à 11:16
0
Merci, je me suis inspirée de cet exemple justement mais leur code est faux! Donc ça m'aide pas franchement!
0
fiddy Messages postés 11069 Date d'inscription samedi 5 mai 2007 Statut Contributeur Dernière intervention 23 avril 2022 1 835 > sarah
28 avril 2009 à 11:52
Tu as dû mal t'inspirer alors, car leur code est correct ;-))).
0
quendistu Messages postés 507 Date d'inscription lundi 3 novembre 2008 Statut Membre Dernière intervention 4 juin 2009 87
28 avril 2009 à 11:43
C'est bien ce que me suis dit ; pour réconcilier le besoin de supprimer des lignes et des colonnes et le besoin de conserver l'intégralité de la matrice, la fonction supprimer soit retourner une copie de la matrice tronquée et non la matrice passée tronquée elle même ; ou alors faire cette copie dans la fonstion Det elle-même.

Je ne m'y connais pas en python, mais ce serait comme ceci :


def Det(mat):
" retourne le déterminant de la matrice mat"
s=0
j=0
while j<3:
copiemat=mat
B=supprimer(j,0,copiemat)
print B
if j%2==0:
s=s+mat[j][0]*Det(B)
else:
s=s-mat[j][0]*Det(B)
j=j+1
return s



def Det(mat):
" retourne le déterminant de la matrice mat"
s=0
j=0
while j<3:
B=supprimer(j,0,matprime)
print B
if j%2==0:
s=s+mat[j][0]*Det(B)
else:
s=s-mat[j][0]*Det(B)
j=j+1
return s
0
fiddy Messages postés 11069 Date d'inscription samedi 5 mai 2007 Statut Contributeur Dernière intervention 23 avril 2022 1 835
28 avril 2009 à 11:56
Utilise les balises de conservations de code (à droite de souligner) lorsque tu postes un programme et en particulier lorsque c'est du python.
copiemat=mat
Cela ne changera rien, étant donné que copiemat contiendra l'adresse de mat. Donc la modification de copiemat agira sur mat également.
0
quendistu Messages postés 507 Date d'inscription lundi 3 novembre 2008 Statut Membre Dernière intervention 4 juin 2009 87
28 avril 2009 à 12:00
Donc fiddy la question à laquelle répondre pour apporter quelquechose c'est :
comment copier la matrice au lieu de copier son adresse.
A toi
0
fiddy Messages postés 11069 Date d'inscription samedi 5 mai 2007 Statut Contributeur Dernière intervention 23 avril 2022 1 835
28 avril 2009 à 12:14
comment copier la matrice au lieu de copier son adresse.
C'est ta question et non la sienne ça. Le lien donné marche parfaitement (je viens de tester).

Sinon pour répondre à ta question :
copieMat = copy.copy(mat) 

PS : n'oublie pas d'importer copy.

Cdlt
0
quendistu Messages postés 507 Date d'inscription lundi 3 novembre 2008 Statut Membre Dernière intervention 4 juin 2009 87
28 avril 2009 à 12:16
La réponse de fiddy e faisant attendre, je propose une fonction Copiemat, inspirée de la fonction Addmat du site déjà cité :

def Addmat(M1,M2):
"Additionne deux matrices carrées"
N=len(M1)
M=[None]*N
for i in range (N):
M[i]=[0]*N
for j in range (N):
M[i][j]=M1[i][j]+M2[i][j]
return M

donc :

def Addmat(M1):
"Copie deux matrices carrées"
N=len(M1)
M=[None]*N
for i in range (N):
M[i]=[0]*N
for j in range (N):
M[i][j]=M1[i][j]
return M


voilààà

N=len(M1)
M=[None]*N
0
fiddy Messages postés 11069 Date d'inscription samedi 5 mai 2007 Statut Contributeur Dernière intervention 23 avril 2022 1 835
28 avril 2009 à 12:22
La réponse de fiddy e faisant attendre, je propose une fonction Copiemat, inspirée de la fonction Addmat du site déjà cité :
J'ai répondu avant ton post (cf post 7).

Sinon, lorsque tu postes un code (surtout en python), utilise la balise prévue à cet effet (à droite du bouton souligner), sinon cela n'affiche pas l'indentation, et le code ne vaut rien (délimitation des blocs perdue).
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
quendistu Messages postés 507 Date d'inscription lundi 3 novembre 2008 Statut Membre Dernière intervention 4 juin 2009 87
28 avril 2009 à 12:23
Bravo
0