diff options
| author | Bdale Garbee <bdale@gag.com> | 2013-12-19 01:38:40 -0700 | 
|---|---|---|
| committer | Bdale Garbee <bdale@gag.com> | 2013-12-19 01:38:40 -0700 | 
| commit | 575bbaf976c5840fd0e308549c45a466fdec1352 (patch) | |
| tree | 11bfb498348bf7687bffc24699c4b1a998988ee4 /altosui/AltosFlightStats.java | |
| parent | b825116df173b77e2cab217a7b76112c742f9279 (diff) | |
| parent | bc3610d8cecbfed40c62d4dcb93fc9a4d2a7c9e3 (diff) | |
Merge branch 'branch-1.3' into debian
Conflicts:
	ChangeLog
	altoslib/AltosRecordMM.java
	altosui/Makefile.am
	altosui/altos-windows.nsi.in
	configure.ac
	debian/changelog
	debian/control
	doc/Makefile
	doc/altusmetrum.xsl
	doc/release-notes-1.2.1.xsl
	doc/release-notes-1.2.xsl
Diffstat (limited to 'altosui/AltosFlightStats.java')
| -rw-r--r-- | altosui/AltosFlightStats.java | 143 | 
1 files changed, 70 insertions, 73 deletions
| diff --git a/altosui/AltosFlightStats.java b/altosui/AltosFlightStats.java index dee31a8d..552210c3 100644 --- a/altosui/AltosFlightStats.java +++ b/altosui/AltosFlightStats.java @@ -18,14 +18,13 @@  package altosui;  import java.io.*; -import org.altusmetrum.altoslib_1.*; +import org.altusmetrum.altoslib_2.*;  public class AltosFlightStats {  	double		max_height;  	double		max_speed;  	double		max_acceleration; -	double[]	state_accel_speed = new double[Altos.ao_flight_invalid + 1]; -	double[]	state_baro_speed = new double[Altos.ao_flight_invalid + 1]; +	double[]	state_speed = new double[Altos.ao_flight_invalid + 1];  	double[]	state_accel = new double[Altos.ao_flight_invalid + 1];  	int[]		state_count = new int[Altos.ao_flight_invalid + 1];  	double[]	state_start = new double[Altos.ao_flight_invalid + 1]; @@ -40,16 +39,19 @@ public class AltosFlightStats {  	boolean		has_other_adc;  	boolean		has_rssi; -	double landed_time(AltosRecordIterable iterable) { -		AltosState	state = null; -		for (AltosRecord record : iterable) { -			state = new AltosState(record, state); +	double landed_time(AltosStateIterable states) { +		AltosState state = null; +		for (AltosState s : states) { +			state = s;  			if (state.state == Altos.ao_flight_landed)  				break;  		} -		double	landed_height = state.height; +		if (state == null) +			return 0; + +		double	landed_height = state.height();  		state = null; @@ -57,13 +59,13 @@ public class AltosFlightStats {  		double	landed_time = -1000; -		for (AltosRecord record : iterable) { -			state = new AltosState(record, state); +		for (AltosState s : states) { +			state = s; -			if (state.height > landed_height + 10) { +			if (state.height() > landed_height + 10) {  				above = true;  			} else { -				if (above && state.height < landed_height + 2) { +				if (above && state.height() < landed_height + 2) {  					above = false;  					landed_time = state.time;  				} @@ -74,84 +76,80 @@ public class AltosFlightStats {  		return landed_time;  	} -	double boost_time(AltosRecordIterable iterable) { -		double boost_time = -1000; - -		AltosState state = null; +	double boost_time(AltosStateIterable states) { +		double boost_time = AltosLib.MISSING; +		AltosState	state = null; -		for (AltosRecord record : iterable) { -			state = new AltosState(record, state); -			 -			if (state.acceleration < 1) +		for (AltosState s : states) { +			state = s; +			if (state.acceleration() < 1)  				boost_time = state.time; -			if (state.state >= Altos.ao_flight_boost) +			if (state.state >= AltosLib.ao_flight_boost && state.state <= AltosLib.ao_flight_landed)  				break;  		} -		if (boost_time == -1000) +		if (state == null) +			return 0; + +		if (boost_time == AltosLib.MISSING)  			boost_time = state.time;  		return boost_time;  	} -	public AltosFlightStats(AltosRecordIterable iterable) throws InterruptedException, IOException { -		AltosState	state = null; -		AltosState	new_state = null; -		double		boost_time = boost_time(iterable); +	public AltosFlightStats(AltosStateIterable states) throws InterruptedException, IOException { +		double		boost_time = boost_time(states);  		double		end_time = 0; -		double		landed_time = landed_time(iterable); +		double		landed_time = landed_time(states); -		year = month = day = -1; -		hour = minute = second = -1; -		serial = flight = -1; -		lat = lon = -1; +		year = month = day = AltosLib.MISSING; +		hour = minute = second = AltosLib.MISSING; +		serial = flight = AltosLib.MISSING; +		lat = lon = AltosLib.MISSING;  		has_gps = false;  		has_other_adc = false;  		has_rssi = false; -		for (AltosRecord record : iterable) { -			if (serial < 0) -				serial = record.serial; -			if ((record.seen & AltosRecord.seen_flight) != 0 && flight < 0) -				flight = record.flight; -			if ((record.seen & AltosRecord.seen_temp_volt) != 0) +		for (AltosState state : states) { +			if (serial == AltosLib.MISSING && state.serial != AltosLib.MISSING) +				serial = state.serial; +			if (flight == AltosLib.MISSING && state.flight != AltosLib.MISSING) +				flight = state.flight; +			if (state.battery_voltage != AltosLib.MISSING)  				has_other_adc = true; -			if (record.rssi != 0) +			if (state.rssi != AltosLib.MISSING)  				has_rssi = true; -			new_state = new AltosState(record, state); -			end_time = new_state.time; -			state = new_state; -			if (state.time >= boost_time && state.state < Altos.ao_flight_boost) -				state.state = Altos.ao_flight_boost; -			if (state.time >= landed_time && state.state < Altos.ao_flight_landed) -				state.state = Altos.ao_flight_landed; -			if (0 <= state.state && state.state < Altos.ao_flight_invalid) { -				if (state.state >= Altos.ao_flight_boost) { -					if (state.gps != null && state.gps.locked && -					    year < 0) { -						year = state.gps.year; -						month = state.gps.month; -						day = state.gps.day; -						hour = state.gps.hour; -						minute = state.gps.minute; -						second = state.gps.second; -					} +			end_time = state.time; + +			int state_id = state.state; +			if (state.time >= boost_time && state_id < Altos.ao_flight_boost) +				state_id = Altos.ao_flight_boost; +			if (state.time >= landed_time && state_id < Altos.ao_flight_landed) +				state_id = Altos.ao_flight_landed; +			if (state.gps != null && state.gps.locked) { +				year = state.gps.year; +				month = state.gps.month; +				day = state.gps.day; +				hour = state.gps.hour; +				minute = state.gps.minute; +				second = state.gps.second; +			} +			if (0 <= state_id && state_id < Altos.ao_flight_invalid) { +				double acceleration = state.acceleration(); +				double speed = state.speed(); +				if (acceleration != AltosLib.MISSING && speed != AltosLib.MISSING) { +					state_accel[state_id] += acceleration; +					state_speed[state_id] += speed; +					state_count[state_id]++;  				} -				state_accel[state.state] += state.acceleration; -				state_accel_speed[state.state] += state.accel_speed; -				state_baro_speed[state.state] += state.baro_speed; -				state_count[state.state]++; -				if (state_start[state.state] == 0.0) -					state_start[state.state] = state.time; -				if (state_end[state.state] < state.time) -					state_end[state.state] = state.time; -				max_height = state.max_height; -				if (state.max_accel_speed != 0) -					max_speed = state.max_accel_speed; -				else -					max_speed = state.max_baro_speed; -				max_acceleration = state.max_acceleration; +				if (state_start[state_id] == 0.0) +					state_start[state_id] = state.time; +				if (state_end[state_id] < state.time) +					state_end[state_id] = state.time; +				max_height = state.max_height(); +				max_speed = state.max_speed(); +				max_acceleration = state.max_acceleration();  			}  			if (state.gps != null && state.gps.locked && state.gps.nsat >= 4) { -				if (state.state <= Altos.ao_flight_pad) { +				if (state_id <= Altos.ao_flight_pad) {  					pad_lat = state.gps.lat;  					pad_lon = state.gps.lon;  				} @@ -162,8 +160,7 @@ public class AltosFlightStats {  		}  		for (int s = Altos.ao_flight_startup; s <= Altos.ao_flight_landed; s++) {  			if (state_count[s] > 0) { -				state_accel_speed[s] /= state_count[s]; -				state_baro_speed[s] /= state_count[s]; +				state_speed[s] /= state_count[s];  				state_accel[s] /= state_count[s];  			}  			if (state_start[s] == 0) | 
