|  |  |  | @ -310,7 +310,7 @@ void Localizer::input_fake_gps_observations(double current_time) { | 
			
		
	
		
			
				
					|  |  |  |  | void Localizer::handle_gps(double current_time, const cereal::GpsLocationData::Reader& log, const double sensor_time_offset) { | 
			
		
	
		
			
				
					|  |  |  |  |   // ignore the message if the fix is invalid
 | 
			
		
	
		
			
				
					|  |  |  |  |   bool gps_invalid_flag = (log.getFlags() % 2 == 0); | 
			
		
	
		
			
				
					|  |  |  |  |   bool gps_unreasonable = (Vector2d(log.getAccuracy(), log.getVerticalAccuracy()).norm() >= SANE_GPS_UNCERTAINTY); | 
			
		
	
		
			
				
					|  |  |  |  |   bool gps_unreasonable = (Vector2d(log.getHorizontalAccuracy(), log.getVerticalAccuracy()).norm() >= SANE_GPS_UNCERTAINTY); | 
			
		
	
		
			
				
					|  |  |  |  |   bool gps_accuracy_insane = ((log.getVerticalAccuracy() <= 0) || (log.getSpeedAccuracy() <= 0) || (log.getBearingAccuracyDeg() <= 0)); | 
			
		
	
		
			
				
					|  |  |  |  |   bool gps_lat_lng_alt_insane = ((std::abs(log.getLatitude()) > 90) || (std::abs(log.getLongitude()) > 180) || (std::abs(log.getAltitude()) > ALTITUDE_SANITY_CHECK)); | 
			
		
	
		
			
				
					|  |  |  |  |   bool gps_vel_insane = (floatlist2vector(log.getVNED()).norm() > TRANS_SANITY_CHECK); | 
			
		
	
	
		
			
				
					|  |  |  | @ -331,7 +331,7 @@ void Localizer::handle_gps(double current_time, const cereal::GpsLocationData::R | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   VectorXd ecef_pos = this->converter->ned2ecef({ 0.0, 0.0, 0.0 }).to_vector(); | 
			
		
	
		
			
				
					|  |  |  |  |   VectorXd ecef_vel = this->converter->ned2ecef({ log.getVNED()[0], log.getVNED()[1], log.getVNED()[2] }).to_vector() - ecef_pos; | 
			
		
	
		
			
				
					|  |  |  |  |   float ecef_pos_std = std::sqrt(this->gps_variance_factor * std::pow(log.getAccuracy(), 2) + this->gps_vertical_variance_factor * std::pow(log.getVerticalAccuracy(), 2)); | 
			
		
	
		
			
				
					|  |  |  |  |   float ecef_pos_std = std::sqrt(this->gps_variance_factor * std::pow(log.getHorizontalAccuracy(), 2) + this->gps_vertical_variance_factor * std::pow(log.getVerticalAccuracy(), 2)); | 
			
		
	
		
			
				
					|  |  |  |  |   MatrixXdr ecef_pos_R = Vector3d::Constant(std::pow(this->gps_std_factor * ecef_pos_std, 2)).asDiagonal(); | 
			
		
	
		
			
				
					|  |  |  |  |   MatrixXdr ecef_vel_R = Vector3d::Constant(std::pow(this->gps_std_factor * log.getSpeedAccuracy(), 2)).asDiagonal(); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
	
		
			
				
					|  |  |  | 
 |