-
Notifications
You must be signed in to change notification settings - Fork 3
Home
.fit
files are the preferred type. They log the most comprehensive amount of data and are also the smallest.
They have room for more summary data and more clearly explain what was going on in the activity. For example,
they record every button-press event: start, pause, resume, lap, stop. The richness of the recorded data
allows heartandsole
to index the trackpoints DataFrame
by record number, lap, and "bout" (a term I coined
to describe the time between hitting "start" and "pause").
While there are many types of fit files, the following are the most relevant to this project.
-
File ID (always first)
-
Activity > Session > Lap > Record
- Timestamp and at least one other value are required for each Record message.
-
Optional message types
- Device Info
- Event (start, stop, pause, ...)
-
https://developer.garmin.com/fit/file-types/activity/#messagesequence
-
File ID (always first)
-
Course > Lap > Record
- "The Record messages contain the latitude, longitude, altitude, and distance values that define the course."
-
https://developer.garmin.com/fit/file-types/course/#messagesequence
.tcx
files have a limited schema and can represent only a subset of the data found in a .fit
file. The
individual trackpoints retain all the relevant information from .fit
files, but the schema does not allow
you to know for sure when your device was paused. The activity itself is divided into laps which contain tracks
which in turn contain trackpoints. When you hit the "new lap" button on your device, a new lap element begins in
the .tcx
file. However, when you hit the "pause" button on your device, nothing explicitly happens in the file;
no new element is created; trackpoints simply stop being recorded. If you have a device that records trackpoints
every second, it is apparent when the device is paused. But if your device is set to use Garmin's so-called
"Smart Recording" feature, there are variable amounts of time between trackpoints. Seeing a seven second gap could
mean the device was paused during that time, or the device waited that long to record a new point.
I am working on a method for inferring device pauses in .tcx
files, but for now, heartandsole
assumes they
do not exist. In general, the inconsistency between devices and files leads me to simply avoid pausing my
device during a workout - more data points are rarely a problem, and the data analysis goes easier if I
am certain I was not paused. I suggest you do the same! Or use .fit
files, which are the industry standard.
As a compromise, if you use .tcx
files and you want to manually delineate stopped and moving periods:
when you would normally pause and restart your device, you could simply start a new lap when you stop
and start another lap when you begin again.
.gpx
files have the most limited schema of all. In fact the .tcx
file schema is actually an extension of the
.gpx
file schema - all the limitations mentioned above limitations apply to .gpx
files too). GPX trackpoints
can only represent latitude, longitude, time, elevation, heart rate, and cadence. Unlike TCX trackpoints, they
lack speed and distance. These quantities can be calculated using the GPS coordinates, but your device calculates
them in a different way that tends to be more accurate. Not having a slot for these fields means your device data
is simply lost.
In addition to the limitations of .tcx
files, as far as I know, .gpx
files only record trackpoints with valid
GPS coordinates. In other words if your device doesn't have a GPS signal at the beginning of your run, no data is
recorded - even your heart rate and cadence. Also, typical .gpx
files do not divide the activity into laps or
indicate pauses. The .gpx
file format is really bare-bones: just a few data fields recorded with each trackpoint,
and no summary data to speak of.