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

Macros et VBA Excel Discussion :

L'exponentielle d'un nombre complexe en VBA.


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Sans emploi - Autonome
    Inscrit en
    Mars 2018
    Messages
    130
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Sans emploi - Autonome

    Informations forums :
    Inscription : Mars 2018
    Messages : 130
    Par défaut L'exponentielle d'un nombre complexe en VBA.
    Bonjour,

    Dans mon programme, j'ai une variable X de type "complex" avec une partie réelle ("Real") et une partie imaginaire ("Imag").

    Quand je compile mon programme, j'obtiens pour cette variable X : un tableau à deux dimensions c'est à dire 801 lignes et 2 colonnes -> X(801,2), avec à l'intérieur un nombre complexe : 1 partie réelle et 1 partie imaginaire, comme ci-dessous.

    Nom : a.png
Affichages : 598
Taille : 9,6 Ko

    Le but de mon programme est de réaliser la fonction exponentielle sur les 801 lignes et pour chaque colonnes. Malheureusement la fonction EXP(X) ne prend en compte que les variables de type Single.

    Du coup, j'ai essayé de contourner le problème en effectuant les opérations étape par étape.

    A présent, je cherche un moyen de stocker uniquement la partie réel sur une variable et de même pour la partie imaginaire : "reel" et "imag" afin d'appliquer la formule de l'exponentielle par la suite.

    Voici ce que j'ai tenté de faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    ReDim X(1 To NBR_POINTS, 1 To M) As Complex
    ReDim reel(1 To NBR_POINTS, 1 To M) As Complex
    ReDim imag(1 To NBR_POINTS, 1 To M) As Complex
     
    For i = 1 To NBR_POINTS
        For k = 1 To M
            reel(i, k) = X(i, k).Real  'j'essaye de récupèrer uniquement la partie réel du tableau à 2D -> X
            imag(i, k) = X(i, k).Imag 'j'essaye de récupèrer uniquement la partie imaginaire du tableau à 2D -> X
        Next k
    Next i
    Cependant, j'ai toujours un problème "d'erreur de compatibilité de type" dans ma boucle for. Pourtant reel et X sont du même type.

    Avez vous des idées à me proposer pour récupérer la partie réel et imag svp ?

  2. #2
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Toujours la même question, toujours la même réponse : https://support.office.com/fr-FR/art...2-a60e7147a95f

    Petite remarque en passant concernant ton code : si mes souvenirs (lointain) d'école sont justes, la multiplication d'un nombre complexe ne se limite pas à la multiplication entre elles des parties réelles et imaginaires. Je pense donc que ton code ne donnera pas un résultat juste.
    https://fr.wikipedia.org/wiki/Nombre...Multiplication

  3. #3
    Membre confirmé
    Homme Profil pro
    Sans emploi - Autonome
    Inscrit en
    Mars 2018
    Messages
    130
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Sans emploi - Autonome

    Informations forums :
    Inscription : Mars 2018
    Messages : 130
    Par défaut
    Finalement, j'ai réussi à récupérer la partie réelle et imaginaire c'était assez trivial ... mais j'ai laissé tombé car la suite de mon programme sera beaucoup trop complexe à coder.

    Du coup, j'ai essayé de crée une fonction qui me retourne l'exponentielle d'un nombre complexe à partir de la formule suivante :

    https://support.office.com/fr-fr/art...rs=fr-FR&ad=FR

    Voici ma fonction :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Public Function EXPtest(val() As Complex) As Single
     
      ' Retourne l'exponentielle d'un complexe
      EXPtest.Real = Exp(val.Real) * Cos(val.Imag)
      EXPtest.Imag = Exp(val.Imag) * Sin(val.Imag)
     
    End Function
    Appel de la fonction :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    ReDim forme_exp(1 To NBR_POINTS, 1 To M) As Complex
     
    For i = 1 To NBR_POINTS
       For k = 1 To M
            forme_exp(i, k) = EXPtest(X(i, k))
        Next k
    Next i
    Quand j'appelle ma fonction, j'obtiens cette erreur de compilation : "Incompatibilité de type : tableau ou type défini par l'utilisateur attendu".

    Avez vous des idées svp ?

  4. #4
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Sincèrement, je ne parviens pas à comprendre pourquoi tu recherches une solution compliquée quand il existe une solution simple à portée de main.
    Pourquoi recréer une fonction alors qu'il y en a une toute faite qui existe déjà ?

    Quant à la raison pour laquelle ton code ne fonctionne pas, c'est toujours la même qui t'a été expliquée plusieurs fois.

  5. #5
    Membre confirmé
    Homme Profil pro
    Sans emploi - Autonome
    Inscrit en
    Mars 2018
    Messages
    130
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Sans emploi - Autonome

    Informations forums :
    Inscription : Mars 2018
    Messages : 130
    Par défaut
    Citation Envoyé par Menhir Voir le message
    Sincèrement, je ne parviens pas à comprendre pourquoi tu recherches une solution compliquée quand il existe une solution simple à portée de main.
    Pourquoi recréer une fonction alors qu'il y en a une toute faite qui existe déjà ?

    Quant à la raison pour laquelle ton code ne fonctionne pas, c'est toujours la même qui t'a été expliquée plusieurs fois.
    La fonction IMEXP() ne fonctionne pas en VBA d’où l’intérêt de crée une fonction ...

  6. #6
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    C'est étonnant parce que chez moi ça fonctionne.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Debug.Print Application.WorksheetFunction.ImExp("2+i")

Discussions similaires

  1. Affichage nombre complexe depuis VBA
    Par igarch96 dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 24/04/2017, 21h34
  2. [Débutant] graphique exponentielle nombre complexe
    Par gc001 dans le forum MATLAB
    Réponses: 5
    Dernier message: 27/11/2012, 16h31
  3. [Débutant] Nombre complexe sous forme exponentielle
    Par xadimbacké dans le forum MATLAB
    Réponses: 4
    Dernier message: 06/05/2010, 17h36
  4. [VBA-E] Nombres complexes
    Par spileo dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 26/04/2007, 22h33
  5. [TP] Exponentielle d'un nombre complexe
    Par nicolas5454 dans le forum Turbo Pascal
    Réponses: 3
    Dernier message: 23/04/2007, 20h30

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