2020-10-14 14:07:38 -07:00
|
|
|
package utils
|
|
|
|
|
|
|
|
import (
|
|
|
|
"sort"
|
2021-01-04 21:18:35 -08:00
|
|
|
"sync"
|
2020-10-14 14:07:38 -07:00
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2021-01-04 21:18:35 -08:00
|
|
|
var l = sync.Mutex{}
|
|
|
|
|
2020-11-13 00:14:59 +01:00
|
|
|
// The "start" timestamp of a timing event.
|
2020-10-14 14:07:38 -07:00
|
|
|
var _pointsInTime = make(map[string]time.Time)
|
|
|
|
|
2020-11-13 00:14:59 +01:00
|
|
|
// A collection of timestamp durations for returning the average of.
|
2020-10-14 14:07:38 -07:00
|
|
|
var _durationStorage = make(map[string][]float64)
|
|
|
|
|
2020-11-13 00:14:59 +01:00
|
|
|
// StartPerformanceMonitor will keep track of the start time of this event.
|
2020-10-14 14:07:38 -07:00
|
|
|
func StartPerformanceMonitor(key string) {
|
2021-01-04 21:18:35 -08:00
|
|
|
l.Lock()
|
2020-11-16 21:02:48 -08:00
|
|
|
if len(_durationStorage[key]) > 20 {
|
|
|
|
_durationStorage[key] = removeHighValue(_durationStorage[key])
|
2020-10-14 14:07:38 -07:00
|
|
|
}
|
|
|
|
_pointsInTime[key] = time.Now()
|
2021-01-04 21:18:35 -08:00
|
|
|
l.Unlock()
|
2020-10-14 14:07:38 -07:00
|
|
|
}
|
|
|
|
|
2020-11-13 00:14:59 +01:00
|
|
|
// GetAveragePerformance will return the average durations for the event.
|
2020-10-14 14:07:38 -07:00
|
|
|
func GetAveragePerformance(key string) float64 {
|
|
|
|
timestamp := _pointsInTime[key]
|
|
|
|
if timestamp.IsZero() {
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2021-01-04 21:18:35 -08:00
|
|
|
l.Lock()
|
2021-01-04 22:02:16 -08:00
|
|
|
defer l.Unlock()
|
|
|
|
|
2020-10-14 14:07:38 -07:00
|
|
|
delta := time.Since(timestamp).Seconds()
|
|
|
|
_durationStorage[key] = append(_durationStorage[key], delta)
|
2020-11-16 21:02:48 -08:00
|
|
|
if len(_durationStorage[key]) < 8 {
|
2020-10-14 14:07:38 -07:00
|
|
|
return 0
|
|
|
|
}
|
2020-11-16 21:02:48 -08:00
|
|
|
_durationStorage[key] = removeHighValue(_durationStorage[key])
|
2021-01-04 21:18:35 -08:00
|
|
|
|
2022-03-16 17:34:44 -07:00
|
|
|
return Avg(_durationStorage[key])
|
2020-10-14 14:07:38 -07:00
|
|
|
}
|
|
|
|
|
2020-11-16 21:02:48 -08:00
|
|
|
func removeHighValue(values []float64) []float64 {
|
2020-10-14 14:07:38 -07:00
|
|
|
sort.Float64s(values)
|
2020-11-16 21:02:48 -08:00
|
|
|
return values[:len(values)-1]
|
2020-10-14 14:07:38 -07:00
|
|
|
}
|
|
|
|
|
2022-03-16 17:34:44 -07:00
|
|
|
// Avg will return the average value from a slice of float64s.
|
|
|
|
func Avg(values []float64) float64 {
|
2020-10-14 14:07:38 -07:00
|
|
|
total := 0.0
|
|
|
|
for _, number := range values {
|
2021-10-25 00:31:45 -07:00
|
|
|
total += number
|
2020-10-14 14:07:38 -07:00
|
|
|
}
|
|
|
|
average := total / float64(len(values))
|
|
|
|
return average
|
|
|
|
}
|
2022-03-16 17:34:44 -07:00
|
|
|
|
|
|
|
// Sum returns the sum of a slice of values.
|
|
|
|
func Sum(values []float64) float64 {
|
|
|
|
total := 0.0
|
|
|
|
for _, number := range values {
|
|
|
|
total += number
|
|
|
|
}
|
|
|
|
return total
|
|
|
|
}
|
|
|
|
|
|
|
|
// MinMax will return the min and max values from a slice of float64s.
|
|
|
|
func MinMax(array []float64) (float64, float64) {
|
|
|
|
max := array[0]
|
|
|
|
min := array[0]
|
|
|
|
for _, value := range array {
|
|
|
|
if max < value {
|
|
|
|
max = value
|
|
|
|
}
|
|
|
|
if min > value {
|
|
|
|
min = value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return min, max
|
|
|
|
}
|
2022-03-16 22:49:27 -07:00
|
|
|
|
|
|
|
func mean(input []float64) float64 {
|
|
|
|
sum := Sum(input)
|
|
|
|
|
|
|
|
return sum / float64(len(input))
|
|
|
|
}
|
|
|
|
|
|
|
|
// Median gets the median number in a slice of numbers.
|
|
|
|
func Median(input []float64) float64 {
|
|
|
|
if len(input) == 1 {
|
|
|
|
return input[0]
|
|
|
|
}
|
|
|
|
|
|
|
|
c := make([]float64, len(input))
|
|
|
|
copy(c, input)
|
|
|
|
|
|
|
|
var median float64
|
|
|
|
l := len(c)
|
|
|
|
if l%2 == 0 {
|
|
|
|
median = mean(c[l/2-1 : l/2+1])
|
|
|
|
} else {
|
|
|
|
median = c[l/2]
|
|
|
|
}
|
|
|
|
|
|
|
|
return median
|
|
|
|
}
|