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 :

Calcul d'intégral d'une portion de courbe [Débutant]


Sujet :

MATLAB

  1. #1
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2016
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Somme (Picardie)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2016
    Messages : 13
    Par défaut Calcul d'intégral d'une portion de courbe
    Bonjour,

    Je cherche à calculer l'intégral d'une courbe ( son aire) entre deux points.

    J'obtiens la courbe suivant à l'aide de la fonction improfile, pour obtenir le profil d'une image en nuance de gris.
    Nom : pique.JPG
Affichages : 1823
Taille : 20,8 Ko

    Je recherche à positionner des droites (je sais comment faire) afin de ne calculer l'aire que pour le pic.

    Je ne trouve pas et ne comprends pas comment faire le calcul de l'intégral sur cette courbe...
    Pouvez-vous m'aider?

    Merci d'avance!

  2. #2
    Membre Expert
    Homme Profil pro
    Inscrit en
    Mai 2008
    Messages
    2 040
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 2 040
    Par défaut Calcul d'intégral d'une portion de courbe
    Bonjour,

    Tu peux utiliser :

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    figure
    x=0:0.01:100;
    y=-0.01*x.^2+x+1;
    plot(x,y)
    grid
    line([10 10],[0 10],'Color','r')
    line([90 90],[0 10],'Color','r')
    intz=trapz(x(1001:9001),y(1001:9001))
    %Vérification
    syms xx yy
    v=eval(int(-0.01*xx.^2+xx+1,10,90))

  3. #3
    Modérateur
    Avatar de le fab
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    1 885
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 885
    Par défaut
    salut

    il te faut commencer par récuper les vecteur vX et vX de ton tracé (y=f(x))
    et le calcul s'opère comme ceci
    et si veux restreindre le calcul entre x = 25 et x = 75 par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    idx = (vX >= 25) & (vX <= 75);
    aire = trapz(vX(idx),vY(idx));
    à ce propos je te suggère un petit tour vers la FAQ

    enfin pour tracer les trait verticaux à x = 25 et x = 75
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    hold on % pour superposer les courbes
    plot([25 25], [min(vY) max(vY)],'r-.');
    plot([75 75], [min(vY) max(vY)],'r-.');
    Fabien

  4. #4
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2016
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Somme (Picardie)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2016
    Messages : 13
    Par défaut
    Merci de votre aide!

    Du coup, j'ai récupéré les Y que me fourni improfile, et les X sont la taille de mon image.
    Voici le code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
            largeur=size(image,2);
            Y=improfile(rectangeGris,x,y);
            vX=[1:largeur];
            vY=Y;
            idx = (vX >= 25) & (vX <= 100);
            %Calcul de l'aire
            aire = trapz(vX(idx),vY(idx));
    Merci encore!

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

Discussions similaires

  1. calcul d'intégrale d'une fonction entre 0 et x
    Par lamine10 dans le forum Signal
    Réponses: 7
    Dernier message: 22/05/2011, 11h22
  2. calcul d'intégrale d'une fonction
    Par lamine10 dans le forum Signal
    Réponses: 1
    Dernier message: 18/05/2011, 23h51
  3. Colorier une portion de courbe
    Par breeder dans le forum MATLAB
    Réponses: 4
    Dernier message: 11/12/2007, 21h32
  4. calcul d'aire d'une courbe
    Par rabiahb dans le forum Delphi
    Réponses: 45
    Dernier message: 11/04/2007, 15h13
  5. Réponses: 2
    Dernier message: 04/04/2007, 17h21

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