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

MATLAB Discussion :

plot avec une boucle for


Sujet :

MATLAB

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2012
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2012
    Messages : 16
    Points : 11
    Points
    11
    Par défaut plot avec une boucle for
    bonsoir,
    Je vais essayer d'expliquer mon problème clairement.
    Je dois résoudre une EDO pour caractériser le comportement mécanique d'un métal subissant des chargement cyclique, on obtient un cycle d'hytérésis.
    Mon système est définit comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    function  dy=f_iso(t,y)
    global    Q b K n E sigma0 epoint
    if abs(y(1))-Q*(1-exp(-b*y(2)))-sigma0<0
        dy(2)=0
    else
        dy(2)=((abs(y(1))-Q*(1-exp(-b*y(2)))-sigma0)/K)^n
    end
    dy(3)=sign(y(1))*dy(2);
    dy(1)=E*(epoint-dy(3));
    dy=dy';
    end
    Puis ma fonction principale est:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    global Q  b   K n E sigma0 epoint
    b=5;
    Q=-150 ;
    E=140000;
    sigma0=200;
    K=800;
    n=6;
    epoint=0.001;
    % 1ere branche
    [Tn,N]=ode45('f_iso',[0 10],[0  0  0]);
    sigma1=N(:,1);
    ep1=N(:,3);
    e1=ep1+sigma1./E;
    plot(e1,sigma1)
    Ce qui me donne la première branche.
    Ensuite je veux tracer 9 autres branches sachant que à partir de la deuxième ça devient cyclique.
    Pour cela je fais une boucle for :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    L=length(N)
    for w = 0:10
    epoint=-epoint
    [Tn,N]=ode45('f_iso',[10*(2*w+1) (30+20*w)],[N(L,:)]);
    sigma2=N(:,1);
    ep2=N(:,3);
    e2=ep2+sigma2./E;
    L=length(N)
    end
    A chaque itération Ti=Ti+20 et Tf=Tf+20 et comme condition initiale je prends la valeur du dernier vecteur précédent .
    Mais je ne sais pas comment ployer pour faire en sorte d'avoir toutes les courbes sigma=f(e) sur un meme grave avec la boucle for...
    De plus avec cette boucle, les valeurs vont être écraser à chaque itération donc ça va pas marcher...

    merci

  2. #2
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2012
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2012
    Messages : 16
    Points : 11
    Points
    11
    Par défaut
    PLus de précisions.
    La boucle marche très bien fait , mais lorsque je plot, je n'ai que le tracé de la dernière itération cependant moi je voudrais tracer toutes les courbes mais je ne sais pas comment faire...

  3. #3
    FLB
    FLB est déconnecté
    Modérateur
    Avatar de FLB
    Homme Profil pro
    Ing. Aérospatiale
    Inscrit en
    Juin 2003
    Messages
    770
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France

    Informations professionnelles :
    Activité : Ing. Aérospatiale
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2003
    Messages : 770
    Points : 1 185
    Points
    1 185
    Par défaut
    Salut,
    si j'ai bien compris tu cherches à sauvegarder e2 et sigma2 à chaque itération de ta boucle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    sauvegardeE2 = zeros(L,11);
    sauvegardeSigma2 = zeros(L,11)
    for w = 0:10
    %[...]
    L=length(N);
    sauvegardeE2(1:L,w+1) = e2;
    sauvegardeSigma2(1:L,w+1) = sigma2;
    end
    plot(sauvegardeE2,sauvegardeSigma2);

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    640
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 640
    Points : 776
    Points
    776
    Par défaut
    Bonjour,

    Pourquoi ne pas tout simplement utiliser un hold on après le premier plot et rajouter un plot de e2 et sigma 2 dans la boucle ?

    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
    global Q  b   K n E sigma0 epoint
    b=5;
    Q=-150 ;
    E=140000;
    sigma0=200;
    K=800;
    n=6;
    epoint=0.001;
    % 1ere branche
    [Tn,N]=ode45('f_iso',[0 10],[0  0  0]);
    sigma1=N(:,1);
    ep1=N(:,3);
    e1=ep1+sigma1./E;
    plot(e1,sigma1)
    hold on
    
    L=length(N);
    
    for w = 0:10
    epoint=-epoint;
    [Tn,N]=ode45('f_iso',[10*(2*w+1) (30+20*w)],[N(L,:)]);
    sigma2=N(:,1);
    ep2=N(:,3);
    e2=ep2+sigma2./E;
    L=length(N);
    
    plot(e2,sigma2)
    
    end

  5. #5
    Membre éclairé
    Homme Profil pro
    Doctorant automatique
    Inscrit en
    Janvier 2012
    Messages
    446
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Doctorant automatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2012
    Messages : 446
    Points : 719
    Points
    719
    Par défaut
    Salut,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    L=length(N)
    for w = 0:10
    epoint=-epoint
    [Tn,N]=ode45('f_iso',[10*(2*w+1) (30+20*w)],[N(L,:)]);
    sigma2=N(:,1);
    ep2=N(:,3);
    e2=ep2+sigma2./E;
    L=length(N)
    figure % ouvre une nouvelle figure et sera donc appelé à chaque itération de ta boucle
    % Ici tu peux donc tracer ce que tu veux dans ta nouvelle figure
    end
    cordialement,
    Je ne réponds pas aux MP techniques. Le forum est là pour ça.
    La raison est simple : il est ennuyeux de répondre à une seule personne, alors que la réponse peut servir à tout le monde.
    Conclusion : n'hésitez pas à utiliser le forum pour poser vos questions.
    Matlab 2005 - ver.7.1.0.183 (R14) Service Pack 3

Discussions similaires

  1. Réponses: 1
    Dernier message: 31/01/2007, 12h30
  2. Structure while avec une boucle for en test
    Par le_voisin dans le forum C++
    Réponses: 9
    Dernier message: 09/09/2006, 19h16
  3. Problème avec une boucle for
    Par cisse18 dans le forum Général JavaScript
    Réponses: 20
    Dernier message: 29/03/2006, 16h50
  4. Incrémentation dynamique d'un textbox avec une boucle for
    Par Etanne dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 06/03/2006, 15h17
  5. : remplir des zones de texte avec une boucle For
    Par Haro_GSD dans le forum Access
    Réponses: 3
    Dernier message: 20/09/2005, 21h23

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