loc_node(NULL),
loc_dist_node(NULL),
gs_deflection_node(NULL),
+ gs_deflection_norm_node(NULL),
gs_rate_of_climb_node(NULL),
gs_dist_node(NULL),
nav_id_node(NULL),
loc_node = node->getChild("nav-loc", 0, true);
loc_dist_node = node->getChild("nav-distance", 0, true);
gs_deflection_node = node->getChild("gs-needle-deflection", 0, true);
+ gs_deflection_norm_node = node->getChild("gs-needle-deflection-norm", 0, true);
gs_rate_of_climb_node = node->getChild("gs-rate-of-climb", 0, true);
gs_dist_node = node->getChild("gs-distance", 0, true);
nav_id_node = node->getChild("nav-id", 0, true);
cdi_xtrack_hdg_err_node->setDoubleValue( 0.0 );
time_to_intercept->setDoubleValue( 0.0 );
gs_deflection_node->setDoubleValue( 0.0 );
+ gs_deflection_norm_node->setDoubleValue(0.0);
+
to_flag_node->setBoolValue( false );
from_flag_node->setBoolValue( false );
}
_cdiCrossTrackErrorM = 0.0;
_toFlag = _fromFlag = false;
_gsNeedleDeflection = 0.0;
+ _gsNeedleDeflectionNorm = 0.0;
inrange_node->setBoolValue(false);
return;
}
//SG_CLAMP_RANGE(deflectionAngle, -0.7, 0.7);
_gsNeedleDeflection = deflectionAngle * 5.0;
_gsNeedleDeflection *= signal_quality_norm;
+ _gsNeedleDeflectionNorm = (deflectionAngle / 0.7) * signal_quality_norm;
+ SG_CLAMP_RANGE(_gsNeedleDeflectionNorm, -1.0, 1.0);
//////////////////////////////////////////////////////////
// Calculate desired rate of climb for intercepting the GS
if (!gs_serviceable_node->getBoolValue() ) {
_gsNeedleDeflection = 0.0;
+ _gsNeedleDeflectionNorm = 0.0;
}
gs_deflection_node->setDoubleValue(_gsNeedleDeflection);
-
+ gs_deflection_norm_node->setDoubleValue(_gsNeedleDeflectionNorm);
+
last_xtrack_error = _cdiCrossTrackErrorM;
}
SGPropertyNode_ptr loc_node;
SGPropertyNode_ptr loc_dist_node;
SGPropertyNode_ptr gs_deflection_node;
+ SGPropertyNode_ptr gs_deflection_norm_node;
SGPropertyNode_ptr gs_rate_of_climb_node;
SGPropertyNode_ptr gs_dist_node;
SGPropertyNode_ptr nav_id_node;
double _cdiDeflection;
double _cdiCrossTrackErrorM;
double _gsNeedleDeflection;
+ double _gsNeedleDeflectionNorm;
bool updateWithPower(double aDt);