/* * Author: Ruthberg * Calculates the fireing solution and updates the result input/output fields * * Arguments: * Nothing * * Return Value: * Nothing * * Example: * call ace_atragmx_calculate_target_solution * * Public: No */ #include "script_component.hpp" [] call FUNC(parse_input); private ["_scopeBaseAngle"]; _scopeBaseAngle = ((GVAR(workingMemory) select GVAR(currentTarget)) select 3); private ["_bulletMass", "_boreHeight", "_airFriction", "_muzzleVelocity", "_bc", "_dragModel", "_atmosphereModel"]; _bulletMass = (GVAR(workingMemory) select GVAR(currentTarget)) select 12; _boreHeight = (GVAR(workingMemory) select GVAR(currentTarget)) select 5; _airFriction = (GVAR(workingMemory) select GVAR(currentTarget)) select 4; _muzzleVelocity = (GVAR(workingMemory) select GVAR(currentTarget)) select 1; _bc = (GVAR(workingMemory) select GVAR(currentTarget)) select 15; _dragModel = (GVAR(workingMemory) select GVAR(currentTarget)) select 16; _atmosphereModel = (GVAR(workingMemory) select GVAR(currentTarget)) select 17; private ["_temperature", "_barometricPressure", "_relativeHumidity"]; _temperature = (GVAR(temperature) select GVAR(currentTarget)); _barometricPressure = (GVAR(barometricPressure) select GVAR(currentTarget)); _relativeHumidity = (GVAR(relativeHumidity) select GVAR(currentTarget)); if (GVAR(currentUnit) == 1) then { _temperature = (_temperature - 32) / 1.8; _barometricPressure = _barometricPressure * 33.8638866667; }; private ["_windSpeed", "_windDirection", "_inclinationAngle", "_targetSpeed", "_targetRange"]; _windSpeed = (GVAR(windSpeed) select GVAR(currentTarget)); _windDirection = (GVAR(windDirection) select GVAR(currentTarget)); _inclinationAngle = (GVAR(inclinationAngle) select GVAR(currentTarget)); _targetSpeed = (GVAR(targetSpeed) select GVAR(currentTarget)); _targetRange = (GVAR(targetRange) select GVAR(currentTarget)); if (GVAR(currentUnit) != 2) then { _targetRange = _targetRange / 1.0936133; }; if (GVAR(currentUnit) == 1) then { _windSpeed = _windSpeed / 2.23693629; _targetSpeed = _targetSpeed / 2.23693629; }; _result = [_scopeBaseAngle, _bulletMass, _boreHeight, _airFriction, _muzzleVelocity, _temperature, _barometricPressure, _relativeHumidity, 1000, _windSpeed, _windDirection, _inclinationAngle, _targetSpeed, _targetRange, _bc, _dragModel, _atmosphereModel, false] call FUNC(calculate_solution); GVAR(elevationOutput) set [GVAR(currentTarget), _result select 0]; GVAR(windageOutput) set [GVAR(currentTarget), _result select 1]; GVAR(leadOutput) set [GVAR(currentTarget), _result select 2]; GVAR(tofOutput) set [GVAR(currentTarget), _result select 3]; GVAR(velocityOutput) set [GVAR(currentTarget), _result select 4]; [] call FUNC(update_result);