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 :

Problème code résolution équation différentielle


Sujet :

MATLAB

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Novembre 2009
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 11
    Par défaut Problème code résolution équation différentielle
    Bonjour, j'aurais voulu savoir si quelqu'un pouvait m'aider quant au problème de mon code, sensé me donner la fréquence de résonance et la résistance idéale d'un circuit RLC, je comprend le message d'erreur que Matlab me donne, mais je n'arrive pas à le résoudre... Quelqu'un aurait-il une idée?
    Merci d'avance
    Voici mon code:
    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
     
    clear all
    clc
    %équation différentielle à résoudre: V''(t)+V'(t)/RC+V(t)/LC=e'(t)/RC
    %où e(t)=A.sin(W.t) et W=2pi.f
    %
    compteR=1                                           %choix de la valeur pour chaque boucle (idem pour omega et t)
    for R=[1000 2000 5000 10000 20000 50000 100000]     %boucle sur R
    C=10e-9;                                            %valeur théorique de la capa
    L=10e-4;                                            %valeur théorique de la self
    A=5;                                                %valeur quelconque de l'amplitude de e(t)
    compteW=1
    for omega=2*pi*500000:2*pi*50000:2*pi*1000000;      %Boucle sur omega
    e(1)=0;                                             %valeur de la tension e(t) en t0
    e_prime(1)=A*omega;                                 %définition de la dérivée de la tension e(t)
    periode=2*pi/omega;                                 %définition de la période
    Tobs=15*periode;                                    %intervalle de temps observé
    pas=Tobs/3000;                                      %définition du pas
    v(1)=0;                                             %condition initiale V(0)
    y(1)=0;                                             %condition initiale y(0)
    B= max(v);
    G=B/A;                                              %définition du gain
    comptet=1;                                                      
    for t=0:pas:Tobs;                                   %boucle sur t
                                                        %méthode d'euler
       e(t+1)=A*sin(omega*t(t+1));
       e_prime(t+1)=A*omega*cos(omega*t(t+1));
       v(t+1)=v(t)+y(t)*pas;
       y(t+1)= y(t)+pas*(-(y(t)/R/C)-(v(t)/L/C)+e_prime(t)/R/C);
    comptet=comptet+1;                                  %changement de valeur avant de refaire la boucle
    end
    compteW=compteW+1;
    end
    compteR=compteR+1;
    end
    hold on;
    figure(1)
    F=500000:50000:1000000;                              %définition de la fréquence
    R=[1000 2000 5000 10000 20000 50000 100000];         %redéfinition de la boucle sur R
    G(compteR,compteW)=G;                                %gain                      
    for i=1:1:size(R);                                   %boucle pour une courbe balayant les valeurs de R
        plot(F,G(i,:));                                  %Graphe
     
    end
    hold off

  2. #2
    Modérateur

    Homme Profil pro
    Ingénieur en calculs scientifiques
    Inscrit en
    Août 2007
    Messages
    4 639
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Ingénieur en calculs scientifiques

    Informations forums :
    Inscription : Août 2007
    Messages : 4 639
    Par défaut
    Salut,

    quel est le message d'erreur?
    Pour une bonne utilisation des balises code c'est ici!
    Petit guide du voyageur MATLABien : Le forum La faq Les tutoriels Les sources


    La nature est un livre écrit en langage mathématique. Galilée.

  3. #3
    Membre averti
    Inscrit en
    Novembre 2009
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 11
    Par défaut
    Voici le message d'erreur:
    ??? Subscript indices must either be real positive integers or logicals.

    Error in ==> onair at 27
    v(t+1)=v(t)+y(t)*pas;
    merci d'avance

  4. #4
    Expert confirmé
    Avatar de Caro-Line
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    9 458
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 9 458

Discussions similaires

  1. Résolution équation différentielle
    Par cpalperou dans le forum MATLAB
    Réponses: 11
    Dernier message: 25/04/2014, 15h22
  2. Réponses: 3
    Dernier message: 24/03/2011, 14h45
  3. Réponses: 5
    Dernier message: 01/04/2010, 08h08
  4. Résolution équations différentielles
    Par alex63000 dans le forum Octave
    Réponses: 1
    Dernier message: 07/10/2007, 23h20

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