2015-04-11 21:40:46 +00:00
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
*/
|
2015-04-06 13:51:59 +00:00
|
|
|
#include "script_component.hpp"
|
|
|
|
|
2015-04-06 18:46:33 +00:00
|
|
|
[] call FUNC(parse_input);
|
2015-04-06 13:51:59 +00:00
|
|
|
|
|
|
|
private ["_scopeBaseAngle"];
|
2015-04-08 09:05:28 +00:00
|
|
|
_scopeBaseAngle = ((GVAR(workingMemory) select GVAR(currentTarget)) select 3);
|
2015-04-06 13:51:59 +00:00
|
|
|
|
|
|
|
private ["_bulletMass", "_boreHeight", "_airFriction", "_muzzleVelocity", "_bc", "_dragModel", "_atmosphereModel"];
|
2015-04-08 09:05:28 +00:00
|
|
|
_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;
|
2015-04-06 13:51:59 +00:00
|
|
|
|
|
|
|
private ["_temperature", "_barometricPressure", "_relativeHumidity"];
|
2015-04-08 09:05:28 +00:00
|
|
|
_temperature = (GVAR(temperature) select GVAR(currentTarget));
|
|
|
|
_barometricPressure = (GVAR(barometricPressure) select GVAR(currentTarget));
|
|
|
|
_relativeHumidity = (GVAR(relativeHumidity) select GVAR(currentTarget));
|
|
|
|
if (GVAR(currentUnit) == 1) then
|
2015-04-06 13:51:59 +00:00
|
|
|
{
|
2015-04-07 20:44:26 +00:00
|
|
|
_temperature = (_temperature - 32) / 1.8;
|
|
|
|
_barometricPressure = _barometricPressure * 33.8638866667;
|
2015-04-06 13:51:59 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
private ["_windSpeed", "_windDirection", "_inclinationAngle", "_targetSpeed", "_targetRange"];
|
2015-04-08 09:05:28 +00:00
|
|
|
_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
|
2015-04-06 13:51:59 +00:00
|
|
|
{
|
2015-04-07 20:44:26 +00:00
|
|
|
_targetRange = _targetRange / 1.0936133;
|
2015-04-06 13:51:59 +00:00
|
|
|
};
|
2015-04-08 09:05:28 +00:00
|
|
|
if (GVAR(currentUnit) == 1) then
|
2015-04-06 13:51:59 +00:00
|
|
|
{
|
2015-04-07 20:44:26 +00:00
|
|
|
_windSpeed = _windSpeed / 2.23693629;
|
|
|
|
_targetSpeed = _targetSpeed / 2.23693629;
|
2015-04-06 13:51:59 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
_result = [_scopeBaseAngle, _bulletMass, _boreHeight, _airFriction, _muzzleVelocity, _temperature, _barometricPressure, _relativeHumidity, 1000,
|
2015-04-07 20:44:26 +00:00
|
|
|
_windSpeed, _windDirection, _inclinationAngle, _targetSpeed, _targetRange, _bc, _dragModel, _atmosphereModel, false] call FUNC(calculate_solution);
|
2015-04-06 13:51:59 +00:00
|
|
|
|
2015-04-08 09:05:28 +00:00
|
|
|
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];
|
2015-04-06 13:51:59 +00:00
|
|
|
|
2015-04-06 18:46:33 +00:00
|
|
|
[] call FUNC(update_result);
|