Consider the following set containing 10 amostras
:
{ 2, 3, 3, 4, 5, 6, 7, 8, 9, 10 }
First of all, we calculate the simple arithmetic mean of the samples in the set:
/ p>
data:image/s3,"s3://crabby-images/bbb66/bbb66afbff490af97f2426692c2ca2015eb84b34" alt=""
Next,wecalculatedthedeviationofallthesesamplesfromthemean:
data:image/s3,"s3://crabby-images/d6052/d605207e71de8859af46df4a3bbe24e6f7ed9656" alt=""
Thus,wesquaredthedeviationofeachsamplefromthemean:
data:image/s3,"s3://crabby-images/780af/780afe295f52c9a111744963529439f01a5f5b6b" alt=""
Withthis,weareabletocalculatethe Variance :
data:image/s3,"s3://crabby-images/98cfe/98cfe6a6a151d01614c05305683d12c753a1169f" alt=""
Calculatethe standard deviation by extracting the square root of the variance:
data:image/s3,"s3://crabby-images/2bb05/2bb0507f4bdd359f74a7707908d4e7845bba44df" alt=""
Hereisacodethatcancalculatethe"Mean", "Variance" and "Standard Deviation" of a set of values separately:
#include <stdio.h>
#include <math.h>
#define MAXSIZE 10
double media( double s[], int n )
{
double sum = 0.0;
int i = 0;
for( i = 0; i < n; i++ )
sum += s[i];
return sum / n;
}
double variancia( double s[], int n )
{
double sum = 0.0;
double dev = 0.0;
double med = media( s, n );
int i = 0;
for( i = 0; i < n; i++ )
{
dev = s[i] - med;
sum += (dev * dev);
}
return sum / n;
}
double desvio_padrao( double s[], int n )
{
double v = variancia( s, n );
return sqrt( v );
}
int main( void )
{
double vetor[ MAXSIZE ];
int i;
for( i = 0; i < MAXSIZE; i++ )
{
printf("Digite um numero: ");
scanf( "%lf", &vetor[i] );
}
printf("Media = %g\n", media( vetor, MAXSIZE ) );
printf("Variancia = %g\n", variancia( vetor, MAXSIZE ) );
printf("Desvio Padrao = %g\n", desvio_padrao( vetor, MAXSIZE ) );
return 0;
}
Compiling:
$ gcc -lm desvio.c -o desvio
Test:
Digite um numero: 2
Digite um numero: 3
Digite um numero: 3
Digite um numero: 4
Digite um numero: 5
Digite um numero: 6
Digite um numero: 7
Digite um numero: 8
Digite um numero: 9
Digite um numero: 10
Media = 5.7
Variancia = 6.81
Desvio Padrao = 2.6096