mirror of
https://github.com/mainflux/mainflux.git
synced 2025-05-08 19:29:17 +08:00

Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com>
26 lines
517 B
Go
26 lines
517 B
Go
package stats
|
|
|
|
import "math"
|
|
|
|
// SoftMax returns the input values in the range of 0 to 1
|
|
// with sum of all the probabilities being equal to one. It
|
|
// is commonly used in machine learning neural networks.
|
|
func SoftMax(input Float64Data) ([]float64, error) {
|
|
if input.Len() == 0 {
|
|
return Float64Data{}, EmptyInput
|
|
}
|
|
|
|
s := 0.0
|
|
c, _ := Max(input)
|
|
for _, e := range input {
|
|
s += math.Exp(e - c)
|
|
}
|
|
|
|
sm := make([]float64, len(input))
|
|
for i, v := range input {
|
|
sm[i] = math.Exp(v-c) / s
|
|
}
|
|
|
|
return sm, nil
|
|
}
|