diff options
| author | Keith Packard <keithp@keithp.com> | 2017-05-25 17:24:14 -0700 | 
|---|---|---|
| committer | Keith Packard <keithp@keithp.com> | 2017-05-25 17:24:14 -0700 | 
| commit | f26cfe417c6977cf1e7e75a4f050e25f64d41859 (patch) | |
| tree | 2f19ca9c93c3246b3eeadafee250f9dd3ee222d6 /altoslib/AltosConvert.java | |
| parent | 7600116a191b3ac252a0f716d200d0e0b3500987 (diff) | |
altoslib: Do data analysis on raw values rather than AltosState
Use AltosFlightSeries instead of a sequence of AltosState records when
processing saved data. This provides a better way of doing filtering
and plotting.
Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'altoslib/AltosConvert.java')
| -rw-r--r-- | altoslib/AltosConvert.java | 42 | 
1 files changed, 33 insertions, 9 deletions
| diff --git a/altoslib/AltosConvert.java b/altoslib/AltosConvert.java index a3343a4f..95c1a99f 100644 --- a/altoslib/AltosConvert.java +++ b/altoslib/AltosConvert.java @@ -24,6 +24,9 @@ package org.altusmetrum.altoslib_11;  import java.util.*;  public class AltosConvert { + +	public static final double gravity = 9.80665; +  	/*  	 * Pressure Sensor Model, version 1.1  	 * @@ -44,20 +47,20 @@ public class AltosConvert {  	 *   in Joules/(kilogram-Kelvin).  	 */ -	public static final double GRAVITATIONAL_ACCELERATION = -9.80665; -	public static final double AIR_GAS_CONSTANT		= 287.053; -	public static final double NUMBER_OF_LAYERS		= 7; -	public static final double MAXIMUM_ALTITUDE		= 84852.0; -	public static final double MINIMUM_PRESSURE		= 0.3734; -	public static final double LAYER0_BASE_TEMPERATURE	= 288.15; -	public static final double LAYER0_BASE_PRESSURE	= 101325; +	private static final double GRAVITATIONAL_ACCELERATION = -gravity; +	private static final double AIR_GAS_CONSTANT		= 287.053; +	private static final double NUMBER_OF_LAYERS		= 7; +	private static final double MAXIMUM_ALTITUDE		= 84852.0; +	private static final double MINIMUM_PRESSURE		= 0.3734; +	private static final double LAYER0_BASE_TEMPERATURE	= 288.15; +	private static final double LAYER0_BASE_PRESSURE	= 101325;  	/* lapse rate and base altitude for each layer in the atmosphere */ -	public static final double[] lapse_rate = { +	private static final double[] lapse_rate = {  		-0.0065, 0.0, 0.001, 0.0028, 0.0, -0.0028, -0.002  	}; -	public static final int[] base_altitude = { +	private static final int[] base_altitude = {  		0, 11000, 20000, 32000, 47000, 51000, 71000  	}; @@ -307,6 +310,10 @@ public class AltosConvert {  		return 434.550 + channel * 0.100;  	} +	public static int telem_to_rssi(int telem) { +		return telem / 2 - 74; +	} +  	public static int[] ParseHex(String line) {  		String[] tokens = line.split("\\s+");  		int[] array = new int[tokens.length]; @@ -384,6 +391,21 @@ public class AltosConvert {  		return lb / 0.22480894;  	} +	public static double acceleration_from_sensor(double sensor, double plus_g, double minus_g, double ground) { +		if (sensor == AltosLib.MISSING) +			return AltosLib.MISSING; + +		if (plus_g == AltosLib.MISSING || minus_g == AltosLib.MISSING) +			return AltosLib.MISSING; + +		if (ground == AltosLib.MISSING) +			ground = plus_g; + +		double counts_per_g = (plus_g - minus_g) / 2.0; +		double counts_per_mss = counts_per_g / gravity; +		return (sensor - ground) / counts_per_mss; +	} +  	public static boolean imperial_units = false;  	public static AltosDistance distance = new AltosDistance(); @@ -410,6 +432,8 @@ public class AltosConvert {  	public static AltosRotationRate rotation_rate = new AltosRotationRate(); +	public static AltosStateName state_name = new AltosStateName(); +  	public static String show_gs(String format, double a) {  		a = meters_to_g(a);  		format = format.concat(" g"); | 
