Accueil > > > CALCUL DE VARIANCE
CALCUL DE VARIANCE
Information sur la source
Description
Ce petit programme sert à calculer la variance d'une série de valeur. Exécutables disponibles sur cette page: http://minilog.freehostia.com/telechargements.php
Source
- //------------------------------------------------------------ Fichier: variance.h ------------------------------------------------------------
-
- #ifndef VARIANCE_H_INCLUDED
- #define VARIANCE_H_INCLUDED
-
- class variance
- {
- public:
-
- //-- CONSTRUCTEUR --
-
- variance();
-
- //-- FONCTIONS --
-
- void saisie(std::vector<double> &);
- double moy(const std::vector<double> &);
- double var(const std::vector<double> & , bool);
-
- };
-
- #endif
-
- //----------------------------------------------------------------------------------------------------------------------------------------------
-
- //------------------------------------------------------------ Fichier: variance.cpp ------------------------------------------------------------
-
- #include <iostream>
- #include <vector>
- #include <sstream>
- #include "variance.h"
-
- //-- CONSTRUCTEUR --
-
- variance::variance(){}
-
- //--FIN DU CONSTRUCTEUR --
-
- //-- METHODES --
-
- void variance::saisie(std::vector<double> &t)// saisie dans un tableau.
- {
-
- std::cout<<std::endl<<"Entrer les valeurs:";
- std::cout<<std::endl<<"_________________________________";
- std::cout<<std::endl<<" >(O_O)< | Valeurs "<<std::endl;
- std::cout<<"-----------|---------------------";
- std::cout<<std::endl;
-
- // fin de présentation, ==> insertion.
-
- std::string saisie;
- std::string verif;
-
- size_t found;
- bool good=1;
-
- for(unsigned int i=0;i<t.size();i++)
- {
- std::cout<<" | "<<i+1<<". : ";
- do
- {
- if(good==0)// en cas d'erreur de saisie...
- {
- std::cout<<">RESSAISIR | "<<i+1<<". : ";
- }
-
- std::cin>>saisie;
-
- found=saisie.find_first_of(",");
- while (found!=std::string::npos)
- {
- saisie[found]='.';// les virgules françaises seront automatiquement transformées en point.
- found=saisie.find_first_of(",",found+1);
- }
-
- std::istringstream iss(saisie);// conversion du type string en type double.
- iss>>t[i];
- if(iss.fail())
- {
- good=0;
- }
- else
- {
- std::ostringstream oss;
- oss<<t[i];
- verif=oss.str();
-
- if(verif.size() < saisie.size())
- {
- good=0;
- }
- else{good=1;}
- }
-
- }while(good==0);
- }
- }
-
- double variance::moy(const std::vector<double> &t)
- {
- double k=0;
- for(unsigned int i=0 ; i<t.size() ; i++)
- {
- k=k+t[i];
- }
-
- k=k/t.size();
-
- return k;
- }
-
- double variance::var(const std::vector<double> &t , bool bout)
- {
- double u;
- u=moy(t);
-
- double k=0;
- for(unsigned int i=0 ; i<t.size() ; i++)
- {
- k=k+(t[i]-u)*(t[i]-u);
- }
-
- if(bout==0)
- {
- k=k/t.size();
- }
- else
- {
- k=k/(t.size()-1);
- }
-
- return k;
- }
-
-
- //--FIN DES METHODES--
-
- //-------------------------------------------------------------------------------------------------------------------------------------------
-
- //------------------------------------------------------------ Fichier: main.cpp ------------------------------------------------------------
-
- #include <iostream>
- #include <vector>
- #include <sstream>
- #include <cmath>
- #include "variance.h"
-
- int entier()
- {
- std::string saisie;
- std::string verif;
-
- bool good=1;
- bool trouble=0;
- int num;
-
- do
- {
- if(good==0)
- {
- std::cout<<std::endl<<"-> Saisie incorrecte, ressaisissez: ";
- }
-
- std::cin>>saisie;
-
- std::istringstream iss(saisie);// conversion du type string en type double.
- iss>>num;
- if(iss.fail())
- {
- good=0;
- trouble=1;
- }
- else
- {
- std::ostringstream oss;
- oss<<num;
- verif=oss.str();
-
- if(verif.size() < saisie.size())
- {
- good=0;
- trouble=1;
- }
- else{good=1;}
- }
-
- if(good==1 && trouble==1)
- {
- std::cout<<"-> OK!"<<std::endl;
- }
-
- }while(good==0);
-
- return num;
- }
-
-
- int main()
- {
- std::cout<<">-------------------- CALCUL DE VARIANCE --------------------<"<<std::endl<<std::endl;
-
- std::cout<<" |--------------------------------------------------------|"<<std::endl;
- std::cout<<" | sigma^2 = somme{i=1 -> i=n}[(Xi-u)^2/n] |"<<std::endl;
- std::cout<<" | |"<<std::endl;
- std::cout<<" | le i de Xi est l'observation <<i>> de la variable X |"<<std::endl;
- std::cout<<" | u est la moyenne de la variable X |"<<std::endl;
- std::cout<<" | n est le nombre d'observations |"<<std::endl;
- std::cout<<" |--------------------------------------------------------|"<<std::endl<<std::endl<<std::endl;
-
- int taille;
- int quitter=0;
- int choix;
- double sigma;
-
- variance v;
-
- do//pour le "quitter" de fin
- {
- std::cout<<"-------------------- MENU --------------------"<<std::endl<<std::endl;
-
- std::cout<<" 1. Calcul de moyenne"<<std::endl;
- std::cout<<" 2. Calcul de variance sur une population"<<std::endl;
- std::cout<<" 3. Calcul de variance sur une partie de population"<<std::endl<<std::endl;
- std::cout<<" 0. ) Quitter ("<<std::endl;
-
- if(quitter==0)// cela ne sera possible que lors de la première utilisation, après il sera obligatoirement égal à 1 pour pouvoir recommencer un autre calcul.
- {
- std::cout<<std::endl<<std::endl;
- std::cout<<" (NOTE: Le calcul de variance s'occupera de faire la moyenne.)";
- std::cout<<std::endl;
- }
-
- std::cout<<std::endl<<"--> Choix: ";
- do
- {
- choix=entier();
- if(choix<0 || choix>3){std::cout<<std::endl<<"-> Le choix "<<choix<<" n'existe pas, ressaisissez: ";}
- }while(choix<0 || choix>3);
-
- if(choix==0)
- {
- std::cout<<std::endl<<">------------------------------------------------------------<"<<std::endl<<std::endl;
- return 0;
- }
-
- std::cout<<std::endl;
-
- do
- {
- std::cout<<"Indiquer le nombre de valeurs: ";
- taille=entier();
- if(taille<1){std::cout<<std::endl<<"-> ATTENTION! Il doit subsister au moins une valeur. Ressaisissez."<<std::endl<<std::endl;}
- }while(taille<1);
-
- std::vector<double> VAL(taille,0);// définition du "tableau" de stockage des valeurs.
-
- v.saisie(VAL);
-
- if(choix==1)
- {
- std::cout<<std::endl<<"==> La moyenne est de "<<v.moy(VAL)<<std::endl;
- }
- else
- {
- if(choix==2)
- {
- sigma=v.var(VAL , 0);
- }
- else
- {
- sigma=v.var(VAL , 1);
- }
-
- std::cout<<std::endl<<"==> La variance est de "<<sigma<<std::endl;
- std::cout<<"==> sigma = "<<sqrt(sigma)<<std::endl;
- }
-
-
- std::cout<<std::endl<<std::endl<<">------------------------------------------------------------<"<<std::endl;
- std::cout<<std::endl<<"--> Faire un autre calcul? (1=oui/0=non): ";
- quitter=entier();
- std::cout<<std::endl<<">------------------------------------------------------------<"<<std::endl<<std::endl;
-
- }while(quitter>0);
- return 0;
- }
-
- //-------------------------------------------------------------------------------------------------------------------------------------------
//------------------------------------------------------------ Fichier: variance.h ------------------------------------------------------------
#ifndef VARIANCE_H_INCLUDED
#define VARIANCE_H_INCLUDED
class variance
{
public:
//-- CONSTRUCTEUR --
variance();
//-- FONCTIONS --
void saisie(std::vector<double> &);
double moy(const std::vector<double> &);
double var(const std::vector<double> & , bool);
};
#endif
//----------------------------------------------------------------------------------------------------------------------------------------------
//------------------------------------------------------------ Fichier: variance.cpp ------------------------------------------------------------
#include <iostream>
#include <vector>
#include <sstream>
#include "variance.h"
//-- CONSTRUCTEUR --
variance::variance(){}
//--FIN DU CONSTRUCTEUR --
//-- METHODES --
void variance::saisie(std::vector<double> &t)// saisie dans un tableau.
{
std::cout<<std::endl<<"Entrer les valeurs:";
std::cout<<std::endl<<"_________________________________";
std::cout<<std::endl<<" >(O_O)< | Valeurs "<<std::endl;
std::cout<<"-----------|---------------------";
std::cout<<std::endl;
// fin de présentation, ==> insertion.
std::string saisie;
std::string verif;
size_t found;
bool good=1;
for(unsigned int i=0;i<t.size();i++)
{
std::cout<<" | "<<i+1<<". : ";
do
{
if(good==0)// en cas d'erreur de saisie...
{
std::cout<<">RESSAISIR | "<<i+1<<". : ";
}
std::cin>>saisie;
found=saisie.find_first_of(",");
while (found!=std::string::npos)
{
saisie[found]='.';// les virgules françaises seront automatiquement transformées en point.
found=saisie.find_first_of(",",found+1);
}
std::istringstream iss(saisie);// conversion du type string en type double.
iss>>t[i];
if(iss.fail())
{
good=0;
}
else
{
std::ostringstream oss;
oss<<t[i];
verif=oss.str();
if(verif.size() < saisie.size())
{
good=0;
}
else{good=1;}
}
}while(good==0);
}
}
double variance::moy(const std::vector<double> &t)
{
double k=0;
for(unsigned int i=0 ; i<t.size() ; i++)
{
k=k+t[i];
}
k=k/t.size();
return k;
}
double variance::var(const std::vector<double> &t , bool bout)
{
double u;
u=moy(t);
double k=0;
for(unsigned int i=0 ; i<t.size() ; i++)
{
k=k+(t[i]-u)*(t[i]-u);
}
if(bout==0)
{
k=k/t.size();
}
else
{
k=k/(t.size()-1);
}
return k;
}
//--FIN DES METHODES--
//-------------------------------------------------------------------------------------------------------------------------------------------
//------------------------------------------------------------ Fichier: main.cpp ------------------------------------------------------------
#include <iostream>
#include <vector>
#include <sstream>
#include <cmath>
#include "variance.h"
int entier()
{
std::string saisie;
std::string verif;
bool good=1;
bool trouble=0;
int num;
do
{
if(good==0)
{
std::cout<<std::endl<<"-> Saisie incorrecte, ressaisissez: ";
}
std::cin>>saisie;
std::istringstream iss(saisie);// conversion du type string en type double.
iss>>num;
if(iss.fail())
{
good=0;
trouble=1;
}
else
{
std::ostringstream oss;
oss<<num;
verif=oss.str();
if(verif.size() < saisie.size())
{
good=0;
trouble=1;
}
else{good=1;}
}
if(good==1 && trouble==1)
{
std::cout<<"-> OK!"<<std::endl;
}
}while(good==0);
return num;
}
int main()
{
std::cout<<">-------------------- CALCUL DE VARIANCE --------------------<"<<std::endl<<std::endl;
std::cout<<" |--------------------------------------------------------|"<<std::endl;
std::cout<<" | sigma^2 = somme{i=1 -> i=n}[(Xi-u)^2/n] |"<<std::endl;
std::cout<<" | |"<<std::endl;
std::cout<<" | le i de Xi est l'observation <<i>> de la variable X |"<<std::endl;
std::cout<<" | u est la moyenne de la variable X |"<<std::endl;
std::cout<<" | n est le nombre d'observations |"<<std::endl;
std::cout<<" |--------------------------------------------------------|"<<std::endl<<std::endl<<std::endl;
int taille;
int quitter=0;
int choix;
double sigma;
variance v;
do//pour le "quitter" de fin
{
std::cout<<"-------------------- MENU --------------------"<<std::endl<<std::endl;
std::cout<<" 1. Calcul de moyenne"<<std::endl;
std::cout<<" 2. Calcul de variance sur une population"<<std::endl;
std::cout<<" 3. Calcul de variance sur une partie de population"<<std::endl<<std::endl;
std::cout<<" 0. ) Quitter ("<<std::endl;
if(quitter==0)// cela ne sera possible que lors de la première utilisation, après il sera obligatoirement égal à 1 pour pouvoir recommencer un autre calcul.
{
std::cout<<std::endl<<std::endl;
std::cout<<" (NOTE: Le calcul de variance s'occupera de faire la moyenne.)";
std::cout<<std::endl;
}
std::cout<<std::endl<<"--> Choix: ";
do
{
choix=entier();
if(choix<0 || choix>3){std::cout<<std::endl<<"-> Le choix "<<choix<<" n'existe pas, ressaisissez: ";}
}while(choix<0 || choix>3);
if(choix==0)
{
std::cout<<std::endl<<">------------------------------------------------------------<"<<std::endl<<std::endl;
return 0;
}
std::cout<<std::endl;
do
{
std::cout<<"Indiquer le nombre de valeurs: ";
taille=entier();
if(taille<1){std::cout<<std::endl<<"-> ATTENTION! Il doit subsister au moins une valeur. Ressaisissez."<<std::endl<<std::endl;}
}while(taille<1);
std::vector<double> VAL(taille,0);// définition du "tableau" de stockage des valeurs.
v.saisie(VAL);
if(choix==1)
{
std::cout<<std::endl<<"==> La moyenne est de "<<v.moy(VAL)<<std::endl;
}
else
{
if(choix==2)
{
sigma=v.var(VAL , 0);
}
else
{
sigma=v.var(VAL , 1);
}
std::cout<<std::endl<<"==> La variance est de "<<sigma<<std::endl;
std::cout<<"==> sigma = "<<sqrt(sigma)<<std::endl;
}
std::cout<<std::endl<<std::endl<<">------------------------------------------------------------<"<<std::endl;
std::cout<<std::endl<<"--> Faire un autre calcul? (1=oui/0=non): ";
quitter=entier();
std::cout<<std::endl<<">------------------------------------------------------------<"<<std::endl<<std::endl;
}while(quitter>0);
return 0;
}
//-------------------------------------------------------------------------------------------------------------------------------------------
Historique
- 06 mars 2010 23:43:39 :
- Modification d'une variable et suppression d'une variable inutile.
Rajout d'un screenshot.
- 11 mars 2010 18:19:12 :
- Refonte des fonctions de traitement d'erreur de saisie + réorganisation de déclaration de certaines variables.
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
[EXCEL]calcul de moyenne scolaire: gerer les absents!! [ par poloiu ]
Bonjour, j'ai besoin de calculer la moyenne de plusieurs note. J'ai deux conditions : 1 l'élève peux être absent 2 les notes sont sur 10 ou sur 20 Co
calcul distance géodésique! [ par charniele2 ]
coucoi à tous![^^clinoeil1] bjr!! j'aimerai que vous m'aider pour la programmation du calcul de la distance géodésique entre 2 points sur une forme co
Maillage 3D + quadtree + calcul de normales [ par buno ]
Hello, J'ai un maillage 3D (terrain) avec 3 niveaux de détails que j'affiche à l'aide d'un quadtree. Le calcul et l'affichage des données se fait uniq
le calcul de la complexité [ par boualiasma ]
Bonjour, Quelle est la complexité au pire de cas pour le calcul de toutes les combinaisons possibles pour n caractères à partir de taille 2 jusqu'à
exercices à résoudre [ par jomsow ]
bonjour je suis débutant en C svp aidez moi à résoudre ces deux exercices : Exercice 1: Modifier le programme suivant de telle sorte qu’il affiche
Créer une socket de calcul parallèle [ par walidhas ]
slt, j'ai voulu créer une socket en MFC .Dans cette Socket le client et le serveur font chacun des calculs différents et durant ce calcul il y a échan
resolution d'un probleme [ par sacrifice1 ]
je voudrais bien savoir la solution de: un programme qui calcul la DCT d'une matrice puis un autre qui calcul la idct à partir du IDC en C. MERCI.
Conversion code [ par jeanphilippe37 ]
[u]Bonjour[/u], Voila, j'ai réalisé ce programme en C++ mais, je dois le rendre en langage C et j'ai bcp de mal à faire la traduction. Pourriez vous
moyenne mobile [ par jeanjeuv ]
Bonjour, Je cherche à réaliser une moyenne mobile en C, lorsque je regarde sur internet (http://fr.wikipedia.org/wiki/Moyenne_glissante) je ne compren
|
Derniers Blogs
IMAGINE CUP 2012, MAKE A SIGN EN FINALEIMAGINE CUP 2012, MAKE A SIGN EN FINALE par junarnoalg
Voilà qui est fait, la nouvelle est officielle ! L'équipe belge "Make a Sign" va au pays des kangourous défendre son projet dans la catégorie Software Design. http://www.imaginecup.com/CompetitionsContent/Competition/WorldwideFinalists.aspx V...
Cliquez pour lire la suite de l'article par junarnoalg KINECT 1.5 IS OUT !KINECT 1.5 IS OUT ! par Vko
La version 1.5 du Kinect For Microsoft vient tout juste de sortir ! Plein de nouveautés: Tracking de squelette en Near Mode Détection en position assise Détection faciale avec un SDK dédié Documentation et des guideline (enfin) Un out...
Cliquez pour lire la suite de l'article par Vko LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) par richardc
Mise à jour des Web API du 14 Mai
Réservez dès maintenant votre journée du 20 juin pour le Windows Azure Dev Camp 2012 à Paris
Mise à jour de Team Foundation Service
MechCommander 2 sur Windows 8
Entity Framework 5 Release Candidate e...
Cliquez pour lire la suite de l'article par richardc REACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITERREACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITER par Groc
Une mauvaise utilisation de rx lors de l'écriture d'une couche d'accès à des services peut conduire à des cas embarassants avec des erreurs mal gérées, des appels qui ne partent lorsqu'ils le devraient, et même des résultats incorrects . le tout nuis...
Cliquez pour lire la suite de l'article par Groc SHAREPOINT BLOG SITE, PROBLèME D'ARCHIVESSHAREPOINT BLOG SITE, PROBLèME D'ARCHIVES par junarnoalg
Dernièrement, nous avons migré le site
myTIC
vers un nouveau serveur SharePoint 2010. Dans les contenus que nous vouloins récupérer, nous avions un certain nombre de blogs.
Nous avons utilisé les commandes Power...
Cliquez pour lire la suite de l'article par junarnoalg
Forum
MATRICE TEMPLATEMATRICE TEMPLATE par hjr2610
Cliquez pour lire la suite par hjr2610 RE : SAC A DOS RE : SAC A DOS par hadjkaddour
Cliquez pour lire la suite par hadjkaddour
Logiciels
sDEVIS-FACTURES vlPRO (8.1.0.3)SDEVIS-FACTURES VLPRO (8.1.0.3)sDEVIS-FACTURES vlPRO a été mis au point pour les particuliers, créateurs, entrepreneurs, artisa... Cliquez pour télécharger sDEVIS-FACTURES vlPRO 974 Application Server (12.2.4.6)974 APPLICATION SERVER (12.2.4.6)Développez de puissantes applications dans un environnement de 'cloud computing', clusterisé, séc... Cliquez pour télécharger 974 Application Server vPicture (1.4.2.1)VPICTURE (1.4.2.1)Avec vPicture, hébergez vos images facilement et rapidement.
vPicture est un utilitaire simple, ... Cliquez pour télécharger vPicture Easy-Planning (2.2.1.6)EASY-PLANNING (2.2.1.6)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté au... Cliquez pour télécharger Easy-Planning COM-BACKUP (2.0)COM-BACKUP (2.0)
COM-BACKUP est un logiciel de sauvegarde qui permet de planifier les sauvegardes de vos dossiers ...
Cliquez pour télécharger COM-BACKUP
|