Skip to main content

Calculate Polar Running Index (VO2max estimate) from FIT files

Project description

Polar Running Index

Calculate Polar Running Index (VO2max estimate) from FIT files.

Running Index estimates your maximal oxygen uptake (VO2max) from heart rate and speed data recorded during a run. It is based on the algorithms described in Polar's patents US2007082789 / EP1795128 and the ACSM metabolic equations for running.

Requirements

  • Python >= 3.11
  • uv

Installation

git clone https://github.com/willianpaixao/polar-running-index.git
cd polar-running-index
uv sync

Usage

uv run polar-running-index <FIT_FILE> --hr-max <MAX_HR> --hr-rest <REST_HR>

You must provide your maximum heart rate (--hr-max) and resting heart rate (--hr-rest) in bpm. These are needed to compute the heart rate reserve used in the VO2max estimation.

Example

$ uv run polar-running-index activity.FIT --hr-max 190 --hr-rest 50

==================================================
  Running Index Report
==================================================

  Activity:    Running (Treadmill)
  Date:        2026-03-04 18:07:54 UTC
  Duration:    1h 4m 21s
  Distance:    12.02 km
  Avg Speed:   11.2 km/h (5:20 min/km)
  Avg HR:      157 bpm
  Max HR:      167 bpm

  Parameters:  HRmax=190, HRrest=50

--------------------------------------------------

  Running Index:  52.6
  Method:         Heart Rate Reserve + Drift Correction
  Level:          Good

--------------------------------------------------

  Statistics:
    Mean:      52.6
    Median:    52.4
    Std Dev:   1.7
    Min:       48.8
    Max:       57.5
    Samples:   3393 used, 28 outliers removed

==================================================

Segment analysis

Use --segments to see Running Index broken down per segment. If the FIT file contains multiple laps, lap boundaries are used. Otherwise, the activity is split into per-kilometer segments.

$ uv run polar-running-index activity.FIT --hr-max 190 --hr-rest 50 --segments

  ...

  Segments:
      Km 1:  RI  55.5  |  5:33 /km  |  HR 141  |  153s
      Km 2:  RI  52.6  |  5:25 /km  |  HR 150  |  324s
      Km 3:  RI  50.9  |  5:26 /km  |  HR 155  |  326s
      Km 4:  RI  51.0  |  5:23 /km  |  HR 157  |  325s
      ...

Comparison with Polar Flow

Use --polar-ri to compare the calculated value against the official Running Index from Polar Flow:

$ uv run polar-running-index activity.FIT --hr-max 190 --hr-rest 50 --polar-ri 58

  ...

  Comparison with Polar:
    Polar RI:      58.0
    Calculated:    52.6
    Difference:    -5.4 (9.3% lower)

Options

Flag Description
--hr-max Maximum heart rate in bpm (required)
--hr-rest Resting heart rate in bpm (required)
--method {hrr,hrmax_ratio} Algorithm variant (default: hrr)
--no-drift-correction Disable cardiac drift correction
--polar-ri Official Polar RI for comparison
--segments Show per-segment Running Index breakdown
--json Output results as JSON

Algorithm methods

  • hrr (default) -- Heart Rate Reserve method (Karvonen). Uses both max and resting HR to estimate what fraction of aerobic capacity is being used. More accurate across different fitness levels.
  • hrmax_ratio -- Simple HRmax ratio method. Uses only max HR. Simpler but less accurate for individuals with unusually high or low resting heart rates.

Both methods include cardiac drift correction by default, which compensates for the natural rise in heart rate over time at constant effort. Disable it with --no-drift-correction if you prefer raw estimates.

How it works

  1. Parse the FIT file to extract per-second heart rate and speed records.
  2. Filter to the valid window (3--60 minutes into the run, speed > 6 km/h).
  3. Estimate VO2 demand at the current speed using the ACSM running equation.
  4. Extrapolate to VO2max using the heart rate reserve ratio.
  5. Correct for cardiac drift by fitting a linear HR trend and normalizing to a 12-minute reference point.
  6. Remove outliers (IQR method) and average the remaining estimates.

The final Running Index value is an estimate of VO2max in ml/kg/min.

References

  • Polar Running Index White Paper (April 2021)
  • Patent US2007082789 / EP1795128 -- Method for determining performance
  • ACSM's Guidelines for Exercise Testing and Prescription (metabolic equations)
  • Swain & Leutholtz (1997) -- %HRR approximates %VO2R

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

polar_running_index-1.0.0.tar.gz (314.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

polar_running_index-1.0.0-py3-none-any.whl (17.4 kB view details)

Uploaded Python 3

File details

Details for the file polar_running_index-1.0.0.tar.gz.

File metadata

  • Download URL: polar_running_index-1.0.0.tar.gz
  • Upload date:
  • Size: 314.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for polar_running_index-1.0.0.tar.gz
Algorithm Hash digest
SHA256 358c7c0fd110377d67a90817a9dcaa6186d4238334894891125d78356031d3b4
MD5 c97f39b668d69d4b1487e24d5fe22466
BLAKE2b-256 3ca083cc1904727d5641d72dd3421e8039f31401ba114237ccac4d5b78719c59

See more details on using hashes here.

Provenance

The following attestation bundles were made for polar_running_index-1.0.0.tar.gz:

Publisher: publish.yml on willianpaixao/polar-running-index

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file polar_running_index-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for polar_running_index-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 08c989fbc0aa645f39f5a0036f9862d1b9931a3d090080c5785afb294175ce78
MD5 3aca83f7ef1a6d11ba55bbdb90e53e45
BLAKE2b-256 d82d987bbc5fb7ee11bdfe9ca645606e793c28922e739cf948aed5b4ad80421a

See more details on using hashes here.

Provenance

The following attestation bundles were made for polar_running_index-1.0.0-py3-none-any.whl:

Publisher: publish.yml on willianpaixao/polar-running-index

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page