mirror of
https://github.com/MontFerret/ferret.git
synced 2025-01-04 03:02:02 +02:00
5f94b77a39
* #7 Added ABS * #7 Added ACOS * #7 Added ASIN * #7 Added ATAN * #7 Added ATAN2 * #7 Added AVERAGE * #7 Added CEIL * #7 Added COS * #7 Added DEGREES * #7 Added EXP * #7 Added EXP2 * #7 Added FLOOR * #7 Added LOG * #7 Added LOG2 * #7 Added LOG10 * #7 Added MAX * #7 Added MEDIAN * #7 Added MIN * #7 Added PERCENTILE * #7 Added PI * #7 Added POW * #7 Added RADIANS * #7 Added RAND * #7 Added RANGE * #7 Added ROUND * #7 Added SIN * #7 Added SQRT * #7 Added TAN * #7 Added SUM * #7 Added STDDEV_POPULATION * #7 Added STDDEV_SAMPLE, VARIANCE_POPULATION, VARIANCE_SAMPLE
40 lines
834 B
Go
40 lines
834 B
Go
package math
|
|
|
|
import (
|
|
"github.com/MontFerret/ferret/pkg/runtime/core"
|
|
"github.com/MontFerret/ferret/pkg/runtime/values"
|
|
"math"
|
|
)
|
|
|
|
func variance(input *values.Array, sample values.Int) (values.Float, error) {
|
|
if input.Length() == 0 {
|
|
return values.NewFloat(math.NaN()), nil
|
|
}
|
|
|
|
m, _ := mean(input)
|
|
|
|
var err error
|
|
var variance values.Float
|
|
|
|
input.ForEach(func(value core.Value, idx int) bool {
|
|
err = core.ValidateType(value, core.IntType, core.FloatType)
|
|
|
|
if err != nil {
|
|
return false
|
|
}
|
|
|
|
n := values.Float(toFloat(value))
|
|
|
|
variance += (n - m) * (n - m)
|
|
|
|
return true
|
|
})
|
|
|
|
// When getting the mean of the squared differences
|
|
// "sample" will allow us to know if it's a sample
|
|
// or population and wether to subtract by one or not
|
|
l := values.Float(input.Length() - (1 * sample))
|
|
|
|
return variance / l, nil
|
|
}
|