diff options
| author | Keith Packard <keithp@keithp.com> | 2014-10-04 00:11:13 -0700 | 
|---|---|---|
| committer | Keith Packard <keithp@keithp.com> | 2014-10-04 00:11:13 -0700 | 
| commit | 00ae706dab6e8fddef4c5730a17c433a022228b7 (patch) | |
| tree | fae976ad891d1776f6e52c078d9eceb35d96a845 /altoslib/AltosIMU.java | |
| parent | a757fd5af53f5721a949181372548afa4757d6c9 (diff) | |
altoslib: Compute tilt angle from eeprom data
This copies the computation of tilt angle from the firmware so that
post-flight analysis can also show the data.
This change also renames all of the imu values to make them easier to
understand:
	accel	gyro	axis
	along	roll	length of the board
	across	pitch	across the board
	through	yaw	through the board.
Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'altoslib/AltosIMU.java')
| -rw-r--r-- | altoslib/AltosIMU.java | 82 | 
1 files changed, 41 insertions, 41 deletions
| diff --git a/altoslib/AltosIMU.java b/altoslib/AltosIMU.java index 89d7def4..d7373f3c 100644 --- a/altoslib/AltosIMU.java +++ b/altoslib/AltosIMU.java @@ -20,36 +20,24 @@ package org.altusmetrum.altoslib_5;  import java.util.concurrent.*;  public class AltosIMU implements Cloneable { -	public double		accel_x; -	public double		accel_y; -	public double		accel_z; +	public int		accel_along; +	public int		accel_across; +	public int		accel_through; -	public double		gyro_x; -	public double		gyro_y; -	public double		gyro_z; +	public int		gyro_roll; +	public int		gyro_pitch; +	public int		gyro_yaw; -/* - * XXX use ground measurements to adjust values - -	public double		ground_accel_x; -	public double		ground_accel_y; -	public double		ground_accel_z; - -	public double		ground_gyro_x; -	public double		ground_gyro_y; -	public double		ground_gyro_z; -*/ - -	public static int	counts_per_g = 2048; +	public static double	counts_per_g = 2048.0; -	public static double convert_accel(int counts) { -		return (double) counts / (double) counts_per_g * (-AltosConvert.GRAVITATIONAL_ACCELERATION); +	public static double convert_accel(double counts) { +		return counts / counts_per_g * (-AltosConvert.GRAVITATIONAL_ACCELERATION);  	}  	public static double	counts_per_degsec = 16.4; -	public static double convert_gyro(int counts) { -		return (double) counts / counts_per_degsec; +	public static double convert_gyro(double counts) { +		return counts / counts_per_degsec;  	}  	public boolean parse_string(String line) { @@ -59,12 +47,12 @@ public class AltosIMU implements Cloneable {  		String[] items = line.split("\\s+");  		if (items.length >= 8) { -			accel_x = convert_accel(Integer.parseInt(items[1])); -			accel_y = convert_accel(Integer.parseInt(items[2])); -			accel_z = convert_accel(Integer.parseInt(items[3])); -			gyro_x = convert_gyro(Integer.parseInt(items[5])); -			gyro_y = convert_gyro(Integer.parseInt(items[6])); -			gyro_z = convert_gyro(Integer.parseInt(items[7])); +			accel_along = Integer.parseInt(items[1]); +			accel_across = Integer.parseInt(items[2]); +			accel_through = Integer.parseInt(items[3]); +			gyro_roll = Integer.parseInt(items[5]); +			gyro_pitch = Integer.parseInt(items[6]); +			gyro_yaw = Integer.parseInt(items[7]);  		}  		return true;  	} @@ -72,13 +60,13 @@ public class AltosIMU implements Cloneable {  	public AltosIMU clone() {  		AltosIMU	n = new AltosIMU(); -		n.accel_x = accel_x; -		n.accel_y = accel_y; -		n.accel_z = accel_z; +		n.accel_along = accel_along; +		n.accel_across = accel_across; +		n.accel_through = accel_through; -		n.gyro_x = gyro_x; -		n.gyro_y = gyro_y; -		n.gyro_z = gyro_z; +		n.gyro_roll = gyro_roll; +		n.gyro_pitch = gyro_pitch; +		n.gyro_yaw = gyro_yaw;  		return n;  	} @@ -93,13 +81,25 @@ public class AltosIMU implements Cloneable {  	}  	public AltosIMU() { -		accel_x = AltosLib.MISSING; -		accel_y = AltosLib.MISSING; -		accel_z = AltosLib.MISSING; +		accel_along = AltosLib.MISSING; +		accel_across = AltosLib.MISSING; +		accel_through = AltosLib.MISSING; + +		gyro_roll = AltosLib.MISSING; +		gyro_pitch = AltosLib.MISSING; +		gyro_yaw = AltosLib.MISSING; +	} + +	public AltosIMU(int accel_along, int accel_across, int accel_through, +			int gyro_roll, int gyro_pitch, int gyro_yaw) { + +		this.accel_along = accel_along; +		this.accel_across = accel_across; +		this.accel_through = accel_through; -		gyro_x = AltosLib.MISSING; -		gyro_y = AltosLib.MISSING; -		gyro_z = AltosLib.MISSING; +		this.gyro_roll = gyro_roll; +		this.gyro_pitch = gyro_pitch; +		this.gyro_yaw = gyro_yaw;  	}  	public AltosIMU(AltosLink link) throws InterruptedException, TimeoutException { | 
