Determinant d'une matrice
hajerboug
-
KX Messages postés 16761 Date d'inscription Statut Modérateur Dernière intervention -
KX Messages postés 16761 Date d'inscription Statut Modérateur Dernière intervention -
Bonsoir,
j'essaie de faire un programme de réseaux ouverts de files d'attentes avec turbo pascal(TP7) dont j'ai besoin de calculer le déterminant d'une matrice donnée.
Le problème c'est que lorsque j'exécute le programme m'affiche une valeur différente de celle que j'ai calculé manuellement.(c-a-d il m'affiche une fausse valeur).
Si vous pouvez m'aider a trouver l'erreur dans mon programme.
Voici le code que j'ai réalisé:
Merci
j'essaie de faire un programme de réseaux ouverts de files d'attentes avec turbo pascal(TP7) dont j'ai besoin de calculer le déterminant d'une matrice donnée.
Le problème c'est que lorsque j'exécute le programme m'affiche une valeur différente de celle que j'ai calculé manuellement.(c-a-d il m'affiche une fausse valeur).
Si vous pouvez m'aider a trouver l'erreur dans mon programme.
Voici le code que j'ai réalisé:
procedure det_aux( ma:matrice;var mb:matrice;l,c:integer); var i,j,d,e:integer; begin e:=1; for i:=1 to l do begin d:=1; if (i<>1) then begin for j:=1 to N do if(j<>c) then begin mb[e,d]:=ma[i,j]; d:=d+1; end; e:=e+1; end; end; end; function expo(n:integer):integer; begin if (n mod 2=0) then expo:=1 else expo:=-1 ; end; function determinant(m:matrice;l:integer):real; var i:integer; var m2:matrice; var x:real; begin x:=0; if(l=1) then determinant:=m[1,1] else begin for i:=1 to l do begin det_aux(m,m2,i,1); x:=x+(expo(i)*m[i,1]*determinant(m2,(l-1))); end; determinant:=x; end; end;
Merci
A voir également:
- Determinant d'une matrice
- Diagonale secondaire d'une matrice - Forum C
- Utiliser une formule pour déterminer pour quelles cellules le format sera appliqué - Guide
- Excel vous ne pouvez pas modifier une partie de matrice ✓ - Forum Excel
- Vous ne pouvez pas modifier une partie de matrice - Forum Excel
- Remplir une matrice 7 lettres ✓ - Forum C
7 réponses
Dans det_aux, tu as mis : if (i<>1) then au lieu de if (i<>l) then
De plus tu vas jusqu'à N sur j, or tu devrais t'arrêter à l comme pour i.
Je ne sais pas si c'est suffisant, néanmoins quelques conseils supplémentaires :
Utilises result dans les fonctions plutôt que le nom de la fonction.
Exemple : result:=x; au lieu de determinant:=x;
De plus je pense que tu aurais intérêt à faire de det_aux une fonction plutôt qu'une procédure (et la renommer) : function matricePriveDe(m:matrice; l,c:integer):matrice;
Comme ça ton calcul principal est plus clair :
result := result + expo(i)*m[i,1]*determinant( matricePriveDe(m,i,1), l-1);
De plus tu vas jusqu'à N sur j, or tu devrais t'arrêter à l comme pour i.
Je ne sais pas si c'est suffisant, néanmoins quelques conseils supplémentaires :
Utilises result dans les fonctions plutôt que le nom de la fonction.
Exemple : result:=x; au lieu de determinant:=x;
De plus je pense que tu aurais intérêt à faire de det_aux une fonction plutôt qu'une procédure (et la renommer) : function matricePriveDe(m:matrice; l,c:integer):matrice;
Comme ça ton calcul principal est plus clair :
result := result + expo(i)*m[i,1]*determinant( matricePriveDe(m,i,1), l-1);
bonsoir,
J'ai essayé de faire ce que vous m'avez dit mais dommage ça ne marche pas aussi surtout le cas où la taille de la matrice est supérieur à 2!!!!!!
Merci beaucoup pour tes conseils, mais a propos de la fonction pascal d'après ce que je cannais pascal ne peut pas me rendre une matrice, c'est pour cela que j'ai fait une procédure(par contre en C on peut la faire normalement).
Vous ne pouvez pas encore m' aidé car si je n'arrive pas à résoudre le problème du déterminant, toutes les valeurs qui viennent après seront fausses(parce qu'elles ont un rapport avec le déterminant).
merci.
J'ai essayé de faire ce que vous m'avez dit mais dommage ça ne marche pas aussi surtout le cas où la taille de la matrice est supérieur à 2!!!!!!
Merci beaucoup pour tes conseils, mais a propos de la fonction pascal d'après ce que je cannais pascal ne peut pas me rendre une matrice, c'est pour cela que j'ai fait une procédure(par contre en C on peut la faire normalement).
Vous ne pouvez pas encore m' aidé car si je n'arrive pas à résoudre le problème du déterminant, toutes les valeurs qui viennent après seront fausses(parce qu'elles ont un rapport avec le déterminant).
merci.
Tout dépend comment est fait ton type matrice...
Voici ce que j'ai fais en utilisanr à peu près le même algorithme que toi.
Mais je ne savais pas ce qu'était ton type matrice, alors j'ai fais le mien...
Voici ce que j'ai fais en utilisanr à peu près le même algorithme que toi.
Mais je ne savais pas ce qu'était ton type matrice, alors j'ai fais le mien...
PROGRAM Determinants; const NMAX = 20; type matrice = record tableau : array[1..NMAX,1..NMAX] of real; nbLignes : byte; nbColonnes : byte; end; function matricePriveDe(m:matrice; ligne,colonne:byte):matrice; var l,c:byte; begin result.nbLignes:=m.nbLignes-1; result.nbColonnes:=m.nbColonnes-1; for l:=1 to ligne-1 do begin for c:=1 to colonne-1 do result.tableau[l,c]:=m.tableau[l,c]; for c:=colonne+1 to m.nbColonnes do result.tableau[l,c-1]:=m.tableau[l,c]; end; for l:=ligne+1 to m.nbLignes do begin for c:=1 to colonne-1 do result.tableau[l-1,c]:=m.tableau[l,c]; for c:=colonne+1 to m.nbColonnes do result.tableau[l-1,c-1]:=m.tableau[l,c]; end; end; procedure afficher(m:matrice); var l,c:byte; begin for l:=1 to m.nbLignes do begin for c:=1 to m.nbColonnes do write(m.tableau[l,c]:0:2,chr(9)); writeln; end; writeln; end; function determinant(m:matrice):real; // calcul sur la première ligne var c:byte; r:real; begin if m.nbLignes=1 then exit(m.tableau[1,1]); result:=0; for c:=1 to m.nbLignes do begin if m.tableau[1,c]=0 then r:=0 else r:=m.tableau[1,c]*determinant(matricePriveDe(m,1,c)); if odd(c) then result:=result-r else result:=result+r; end; end; VAR m:matrice; BEGIN m.nbLignes:=3; m.nbColonnes:=3; m.tableau[1,1]:=4; m.tableau[1,2]:=3; m.tableau[1,3]:=1; // 4 3 1 m.tableau[2,1]:=5; m.tableau[2,2]:=2; m.tableau[2,3]:=7; // 5 2 7 m.tableau[3,1]:=8; m.tableau[3,2]:=0; m.tableau[3,3]:=2; // 8 0 2 afficher(m); writeln(determinant(m):0:3); // 138.000 readln; END.
voici mon type matrice:
const nb_max=10
Type matrice = array [1..nb_max,1..nb_max] of real;
..
..
..
J'ai pas pu utiliser la fonction:
function matricePriveDe(m:matrice; ligne,colonne:byte):matrice; car pascal ne peut pas me rendre une matrice,, vous ne pouvez pas me transformer cette fonction en procédure??
pour que je puisse l'utiliser!!!
j' attend votre réponse.
merci d'avance
const nb_max=10
Type matrice = array [1..nb_max,1..nb_max] of real;
..
..
..
J'ai pas pu utiliser la fonction:
function matricePriveDe(m:matrice; ligne,colonne:byte):matrice; car pascal ne peut pas me rendre une matrice,, vous ne pouvez pas me transformer cette fonction en procédure??
pour que je puisse l'utiliser!!!
j' attend votre réponse.
merci d'avance
Il est possible de mettre ton type matrice en résultat d'une fonction (d'ailleurs je ne connais aucun type qui ne peut pas être passé en retour d'une fonction)
J'ai adapté mon code à ton type matrice ce qui donne :
J'ai adapté mon code à ton type matrice ce qui donne :
PROGRAM Determinants; const nb_max = 10; type matrice = array [1..nb_max,1..nb_max] of real; function matricePriveDe(m:matrice; nbLigne,nbColonne,ligne,colonne:byte):matrice; var l,c:byte; begin for l:=1 to ligne-1 do begin for c:=1 to colonne-1 do result[l,c]:=m[l,c]; for c:=colonne+1 to nbColonne do result[l,c-1]:=m[l,c]; end; for l:=ligne+1 to nbLigne do begin for c:=1 to colonne-1 do result[l-1,c]:=m[l,c]; for c:=colonne+1 to nbColonne do result[l-1,c-1]:=m[l,c]; end; end; procedure afficher(m:matrice; nbLignes,nbColonnes:byte); var l,c:byte; begin for l:=1 to nbLignes do begin for c:=1 to nbColonnes do write(m[l,c]:0:2,chr(9)); writeln; end; writeln; end; function determinant(m:matrice; nbLC:byte):real; // calcul sur la première ligne var c:byte; r:real; begin if nbLC=1 then exit(m[1,1]); result:=0; for c:=1 to nbLC do begin if m[1,c]=0 then r:=0 else r:=m[1,c]*determinant(matricePriveDe(m,nbLC,nbLC,1,c),nbLC-1); if odd(c) then result:=result-r else result:=result+r; end; end; VAR m:matrice; BEGIN m[1,1]:=4; m[1,2]:=3; m[1,3]:=1; // 4 3 1 m[2,1]:=5; m[2,2]:=2; m[2,3]:=7; // 5 2 7 m[3,1]:=8; m[3,2]:=0; m[3,3]:=2; // 8 0 2 afficher(m,3,3); writeln(determinant(m,3):0:3); // 138.000 readln; END.
bonjour,,
Merci beaucoup.
J'ai essayé ce que vous avez fait, j'ai pas dit que ça ne marche pas sans tester.
J'ai fait et j'ai exécuté le programme et voici l'erreur qui s'affiche:
ERROR 34: INVALID FUNCTION RESULT TYPE.
(car en pascal le type MATRICE peut pas être en retour d'une fonction c'est pour cela j'aimerai bien remplacé la fonction: matricePriveDe avec une procédure pour que je puisse exécuté le programme )
J'attend votre reponse et merci.
Merci beaucoup.
J'ai essayé ce que vous avez fait, j'ai pas dit que ça ne marche pas sans tester.
J'ai fait et j'ai exécuté le programme et voici l'erreur qui s'affiche:
ERROR 34: INVALID FUNCTION RESULT TYPE.
(car en pascal le type MATRICE peut pas être en retour d'une fonction c'est pour cela j'aimerai bien remplacé la fonction: matricePriveDe avec une procédure pour que je puisse exécuté le programme )
J'attend votre reponse et merci.
En Pascal on peut le faire, j'ai testé le code avec Dev-Pascal et ça marche très bien, c'est juste Turbo Pascal qui fait un petit caprice voilà tout ^^
Alors avec une procédure ça donnerait :
Alors avec une procédure ça donnerait :
procedure matricePriveDe(m:matrice; nbLigne,nbColonne,ligne,colonne:byte; var mpd:matrice); var l,c:byte; begin for l:=1 to ligne-1 do begin for c:=1 to colonne-1 do mpd[l,c]:=m[l,c]; for c:=colonne+1 to nbColonne do mpd[l,c-1]:=m[l,c]; end; for l:=ligne+1 to nbLigne do begin for c:=1 to colonne-1 do mpd[l-1,c]:=m[l,c]; for c:=colonne+1 to nbColonne do mpd[l-1,c-1]:=m[l,c]; end; end; function determinant(m:matrice; nbLC:byte):real; // calcul sur la première ligne var c:byte; r:real; var mpd:matrice; begin //... else begin matricePriveDe(m,nbLC,nbLC,1,c,mpd); r:=m[1,c]*determinant(mpd,nbLC-1); end; //... end;
bonsoir,merci d'abord pour la réponse je vais essayer avec DEVpascal.
j'ai fait le même programme avec delphi7 pour la simulation des réseaux ouverts de filles d'attentes,pour calculer les arrivées (lambda=A(I-M)puissance (-1))
(tel que:A(vecteur),I:matrice identité et M:matrice de routage).
Je suis obligé de faire des opération sur les matrices:
1:différence entre les 2 matrices(I-P)
2:l'inverse du résultat(inverse(I-P))
3:produit de A * le résultat(A*inverse(I-P))
4:le résultat final du produit c'est lambda.
Mais le problème c'est que les valeurs que j'ai obtenues (qui sont affichées lorsque j'exécute le programme)sont fausses par rapport aux celles que j'ai calculées manuellement.
j'ai vérifié les étapes pas à pas mais je n'arrive pas à connaitre où il y a l'erreur.
Voici le code que j'ai réalisé si vous pouvez m'aidé à trouver l'erreur pour que lambda soit correcte.
Merci j'attend votre réponse.
j'ai fait le même programme avec delphi7 pour la simulation des réseaux ouverts de filles d'attentes,pour calculer les arrivées (lambda=A(I-M)puissance (-1))
(tel que:A(vecteur),I:matrice identité et M:matrice de routage).
Je suis obligé de faire des opération sur les matrices:
1:différence entre les 2 matrices(I-P)
2:l'inverse du résultat(inverse(I-P))
3:produit de A * le résultat(A*inverse(I-P))
4:le résultat final du produit c'est lambda.
Mais le problème c'est que les valeurs que j'ai obtenues (qui sont affichées lorsque j'exécute le programme)sont fausses par rapport aux celles que j'ai calculées manuellement.
j'ai vérifié les étapes pas à pas mais je n'arrive pas à connaitre où il y a l'erreur.
Voici le code que j'ai réalisé si vous pouvez m'aidé à trouver l'erreur pour que lambda soit correcte.
const NMAX = 20; type tab=array[1..nmax]of real; type matrice = record tableau : array[1..NMAX,1..NMAX] of real; nbLignes : byte; nbColonnes : byte; end; les opérations: function matricePriveDe(m:matrice; ligne,colonne:byte):matrice; var l,c:byte; begin result.nbLignes:=m.nbLignes-1; result.nbColonnes:=m.nbColonnes-1; for l:=1 to ligne-1 do begin for c:=1 to colonne-1 do result.tableau[l,c]:=m.tableau[l,c]; for c:=colonne+1 to m.nbColonnes do result.tableau[l,c-1]:=m.tableau[l,c]; end; for l:=ligne+1 to m.nbLignes do begin for c:=1 to colonne-1 do result.tableau[l-1,c]:=m.tableau[l,c]; for c:=colonne+1 to m.nbColonnes do result.tableau[l-1,c-1]:=m.tableau[l,c]; end; end; function determinant(m:matrice):real; // calcul sur la première ligne var c:byte; r:real; begin if m.nbLignes=1 then begin result:=m.tableau[1,1]; exit; end; result:=0; for c:=1 to m.nbLignes do begin if m.tableau[1,c]=0 then r:=0 else r:=m.tableau[1,c]*determinant(matricePriveDe(m,1,c)); if not odd(c) then result:=result-r else result:=result+r; end; end; function expo(n:integer):integer; begin if (n mod 2=0) then expo:=1 else expo:=-1 ; end; procedure coffacteur(ma:matrice;var mb:matrice;l:integer); var i,j : integer; var m2:matrice; begin if l=1 then begin mb.tableau[1,1]:=1; end else begin for i:=1 to l do begin for j:=1to l do begin m2:=matricePriveDe(m,i,j); mb.tableau[i,j]:=expo(i+j)*determinant(m2); end; end; end; end; procedure transp_mat(ma:matrice;var mb:matrice); var i,j:integer; begin for i:=1 to N do begin for j:=1 to N do begin mb.tableau[j,i]:=ma.tableau[i,j]; end; end; end; procedure multi_R(a:real;ma:matrice; var mb:matrice); var i,j:integer; begin for i:=1 to N do begin for j:=1 to N do begin mb.tableau[i,j]:=ma.tableau[i,j]*a; end; end; end; procedure inverse(ma:matrice;var mb:matrice;l:integer); var m1,m2:matrice; d:real; begin if determinant(ma)<> 0 then begin d:=(1/determinant(ma)); writeln ('1/d = ',d); coffacteur(ma,m1,l); transp_mat(m1,m2); multi_R(d,m2,mb); end; end; procedure produimat (t:tab; M:matrice;N:integer; var r:tab); var i,j,k:integer; begin for i:=1 to N do begin r[i]:=0; for j:=1 to N do r[i]:=r[i]+t[j]*M.tableau[j,i]; end; end; procedure init_identite (var m:matrice;n:integer); var i,j:integer; begin for i:=1 to n do for j:=1 to n do if i=j then m.tableau[i,j]:=1 else m.tableau[i,j]:=0; end; procedure difmat(m1,m2:matrice;var m3:matrice); var i,j: integer; begin for i:=1 to N do for j:=1 to N do m3.tableau[i,j]:=m1.tableau[i,j]-m2.tableau[i,j]; end; procedure calcullambda (t:tab; M:matrice); var i:integer; I_P:matrice; begin init_identite(mat_I,n); difmat(mat_I,M,I_P); I_P.nbLignes:=m.nbLignes; I_P.nbColonnes:=m.nbColonnes; mat_inv.nbLignes:=m.nbLignes; mat_inv.nbColonnes:=m.nbColonnes; inverse(I_P,mat_inv,N); produimat (t,mat_inv,N,lambda); affichlambda (lambda,N); end;
Merci j'attend votre réponse.
Si A est un vecteur colonne, la multiplication A*B impose que B soit un vecteur ligne, or (I-P)^(-1) est une matrice carrée ce qui pose un "petit" problème.
Par contre, on pourrait avoir (I-P)^-1*A ce qui donnerait toujours une "division" par (I-P) mais dans ce cas lambda serait un vecteur colonne... est-ce ce que l'on doit obtenir ?
Par contre, on pourrait avoir (I-P)^-1*A ce qui donnerait toujours une "division" par (I-P) mais dans ce cas lambda serait un vecteur colonne... est-ce ce que l'on doit obtenir ?
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Je regarderais plus un détail le reste du code demain si ça ne résout pas ton problème, mais tu as modifié mon code de façon erronée :
Tu as écrit :
Alors que moi j'avait écrit :
Tu as écrit :
if not odd(c) then result:=result-r else result:=result+r;
Alors que moi j'avait écrit :
if odd(c) then result:=result-r else result:=result+r;
Autant pour moi, je me suis fait avoir par mon exemple (j'obtient +138.0 avec ou sans le not)
Effectivement c'est logique, on a un + quand c est impair (car 1 est impair), et - sinon.
Dans ce cas il est plus propre d'écrire :
Je vais chercher le problème avec le reste du code, je te dirais ça demain.
Effectivement c'est logique, on a un + quand c est impair (car 1 est impair), et - sinon.
Dans ce cas il est plus propre d'écrire :
if odd(c) then result:=result+r else result:=result-r;
Je vais chercher le problème avec le reste du code, je te dirais ça demain.
Je n'ai pas repris ton code car je trouve que tu fais beaucoup plus de fonctions que tu n'en as besoin !
J'ai donc repris tes 4 points et fais une fonction pour chacun des ces 4 points.
Faire des fonctions intermédiaires n'est pas utile ici puisque tes 3 premiers points définissent déjà les fonctions intermédiaires de la quatrième.
De plus, pour être cohérent, j'ai modifié ton type tab en un type vecteur qui contient la taille réelle de celui-ci (comme le type matrice). Ça évite d'avoir à se promener avec des paramètres de tailles dans les fonctions alors qu'ils sont inhérents non pas au calcul mais aux données !
Remarque : je n'ai pas effectué de tests, je te laisse le soin de regarder ce que ça donne...
La confiance n'exclut pas le contrôle
J'ai donc repris tes 4 points et fais une fonction pour chacun des ces 4 points.
Faire des fonctions intermédiaires n'est pas utile ici puisque tes 3 premiers points définissent déjà les fonctions intermédiaires de la quatrième.
De plus, pour être cohérent, j'ai modifié ton type tab en un type vecteur qui contient la taille réelle de celui-ci (comme le type matrice). Ça évite d'avoir à se promener avec des paramètres de tailles dans les fonctions alors qu'ils sont inhérents non pas au calcul mais aux données !
Remarque : je n'ai pas effectué de tests, je te laisse le soin de regarder ce que ça donne...
PROGRAM Determinants; //--------------------------------------------- const NMAX = 20; type vecteur = record tableau : array[1..NMAX] of real; nbLignes : byte; end; type matrice = record tableau : array[1..NMAX,1..NMAX] of real; nbLignes : byte; nbColonnes : byte; end; //--------------------------------------------- function matricePriveDe(m:matrice; ligne,colonne:byte):matrice; var l,c:byte; begin result.nbLignes:=m.nbLignes-1; result.nbColonnes:=m.nbColonnes-1; for l:=1 to ligne-1 do begin for c:=1 to colonne-1 do result.tableau[l,c]:=m.tableau[l,c]; for c:=colonne+1 to m.nbColonnes do result.tableau[l,c-1]:=m.tableau[l,c]; end; for l:=ligne+1 to m.nbLignes do begin for c:=1 to colonne-1 do result.tableau[l-1,c]:=m.tableau[l,c]; for c:=colonne+1 to m.nbColonnes do result.tableau[l-1,c-1]:=m.tableau[l,c]; end; end; //--------------------------------------------- function determinant(m:matrice):real; var c:byte; r:real; begin if m.nbLignes=1 then begin result:=m.tableau[1,1]; exit; end; result:=0; for c:=1 to m.nbLignes do begin if m.tableau[1,c]=0 then r:=0 else r:=m.tableau[1,c]*determinant(matricePriveDe(m,1,c)); if odd(c) then result:=result+r else result:=result-r; end; end; //--------------------------------------------- function difference(m:matrice):matrice; // calcul de (I-M) var l,c:byte; begin result.nbLignes:=m.nbLignes; result.nbColonnes:=m.nbColonnes; for l:=1 to m.nbLignes do for c:=1 to m.nbColonnes do if l=c then result.tableau[l,c]:=1-m.tableau[l,c] else result.tableau[l,c]:=-m.tableau[l,c]; end; //--------------------------------------------- function inverse(m:matrice):matrice; // méthode des cofacteurs var l,c:byte; r,d:real; begin d:=determinant(m); if d=0 then begin writeln('matrice non inversible'); halt; end; result.nbLignes:=m.nbColonnes; result.nbColonnes:=m.nbLignes; for l:=1 to m.nbLignes do for c:=1 to m.nbColonnes do begin r:=determinant(matricePriveDe(m,l,c)); // cofacteur if odd(l+c) then result.tableau[c,l]:=-r/d // on transpose directement else result.tableau[c,l]:= r/d; // sans oublier la division end; end; //--------------------------------------------- function multiplier(m:matrice;v:vecteur):vecteur; // m*v var l,c:byte; r:real; begin if m.nbColonnes<>v.nbLignes then begin writeln('multiplication incompatible'); halt; end; result.nbLignes:=v.nbLignes; for l:=1 to m.nbLignes do begin r:=0; for c:=1 to m.nbColonnes do r:=r+m.tableau[l,c]*v.tableau[c]; result.tableau[l]:=r; end; end; //--------------------------------------------- function lambda(m:matrice;v:vecteur):vecteur; begin result:=multiplier(inverse(difference(m)),v); end; //--------------------------------------------- BEGIN END.
La confiance n'exclut pas le contrôle
En mettant les deux fonctions matricePriveDe et Determinant, as-tu pensé à enlever les deux lignes suivantes :
Je n'ai pas Delphi pour tester, mais pour l'avoir utilisé il y a quelques années je ne pense pas que ça vienne d'un bug de Delphi (contrairement à TP7) donc comme ça marche chez moi sur Dev-Pascal, ça doit marcher chez toi sur Delphi ^^
function matricePriveDe(m:matrice; ligne,colonne:byte):matrice; function determinant(m:matrice):real;
Je n'ai pas Delphi pour tester, mais pour l'avoir utilisé il y a quelques années je ne pense pas que ça vienne d'un bug de Delphi (contrairement à TP7) donc comme ça marche chez moi sur Dev-Pascal, ça doit marcher chez toi sur Delphi ^^
Resource file icon file not found : tu as surement dû vouloir faire un nouveau projet ou je ne sais pas trop quoi dont je ne me sers jamais...
Si tu fais un "New Source File (Ctrl+U)" et que tu colles exactement ce que j'ai mis dans Dev-Pascal et que tu enregistres ça dans un fichier .pas, ça marche (c'est ce que je fais)
Il est possible qu'il ne t'affiche que des 0.00 car les valeurs sont trop petites.
En effet ma fonction d'affichage (que je n'avais pas remise d'ailleurs) tronquait les valeurs à 2 chiffres après la virgule, donc 0.002 est tronquée en 0.00
De mon côté j'ai fait quelques tests, et je trouve à la main les même résultats que le programme pour déterminant, différence, inverse, et multiplier (je n'ai pas fait lambda mais ça se déduit des précédents)
Si tu fais un "New Source File (Ctrl+U)" et que tu colles exactement ce que j'ai mis dans Dev-Pascal et que tu enregistres ça dans un fichier .pas, ça marche (c'est ce que je fais)
Il est possible qu'il ne t'affiche que des 0.00 car les valeurs sont trop petites.
En effet ma fonction d'affichage (que je n'avais pas remise d'ailleurs) tronquait les valeurs à 2 chiffres après la virgule, donc 0.002 est tronquée en 0.00
De mon côté j'ai fait quelques tests, et je trouve à la main les même résultats que le programme pour déterminant, différence, inverse, et multiplier (je n'ai pas fait lambda mais ça se déduit des précédents)
//--------------------------------------------- const NCAV = 4; // nombre de chiffres après la virgule procedure afficher(m:matrice); var l,c:byte; begin for l:=1 to m.nbLignes do begin for c:=1 to m.nbColonnes do write(m.tableau[l,c]:0:NCAV,chr(9)); writeln; end; writeln; end; procedure afficher(v:vecteur); var l:byte; begin for l:=1 to v.nbLignes do writeln(v.tableau[l]:0:NCAV); writeln; end; var m:matrice; v:vecteur; BEGIN m.nbLignes:=3; m.nbColonnes:=3; m.tableau[1,1]:=6; m.tableau[1,2]:=2; m.tableau[1,3]:=5; m.tableau[2,1]:=7; m.tableau[2,2]:=1; m.tableau[2,3]:=0; m.tableau[3,1]:=4; m.tableau[3,2]:=8; m.tableau[3,3]:=3; afficher(m); // OK v.nbLignes:=3; v.tableau[1]:=5; v.tableau[2]:=2; v.tableau[3]:=4; afficher(v); // OK writeln(determinant(m):0:NCAV,chr(10)); // 236 : OK afficher(difference(m)); // [-5 -2 -5 -7 0 0 -4 -5 -2] : OK afficher(inverse(m)); // [3 34 -5 -21 -2 35 52 -40 -8]/236 : OK afficher(multiplier(m,v)); // [54 37 48] : OK afficher(lambda(m,v)); // [-0.2857 -0.1984 -0.63] readln; END.
Est ce que je peux vous envoyer mon code source sous une forme confidentielle(par exemple votre mail, si cela ne vous dérange pas ), car j'ai pas envie qu'il soit copié si je le mets sur le forum en totalité. Car je n'arrive pas à me débarrasser des messages d'erreurs.
Je m'excuse d'abuser de votre gentillesse.
Merci
Je m'excuse d'abuser de votre gentillesse.
Merci