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

Signal Discussion :

Classification de signaux via Kmeans et BIC.


Sujet :

Signal

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2012
    Messages : 15
    Points : 11
    Points
    11
    Par défaut Classification de signaux via Kmeans et BIC.
    Bonjours,

    Je suis entrain de développer un programme sous Matlab, de classification de signaux.

    Pour cela j'utilise la fonction kmeans de Matlab ou je lui envoie en entrée la matrice D (par exemple: de taille 37*348), les lignes correspondant aux signaux et les colonnes aux échantillons.
    Par kmeans cela est interprété comme 37 points se trouvant dans 348 dimensions.
    Et aussi en entré le scalaire K qui est le nombre de classes que je veux.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    [IDX,~,~,sqEuDist] = kmeans(D,K,'emptyaction','drop','replicate',18);%classification
    Et ensuite pour évaluer l'efficacité de la classification réalisé par kmeans j'utilise le Critère d'Information Bayesien:
    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
    R=size(D,1);%nombre de points
    M=size(D,2);%dimmension du système
     
    variance=1/(size(D,1)-K)*sum(min(sqEuDist.'));%varraince du modèle identité
    ecart_type=sqrt(variance);%ecart-type du modèle identité
     
    k=1:K;
    nbPtsParClasse=arrayfun(@(classe) numel(find(IDX==classe)),k);
    Rclust=nbPtsParClasse(IDX(1:R));%Rclust(p)= nombres de points dans la classe du point p
     
    Temp1=log(1/(ecart_type^M*sqrt(2*pi)))*ones(1,R);
    Temp2=-1/(2*variance)*min(sqEuDist.');
    Temp3=log(Rclust/R);
    log_vraisemblance=sum(Temp1+Temp2+Temp3);
     
    Pj=K-1+M*K+1;%nombre de paramètres
    BIC(K)=log_vraisemblance-Pj/2*log(R);%critère d'information Bayesien
    Mon problème se trouve à la ligne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Temp1=log(1/(ecart_type^M*sqrt(2*pi)))*ones(1,R);
    ou ecart_type est à la puissance M càd 348.
    L'ordi ne peux pas quantifier ce résultat et le détermine comme un scalaire de valeur Inf.Et mon plus gros problème est que j'aimerais pouvoir faire marcher mon programme pour des signaux avec une valeur d’échantillon bien plus important

    Auriez vous déjà utilisé le BIC dans une application proche de la mienne et comment vous en êtes vous sortie ?

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    Tu peux te servir des propriétés du logarithme :
    log(x.y) = log(x) + log(y)
    log(x^n) = n.log(x)
    Ce qui donne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    log(1/(ecart_type^M*sqrt(2*pi)))
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    -(M*log(ecart_type) + log(sqrt(2*pi)) )

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2012
    Messages : 15
    Points : 11
    Points
    11
    Par défaut
    Bravo et merci Winjerome, simple et efficace.

    Je pense sérieusement que remettre ma tête dans mes cahiers de lycée ne me ferais pas de mal

    Mais quand même, voila un problème sur l'overflow en informatique que je ne pourrais expliqué.

  4. #4
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par baalk42 Voir le message
    Mais quand même, voila un problème sur l'overflow en informatique que je ne pourrais expliqué.
    Les valeurs sont stockées sur un certain nombre de bits, et ce nombre n'est pas extensible . Un peu de lecture

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

Discussions similaires

  1. Calcul d'un déphasage entre 2 signaux via une FFT
    Par JeKiffeLesMath dans le forum Traitement du signal
    Réponses: 6
    Dernier message: 13/05/2011, 14h46
  2. Réponses: 1
    Dernier message: 07/06/2010, 14h40
  3. Réponses: 7
    Dernier message: 11/01/2010, 18h52
  4. Réseau de neurones pour la classification de signaux.
    Par jeanlouis_lecodeur dans le forum Méthodes prédictives
    Réponses: 3
    Dernier message: 26/03/2008, 18h28
  5. Classification de signaux (stationnaire - non stationnaire)
    Par yoann_deygas dans le forum Signal
    Réponses: 1
    Dernier message: 16/05/2007, 14h59

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