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 :

Tronquer une série de données


Sujet :

MATLAB

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Tronquer une série de données
    Bonjour à tous,

    Je cherche une fonction matlab permettant de tronquer une série de données si la fin de la série contient des zéros.
    Exemple:
    serie1 est une série de 5 chiffres : 5,3,4,10,0.
    Et je voudrais que serie1 devienne 5,3,4,10 et soit de longueur 4.

    Merci à tous pour votre aide.

    felixgray87

  2. #2
    Membre chevronné
    Avatar de kmaniche
    Inscrit en
    Janvier 2006
    Messages
    1 717
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 717
    Points : 1 884
    Points
    1 884
    Par défaut
    Bonsoir,

    La solution qui passe rapidement par ma tête est la suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    >> a = [1 2 3 4 0 0 1 0 2 1 0 1 4]
     
    a =
     
         1     2     3     4     0     0     1     0     2     1     0     1     4
     
    >> b = a(1:find(a==0, 1, 'first')-1)
     
    b =
     
         1     2     3     4
     
    >>

  3. #3
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 304
    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 304
    Points : 52 881
    Points
    52 881
    Par défaut
    Une autre solution en considérant a comme une chaine de caractères :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    a = [1 2 3 4 0 0 1 0 2 1 0 1 4];
     
    b = strtok(a,0);

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    640
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 640
    Points : 776
    Points
    776
    Par défaut
    Une petite précision par rapport à la demande de félix. Si tu souhaites tronquer uniquement les 0 à la fin de ton vecteur et conserver ceux à l'intérieur de celui-ci, tu peux utiliser ce 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
     
    >> a=[1 5 0 6 8 7 5 1 0 0 0 ]
     
    b=numel(a);
     
    while a(b)==0
        b=b-1;
    end
     
    c=a(1:b)
     
    % RESULTAT
     
    a =
     
         1     5     0     6     8     7     5     1     0     0     0
     
     
    c =
     
         1     5     0     6     8     7     5     1

  5. #5
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 304
    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 304
    Points : 52 881
    Points
    52 881
    Par défaut
    Citation Envoyé par Merel Voir le message
    Une petite précision par rapport à la demande de félix. Si tu souhaites tronquer uniquement les 0 à la fin de ton vecteur et conserver ceux à l'intérieur de celui-ci, tu peux utiliser ce code.
    Effectivement, cela semble mieux répondre à la question

    Une alternative :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    >> a = [1 5 0 6 8 7 5 1 0 0 0]
     
    a =
     
         1     5     0     6     8     7     5     1     0     0     0
     
    >> a = deblank(char(a+32))-32
     
    a =
     
         1     5     0     6     8     7     5     1

  6. #6
    Membre chevronné
    Avatar de kmaniche
    Inscrit en
    Janvier 2006
    Messages
    1 717
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 717
    Points : 1 884
    Points
    1 884
    Par défaut
    Bonsoir,


    Avec le code que j'ai proposé, il suffit de remplacer 'first' par 'last'

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    >> a=[1 5 0 6 8 7 5 1 0 0 0 ]
     
    a =
     
         1     5     0     6     8     7     5     1     0     0     0
     
    >> b=a(1:find(a, 1, 'last'))
     
    b =
     
         1     5     0     6     8     7     5     1

Discussions similaires

  1. [Débutant] Application d'un script KPSS sur une série de données
    Par latiole dans le forum MATLAB
    Réponses: 18
    Dernier message: 17/07/2012, 23h07
  2. Recherche de patron dans une série de données
    Par talrashha dans le forum Mathématiques
    Réponses: 2
    Dernier message: 18/06/2010, 14h52
  3. Approximation d'une série de données par une fonction théorique
    Par Natrio dans le forum Statistiques, Data Mining et Data Science
    Réponses: 6
    Dernier message: 05/01/2010, 09h35
  4. Masquer une série de données sur un graphique
    Par Lameth dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 23/07/2008, 01h26
  5. Réponses: 15
    Dernier message: 26/06/2005, 15h53

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