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 :

générer une matrice de covariance


Sujet :

MATLAB

  1. #1
    Membre éprouvé
    Inscrit en
    Août 2010
    Messages
    1 124
    Détails du profil
    Informations forums :
    Inscription : Août 2010
    Messages : 1 124
    Points : 1 277
    Points
    1 277
    Par défaut générer une matrice de covariance
    Bonjour,

    Je génère une matrice symétrique définie positive, comme suit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    P=10;N=1000;
    cr= rand(P,P)-0.5; % éléments extra diago
    cr= cr .* (1- diag(nan(P,1))); cr(isnan(cr))= 1; % 1 sur la diago
    cr= (cr + cr')/2; % symétrisation
    Mais quand je veux l'utiliser en tant que matrice de covariance
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    x= mvnrnd(zeros(P,1)',cr,N);
    J'obtiens l'erreur
    Error using ==> mvnrnd at 118
    SIGMA must be a symmetric positive semi-definite matrix.
    La fonction cholcov() ne la valide pas comme un matrice de covariance.

    Êtes vous d'accord pour affirmer que cr est bien une matrice de corrélation ?
    Ais-je raté quelque chose ? Voyez vous un moyen de générer une matrice acceptée par cholcov() ?

    Merci d'avance

  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
    Je ne sais pas si cela répond à ta question, mais d'après ceci, c'est dû au fait que la matrice cr a parfois une valeur propre négative.

    Un contournement :

    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
    P=10;
    N=1000;
     
    f = 1;
     
    while f
        cr = rand(P,P)-0.5;
        cr = (cr + cr.')/2;
        cr(1:P+1:end) = 1;
     
        if all(eig(cr)>0)
            f = 0;
        end
    end
     
    x = mvnrnd(zeros(1,P),cr,N);
    Maintenant, si ta question porte plus sur le pourquoi mathématique de ton problème, je te propose de poser ta question dans le forum Algorithmes > Mathématiques
    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
    FLB
    FLB est déconnecté
    Modérateur
    Avatar de FLB
    Homme Profil pro
    Ing. Aérospatiale
    Inscrit en
    Juin 2003
    Messages
    770
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France

    Informations professionnelles :
    Activité : Ing. Aérospatiale
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2003
    Messages : 770
    Points : 1 185
    Points
    1 185
    Par défaut
    Citation Envoyé par VV33D
    Êtes vous d'accord pour affirmer que cr est bien une matrice de corrélation
    Symétrique, ok, mais quels sont tes arguments pour affirmer ça?
    Tu ne préfères pas utiliser :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    xcorr(rand(1,P),rand(1,P));

  4. #4
    Membre éprouvé
    Inscrit en
    Août 2010
    Messages
    1 124
    Détails du profil
    Informations forums :
    Inscription : Août 2010
    Messages : 1 124
    Points : 1 277
    Points
    1 277
    Par défaut
    Merci beaucoup à tous les 2 !

    cr a parfois une valeur propre négative
    quels sont tes arguments
    Bah du coup je ne me risquerai pas à donner un argument

    Par ailleurs, je n'ai pas xcorr(). De quelle toolbox provient elle ?

    J'utilise finalement un simple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    S = randn(P); [~,cr]= cov2corr(S'*S)
    qui permet de plus d'avoir des corrél. positives en changeant randn -> rand

  5. #5
    FLB
    FLB est déconnecté
    Modérateur
    Avatar de FLB
    Homme Profil pro
    Ing. Aérospatiale
    Inscrit en
    Juin 2003
    Messages
    770
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France

    Informations professionnelles :
    Activité : Ing. Aérospatiale
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2003
    Messages : 770
    Points : 1 185
    Points
    1 185
    Par défaut
    Moi non plus
    De quelle toolbox provient elle
    La signal processing toolbox
    cov2corr
    C'est par la financial toolbox que t'as ça ?!

  6. #6
    Membre éprouvé
    Inscrit en
    Août 2010
    Messages
    1 124
    Détails du profil
    Informations forums :
    Inscription : Août 2010
    Messages : 1 124
    Points : 1 277
    Points
    1 277
    Par défaut
    Merci.

    cov2corr
    C'est par la financial toolbox que t'as ça ?!
    Oui, mais il y a aussi corrcov

  7. #7
    FLB
    FLB est déconnecté
    Modérateur
    Avatar de FLB
    Homme Profil pro
    Ing. Aérospatiale
    Inscrit en
    Juin 2003
    Messages
    770
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France

    Informations professionnelles :
    Activité : Ing. Aérospatiale
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2003
    Messages : 770
    Points : 1 185
    Points
    1 185
    Par défaut
    corrcov
    Ca c'est de la statistic toolbox. Tout ce que je connais dans le genre et disponible sans toolbox est conv (et ses cousins conv2, convn), pour obtenir une correlation on peut faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    n = 10; 
    sig1 = rand(1,n); %premier signal
    sig2 = rand(1,n); %second signal
    convol = conv(sig1,fliplr(sig2)); 
    correl = convol(n)/norm(sig1)/norm(sig2)%valeur de la correlation entre les signaux

  8. #8
    Membre éprouvé
    Inscrit en
    Août 2010
    Messages
    1 124
    Détails du profil
    Informations forums :
    Inscription : Août 2010
    Messages : 1 124
    Points : 1 277
    Points
    1 277
    Par défaut
    Y'a plus simple non ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (1./std(x)')*cov(x)*(1./std(x))
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    c=cov(x); 1./sqrt(diag(c))'*c*1./sqrt(diag(c))

  9. #9
    FLB
    FLB est déconnecté
    Modérateur
    Avatar de FLB
    Homme Profil pro
    Ing. Aérospatiale
    Inscrit en
    Juin 2003
    Messages
    770
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France

    Informations professionnelles :
    Activité : Ing. Aérospatiale
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2003
    Messages : 770
    Points : 1 185
    Points
    1 185
    Par défaut
    Pas tout à fait je crois :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    covarNormed = (1./std(sig1)')*cov(sig1,sig2)*(1./std(sig2));
    covarNormed(1,2)
    Ne donne la même valeur que la corrélation que si les signaux à corréler sont de moyenne nulle.

  10. #10
    Membre éprouvé
    Inscrit en
    Août 2010
    Messages
    1 124
    Détails du profil
    Informations forums :
    Inscription : Août 2010
    Messages : 1 124
    Points : 1 277
    Points
    1 277
    Par défaut
    J'avais raté ta remarque FLB, du coup je me réveille.
    Mon code repose sur std/cov qui centrent les données. Si tes résultats sur données non centrées diffèrent, c'est que tu ne calcules pas une covariance E(X-EX)'(X-EX) mais un moment décentré E(X'X) avec les conv.

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

Discussions similaires

  1. [Débutant] Générer une matrice à partir d'un fichier
    Par thtghgh dans le forum MATLAB
    Réponses: 1
    Dernier message: 25/04/2010, 19h22
  2. Réponses: 1
    Dernier message: 14/02/2010, 01h18
  3. Générer une matrice de rotation à partir d'un axe et d'un angle
    Par IXaMaXI dans le forum Développement 2D, 3D et Jeux
    Réponses: 4
    Dernier message: 29/07/2009, 14h35
  4. Comment générer une matrice de rotation pour un axe et un angle donnés ?
    Par Kromagg dans le forum Développement 2D, 3D et Jeux
    Réponses: 6
    Dernier message: 20/07/2009, 12h45
  5. générer une matrice aléatoire
    Par harris_macken dans le forum Collection et Stream
    Réponses: 1
    Dernier message: 17/03/2008, 19h23

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