package pcp import ( "container/ring" "math" "strconv" "strings" ) var RAPLUnits = math.Pow(2, -32) func AverageNodePowerHistory(history *ring.Ring) float64 { total := 0.0 count := 0.0 history.Do(func(x interface{}) { if val, ok := x.(float64); ok { //Add it if we can get a float total += val count++ } }) if count == 0.0 { return 0.0 } count /= 4 // Two PKGs, two DRAM for all nodes currently. return (total / count) } // TODO: Figure a way to merge this and avgpower. func AverageClusterPowerHistory(history *ring.Ring) float64 { total := 0.0 count := 0.0 history.Do(func(x interface{}) { if val, ok := x.(float64); ok { // Add it if we can get a float. total += val count++ } }) if count == 0.0 { return 0.0 } return (total / count) } func utilization(used string, free string) float64 { u, _ := strconv.ParseFloat(used, 64) f, _ := strconv.ParseFloat(free, 64) return u / (u + f) } func CpuUtilPerNode(text string) []float64 { tokenSlice := strings.Split(text, ",") cpuUtil := make([]float64, 8) for i := 0; i < 8; i++ { cpuUtil[i] = utilization(tokenSlice[8+i], tokenSlice[24+i]) } return cpuUtil } func MemUtilPerNode(text string) []float64 { tokenSlice := strings.Split(text, ",") memUtil := make([]float64, 8) for i := 0; i < 8; i++ { memUtil[i] = utilization(tokenSlice[40+i], tokenSlice[32+i]) } return memUtil }