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 :

Aide à la création d'un graphique


Sujet :

MATLAB

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2015
    Messages : 20
    Points : 15
    Points
    15
    Par défaut Aide à la création d'un graphique
    Bonjour,

    Tout d'abord je vous remercie d'avance pour l'aide que vous allez m'apporter. Voici le code ma fonction :

    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
    function  [wOpt,kopt] = minimumVariance_acp(x,Kmax)
     
    %purpose: this function runs the global minimum variance portfolio program with 
    %         the inputs computed from a principal component analysis
    %inputs: x is a (n,k) matrix of securities returns, with in each column the returns of 
    %        a given security
    %        K is the maximal number of factors
    %output: wOpt is the (k,1) vector of optimal portfolio weights
     
    [n,p] = size(x);
    Cov = cov(x,1);
     
    %acp pour la valeur maximale (soit Kmax)
    [EigenVectors,EigenValues] = pcacov(Cov);
    ReturnsOfAxis = x*EigenVectors(:,1:Kmax);
    Residuals = x-ReturnsOfAxis*EigenVectors(:,1:Kmax)';
    sig2Kmax = mean(var(Residuals));
     
    crit = ones(Kmax,1)*NaN;
    for k=1:Kmax
      % estimation des inputs par acp
      [EigenVectors,EigenValues] = pcacov(Cov);
      ReturnsOfAxis = x*EigenVectors(:,1:k);
      Residuals = x-ReturnsOfAxis*EigenVectors(:,1:k)';
      sig2k = mean(var(Residuals));
      crit(k) = k*sig2k+k*sig2Kmax*((p+n)/(p*n))*log((p*n)/(p+n));
    end
     
     
    [val,idx] = min(crit);
    kopt = idx;
    %
    [EigenVectors,EigenValues] = pcacov(Cov);
    ReturnsOfAxis = x*EigenVectors(:,1:kopt);
    Residuals = x-ReturnsOfAxis*EigenVectors(:,1:kopt)';
    CovPCA = EigenVectors(:,1:kopt)*cov(ReturnsOfAxis,1)*EigenVectors(:,1:kopt)'+...
                  diag(diag(cov(Residuals,1)));
     wOpt = (inv(CovPCA)*ones(p,1))/sum(inv(CovPCA)*ones(p,1));
    Mon soucis est que je souhaiterai créer un graphique avec comme abscisse k et ordonné crit(k) de telle sorte que pour k=1, j'ai la valeur crit(1) ainsi de suite.
    J'ai testé plusieurs manipulations (plot(1:Kmax,crit(1:Kmax)) pour essayer d'arriver à ce résultat sans grande réussite.

    Si vous pouvez m'indiquer une méthode ou me mettre sur la voie.

    Cordialement,

  2. #2
    Modérateur

    Homme Profil pro
    Ingénieur en calculs scientifiques
    Inscrit en
    Août 2007
    Messages
    4 639
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Ingénieur en calculs scientifiques

    Informations forums :
    Inscription : Août 2007
    Messages : 4 639
    Points : 7 614
    Points
    7 614
    Par défaut
    Bonjour,
    Citation Envoyé par Crimsim Voir le message
    J'ai testé plusieurs manipulations (plot(1:Kmax,crit(1:Kmax)) pour essayer d'arriver à ce résultat sans grande réussite.
    pourtant, ça a l'air pas mal ça. Qu'est-ce qui ne va pas exactement?
    Pour une bonne utilisation des balises code c'est ici!
    Petit guide du voyageur MATLABien : Le forum La faq Les tutoriels Les sources


    La nature est un livre écrit en langage mathématique. Galilée.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2015
    Messages : 20
    Points : 15
    Points
    15
    Par défaut
    Ca ne fonctionnait pas. J'avais l'ensemble des points sur une ligne verticale. Mais j'ai trouvé la solution, il fallait juste écrire plot(crit)

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

Discussions similaires

  1. Création de composants graphiques perso Visual C++
    Par jacques_henry dans le forum MFC
    Réponses: 1
    Dernier message: 06/01/2006, 11h40
  2. Réponses: 3
    Dernier message: 10/12/2005, 11h06
  3. [MySQL] Aide à la création d'une requête
    Par tom06440 dans le forum Requêtes
    Réponses: 6
    Dernier message: 19/10/2005, 22h05
  4. aide sur création d'un composant
    Par laetus dans le forum C++Builder
    Réponses: 2
    Dernier message: 14/07/2004, 10h45
  5. Réponses: 2
    Dernier message: 29/03/2004, 18h29

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