All wearable devices should implement local-host functionality and capability by default, failure to do so it's not acceptable from the perspective of Murphy's Law [1], [2].
Yup, I have a Garmin Fenix 8 AMOLED. It's an excellent watch. I run for 6-8 hours a week and I only need to charge it once a week. It is very hard wearing and has so many capabilities I don't know where to start. It even has a flashlight with red LED for during the night. With Garmin connect down I can just grab the FIT file from the watch and upload to Strava manually or perform my own analysis locally.
Sure. It's a binary file and there is a spec for it on the garmin website. There's lots of libraries available for most popular languages for decoding and encoding. You can download an app for your computer. I believe it's called Garmin Express, which allows you to sync fit files to your machine.
I'm building a running analytics app, which is really just for myself but if it turns out to be any good then I'll might turn it into a SaaS. Target market would be for fairly decent amateur runners (e.g. 2:20-2:30 marathon) but not good enough to be pro. The pros have awesome tools but sadly most are not available for us mere mortals but I can build some of them! Example features:
1. The strava GAP model doesn't fit very well for me. So I've made my own. I update the model each month too.
2. I've also built a wind resistance model which works quite well. I'm trying to do the same for surface types, heat and humidity as well.
3.Using adjused pace data I built a pace/duration model to estimate critical speed and this model forms the basis of tracking progress over time. Clearly most training wont be all out efforts, so I also estimate race performances based upon current fitness as well. E.g. if you ran X speed for Y time at a sub maximal effort then you can estimate what a maximal effort would be based upon the remaining aerobic and anaerobic power. From reading sports science literure, this is the most advanced way to track performance at the moment. The actual model I use is called an omniduration model [1].
4. I also have build some other models, e.g. Daniels running formula, which can be used but I don't find them to be as useful as the omniduration model.
5. I'm also trying to model how a workout will effect your fitness. Where it's base/aerobic, threshold, VO2max or an anaerobic effect. Then, the idea would be to look at future training performance to assess whether the model was correct. This was you might be able to determine which types of sessions result in the best outcomes for you.
To add to what others have posted... Activity (i.e. running, walking, cycling, etc.) FIT files are found in the GARMIN/Activity directory on the watch after connecting it to a computer over USB. File names are date time stamps.
Can confirm, everything runs in the watch, no connection to the app is needed. All your workouts are stored in the watch locally and synced to the Connect App once it is available. I never take my phone with me while doing workouts because its not really needed.
I've just started exploring analysing runs from my Garmin watch. In summary:
- Attach watch to laptop via USB-C -> opens like a USB drive, showing all the config and activity data files. You aren't locked into Garmin Connect or Strava or any other platform.
- You can also use the Garmin Connect API and go via the web service. I tried that first. But since discovering the raw data is available directly on the watch, I don't anymore.
- Activity data files are in the FIT format. Garmin has an SDK on GitHub in languages including Python, C# and a few others. I've tried the Python one.
- There are a couple of projects on GitHub for decoding FIT files. I've just started writing my own as I want to output modern Pydantic models. (And the Python code in the Garmin SDK is not the most efficient or idiomatic).
I've had my Garmin watch for 10 months now, and rate it as my best ever purchase for improving my fitness and performance, and for overall motivation to be more active. Having easy access to the raw data files is a huge bonus that I didn't originally consider.
To answer your question, there is no "embrace of opensource tools" and I'm not aware of any in existence. They could exist, I haven't looked for them.
Here's a quick writeup of my experience:
I'm a very happy Garmin customer. I'm on my 2nd watch, a Venu 3. My favorite feature: the battery lasts multiple days, usually a week, w/o a charge (depending on how I use it).
The watch provides access to its flash storage using MTP (Media Transfer Protocol). This allows me to access the contents and update the music on it using my Linux computer.
I manage the other watch features (tap-to-pay, custom watchfaces, apps) using the Garmin Connect and Garmin IQ app on an Android phone. These are not open source, and I don't know of clones.
The watch UI itself is a pretty clunky, menu-driven design. It took quite a bit of tweaking to configure it to my tastes, but the combination of "glances" and "shortcuts" let me access the features I want within a few swipes, taps, or button presses.
Configuring apps and custom watchfaces requires internet access, as these use javascript-based applets running on your phone inside the Garmin app to do the configuration. This is annoying. Everything else works offline, or with a bluetooth connection to an offline phone (for example, I have a habit of changing the time to my destination timezone when I'm on a flight, this works once I update the timezone on my phone with no internet).
There is a desktop Garmin program for updating firmware, but it is terrible. It is designed to work with every Garmin product (not just watches) and has a definite "design by committee" feel. Luckily, I don't need it. I think I would need to use it if I had one of the larger watches that supports offline maps.
The features I use the most:
- the clock
- sports tracking, step & stair tracking
- tap-to-pay (this is so nice)
- pulse
- the compass (sometimes I just want a cardinal direction when I'm disoriented)
The sleep tracking is interesting, though I don't need it (mostly it says I don't sleep enough).
They don't directly embrace open source, but their more advanced watches that don't require the connect app for certain features like sleep (such as the fenix series) are nearly completely supported by https://gadgetbridge.org/ - the only thing I can think of that doesn't work is the weather map. You can even update the firmware and maps over wifi directly on the watch or use the PC software.
I got one for Christmas. The OS is a bit unique and very much not open source.
They let you develop apps with an API and a proprietary programming language called Monkey C that looks a bit more like JavaScript / ActionScript. It runs in a bespoke VM that has been reverse engineered but I don’t think anyone ported another programming language or LLVM to it.
There is a small open source community.
Overall it’s not that different than developing open source apps for Apple, but with much fewer people.
Garmin makes solid products but I will say to be prepared for non-intuitive UX across everything. I am only guessing about watches specifically, but having used an InReach and a Zumo XT motorcycle navigator extensively, I will posit that they are much more an engineering culture than a design culture.
as a user, cant say much about the hardware side - but on the software side they aren't the most developer friendly IMO.
APIs are locked behind "contact us" button and is only reserved for enterprise users with seemingly arbitrary criteria on what/who they want to work with
Yes, but not too long ago they ruined the Android app and made it depend on their servers. At least the watch works fine, but I suspect it's only because the battery isn't large enough to cut lazy devs and hasty PMs from working on harder problems.
The watches don't need the server to function (I'm wearing one), which seems to satisfy what you are saying.
I think the only major impact is that "coached" activities won't be available, but everything else in the watches works without a network connection. Data history isn't hugely available on the watch either, but that's just an inconvenience.
same. All of the data should still be stored on the watch and the app, since that works local via Bluetooth. Sync to other services like strava or trainingpeaks should happen once the services are online. Even the external sync on the watches should work, i just updated my deezer playlist on my epix 2 without issues and with connect down.
It might be annoying, but it still works. Without a note in the app, i would not have noticed.
I use Gadgetbridge[1] exactly for this reason. It's a FOSS app (on f-droid as well) that tricks wearables into thinking that your phone is actually communicating legitimately with the server.
Garmin support[2] is not really good. Some commenters here mentioned that Garmin watches can work without servers, maybe that's why.
It's not local-first by definition, because you still need a phone with an app, but it's the best I got for now (apart from finally assembling my PineTime watch).
This affects most (all?) Garmin fitness products such as the popular Fenix watches.
The Garmin Connect app seems to be completely useless without the Garmin Connect servers being up. It is not even possible to see local data on the phone.
I guess this also means that at some point in the future when Garmin discontinues the servers an enormous amount of watches becomes useless worldwide.
You can still read and parse FIT files via many many utilities and services.
The problem that happened last time is the satellite shortcut files for GPS were never updated for weeks and went stale, so GPS took minutes to lock instead of seconds.
However it is well known now after years how to create the GPS files for mediatek chipsets.
What's never been documented is how to make them for the SONY GPS chipsets.
EPO.bin (mediatek) vs CPE.bin (sony)
this paper lists other potential sources for those files
aha! this is the url for direct download of CPE.bin which you should put into the \GARMIN\REMOTESW directory on your garmin watch/device that has SONY GPS (not mediatek)
#(save as CPE.bin into \GARMIN\REMOTESW )
# https://api.gcs.garmin.com/ephemeris/cpe/sony/lle?coverage=WEEKS_1&constellations=GPS,GLONASS,GALILEO,QZSS
> The Garmin Connect app seems to be completely useless without the Garmin Connect servers being up. It is not even possible to see local data on the phone.
Not the case, I can see all the local data from my watch in the app and still sync the two, just missing cloud backups and online specific functionality
Are you sure about that? I have a Garmin Fenix 6 and the Connect app on Android. While it's true that all data is stored locally on the watch and it doesn't need to be tethered to a phone to work, I'm pretty sure that syncing the watch to the Connect app does require the Connect app to be connected to the server. I have experienced this multiple times, after completing a hike in a remote area and I try to sync the Hike Activity to Connect it fails due to not having a cellular connection despite the watch being connected to the phone via Bluetooth.
I could swear I've also gotten data sync's while in limited connectivity situations, but to be fair could be that occasionally it was just able to phone in enough to do its thing.
Service is back up, so just testing real quick, at least on IOS , turning off wifi/cellular (not airplane mode) - my fenix at least seems to still be streaming heart rate data to the app. Not entirely sure what else will update from local data though (if anything).
Last time this happened, there were two effects: on one hand people making fun of not being able to upload their activities to Strava and on the other hand, and more seriously, people not being able to use their aviation navigation systems. Can someone comment if the Garmin aviation devices are affected?
Garmin glass cockpits don’t depend on Garmin services at all. Perhaps updating charts but that’s a monthly thing generally and it’s not done while airborne.
The “not FAA approved” isn’t a thing — there are devices that go in uncertified (experimental) aircraft, but those also don’t depend on live connections to Garmin services.
Likely they are, likely it "shouldn't" matter, as all their advertising says: "Not FAA approved [wink]"
...like, in an emergency it's cool to be able to click a button on your watch and see the closest airport, but you're supposed to have paper maps, a flight plan, a checklist, etc, etc.
interesting, when I first checked the app I got all panels as "no data available" but after reading your comment I checked it again and indeed content showed up.
I guess it might need second refresh to properly fallback to local mode
Yeah, it seems they've finally added some local caching to the app. Previously when their services were down the Connect app was completely useless, but now even though the graphs aren't updating, I can still see a lot of information.
> an enormous amount of watches becomes useless worldwide
Not necessarily, some (many?) of these watches are usable without being connected to a phone. Besides being a funcional watch, including timers and alarms, all the fitness tracking and activity recording features work fine, even those that use GPS, at least on my Venu 2.
> The Garmin Connect app seems to be completely useless without the Garmin Connect servers being up. It is not even possible to see local data on the phone.
Yes, I think it was so obvious from their UX/UI because it has lags when you use the application which is very common on basic UI front-end consuming remote APIs as its where local. I would say that it even feel slower than great web apps that also depend on remote services.
I haven't looked at what is directly impacted yet, but this is an oversimplification. Assuming it is all Garmin services down, I've personally used my inReach for the following situations that have no real map involvement:
- Coordination of supply drops during multi-day backcountry ski tours.
- Weather updates in the Rocky Mountains where weather can change in an instant.
- Contacting a personal dispatch POC over messaging during an avalanche injury that required SAR without having to hit the SOS button.
Additionally, my wife relies on her inReach mini every day as a safety net as a biologist in remote areas of Colorado. Most people I encounter in the outdoors space rarely use their Garmin for navigation. Instead they use an app akin to onX, Gaia, CalTopo, etc.
Well, nobody needs anything 100% of the time besides oxygen. But if you pay a lot of money for a watch because it has certain features backed by services, I would definitely hope that I can actually use them when I want to.
and nobody can guarantee 100% uptime of online software services. Not to give a free pass or excuse downtime, but you shouldn't expect 100% uptime if its not in an SLA you are paying for, which would be quite expensive
We got a Garmin watch for our daughter when she started walking to school on her own. It works pretty well but communication is delayed and sometimes not reliable on rainy days. When we first got it was very unreliable, but after contacting Garmin support, the did some sort of test over the network, made some change, and it was working much more reliably after that. I have no idea what they adjusted to get it working. We're pretty happy with it.
> We got a Garmin watch for our daughter when she started walking to school on her own.
How does that work? Does the watch have its own SIM card? Does she need to carry a phone for the Garmin watch to work?
Asking for I bought a cheap chinese watch but it's a standalone watch that takes a SIM and, James Bond style, allows to pass and receive phone calls (without needing a lame iPhone in your pocket: the watch is really standalone). The phone feature is really fine but sadly the battery empties quickly (in a day) and the location isn't very accurate.
What's the motivation behind keeping Bluetooth off? If you're just trying to avoid Bluetooth, I would just turn on Bluetooth, it works better than the Wifi sync and at the end of the day it's doing exactly the same thing, just with your phone as a bridge.
Another option for syncing is the desktop app, or just manually copying the fit files to somewhere. I sometimes copy the fit files and convert them to gpx to upload GPS traces places. Also I can view the GPX files in e.g. gpxsee which shows them on a map.
[1] Local-first software:
https://localfirstweb.dev/
[2] Murphy's law:
https://en.wikipedia.org/wiki/Murphy%27s_law
reply