// vertical_speed_indicator.cxx - a regular VSI. // Written by David Megginson, started 2002. // // This file is in the Public Domain and comes with no warranty. #include #include "vertical_speed_indicator.hxx" #include
#include
VerticalSpeedIndicator::VerticalSpeedIndicator ( SGPropertyNode *node ) : _internal_pressure_inhg(29.92), _name(node->getStringValue("name", "vertical-speed-indicator")), _num(node->getIntValue("number", 0)), _static_pressure(node->getStringValue("static-pressure", "/systems/static/pressure-inhg")) { } VerticalSpeedIndicator::~VerticalSpeedIndicator () { } void VerticalSpeedIndicator::init () { string branch; branch = "/instrumentation/" + _name; SGPropertyNode *node = fgGetNode(branch.c_str(), _num, true ); _serviceable_node = node->getChild("serviceable", 0, true); _pressure_node = fgGetNode(_static_pressure.c_str(), true); _speed_node = node->getChild("indicated-speed-fpm", 0, true); _speed_up_node = fgGetNode("/sim/speed-up", true); // Initialize at ambient pressure _internal_pressure_inhg = _pressure_node->getDoubleValue(); } void VerticalSpeedIndicator::update (double dt) { // model taken from steam.cxx, with change // from 10000 to 10500 for manual factor if (_serviceable_node->getBoolValue()) { double pressure = _pressure_node->getDoubleValue(); double speed_up = _speed_up_node->getDoubleValue(); if( speed_up > 1 ) dt *= speed_up; _speed_node ->setDoubleValue((_internal_pressure_inhg - pressure) * 10500); _internal_pressure_inhg = fgGetLowPass(_internal_pressure_inhg, _pressure_node->getDoubleValue(), dt/6.0); } } // end of vertical_speed_indicator.cxx