76 lines
1.1 KiB
C
76 lines
1.1 KiB
C
|
#ifndef _MATH_GUARD
|
||
|
#define _MATH_GUARD
|
||
|
|
||
|
typedef struct Stats {
|
||
|
float mean;
|
||
|
float std;
|
||
|
} Stats;
|
||
|
|
||
|
int
|
||
|
ceil(float in)
|
||
|
{
|
||
|
int num = (int) in;
|
||
|
if(in - num > 0) num++;
|
||
|
return num;
|
||
|
}
|
||
|
|
||
|
float
|
||
|
sqrt(float in)
|
||
|
{
|
||
|
float sqrt = in/2;
|
||
|
float temp = 0;
|
||
|
|
||
|
while(sqrt != temp)
|
||
|
{
|
||
|
temp = sqrt;
|
||
|
sqrt = (in/temp + temp) / 2;
|
||
|
}
|
||
|
return sqrt;
|
||
|
}
|
||
|
|
||
|
float
|
||
|
calculateMean(float buffer[], int length)
|
||
|
{
|
||
|
if(length <= 0)
|
||
|
{
|
||
|
printf("%i items is not valid length\n", length);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
float sum = 0;
|
||
|
int i;
|
||
|
for(i = 0; i < length; i++)
|
||
|
{
|
||
|
sum += buffer[i];
|
||
|
}
|
||
|
|
||
|
return sum / length;
|
||
|
}
|
||
|
|
||
|
Stats
|
||
|
calculateStdDev(float buffer[], int length)
|
||
|
{
|
||
|
Stats stats;
|
||
|
if(length <= 0)
|
||
|
{
|
||
|
printf("%i items is not valid length\n", length);
|
||
|
return stats;
|
||
|
}
|
||
|
|
||
|
stats.mean = calculateMean(buffer, length);
|
||
|
|
||
|
float sum = 0;
|
||
|
int i;
|
||
|
for(i = 0; i < length; i++)
|
||
|
{
|
||
|
float diffFromMean = buffer[i] - stats.mean;
|
||
|
sum += diffFromMean*diffFromMean;
|
||
|
}
|
||
|
|
||
|
stats.std = sqrt(sum/length);
|
||
|
|
||
|
return stats;
|
||
|
}
|
||
|
|
||
|
#endif
|