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 :

Stopper une procédure dans le code


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Inscrit en
    Mars 2010
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Mars 2010
    Messages : 39
    Par défaut Stopper une procédure dans le code
    Bonjour,

    J'ai une procédure qui fait des itérations. Je voudrais la stopper dès qu'une certaine valeur est inférieur à un coefficient, car dans ce cas-là l'itération ne sert à rien.

    Comment puis-je intégrer le fait d'arrêter la procédure ? J'ai essayer Stop, Exit Sub, sans succès...

    Merci de votre réponse.

  2. #2
    Expert confirmé
    Avatar de kiki29
    Homme Profil pro
    ex Observeur CGG / Analyste prog.
    Inscrit en
    Juin 2006
    Messages
    6 132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : ex Observeur CGG / Analyste prog.

    Informations forums :
    Inscription : Juin 2006
    Messages : 6 132

  3. #3
    Membre averti
    Inscrit en
    Mars 2010
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Mars 2010
    Messages : 39
    Par défaut
    Merci pour tes liens.
    J'utilise une boucle en Do While + Loop, et à priori un Exit Do me permettrait d'arrêter la boucle... mais sans résultat.
    Je mets ici mon code (je vous épargne toutes les définitions des fonctions), peut-être que mon erreur va vous apparaître flagrante.

    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
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    Sub NRmethod(N, eps, maxval)
     
        Dim iter As Integer
     
        Tw0 = Cells(23, 5)
        Tg0 = Cells(23, 4)
        Tf0 = Cells(23, 6)
        qs0 = Cells(23, 2)
        i = 24
     
        Do While N > 0
            Application.StatusBar = "N= " & N    
     
                If Abs(determinant(qs0, Tw0, Tg0, Tf0)) < eps Then
                MsgBox "Error"
                Exit Do
                End If
     
            Tw = Tw0 - jacobianinvmat(0, 0) * fw(qs0, Tw0, Tg0, Tf0) - jacobianinvmat(0, 1) * fg(qs0, Tw0, Tg0, Tf0) - jacobianinvmat(0, 2) * ff(Tw0, Tg0, Tf0)
            Tg = Tg0 - jacobianinvmat(1, 0) * fw(qs0, Tw0, Tg0, Tf0) - jacobianinvmat(1, 1) * fg(qs0, Tw0, Tg0, Tf0) - jacobianinvmat(1, 2) * ff(Tw0, Tg0, Tf0)
            Tf = Tf0 - jacobianinvmat(2, 0) * fw(qs0, Tw0, Tg0, Tf0) - jacobianinvmat(2, 1) * fg(qs0, Tw0, Tg0, Tf0) - jacobianinvmat(2, 2) * ff(Tw0, Tg0, Tf0)
     
            Cells(i, 5) = Tw
            Cells(i, 4) = Tg
            Cells(i, 6) = Tf
     
                If Abs(fw(qs, Tw, Tg, Tf)) < eps And Abs(fg(qs, Tw, Tg, Tf)) < eps And Abs(ff(Tw, Tg, Tf)) < eps Then
                iter = 100 - N
                Cells(i + 1, 6) = Tw
                Cells(i + 1, 7) = Tg
                Cells(i + 1, 8) = Tf
                MsgBox "Convergence after " & iter & " iterations"
                Exit Do
                End If
     
                If Abs(fw(qs, Tw, Tg, Tf)) > maxval And Abs(fg(qs, Tw, Tg, Tf)) > maxval And Abs(ff(Tw, Tg, Tf)) > maxval Then
                iter = 100 - N
                MsgBox "Divergence after " & iter & " iterations"
                Exit Do
                End If
     
            N = N - 1
            i = i + 1
            Tw0 = Tw
            Tg0 = Tg
            Tf0 = Tf
        Loop
     
        MsgBox "No convergence after " & N & " iterations"
     
    End Sub

  4. #4
    Membre averti
    Femme Profil pro
    Chargé d'affaire
    Inscrit en
    Octobre 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2011
    Messages : 10
    Par défaut
    Bonjour au forum

    une Proposition avec une étiquette

    Goto Sortie

    avec Sortie: la ou on veux aller


    Toty

  5. #5
    Membre Expert
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2011
    Messages
    1 858
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Avril 2011
    Messages : 1 858
    Par défaut
    Bonjour,

    Ton code semble correct.

    Seule anomalie : quand tu sors de la boucle via un exit do, tu affiches quand même le message "No convergence after " & N & " iterations"

    Cordialement.

Discussions similaires

  1. Importer une librairie dans un code c++
    Par wikers dans le forum Linux
    Réponses: 6
    Dernier message: 14/08/2009, 00h31
  2. Création d'une procédure dans une base externe par code
    Par AndréPe dans le forum VBA Access
    Réponses: 1
    Dernier message: 22/07/2007, 10h19
  3. [FLASH MX2004] Utiliser une variable dans le code
    Par arnolem dans le forum Flash
    Réponses: 25
    Dernier message: 02/12/2005, 16h37
  4. [vb.net] utilisation d'une variable dans le code
    Par arnolem dans le forum Windows Forms
    Réponses: 9
    Dernier message: 30/09/2005, 19h22
  5. Surcharge d'une procédure dans l'instance d'une frame
    Par damien.yep dans le forum Composants VCL
    Réponses: 3
    Dernier message: 14/09/2005, 15h28

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