diff options
author | Bdale Garbee <bdale@gag.com> | 2014-08-14 17:08:36 -0600 |
---|---|---|
committer | Bdale Garbee <bdale@gag.com> | 2014-08-14 17:08:36 -0600 |
commit | 4828be0ca5252ac9cd6061209385dcd6c4c57965 (patch) | |
tree | dde4f86d893d280fbeef284120d6f967cdbfeaa5 /altoslib/AltosTelemetryMegaData.java | |
parent | 17e894d1b65231d07df009bc4e8ca92864ccf790 (diff) | |
parent | 165b7dcf6fba90b15ff32b891cba4b9111c1965b (diff) |
Merge branch 'master' of ssh://git.gag.com/scm/git/fw/altos
Diffstat (limited to 'altoslib/AltosTelemetryMegaData.java')
-rw-r--r-- | altoslib/AltosTelemetryMegaData.java | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/altoslib/AltosTelemetryMegaData.java b/altoslib/AltosTelemetryMegaData.java index 93610118..8b1869bb 100644 --- a/altoslib/AltosTelemetryMegaData.java +++ b/altoslib/AltosTelemetryMegaData.java @@ -31,7 +31,7 @@ public class AltosTelemetryMegaData extends AltosTelemetryStandard { int acceleration; int speed; - int height; + int height_16; public AltosTelemetryMegaData(int[] bytes) { super(bytes); @@ -55,7 +55,8 @@ public class AltosTelemetryMegaData extends AltosTelemetryStandard { acceleration = int16(26); speed = int16(28); - height = int16(30); + + height_16 = int16(30); } public void update_state(AltosState state) { @@ -79,7 +80,13 @@ public class AltosTelemetryMegaData extends AltosTelemetryStandard { state.set_ground_pressure(ground_pres); state.set_accel_g(accel_plus_g, accel_minus_g); - state.set_kalman(height, speed/16.0, acceleration / 16.0); + /* Fill in the high bits of height from recent GPS + * data if available, otherwise guess using the + * previous kalman height + */ + + state.set_kalman(extend_height(state, height_16), + speed/16.0, acceleration / 16.0); } } |