IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Lazarus Pascal Discussion :

Multiplication de nombres complexes [Lazarus]


Sujet :

Lazarus Pascal

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2013
    Messages : 7
    Par défaut Multiplication de nombres complexes
    Bonjour,

    Je suis étudiant en physique-chimie et je dois dans le cadre de mon stage écrire un programme qui fait intervenir des nombres complexes pour calculer les coefficients de réflexion et transmission, puis afficher 2 graphiques de ces derniers en fonction de lambda. Pour le dernier j'ai déjà fait quelque chose.Or le pascal n'aime pas les complexes et si je prends uniquement l'amplitude au carré, ce qui élimine les complexes, je n'ai que ma dernière couche mince.

    Je dois donc au préalable écrire un programme pouvant prendre en compte la multiplication de nombres complexes puis de matrices complexes. Le problème est que je ne sais pas du tout comment faire et les sujets d'aides pour lazarus sont faibles.

    Si quelqu'un pouvait m'aider ce serait vraiment bien car je suis en train de me casser la tête depuis hier sans résultat...

  2. #2
    Membre averti
    Homme Profil pro
    Inscrit en
    Octobre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Octobre 2012
    Messages : 22
    Par défaut
    Bonjour,

    cela me semble être plus un problème mathématique que de langage pascal, lequel à ma connaissance ne possède pas de type prédéfini pour représenter un nombre complexe.

    Un nombre complexe peut être représenté par un couple de nombres réels (partie réelle et partie imaginaire). Le codage de la multiplication est simple :

    (a+ib)*(c+id) = (ac-bd) +i(ad+bc) sauf erreur de ma part

    pour la multiplication de matrices, mes souvenirs sont trop lointains mais je suppose qu'il faut utiliser les mêmes règles que pour le produit de matrices réelles et tenir compte du fait que les éléments de chaque matrice sont des nombres complexes ...

  3. #3
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2013
    Messages : 7
    Par défaut
    Tout d'abord merci pour ta réponse qui fut très rapide,

    J'ai essayé ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    procedure Produit_Z;
    var
    a,b,c,d: integer;
    Z_1,Z_2:real;
     
    Begin
    Z_1:=(a+i*b);
    Z_2:=(c+i*d);
    Z_1*Z_2:=(a*c-b*d)+i*(ad+bc);
     
    end;
    Le problème est qu'il ne connaît pas 'i' et que je ne sais pas comment faire pour qu'il sache que c'est un nombre complexe. Créer simplement une variable? Mais après est ce qu'il va reconnaitre le 'i' comme le nombre complexe?

    Pour le produit matriciel j'ai écris ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    procedure Produit_M;
    var
    i,j,k:integer;
    M:array [1..2,1..2] of real;
    Mi:array [1..2,1..2] of real;
    Mint:array [1..2,1..2] of real;
    R:real;
      begin
      Mint[1,0]:=1;
      Mint[0,1]:=0;
      Mint[1,0]:=0;
      Mint[0,1]:=1;
      for i:=1 to 2 do
        for j:=1 to 2 do
        begin
         R:=0;
           for k:=1 to 2 do
           R:=R+Mi[i,k]*Mint[k,j];
           M[i,j]:=R
        end;
      end;
    On m'a dit qu'il faudrait pour les matrices complexes que je fasse un tableau et que dans chaque case j'entre 2 valeurs comme (2+5i). Il faudrait que je fasse un array of string et que je transforme mon (2+5i) en string pour le rentrer ?

  4. #4
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 172
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 172
    Billets dans le blog
    9
    Par défaut
    Bonjour !

    Il y a de nombreuses librairies mathématiques en Pascal (à utiliser telles quelles ou à étudier comme exemple), comme celle-ci.

  5. #5
    Membre averti
    Homme Profil pro
    Inscrit en
    Octobre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Octobre 2012
    Messages : 22
    Par défaut
    Il est clair que tu ne peux pas écrire : Z_1:=(a+i*b);
    effectivement i n'est pas reconnu ...

    Comme je te l'ai indiqué, un nombre complexe peut être représenté par un couple de nombres réels (partie réelle et partie imaginaire). Il faut donc créer un type pour représenter un nombre complexe (record ou array ...), par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    type 
      complex = record 
           re, im : integer 
       end;
    ensuite tu écris une fonction qui prend 2 nombres complexes en arguments et renvoie leur produit ...

  6. #6
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2013
    Messages : 7
    Par défaut
    Si je me dis que mon nombre complexe est un tableau de 2 valeurs (première case: partie réelle et la seconde la partie imaginaire). Est ce que cela fonctionne?

    Ainsi:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    procedure Produit_Z (var Z1,Z2,Zp : array of real);
    Begin
    Zp[1]:=Z1[1]*Z2[1]-Z1[2]*Z2[2];
    Zp[2]:=Z1[1]*Z2[2]+Z1[2]*Z2[1];
     
    end;
    Merci beaucoup

  7. #7
    Membre averti
    Homme Profil pro
    Inscrit en
    Octobre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Octobre 2012
    Messages : 22
    Par défaut
    Oui, c'est le principe, à vérifier pour la syntaxe de l'array que je n'ai pas utilisé depuis longtemps ...

  8. #8
    Membre Expert
    Avatar de e-ric
    Homme Profil pro
    Apprenti chat, bienfaiteur de tritons et autres bestioles
    Inscrit en
    Mars 2002
    Messages
    1 568
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Apprenti chat, bienfaiteur de tritons et autres bestioles

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 568
    Par défaut
    Salut à tous

    En fouillant dans les unités de FPC (2.6), j'ai trouvé une unité ucomplex.pp dans le dossier \source\rtl\inc. Le reproche que l'on peut y faire est l'utilisation du type Real, les types Double ou Extended aurait été du meilleur effet... Copie l'unité et adapte-la selon tes besoins et si cela en vaut la peine, fait partager ton travail à la communauté.

    Cela t'évitera de réinventer la roue, pour les matrices, je n'ai pas cherché.

    e-ric

    M E N S . A G I T A T . M O L E M
    Debian 64bit, Lazarus + FPC -> n'oubliez pas de consulter les FAQ Delphi et Pascal ainsi que les cours et tutoriels Delphi et Pascal

    "La théorie, c'est quand on sait tout, mais que rien ne marche. La pratique, c'est quand tout marche, mais qu'on ne sait pas pourquoi. En informatique, la théorie et la pratique sont réunies: rien ne marche et on ne sait pas pourquoi!".
    Mais Emmanuel Kant disait aussi : "La théorie sans la pratique est inutile, la pratique sans la théorie est aveugle."

  9. #9
    Membre Expert
    Avatar de e-ric
    Homme Profil pro
    Apprenti chat, bienfaiteur de tritons et autres bestioles
    Inscrit en
    Mars 2002
    Messages
    1 568
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Apprenti chat, bienfaiteur de tritons et autres bestioles

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 568
    Par défaut
    en ce qui concerne l'utilisation de tableau, tu peux la combiner en redéfinissant le type sous forme d'un enreg. avec variante

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
        type complex = record
           case boolean of
           False : (re, im : Extended);
           True : (array[1..2] of Extended);
          end;
       end;
    J'ai pas fait de test, corrige si nécessaire et adapte le code. Les détails sur l'emploi des enreg. avec variante se trouve dans le 'Language Reference Guide'.

    e-ric

    M E N S . A G I T A T . M O L E M
    Debian 64bit, Lazarus + FPC -> n'oubliez pas de consulter les FAQ Delphi et Pascal ainsi que les cours et tutoriels Delphi et Pascal

    "La théorie, c'est quand on sait tout, mais que rien ne marche. La pratique, c'est quand tout marche, mais qu'on ne sait pas pourquoi. En informatique, la théorie et la pratique sont réunies: rien ne marche et on ne sait pas pourquoi!".
    Mais Emmanuel Kant disait aussi : "La théorie sans la pratique est inutile, la pratique sans la théorie est aveugle."

  10. #10
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 967
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 967
    Par défaut
    Fie,

    Pourquoi vouloir persister à utiliser un tableau que que le type record est fait pour ça, et, non négligeable, rend le code beaucoup plus lisible, donc modifiable.

    Quelle est la version la plus lisible :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    type
      complexe = record
        reel, imagin : real
      end;
     
    var
      cpx : complexe;
     
    ...
     
      cpx.reel := 1.0;
      cpx.imagin := 1.56;
    ...
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    type
      complexe = array [1..2] of real;
     
    var
      cpx : array;
     
    ...
      cpx[1] := 1.0;
      cpx[2] := 1.56;
    ...
    et en plus, en utilisant quand même un record !

    Un record avec un case of ne se justifie que pour le stockage de diverses données, avec généralement divers types, et toujours des noms différents dans une même variable, en se donnant le moyen de distinguer la variante réellement concernée, pour orienter l'utilisation.

  11. #11
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 172
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 172
    Billets dans le blog
    9
    Par défaut
    Dans un tableau aussi on peut mettre des noms.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    const
      reel = 0;
      imagin = 1;
     
    type
      complexe = array[reel..imagin] of real;
     
    var
      cpx: complexe;
     
    begin
      cpx[reel] := 1.0;
      cpx[imagin] := 1.56;
    end.
    Cela est dit sans intention de contester le choix recommandé par droggo.

  12. #12
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2013
    Messages : 7
    Par défaut
    Merci à tous pour vos réponses. Je n'ai pas pu répondre du week end car lors de ma copie sur clé de mon programme je l'ai corrompus et j'ai du tout refaire ce matin.

    Je ne persistais pas dans le style array car je ne connaissais pas le record :S.
    Donc là si je comprends bien, EtherOS m'a mit comment faire pour le produit de matrice complexe?

    Ainsi?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    Type
             TComplex = Record
                 Re, Img : Real;
             End;
     
    Type
    CMatrix = array[1..2,1..2] of TComplex;
    Function Som_Z(z1,z2:TComplex):TComplex;
    Begin
      Som_Z.Re:=z1.Re+z2.Re;
      Som_Z.Img:=z1.Img+z2.Img;
    end;
    Function Prod_Z(z1,z2:TComplex):TComplex;
    Begin
    Prod_Z.Re:=z1.Re*z2.Re-z1.Img*z2.Img;
    Prod_Z.Img:=z1.Re*z2.Img + z1.Img*z2.Re;
    end;
     
    Function ProdMatrix(M1,M2 : CMatrix) : CMatrix;
    Var
     i,j,k:integer;
    Begin
     
     For i:= 1 To 2 Do
       For j:= 1 To 2 Do
         For k:= 1 To 2 Do
     
         ProdMatrix[i,j]:= Prod_Z(M1[i,k],M2[k,j]);
     
     end;

  13. #13
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 967
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 967
    Par défaut
    Hie,
    Citation Envoyé par Roland Chastain Voir le message
    Dans un tableau aussi on peut mettre des noms.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    const
      reel = 0;
      imagin = 1;
     
    type
      complexe = array[reel..imagin] of real;
     
    var
      cpx: complexe;
     
    begin
      cpx[reel] := 1.0;
      cpx[imagin] := 1.56;
    end.
    Cela est dit sans intention de contester le choix recommandé par droggo.
    Oups, j'avais loupé ça.

    Tu ne mets pas des noms aux éléments du tableau, tu nommes les constantes qui vont servir à en définir les bornes.

  14. #14
    Membre très actif
    Avatar de EtherOS
    Homme Profil pro
    Etudiant Polytechnicien
    Inscrit en
    Juillet 2012
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Etudiant Polytechnicien
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2012
    Messages : 58
    Par défaut juste une proposition
    Il faut créer une structure du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Type
             TComplex = Record
                 Re, Img : Real;
             End;
     
            CMatrix = array[1..MAX][1..MAX] of TComplex;
    Puis créer une fonction ProdMatrix( Var z1,z2 : TComplex) : TComplex

    qui renvoie le produit de deux complexes.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Function ProdMatrix(Var z1,z2 : TComplex) : TComplex;
    Var z : TComplex;
    Begin
           z.Re := z1.Re*z2.Re - z1.Img*z2.Img;
     
           z.Img := z1.Re*z2.Img + z1.Img*z2.Re;
     
           ProdMatrix := z;
    End;
    Ensuite déclarer trois variables:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Var   P, A, B : CMatrix;
                     Index1,Index2,Index3 : Integer;
    Puis lire les matrices A et B, Ensuite vous faites simplement:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     For Index1:= 1 To MAX Do
             For Index2:= 1 To MAX Do
               For Index3:= 1 To MAX Do
                 P[Index1,Index2]:= ProdMatrix(A[Index1,Index3],B[Index3,Index2]);
    Ensuite afficher avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    writeln(P[Index1,Index2]);
    Ou plus dynamiquement(inclure l'unité Crt):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    GotoXY(Index2,Index1);writeln(P[Index1,Index2]);

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Multiplication de nombres complexes
    Par progfou dans le forum Algorithmes et structures de données
    Réponses: 7
    Dernier message: 13/04/2006, 07h23
  2. [xml+xslt] débutant - multiplication de nombre
    Par Silvia12 dans le forum XSL/XSLT/XPATH
    Réponses: 3
    Dernier message: 17/11/2005, 11h04
  3. [Nombre Complexe]affichage formatte
    Par parsy dans le forum Langage
    Réponses: 2
    Dernier message: 20/08/2005, 00h36
  4. Les nombres complexe et delphi
    Par wikers dans le forum Langage
    Réponses: 3
    Dernier message: 04/08/2005, 11h47
  5. [LG]Nombres complexes et forme polaire
    Par chavernac dans le forum Langage
    Réponses: 3
    Dernier message: 28/03/2005, 18h36

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo