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

Scilab Discussion :

Modification d'un signal carré


Sujet :

Scilab

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    58
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 58
    Points : 28
    Points
    28
    Par défaut Modification d'un signal carré
    bonjour,
    j'ai un signal carré non périodique (figure pièce jointe) échantillonné à une fréquence 44,1 khz.
    comment je peux faire pour enlever les "0" qui se trouve entre les "1"?
    ça veut dire avoir un signal continu entre le premier "1" et le dernier "1".
    sachant que si j'ai un "1" entre 500 "0" à droite et 500 "0" à gauche, je considère que c'est un "0" et pas un "1".
    est ce que je doit faire un filtre ou calculer une somme ou calculer une moyenne?
    merci.
    je travail sur scilab.

  2. #2
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    58
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    comment je calcule le nombre des "1" pour chaque 1000 ech de signal

  3. #3
    Membre émérite
    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
    Points : 2 841
    Points
    2 841
    Par défaut
    Bonjour.
    Un exemple pour éliminer un 0 entre deux 1 :
    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
    clear
    N=100;
    x=ones(1,N).*floor(2*rand(1,N))
    %plot(1:N,x,'.','markersize',15)
    plot(1:N,x)
    axis([0 N 0 1.5])
    grid
    for k=2:N-1
      if x(k-1) ==1 & x(k) ==0 & x(k+1)==1
          x(k)=1;
      end
    end
    figure(2)
    plot(1:N,x)
    grid
    axis([0 N 0 1.5])

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    58
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    bonjour phryte,
    est ce que vous pouvez faire une fenetre de 1000 échantillon (pour un signal de 50000 échantillon) qui se décale de debut de signal jusqu'à la fin en calculant a chaque 1000 échantillon le nombre des "1" et des "0"?

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    58
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    quelq'un d'autre à une idée?

  6. #6
    Membre émérite
    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
    Points : 2 841
    Points
    2 841
    Par défaut
    le nombre des "1" et des "0"?
    Voici un exemple basique pour 10 et 500 :
    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
    clear
    N=500;
    x=ones(1,N).*floor(2*rand(1,N));
    plot(1:N,x)
    axis([0 N 0 1.5])
    grid
    H=10;
    pas=1;
    for k=1:H:N
        nbzero(pas)=0;
        nbun(pas)=0;
         for j=k:k+H-1
    if x(j) == 0
        nbzero(pas)=nbzero(pas)+1;
    else
        nbun(pas)=nbun(pas)+1;
    end
     
    end
    pas=pas+1;
    end
    nbun
    nbzero

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    58
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    exactement ce que je veux
    merci

  8. #8
    Expert éminent sénior
    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
    Points : 14 830
    Points
    14 830
    Par défaut
    AXIS est une commande MATLAB qui n'existe pas sous Scilab.
    Je te donne l'aide de MATLAB dans l'utilisation qu'en fait phryte, peut-être connais-tu un équivalent ? (enfin sinon c'est juste pour faire plus joli, tu peux essayer en mettant cette ligne en commentaire) :
    Citation Envoyé par help axis MATLAB
    AXIS Control axis scaling and appearance.
    AXIS([XMIN XMAX YMIN YMAX]) sets scaling for the x- and y-axes
    on the current plot.
    Règles du Forum

    Adepte de la maïeutique

  9. #9
    Membre émérite
    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
    Points : 2 841
    Points
    2 841
    Par défaut
    Pardon, je me croyais sous matlab.
    Il faut :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    mtlb_axis([0 N 0 1.5])
    xgrid()

  10. #10
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    58
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 58
    Points : 28
    Points
    28
    Par défaut
    probleme résolut.
    merci à vous

  11. #11
    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 884
    Points
    52 884
    Par défaut
    Citation Envoyé par phryte Voir le message
    Voici un exemple basique pour 10 et 500 :
    Ou directement :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    N=500;
    m = 10;
    x=ones(1,N).*floor(2*rand(1,N));
     
    n = N/m;
     
    x = reshape(x,m,n);
     
    nbun = sum(x);
    nbzero = m-nbun;
    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)

  12. #12
    Membre émérite
    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
    Points : 2 841
    Points
    2 841
    Par défaut
    Bonjour.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    n = N/m;
     
    x = reshape(x,m,n);
     
    nbun = sum(x);
    nbzero = m-nbun;
    C'est parfait Dut. Je m'en veux de ne pas y avoir pensé.

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

Discussions similaires

  1. [Débutant] Modification d'un signal carré
    Par th0re dans le forum MATLAB
    Réponses: 3
    Dernier message: 07/05/2010, 11h48
  2. Génération signal carré
    Par nuans dans le forum Signal
    Réponses: 6
    Dernier message: 17/04/2007, 10h49
  3. Générer un signal carré
    Par sandball22 dans le forum Signal
    Réponses: 4
    Dernier message: 26/03/2007, 14h57
  4. Convertir une chaîne binaire en signal carré
    Par hotdog dans le forum Signal
    Réponses: 1
    Dernier message: 06/09/2006, 10h01
  5. signal carré sur port //
    Par MLOLO dans le forum C++
    Réponses: 2
    Dernier message: 14/01/2005, 02h02

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