Guide for rower specific settings
This guide helps you to adjust the rowing monitor specifically for a new type of rower or even for your specific use, when the default rowers don’t suffice.
Why we need rower specific settings
No rowing machine is the same, and some physical construction parameters are important for the Rowing Monitor to be known to be able to understand your rowing stroke. By far, the easiest way is to select your rower profile from config/rowerProfiles.js
and put its name in config.js
(i.e. rowerSettings: rowerProfiles.WRX700
). The rowers mentioned there are maintained by us for OpenRowingMonitor and are structurally tested with changes typically automatically implemented.
If you want something special, or if your rower isn’t in there, this guide will help you set it up. Please note that determining these settings is quite labor-intensive, and typically some hard rowing is involved. If you find suitable settings for a new type of rower, please send in the data and settings, so we can add it to OpenRowingMonitor and make other users happy as well.
Settings you must change for a new rower
The key feature for Open Rowing Monitor is to reliably produce metrics you see on the monitor, share via Bluetooth with games and share with Strava and the like. Typically, these metrics are reported on a per-stroke basis. So, to be able to use these metrics for these goals, you need two key parts of the settings right:
- Stroke detection
- Physical metrics (like distance, power and speed)
Getting stroke detection right
A key element in getting rowing data right is getting the stroke detection right, as we report many metrics on a per-stroke basis. The Impulse Noise reduction settings reduce the level of noise on the level of individual impulses. You should change these settings if you experience issues with stroke detection or the stability of the drag factor calculation. The stroke detection consists out of three types of filters:
- A smoothing filter, using a running average. The smoothing setting determines the length of the running average for the impulses, which removes the height of the peaks, removes noise to a certain level but keeps the stroke detection responsive. Smoothing typically varies between 1 to 4, where 1 effectively turns it off.
- A high-pass/low-pass filter, based on minimumTimeBetweenImpulses (the shortest allowable time between impulses) and maximumTimeBetweenImpulses (the longest allowed time between impulses). Combined, they remove any obvious errors in the duration between impulses (in seconds) during active rowing. Measurements outside of this range are filtered out to prevent the stroke detection algorithm to get distracted. This setting is highly dependent on the physical construction of your rower, so you have to determine it yourself without any hints. The easiest way to determine this is by visualizing your raw recordings in Excel.
- A maximum change filter, which based on the the previous impulse determines the maximum amount of change (percentage) through the maximumDownwardChange and maximumUpwardChange settings.
By changing the noise reduction settings, you can remove any obvious errors. You don’t need to filter everything: it is just to remove obvious errors that might frustrate the stroke detection, but in the end you can’t prevent every piece of noise out there. Begin with the noise filtering, when you are satisfied, you can adjust the rest of the stroke detection settings.
Another set of settings are the flankLength and numberOfErrorsAllowed setting, which determine the condition when the stroke detection is sufficiently confident that the stroke has started/ended. In essence, the stroke detection looks for a consecutive increasing/decreasing impulse lengths, and the flankLength determines how many consecutive flanks have to be seen before the stroke detection considers a stroke to begin or end. Please note that making the flank longer does not change your measurement in any way: the algorithms always rely on the beginning of the flank, not at the current end. Generally, a flankLength of 2 to 3 typically works. Sometimes, a measurement is too noisy, which requires some errors in the flanks to be ignored, which can be done through the numberOfErrorsAllowed setting. For example, the NordicTrack RX-800 successfully uses a flankLength of 9 and a numberOfErrorsAllowed of 2, which allows quite some noise but forces quite a long flank. This setting requires a lot of tweaking and rowing.
At the level of the stroke detection, there is some additional noise filtering, preventing noise to start a drive- or recovery-phase too early. The settings minimumDriveTime and minimumRecoveryTime determine the minimum times (in seconds) for the drive and recovery phases. Generally, the drive phase lasts at least 0.500 second, and the recovery phase 1.250 second for recreational rowers.
For the noise reduction settings and stroke detection settings, you can use the Excel tool. When OpenRowingMonitor records a log (set setting createRawDataFiles to true
), you can paste the values in the first column of the “Raw Data” tab (please observe that the Raspberry uses a point as separator, and your version of Excel might expect a comma). From there, the Excel file simulates the calculations the OpenRowingMonitor makes, allowing you to play with these settings.
Please note that changing the noise filtering and stroke detection settings will affect your calculated dragFactor. So it is best to start with rowing a few strokes to determine settings for noise filtering and stroke detection, and then move on to the other settings.
Getting the metrics right
There are some parameters you must change to get Open Rowing Monitor to calculate the real physics with a rower. These are:
- numOfImpulsesPerRevolution: this tells Open Rowing Monitor how many impulses per rotation of the flywheel to expect. An inspection of the flywheel could reveal how many magnets it uses (typically a rower has 2 to 4 magnets). Although sometimes it is well-hidden, you can sometimes find it in the manual under the parts-list of your rower.
- dragFactor: tells Open Rowing Monitor how much damping and thus resistance your flywheel is offering. This is typically also dependent on your damper-setting (if present). Regardless if you use a static or dynamically calculated drag factor, this setting is needed as the first stroke also needs it to calculate distance, speed and power. Just as a frame of reference: the Concept2 can display this factor from the menu. Please note that the drag factor is much dependent on the physical construction of the flywheel and mechanical properties of the transmission of power to the flywheel. For a new Concept2, the Drag Factor ranges between 80 (Damper setting 1) and 220 (Damper setting 10). The NordicTrack RX-800 ranges from 150 to 450, where the 150 feels much lighter than a 150 on the Concept2.
Here, some rowing and some knowledge about your rowing gets involved. Setting your damping factor is done by rowing a certain number of strokes and then seeing how much you have rowed and at what pace. If you know these metrics by hart, it just requires some rowing and adjusting to get them right. If you aren’t that familiar with rowing, a good starting point is that a typical distance covered by a single stroke at 20 strokes per minute (SPM) is around 10 meters. So when you row a minute, you will have 20 strokes recorded and around 200 meters rowed. When possible, we use the Concept Model D (or RowerErg) as a “Golden standard”: when you know your pace on that machine, you can try to mimic that pace on your machine. Most gym’s have one, so trying one can help you a lot in finding the right settings for your machine.
Settings you COULD change for a new rower
In the previous section, we’ve guided you to set up a real robust working rower, but it will result in more crude data. To improve the accuracy of many measurements, you could switch to a more accurate and dynamic rower. This does require a more sophisticated rower: you need quite a few data points per stroke, with much accuracy, to get this working reliably. And a lot of rowing to get these settings right is involved.
More accurate stroke detection
The naturalDeceleration setting determines the natural deceleration. This setting is used to distinguish between a powered and unpowered flywheel. This must be a negative number and indicates the level of deceleration required to interpret it as a free spinning flywheel. The best way to find the correct value for your rowing machine is a try and error approach. You can also set this to zero (or positive), to use the more robust, but not so precise acceleration-based stroke detection algorithm. Setting it to -0.1 enables the alternative less robust algorithm. By seeing how your stroke detection behaves during a row, you can slowly lower this number until you start missing strokes.
Please note that changing this stroke detection will affect your calculated dragFactor.
Dynamically adapting the drag factor
In reality, the drag factor of a rowing machine isn’t static: it depends on air temperature, moisture, dust, (air)obstructions of the flywheel cage and sometimes even speed of the flywheel. So using a static drag factor is reliable, it isn’t accurate. Open Rowing Monitor can automatically calculate the drag factor on-the-fly based on the recovery phase (see this description of the underlying physics). To do this, you need to set the following settings:
- autoAdjustDragFactor: the Drag Factor can be calculated automatically. Setting it to true, will allow Open Rowing Monitor to automatically calculate the drag factor based on the flywheelInertia and the on the measured values in the stroke recovery phase.
- flywheelInertia: The moment of inertia of the flywheel (in kg*m^2), which in practice influences your power values and distance. A formal way to measure it is outlined in Flywheel moment of inertia. However, the most practical way to set it is by rowing and see what kind of power is displayed on the monitor. Typical ranges are weight dependent (see this explanation), and it helps if you know your times on a reliable machine like the Concept2.
Please note that you don’t need to use the dynamic drag factor to test your settings. To see the calculated drag factor for your rowing machine, please ensure that the logging level of the RowingEngine is set to ‘info’ or higher. Then do some strokes on the rower and observe the calculated drag factor in the logging.
It must be noted that you have to make sure that your machine’s measurements are sufficiently free of noise: noise in the drag calculation can have a strong influence on your speed and distance calculations and thus your results. If your rower produces stable damping values, then this could be a good option to dynamically adjust your measurements to the damper setting of your rower as it takes in account environmental conditions. When your machine’s power and speed readings are too volatile it is wise to turn it off
Settings you can tweak
Some people want it all, and we’re happy to give to you when your rower and your Raspberry Pi can handle the pain. Some interesting settings:
- maximumImpulseTimeBeforePause determines the maximum time between impulses before the rowing engine considers it a pause.
- magicConstant is a constant that is commonly used to convert flywheel revolutions to a rowed distance and speed (see the physics of ergometers). Concept2 seems to use 2.8, which they admit is an arbitrary number which came close to their expectations of a competetion boat. As this setting only affects speed/distance, this setting typically is used to change the power needed to row a certain distance or reach a certain speed. So changing this can make your rower’s metrics act as sluggish as an oil tanker (much power needed for little speed), or more like a smooth eight (less power needed for more speed). So for your rower, you could set your own plausible distance for the effort you put in. Please note that the rowed distance also depends on flywheelInertia, so please calibrate that before changing this constant. Another note: increasing this number decreases your rowed meters, but not in a linear fashion.
- webUpdateInterval: normally set at 1000 milliseconds, but for a more smoother experience on your monitor you can go as low as 100 ms. This makes the transition of the distance and time quite smooth, but at the price of some more network and CPU-load.
- numOfPhasesForAveragingScreenData: we average the data from several stroke phases to prevent the monitor and Bluetooth devices to become fidgety. Typically, we set this value to 6, which means 3 strokes (there are two phases in each stroke). However, some Bluetooth devices do their own calculations. And sometimes you really want the feedback on your individual strokes without any punches hold back. Setting this to 1 will result in a very volatile, but direct feedback mechanism on your stroke.
- dampingConstantSmoothing determines the smoothing of the dragfactor across strokes (if autoAdjustDragFactor is set to true). Normally set at 5 strokes, which prevents wild values to throw off all your measurements. If you have rower that produces very little noise in the data, then it could be an option to reduce. If your machine produces noisy data, this is the one to increase before anything else.
- dampingConstantMaxChange determines the maximum change between a currently determined dragfactor and the current average of the previous dampingConstantSmoothing strokes (if autoAdjustDragFactor is set to true). This filter reduces spikes in the calculation and thus makes the dragfactor less responsive to changes. The default value of 0.10 implies that the maximum upward/downward change is an increase of the drag with 10%. Please note that this filter still allows changes, it just limits their impact to this percentage. Most rower’s dragfactor is relatively constant, however certain hyrid rower’s dragfactor changes when the speed changes. To allow for bigger changes within a stroke, increase this setting. When the expected changes are small, set this setting small. When your rower is a hybrid or when you have one configuration for all your damper settings, this should be a bit wider.
- createRawDataFiles: This is as raw as it gets, as setting this to
true
makes Open Rowing Monitor dump the raw impulse-lengths to a file (see how we interpret this data).