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

 C++ Discussion :

Erreur lors de la compilation


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 8
    Par défaut Erreur lors de la compilation
    Bonjour,

    Je suis débutant en c++ et j'essaie de compiler le programme ci dessous mais j obtiens le message d erreur suivant 4 fois:invalid types 'double[int]' for array subscript. Je ne vois pas à quoi cela correspond....
    Merci d'avance!!

    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    #include "VA.cpp"
    #include <vector> 
    #include <algorithm> //pour utiliser la fonction min()
    using namespace std;
     
    class CDO
    {
    public:	
    	CDO (const int a, const int N, const double c, const double k1,const double k2);
    	~CDO();
    	void getELK1K2();
    	double price();
    	double* ELK1K2;
        double* TRESHOLD, BONDS;
    private:
    	int years, contracts;//nombre d'annèes de vie du cdo (avec payment trimestriel) et nombre de contracts sous-jacents	
    	double correl,K1,K2;//Corrélation et pourcentages de la tranche
        ;
    };
     
    CDO::CDO (const int a,const  int N, const double c,const double k1,const  double k2)
    	: years(a),contracts(N), correl(c),K1(k1),K2(k2){
    	double* ELK1K2=new double[4*years+1];
    	double* TRESHOLD=new double[4*years];
    	double* BONDS=new double[4*years];
     
    	for (int i=0;i<4*years;i++)
    	{ TRESHOLD[i]=i/100.;
    	  BONDS[i]=1/pow(1.03,0.25*(1+i));	}
     
    	}
     
     // ~ CDO()	 {
    	 // delete [] ELK1K2;
    	 // delete [] TRESHOLD;
    	 // delete [] BONDS; }
     
    void CDO::getELK1K2()
    {
    		const double n=(years*4);
    		const double MC=100000;
    		int j;
    		ELK1K2[0]=0.;
    		Norm M(0,1);//facteur de marché commun
    		double MM,L;
    		L=0.;
    		vector<Norm> NGauss(contracts);//vecteur de loi gaussiennes modélisant les rendements des titres
    		vector <double> Gauss(contracts);
    		for (int i=0;i<n;i++)
    		{
    		for (int ii=0;i<MC;ii++)
    		{MM=M();
    		j=0;
    		for(int iii=0;iii<contracts;iii++)
    		{Gauss[iii]=NGauss[iii]()*sqrt(1-correl*correl)+correl*MM;
    		if (Gauss[iii]<TRESHOLD[i]) j=j+1;}
    		L=L+max(min(j/n,K2)-K1,0.)/(K2-K1);
    		}
    		ELK1K2[i+1]=L/MC;
    		}
    }
     
    double CDO::price()
    {   const double n=(years*4);
    	double premium, protection,s,price; //les deux jambes du CDO, le taux s et le pix de la tranche
    	double denom;
        premium=0.;
    	protection=0.;	
    	denom=0.;
    	for (int i=0;i<n;i++)
    	{
    	protection=protection+(ELK1K2[i+1]-ELK1K2[i])*BONDS[i];
    	denom=denom+0,25.*(1-ELK1K2[i+1])*BONDS[i];
    	}
    	s=protection/denom;
     
    	for (int i=0;i<n;i++)
    	{premium=premium+0,25.*s*(1-ELK1K2[i+1])*BONDS[i];}
     
    	price=protection-premium;
    	return price;
    	}
     
    	int main(){
     
     
        CDO AIG (1, 80,0.09,0.03,0.09);
    	AIG.getELK1K2();
    	AIG.price();
     
     
     
    	return 1;
    }

  2. #2
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 8
    Par défaut Suite
    Peut être devrais je ajouter que les erreurs apparaissent dans la fonction CDO::price aux lignes
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
           protection=protection+(ELK1K2[i+1]-ELK1K2[i])*BONDS[i];
    	denom=denom+0,25.*(1-ELK1K2[i+1])*BONDS[i];
    	}
    	s=protection/denom;
     
    	for (int i=0;i<n;i++)
    	{premium=premium+0,25.*s*(1-ELK1K2[i+1])*BONDS[i];}

  3. #3
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Par défaut
    Bonjour et bienvenu,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    double* TRESHOLD, BONDS;
    déclare TRESHOLD de type double* et BONDS de type double. Donc BONDS n'est pas un tableau dynamique :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    double* TRESHOLD;
    double*  BONDS;
    Mais encore mieux :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    std::vector<double> TRESHOLD;
    std::vector<double> BONDS;
    Dans ton cas, tu n'as vraiment aucune raison de ne pas passer par un std::vector !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    CDO::CDO (const int a,const  int N, const double c,const double k1,const  double k2)
    	: years(a),contracts(N), correl(c),K1(k1),K2(k2){
    	double* ELK1K2=new double[4*years+1];
    	double* TRESHOLD=new double[4*years];
    	double* BONDS=new double[4*years];
     
    	for (int i=0;i<4*years;i++)
    	{ TRESHOLD[i]=i/100.;
    	  BONDS[i]=1/pow(1.03,0.25*(1+i));	}
     
    	}
    ne fait pas ce que tu penses !
    Les variables ELK1K2,TRESHOLD et BONDS allouées ne sont pas celles de ton objet mais les variables locales du constructeur qui les masquent.

    Ca marchera mieux comme ça et sans avoir à te préoccuper d'allocation/libération :
    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
    class CDO
    {
    public:	
    	CDO (const int a, const int N, const double c, const double k1,const double k2);
    	void getELK1K2();
    	double price();
       std::vector<double> ELK1K2;
        std::vector<double> TRESHOLD, BONDS;
    private:
    	int years, contracts;//nombre d'annèes de vie du cdo (avec payment trimestriel) et nombre de contracts sous-jacents	
    	double correl,K1,K2;//Corrélation et pourcentages de la tranche
        ;
    };
     
    CDO::CDO (const int a,const  int N, const double c,const double k1,const  double k2)
    	: years(a),contracts(N), correl(c),K1(k1),K2(k2){
    	ELK1K2.resize(4*years+1);
    	TRESHOLD.resize(4*years);
    	BONDS.resize(4*years);

  4. #4
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 8
    Par défaut
    Merci beaucoup pour ton aide!!!!!

Discussions similaires

  1. Réponses: 3
    Dernier message: 09/04/2015, 11h01
  2. Erreur lors de la compilation de MySQL
    Par webrider dans le forum SUSE
    Réponses: 2
    Dernier message: 06/03/2007, 11h21
  3. Erreur lors de la compilation avec OmniORB
    Par JohnKwada dans le forum CORBA
    Réponses: 1
    Dernier message: 07/09/2006, 17h34
  4. erreur lors de la compilation
    Par ksoft dans le forum MFC
    Réponses: 2
    Dernier message: 02/05/2006, 15h40
  5. Réponses: 4
    Dernier message: 22/02/2006, 14h11

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