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 :

sinusoide interrompues: mise en place du programme [Débutant]


Sujet :

MATLAB

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2010
    Messages
    2 051
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 2 051
    Points : 877
    Points
    877
    Par défaut sinusoide interrompues: mise en place du programme
    Bonjour tous,

    j'ai fais un petit programme d'une façon très bête pour effectuer des sinusoides interrompues.
    Je voudrais réécrire ce programme d'une façon beaucoup plus intelligente avec des boucles ou autre mais je n'y arrive pas, j'espere que vous pourrez m'aider

    1°) ce que je veux faire

    -je veux faire une premiere sinusoide de frequence 0,2 pendant un temps "t", (pour cela pas de problème)
    -ensuite je veux faire une courbe comprenant: une sinusoide de frequence 1 Hz, une partie de courbe nulle, une sinusoide de frequence 1hz, une partie de courbe nulle...
    -de même que la précédente mais avec 5Hz

    2°) contrainte à respecter
    je veux pour les courbe 2 et 3 que les temps où démarre la sinusoide soient les meme temps que pour la courbe 1

    3°) mon programme
    le programme ci dessous permet de faire ce que je veux mais il n'est pas du tout optimisé car je ne vois pas comment faire...

    4°) voici mon programme
    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
     
    wa=2*pi*0.2;
    ta1=[2.5:0.1:7.5];
    ta2=[7.5:0.1:12.5];
    ta3=[12.5:0.1:17.5];
    ta4=[17.5:0.1:22.5];
    a1=30*sin(wa*ta1);
    a2=30*sin(wa*ta2);
    a3=30*sin(wa*ta3);
    a4=30*sin(wa*ta4);
    ta=[ta1,ta2,ta3,ta4];
    a=[a1,a2,a3,a4];
    figure(1)
    plot(ta,a)
    %------------------------------------------
    wb=2*pi*1;
    tb1=[2.5:0.1:3.5];
    tb2=[3.5:0.1:7.5];
    tb3=[7.5:0.1:8.5];
    tb4=[8.5:0.1:12.5];
    tb5=[12.5:0.1:13.5];
    tb6=[13.5:0.1:17.5];
    tb7=[17.5:0.1:18.5];
    tb8=[18.5:0.1:22.5];
    b1=30*sin(wb*tb1);
    b2=zeros(1,length(tb2));
    b3=30*sin(wb*tb3);
    b4=zeros(1,length(tb4));
    b5=30*sin(wb*tb5);
    b6=zeros(1,length(tb6));
    b7=30*sin(wb*tb7);
    b8=zeros(1,length(tb8));
    tb=[tb1,tb2,tb3,tb4,tb5,tb6,tb7,tb8];
    b=[b1,b2,b3,b4,b5,b6,b7,b8];
    figure(2)
    plot(tb,b)
    %------------------------------------------
    wc=2*pi*5;
    tc1=[2.5:0.01:2.7];
    tc2=[2.7:0.01:7.5];
    tc3=[7.5:0.01:7.7];
    tc4=[7.7:0.01:13.5];
    tc5=[13.5:0.01:13.7];
    tc6=[13.7:0.01:18.5];
    tc7=[18.5:0.01:18.7];
    tc8=[18.7:0.01:22.5];
    c1=30*sin(wc*tc1);
    c2=zeros(1,length(tc2));
    c3=30*sin(wc*tc3);
    c4=zeros(1,length(tc4));
    c5=30*sin(wc*tc5);
    c6=zeros(1,length(tc6));
    c7=30*sin(wc*tc7);
    c8=zeros(1,length(tc8));
    tc=[tc1,tc2,tc3,tc4,tc5,tc6,tc7,tc8];
    c=[c1,c2,c3,c4,c5,c6,c7,c8];
    figure(3)
    plot(tc,c)

  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 : 53 166
    Points
    53 166
    Par défaut
    Citation Envoyé par 21did21 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    wa=2*pi*0.2;
    ta1=[2.5:0.1:7.5];
    ta2=[7.5:0.1:12.5];
    ta3=[12.5:0.1:17.5];
    ta4=[17.5:0.1:22.5];
    a1=30*sin(wa*ta1);
    a2=30*sin(wa*ta2);
    a3=30*sin(wa*ta3);
    a4=30*sin(wa*ta4);
    ta=[ta1,ta2,ta3,ta4];
    a=[a1,a2,a3,a4];
    figure(1)
    plot(ta,a)
    est équivalent à :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    wa = 2*pi*0.2;
    ta = 2.5:0.1:22.5;
    a = 30*sin(wa*ta);
     
    figure
    plot(ta,a)
    A quelques répétitions près... je ne comprends pas vraiment ce que tu cherches à faire
    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
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2010
    Messages
    2 051
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 2 051
    Points : 877
    Points
    877
    Par défaut
    Citation Envoyé par Dut Voir le message
    est équivalent à :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    wa = 2*pi*0.2;
    ta = 2.5:0.1:22.5;
    a = 30*sin(wa*ta);
    figure
    plot(ta,a)
    A quelques répétitions près... je ne comprends pas vraiment ce que tu cherches à faire
    oui, merci DUT. En fait pour ce cas là j'avais remarqué mais pour les autres je ne sais pas comment faire
    (en fait pour le "a" j'ai gardé la même structure que les autres juste pour expliquer ce que je cherche à faire)

  4. #4
    Membre éclairé Avatar de tubaas
    Homme Profil pro
    Acousticien
    Inscrit en
    Août 2009
    Messages
    641
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Acousticien
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2009
    Messages : 641
    Points : 825
    Points
    825
    Par défaut
    salut
    je te propose ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    f=[0.2;1;5];
    N=4; % nombre de périodes
    dt=0.01;
    ti=2.5;
    t=ti:dt:ti+N/f(1)-dt;
    a=zeros(3,length(t));
    a(1,:)=sin(2*pi*f(1)*t);
    a(2,:)=repmat([sin(2*pi*f(2)*t(1:1/(dt*f(2)))) zeros(1,1/(dt*f(1))-1/(dt*f(2)))],1,N);
    a(3,:)=repmat([sin(2*pi*f(3)*t(1:1/(dt*f(3)))) zeros(1,1/(dt*f(1))-1/(dt*f(3)))],1,N);
    figure;
    plot(t,a);
    mais tu vois qu'il faut un nombre entier de périodes.
    Sinon tu peux toujours placer tes "impulsions" où il faut mais ce peut-être un peu plus lourd

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2010
    Messages
    2 051
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 2 051
    Points : 877
    Points
    877
    Par défaut
    merci beaucoup d'avoir pris le temps de repondre.

    pourrais tu m'expliquer ce que fait repmat car j'ai regardé sur le net et je n'ai pas vraiment saisi


  6. #6
    Membre éclairé Avatar de tubaas
    Homme Profil pro
    Acousticien
    Inscrit en
    Août 2009
    Messages
    641
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Acousticien
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2009
    Messages : 641
    Points : 825
    Points
    825
    Par défaut
    repmat(A,i,j) réplique une matrice A i fois verticalement et j fois horizontalement.
    Ici je m'en sers car je construis le signal sur une période du premier signal et je le duplique pour le bon nombre de périodes. C'est à cause de ça que je dois avoir un nombre de périodes entier.

    Edit : une autre méthode. Je ne sais pas si c'est très efficace mais c'était rigolo.
    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
    function creaSignal
    f=0.2;
    df=[1;5;18];
    dt=0.01;
    ti=2.5;
    t=ti:dt:ti+1366*dt;
    a=arrayfun(@(x,y)partialPeriod(x,y),repmat(t,length(df),1),repmat(df,1,length(t)));
    figure;
    plot(t,a);
     
        function a=partialPeriod(x,y)
            if mod(floor((x-ti)*y*f),y)==0
                a=sin(2*pi*f*y*x);
            else
                a=0;
            end
        end
    end
    ici tu vois que j'introduis un vecteur df qui correspond à un multiple par rapport à la fréquence de base. Il doit être entier.

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2010
    Messages
    2 051
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 2 051
    Points : 877
    Points
    877
    Par défaut
    j'ai un peu de mal avec cette ligne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    a=arrayfun(@(x,y)partialPeriod(x,y),repmat(t,3,1),repmat(df,1,length(t)));
    si je comprends bien arrayfun est une fonction et entre parenthèse on a les arguments? c'est quoi ce truc bizarre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    @(x,y)partialPeriod(x,y)
    merci beaucoup tubaas pour ton aide!!!

  8. #8
    Membre éclairé Avatar de tubaas
    Homme Profil pro
    Acousticien
    Inscrit en
    Août 2009
    Messages
    641
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Acousticien
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2009
    Messages : 641
    Points : 825
    Points
    825
    Par défaut
    arrayfun applique une fonction à chaque élément d'un tableau (ou ici de deux tableaux)
    dans la fonction appelée x va correspondre à un élément du tableau dans lequel j'ai le temps, l'élément y à mon élément multiplicateur.

    c'est équivalent à
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    a=zeros(length(df),length(t));
    for i=1:length(df)
        for j=1:length(t)
            if mod(floor((t(j)-ti)*df(i)*f),df(i))==0
                a(i,j)=sin(2*pi*f*df(i)*t(j));
            end
        end
    end
    edit : le truc bizarre c'est parce que la Matlab va automatiquement passer deux argument à arrayfun car j'ai deux tableaux, je les récupère avant d'appeler la fonction et je les repasse à la fonction. cette notation ne sert à rien ici on peut se contenter de @partialPeriod

  9. #9
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2010
    Messages
    2 051
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 2 051
    Points : 877
    Points
    877
    Par défaut
    merci beaucoup de ton aide

    (je vais conserver la premiere solution c'est plus facile pour moi)

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

Discussions similaires

  1. mise en place d'un programme pop up
    Par epaminondas dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 04/02/2007, 02h02
  2. [AD]Mise en place de Active Directory
    Par guiguisi dans le forum Windows Serveur
    Réponses: 9
    Dernier message: 29/07/2004, 08h50
  3. [C#] Mise en place d'un site multilingue
    Par regbegpower dans le forum ASP.NET
    Réponses: 6
    Dernier message: 19/03/2004, 19h15
  4. mise en place serveur web intranet
    Par gui4593 dans le forum Installation
    Réponses: 7
    Dernier message: 01/01/2004, 18h18
  5. Mise en place d'index....??
    Par liv dans le forum Requêtes
    Réponses: 6
    Dernier message: 18/12/2003, 11h04

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