zwiftout/src/tss.ts

38 lines
1020 B
TypeScript

import { Interval } from "./ast";
// Training Stress Score formula from Training and Racing with a Power Meter:
//
// TSS = (s * W * IF) / (FTP * 3600) * 100
//
// s - duration in seconds
// W - power in watts
// IF - intensity factor (power / FTP)
const steadyTss = (duration: number, power: number): number => {
const intensity = power / 100;
return ((duration * intensity * intensity) / 3600) * 100;
};
const rangeTss = (duration: number, from: number, to: number): number => {
let score = 0;
const step = 1;
for (let i = 0; i < duration; i += step) {
let power = from + (to - from) * (i / duration);
score += steadyTss(step, power);
}
return score;
};
const intervalTss = ({ duration, power }: Interval): number => {
if (power.from === power.to) {
return steadyTss(duration, power.from);
} else {
return rangeTss(duration, power.from, power.to);
}
};
export const tss = (intervals: Interval[]): number => {
return intervals.map(intervalTss).reduce((a, b) => a + b, 0);
};