func meanTempForPoint(arr []int64) int64 { sum := 0.0 for _, i := range arr { sum += float64(i) } return statistics.Round(sum / float64(len(arr))) }
func populateWorkoutOneBody(req *models.WorkoutResponse) { var sumIncreased int64 = 0 for _, p := range req.DeltaPoints { sumIncreased += statistics.Round(math.Abs(float64(p.MedianTemp))) } meanIncrease := float64(sumIncreased) / float64(len(req.DeltaPoints)) var sumMins int64 for _, p := range req.PrePoints { sumMins += p.MinTemp - 273 } meanMins := float64(sumMins) / float64(len(req.PrePoints)) var sumMaxs int64 for _, p := range req.PostPoints { sumMaxs += p.MaxTemp - 273 } meanMaxs := float64(sumMaxs) / float64(len(req.PostPoints)) req.Body += "Woah! What a great work out! The overall temperature of your targeted muscles increased by " req.Body += fmt.Sprintf("an average of %.2f˚C, with extremes of %.2f˚C to %.2f˚C. ", math.Abs(meanIncrease), meanMins, meanMaxs) lMedians := make([]int64, 6) rMedians := make([]int64, 6) for _, p := range req.PostPoints { alpha := p.Name[0:1] num, _ := strconv.Atoi(p.Name[1:2]) if alpha == "R" { rMedians[num] = p.MedianTemp } else { lMedians[num] = p.MedianTemp } } diffHamstrings := float64((lMedians[0]+lMedians[1]))/2.0 - float64((rMedians[0]+rMedians[1]))/2.0 if diffHamstrings > 0 { req.Body += fmt.Sprintf("In addition, we noticed that you worked your left hamstrings a bit harder than your right hamstrings. ") } else { req.Body += fmt.Sprintf("In addition, we noticed that you worked your right hamstrings a bit harder than your left hamstrings. ") } diffCalves := float64((lMedians[2]+lMedians[3]+lMedians[4]))/2.0 - float64((rMedians[2]+rMedians[3]+rMedians[4]))/2.0 if diffCalves > 0 { req.Body += fmt.Sprintf("You also worked your left calves a bit harder than your right calves. ") } else { req.Body += fmt.Sprintf("You also worked your left calves a bit harder than your right calves. ") } diffAchilles := lMedians[5] - rMedians[5] if diffAchilles > -3 && diffAchilles < 3 { req.Body += fmt.Sprintf("On the other hand, your achilles are both of nearly the same temperature. ") } if (float64((lMedians[0]+lMedians[1]))/2.0+float64((rMedians[0]+rMedians[1]))/2.0)/2.0 > (float64((lMedians[2]+lMedians[3]+lMedians[4]))/2.0+float64((rMedians[2]+rMedians[3]+rMedians[4]))/2.0)/2.0 { req.Body += fmt.Sprintf("During your work out, you warmed up your calves more than your hamstrings. Good job, if this was your goal, if not, work on targeting your hamstrings with some hamstring curls, or Romanian deadlift. ") } else { req.Body += fmt.Sprintf("During your work out, you warmed up your hamstrings more than your calves. Good job, if this was your goal, if not, work on targeting your calves more with some calf raises. ") } if req.TimeSpentS < 60 { req.Body += fmt.Sprintf("Spend more time working out! You worked out for less 60 seconds, so next time try to do it for a few minutes! ") } else if req.TimeSpentS < 150 { req.Body += fmt.Sprintf("For spending less than two and a half minutes working out, this wasn't bad, next time try for a few minutes! ") } else { req.Body += fmt.Sprintf("Amazing job, you spent over two and a half minutes working out. Listen to these tips, and keep pushin' it! ") } }