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 :

pouvez vous m'aider avec se programme


Sujet :

MATLAB

  1. #1
    Futur Membre du Club
    Étudiant
    Inscrit en
    Décembre 2009
    Messages
    7
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2009
    Messages : 7
    Points : 5
    Points
    5
    Par défaut pouvez vous m'aider avec se programme
    Bonjour,

    voila c'est un programme basé sur les descripteurs de Fourier (issu du livre Feature Extraction and Image Processing que mon encadreur m'a donné)

    Sur ce dernier il y a un programme que j'ai du mal à compiler. En fait c'est une fonction créée pour laquelle je dois connaitre le paramètre qui est "curve"

    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
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    %Angular function
    function AngFuncDescrp(curve)
    %Function
    X=curve(1,:);Y=curve(2,:);
    M=size(X,2);%number points
    %Arc length
    S=zeros(1,m);
    S(1)=sqrt((X(1)-X(m))^2+(Y(1)-Y(m))^2);
    for i=2:m
        S(i)=S(i-1)+sqrt((X(i)-X(i-1))^2+(Y(i)-Y(i-1))^2);
    end
    L=S(m);
    %Normalised Parameter
    t=(2*pi*S)/L;
    %Graph of the curve
    subplot(3,3,1);
    plot(X,Y);
    mx=max(max(X),max(Y))+10;
    axis([0,mx,0,mx]); axis square; %Aspect ratio
    %Graph of the angular function y’/x’
    avrg=10;
    A=zeros(1,m);
    for i=1:m
        x1=0; x2=0; y1=0; y2=0;
        for j=1:avrg
            pa=i-j; pb=i+j;
            if(pa<1) pa=m+pa;
            end
            if(pb>m) pb=pb-m;
            end
            x1=x1+X(pa); y1=y1+Y(pa);
            x2=x2+X(pb); y2=y2+Y(pb);
        end
        x1=x1/avrg; y1=y1/avrg;
        x2=x2/avrg; y2=y2/avrg;
        dx=x2-x1; dy=y2-y1;
        if(dx==0) dx=.00001;
        end
        if dx>0 & dy>0
            A(i)=atan(dy/dx);
        elseif dx>0 & dy<0
            A(i)=atan(dy/dx)+2*pi;
        else
            A(i)=atan(dy/dx)+pi;
        end
    end
    subplot(3,3,2);
    plot(S,A);
    axis([0,S(m),-1,2*pi+1]);
    %Cumulative angular G(s)=-2pi
    G=zeros(1,m);
    for i=2:m
        d=min(abs(A(i)-A(i-1)),abs(abs(A(i)-A(i-1))-2*pi));
        if d>.5
            G(i)=G(i-1);
        elseif (A(i)-A(i-1))<-pi
            G(i)=G(i-1)-(A(i)-A(i-1)+2*pi);
        elseif (A(i)-A(i-1))>pi
            G(i)=G(i-1)-(A(i)-A(i-1)-2*pi);
        else
            G(i)=G(i-1)-(A(i)-A(i-1));
        end
    end
    subplot(3,3,3);
    plot(S,G);
    axis([0,S(m),-2*pi-1,1]);
    %Cumulative angular Normalised
    F=G+t;
    subplot(3,3,4);
    plot(t,F);
    axis([0,2*pi,-2*pi,2*pi]);
    Je voudrais aussi pouvoir créer une courbe en forme d'avion si c'est possible

    voila si vous pouvez m'aider à comprendre et surtout quels sont les paramètres à mettre lors de l'appel de cette fonction

    merci

  2. #2
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 52 882
    Points
    52 882
    Par défaut
    Citation Envoyé par lunalutcha Voir le message
    paramètre qui est "curve"
    curve semble être simplement un tableau de dimension 2xn où n serait le nombre de points du profil, non ?

    Citation Envoyé par lunalutcha Voir le message
    Je voudrais aussi pouvoir créer une courbe en forme d'avion si c'est possible
    Tu veux dire, tracer toi-même le profile sous MATLAB avec la souris ?
    Dans ce cas, tu peux utiliser la fonction GINPUT
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  3. #3
    Futur Membre du Club
    Étudiant
    Inscrit en
    Décembre 2009
    Messages
    7
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2009
    Messages : 7
    Points : 5
    Points
    5
    Par défaut
    j'ai essayé pour la fonction ginput mais sa reste comme même vague j'arrive toujours pas a tracer ma figure
    pour les paramètre curve j'ai essayé d'introduire aussi pour n=50 si j'ai bien compris
    il trouve le x et le x parcontre arriver a S il affiche cette erreur je crois que c m qui est indefinie
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Error in ==> AngFuncDescrp at 8
    S=zeros(1,m);
    voila svp si vous pouvez m'aider merci

  4. #4
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 52 882
    Points
    52 882
    Par défaut
    Il faut remplacer la ligne suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    M=size(X,2);%number points
    par

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    m=size(X,2);%number points
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  5. #5
    Futur Membre du Club
    Étudiant
    Inscrit en
    Décembre 2009
    Messages
    7
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2009
    Messages : 7
    Points : 5
    Points
    5
    Par défaut
    voila j'ai déjà eu cette idée de le remplacer
    mais bon j'ai le premier graph
    il reste le problem de x bon l'erreur est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    ??? Attempted to access X(0); index must be a positive integer or logical.
     
    Error in ==> AngFuncDescrp at 32
    x1=x1+X(pa); y1=y1+Y(pa);
    voila j'ai essayé de modifier la boucle enfin la valeur de pa sa ne marche pas

  6. #6
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 52 882
    Points
    52 882
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  7. #7
    Futur Membre du Club
    Étudiant
    Inscrit en
    Décembre 2009
    Messages
    7
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2009
    Messages : 7
    Points : 5
    Points
    5
    Par défaut
    ben donc le problème je l'ai compris et je trouve sa logique
    enfin mais je dois donc changer le boucle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if(pa<1) pa=m+pa 
    end
    if(pb>m) pb=pb-m
    end
    de maniere a se que ''pa'' ne prenne pas la valeur nul vu que quand j'ai compiler elle prend deux valeur
    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
    pa =
     
         1
     
     
    pb =
     
         1
     
     
    pa =
     
         0
     
     
    pb =
     
         2
    donc voila j'ai changer la valeur de curve d'éviter cette erreur mais c'est pas les graphe que je voulais avoir enfaite voila les graphes Nom : graph.jpg
Affichages : 88
Taille : 47,3 Ko

Discussions similaires

  1. [HTML] Pouvez vous m'aider à comprendre ces balises HTML ?
    Par DionCeli dans le forum Balisage (X)HTML et validation W3C
    Réponses: 8
    Dernier message: 02/07/2008, 11h54
  2. Pouvez-vous m'aider à créer un script
    Par buddydaft dans le forum VBScript
    Réponses: 2
    Dernier message: 02/08/2007, 11h03
  3. pouvez vous m'aider a optimiser cette requete
    Par taoufikiory dans le forum SQL
    Réponses: 4
    Dernier message: 20/07/2007, 15h32
  4. Je n'arrive pas à faire une pop-up. Pouvez-vous m'aider?
    Par Davidoux94 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 01/12/2006, 12h24
  5. Pouvez vous m'aider a resoudres ces 3 exercices
    Par algorithmique dans le forum Algorithmes et structures de données
    Réponses: 11
    Dernier message: 09/08/2002, 17h26

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