2002-09-27 18:27:58 +00:00
|
|
|
// altimeter.cxx - an altimeter tied to the static port.
|
|
|
|
// Written by David Megginson, started 2002.
|
2007-03-31 09:36:19 +00:00
|
|
|
// Modified by John Denker in 2007 to use a two layer atmosphere
|
|
|
|
// model in src/Environment/atmosphere.?xx
|
2012-11-26 18:59:48 +01:00
|
|
|
// Last modified by Eric van den Berg, 25 Nov 2012
|
2002-09-27 18:27:58 +00:00
|
|
|
//
|
|
|
|
// This file is in the Public Domain and comes with no warranty.
|
|
|
|
|
2007-03-31 09:36:19 +00:00
|
|
|
// Example invocation, in the instrumentation.xml file:
|
|
|
|
// <altimeter>
|
|
|
|
// <name>encoder</name>
|
|
|
|
// <number>0</number>
|
|
|
|
// <static-pressure>/systems/static/pressure-inhg</static-pressure>
|
|
|
|
// <quantum>10</quantum>
|
|
|
|
// <tau>0</tau>
|
|
|
|
// </altimeter>
|
|
|
|
// Note non-default name, quantum, and tau values.
|
|
|
|
|
2007-04-03 11:36:47 +00:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include <config.h>
|
|
|
|
#endif
|
|
|
|
|
2012-11-26 18:59:48 +01:00
|
|
|
#include <simgear/constants.h>
|
2002-09-27 18:27:58 +00:00
|
|
|
#include <simgear/math/interpolater.hxx>
|
2007-03-31 15:17:55 +00:00
|
|
|
#include <simgear/math/SGMath.hxx>
|
2002-09-27 18:27:58 +00:00
|
|
|
|
|
|
|
#include <Main/fg_props.hxx>
|
2002-09-27 22:04:21 +00:00
|
|
|
#include <Main/util.hxx>
|
2007-03-31 09:36:19 +00:00
|
|
|
#include <Environment/atmosphere.hxx>
|
2002-09-27 18:27:58 +00:00
|
|
|
|
2007-03-31 09:36:19 +00:00
|
|
|
#include "altimeter.hxx"
|
2002-09-27 18:27:58 +00:00
|
|
|
|
2013-05-11 18:35:54 +01:00
|
|
|
Altimeter::Altimeter ( SGPropertyNode *node, const std::string& aDefaultName, double quantum ) :
|
|
|
|
_name(node->getStringValue("name", aDefaultName.c_str())),
|
|
|
|
_num(node->getIntValue("number", 0)),
|
2006-12-06 22:11:43 +00:00
|
|
|
_static_pressure(node->getStringValue("static-pressure", "/systems/static/pressure-inhg")),
|
2007-03-31 09:36:19 +00:00
|
|
|
_tau(node->getDoubleValue("tau", 0.1)),
|
2012-02-13 22:25:30 +01:00
|
|
|
_quantum(node->getDoubleValue("quantum", quantum)),
|
|
|
|
_settingInHg(29.921260)
|
|
|
|
{
|
2013-05-08 17:34:20 +02:00
|
|
|
// FIXME: change default to false once all aircraft which use
|
|
|
|
// altimiter as an encoder are converted to request this explicitly
|
|
|
|
_encodeModeC = node->getBoolValue("encode-mode-c", true);
|
|
|
|
_encodeModeS = node->getBoolValue("encode-mode-s", false);
|
|
|
|
|
2012-02-13 22:25:30 +01:00
|
|
|
_tiedProperties.setRoot( _rootNode );
|
|
|
|
}
|
2002-09-27 18:27:58 +00:00
|
|
|
|
|
|
|
Altimeter::~Altimeter ()
|
2007-03-31 09:36:19 +00:00
|
|
|
{}
|
2002-09-27 18:27:58 +00:00
|
|
|
|
2012-02-13 22:25:30 +01:00
|
|
|
double
|
|
|
|
Altimeter::getSettingInHg() const
|
|
|
|
{
|
2014-12-30 16:04:33 +01:00
|
|
|
return int(_settingInHg*100.0)/100.0; /* return only 2 decimals: xx.xx */
|
2012-02-13 22:25:30 +01:00
|
|
|
}
|
|
|
|
|
2002-09-27 18:27:58 +00:00
|
|
|
void
|
2012-02-13 22:25:30 +01:00
|
|
|
Altimeter::setSettingInHg( double value )
|
|
|
|
{
|
|
|
|
_settingInHg = value;
|
|
|
|
}
|
|
|
|
|
2014-12-30 16:04:33 +01:00
|
|
|
int
|
2012-02-13 22:25:30 +01:00
|
|
|
Altimeter::getSettingHPa() const
|
|
|
|
{
|
2014-12-30 16:04:33 +01:00
|
|
|
return int(_settingInHg * SG_INHG_TO_PA / 100.0); /* return an INT: xxxx */
|
2012-02-13 22:25:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2014-12-30 16:04:33 +01:00
|
|
|
Altimeter::setSettingHPa( int value )
|
2002-09-27 18:27:58 +00:00
|
|
|
{
|
2012-11-26 18:59:48 +01:00
|
|
|
_settingInHg = value * SG_PA_TO_INHG * 100;
|
2012-02-13 22:25:30 +01:00
|
|
|
}
|
2004-10-16 12:37:39 +00:00
|
|
|
|
2012-02-13 22:25:30 +01:00
|
|
|
|
|
|
|
void
|
|
|
|
Altimeter::init ()
|
|
|
|
{
|
2007-03-31 09:36:19 +00:00
|
|
|
_pressure_node = fgGetNode(_static_pressure.c_str(), true);
|
2012-02-13 22:25:30 +01:00
|
|
|
_serviceable_node = _rootNode->getChild("serviceable", 0, true);
|
|
|
|
_press_alt_node = _rootNode->getChild("pressure-alt-ft", 0, true);
|
2013-05-08 17:34:20 +02:00
|
|
|
if (_encodeModeC) {
|
|
|
|
_mode_c_node = _rootNode->getChild("mode-c-alt-ft", 0, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (_encodeModeS) {
|
|
|
|
_mode_s_node = _rootNode->getChild("mode-s-alt-ft", 0, true);
|
|
|
|
}
|
|
|
|
|
2012-02-13 22:25:30 +01:00
|
|
|
_altitude_node = _rootNode->getChild("indicated-altitude-ft", 0, true);
|
2012-09-17 00:12:29 +02:00
|
|
|
|
|
|
|
reinit();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
Altimeter::reinit ()
|
|
|
|
{
|
|
|
|
_raw_PA = 0.0;
|
|
|
|
_kollsman = 0.0;
|
2012-02-13 22:25:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
Altimeter::bind()
|
|
|
|
{
|
2013-05-11 18:35:54 +01:00
|
|
|
_rootNode = fgGetNode("/instrumentation/" + _name, _num, true );
|
|
|
|
_tiedProperties.setRoot(_rootNode);
|
|
|
|
|
2012-02-13 22:25:30 +01:00
|
|
|
_tiedProperties.Tie("setting-inhg", this, &Altimeter::getSettingInHg, &Altimeter::setSettingInHg );
|
|
|
|
_tiedProperties.Tie("setting-hpa", this, &Altimeter::getSettingHPa, &Altimeter::setSettingHPa );
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
Altimeter::unbind()
|
|
|
|
{
|
|
|
|
_tiedProperties.Untie();
|
2002-09-27 18:27:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
Altimeter::update (double dt)
|
|
|
|
{
|
|
|
|
if (_serviceable_node->getBoolValue()) {
|
2007-03-31 09:36:19 +00:00
|
|
|
double trat = _tau > 0 ? dt/_tau : 100;
|
2002-09-27 18:27:58 +00:00
|
|
|
double pressure = _pressure_node->getDoubleValue();
|
2007-03-31 09:36:19 +00:00
|
|
|
double press_alt = _press_alt_node->getDoubleValue();
|
|
|
|
// The mechanism settles slowly toward new pressure altitude:
|
2012-09-17 00:12:29 +02:00
|
|
|
_raw_PA = fgGetLowPass(_raw_PA, _altimeter.press_alt_ft(pressure), trat);
|
2013-05-08 17:34:20 +02:00
|
|
|
|
|
|
|
if (_encodeModeC) {
|
|
|
|
_mode_c_node->setDoubleValue(100 * SGMiscd::round(_raw_PA/100));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (_encodeModeS) {
|
|
|
|
_mode_s_node->setDoubleValue(10 * SGMiscd::round(_raw_PA/10));
|
|
|
|
}
|
|
|
|
|
2012-02-13 22:25:30 +01:00
|
|
|
_kollsman = fgGetLowPass(_kollsman, _altimeter.kollsman_ft(_settingInHg), trat);
|
2007-03-31 09:36:19 +00:00
|
|
|
if (_quantum)
|
2012-09-17 00:12:29 +02:00
|
|
|
press_alt = _quantum * SGMiscd::round(_raw_PA/_quantum);
|
2007-03-31 09:36:19 +00:00
|
|
|
else
|
2012-09-17 00:12:29 +02:00
|
|
|
press_alt = _raw_PA;
|
2007-03-31 09:36:19 +00:00
|
|
|
_press_alt_node->setDoubleValue(press_alt);
|
|
|
|
_altitude_node->setDoubleValue(press_alt - _kollsman);
|
2002-09-27 18:27:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// end of altimeter.cxx
|