Calcule estatísticas como tempo gasto em frequência cardíaca individualizada e zonas de potência, potência normalizada, fator de intensidade, pontuação de estresse de treinamento, índice de variabilidade, fator de eficiência, carga de treinamento crônica, carga de treinamento aguda e equilíbrio de estresse de treinamento, a partir de medidores de frequência cardíaca e potência.
O pacote está disponível em pypi:
pip install cycling-stats
Você pode usar o pacote da seguinte maneira. Um exemplo simples: você pode importar a função training_stress_score
da seguinte maneira.
from cyclingstats . stats import training_stress_score
O pacote requer que você tenha seus dados em pandas.DataFrame
. O exemplo a seguir ilustra quando você tem uma série temporal de diversas sessões de treinamento separadas e deseja calcular estatísticas separadamente para cada dia de ciclismo.
import pandas as pd
from cyclingstats . stats import calc_hr_zones , calc_power_zones , agg_zones , agg_power
from cyclingstats . stats import chronic_training_load , acute_training_load , training_stress_balance
# read time series of power and/or heart rate
df = pd . read_csv ( "PATH_TO_YOUR_HEARTRATE_AND_POWER_DATA" )
df [ 'date' ] = pd . to_datetime ( df [ 'timestamp' ]. dt . date )
# perform any other preprocessing steps here
# ---------- zones
# define LTHR and FTP to calculate custom Coggan heart rate and power zones
LTHR = # TODO: fill in a number for the lactate threshold heart rate [bpm]
FTP = # TODO: fill in a number for the functional threshold power [W]
hr_zones = calc_hr_zones ( LTHR )
power_zones = calc_power_zones ( FTP )
# calculate hr and power zones
df_zones = df . groupby ( 'date' ). apply ( agg_zones , hr_zones = hr_zones , power_zones = power_zones )
# ---------- power
df = df . set_index ( 'timestamp' )
# calculate power statistics
df_power = df . groupby ( 'date' ). apply ( agg_power , FTP = FTP )
# fill up dates for which we don't have an entry to get exponential weighted mean (ewm)
dates = df_power . index
df_power = df_power . reindex ( date_range )
# calculate ctl, atl and tsb
df_power [ 'chronic_training_load' ] = chronic_training_load ( df_power [ 'training_stress_score' ])
df_power [ 'acute_training_load' ] = acute_training_load ( df_power [ 'training_stress_score' ])
df_power [ 'training_stress_balance' ] = training_stress_balance ( df_power [ 'chronic_training_load' ], df_power [ 'acute_training_load' ])
# get back to indices for which there is a training session
df_power = df_power . loc [ dates ]
Se você estiver tendo problemas, entre em contato com o autor ([email protected]).
Este código é © E. van Weenen, 2022 e está disponível sob a licença MIT que acompanha o software.
Além das restrições legais impostas por esta licença, se você usar este software para uma publicação acadêmica, será obrigado a fornecer a devida atribuição.
E. van Weenen. cycling-stats: Calculate advanced cycling statistics from power and/or heart rate data, v0.1 (2022). github.com/evavanweenen/cycling-stats.