2018-09-17 19:19:29 +00:00
|
|
|
#include "script_component.hpp"
|
2015-04-11 21:40:46 +00:00
|
|
|
/*
|
|
|
|
* Author: Ruthberg
|
|
|
|
* Calculates the fireing solution and updates the result input/output fields
|
|
|
|
*
|
|
|
|
* Arguments:
|
2017-06-08 13:31:51 +00:00
|
|
|
* None
|
2015-04-11 21:40:46 +00:00
|
|
|
*
|
|
|
|
* Return Value:
|
2017-06-08 13:31:51 +00:00
|
|
|
* None
|
2015-04-11 21:40:46 +00:00
|
|
|
*
|
|
|
|
* Example:
|
2016-07-20 04:15:18 +00:00
|
|
|
* call ace_atragmx_fnc_calculate_target_solution
|
2015-04-11 21:40:46 +00:00
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
2015-04-06 13:51:59 +00:00
|
|
|
|
2015-04-06 18:46:33 +00:00
|
|
|
[] call FUNC(parse_input);
|
2015-04-06 13:51:59 +00:00
|
|
|
|
2017-10-10 14:39:59 +00:00
|
|
|
private _scopeBaseAngle = (GVAR(workingMemory) select 3);
|
2015-04-06 13:51:59 +00:00
|
|
|
|
2017-10-10 14:39:59 +00:00
|
|
|
private _bulletMass = GVAR(workingMemory) select 12;
|
|
|
|
private _bulletDiameter = GVAR(workingMemory) select 13;
|
|
|
|
private _boreHeight = GVAR(workingMemory) select 5;
|
|
|
|
private _airFriction = GVAR(workingMemory) select 4;
|
|
|
|
private _barrelTwist = GVAR(workingMemory) select 14;
|
|
|
|
private _muzzleVelocity = GVAR(workingMemory) select 1;
|
|
|
|
private _bc = GVAR(workingMemory) select 15;
|
|
|
|
private _dragModel = GVAR(workingMemory) select 16;
|
|
|
|
private _atmosphereModel = GVAR(workingMemory) select 17;
|
2015-04-06 13:51:59 +00:00
|
|
|
|
2017-10-10 14:39:59 +00:00
|
|
|
private _twistDirection = 0;
|
2015-04-17 22:11:53 +00:00
|
|
|
if (_barrelTwist > 0) then {
|
|
|
|
_twistDirection = 1;
|
|
|
|
} else {
|
|
|
|
if (_barrelTwist < 0) then {
|
|
|
|
_twistDirection = -1;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
_barrelTwist = abs(_barrelTwist);
|
|
|
|
|
2017-10-10 14:39:59 +00:00
|
|
|
private _altitude = GVAR(altitude);
|
|
|
|
private _temperature = GVAR(temperature);
|
|
|
|
private _barometricPressure = GVAR(barometricPressure);
|
|
|
|
private _relativeHumidity = GVAR(relativeHumidity);
|
2015-04-17 22:11:53 +00:00
|
|
|
if (!GVAR(atmosphereModeTBH)) then {
|
2015-05-29 09:18:40 +00:00
|
|
|
_barometricPressure = 1013.25 * (1 - (0.0065 * _altitude) / (273.15 + _temperature + 0.0065 * _altitude)) ^ 5.255754495;
|
2017-09-08 16:18:17 +00:00
|
|
|
_relativeHumidity = 0.5;
|
2015-04-06 13:51:59 +00:00
|
|
|
};
|
|
|
|
|
2017-10-10 14:39:59 +00:00
|
|
|
private _bulletLength = 50 * _bulletMass / ((_bulletDiameter/2)^2);
|
|
|
|
private _stabilityFactor = 1.5;
|
2015-04-25 11:34:47 +00:00
|
|
|
if (missionNamespace getVariable [QEGVAR(advanced_ballistics,enabled), false]) then {
|
2015-04-17 22:11:53 +00:00
|
|
|
if (_bulletDiameter > 0 && _bulletLength > 0 && _bulletMass > 0 && _barrelTwist > 0) then {
|
2015-05-08 11:56:38 +00:00
|
|
|
_stabilityFactor = [_bulletDiameter, _bulletLength, _bulletMass, _barrelTwist * 10, _muzzleVelocity, _temperature, _barometricPressure] call EFUNC(advanced_ballistics,calculateStabilityFactor);
|
2015-04-17 22:11:53 +00:00
|
|
|
};
|
2015-04-06 13:51:59 +00:00
|
|
|
};
|
2015-04-17 22:11:53 +00:00
|
|
|
|
2017-10-10 14:39:59 +00:00
|
|
|
private _latitude = GVAR(latitude) select GVAR(currentTarget);
|
|
|
|
private _directionOfFire = GVAR(directionOfFire) select GVAR(currentTarget);
|
|
|
|
private _windSpeed1 = GVAR(windSpeed1) select GVAR(currentTarget);
|
|
|
|
private _windSpeed2 = GVAR(windSpeed2) select GVAR(currentTarget);
|
|
|
|
private _windDirection = GVAR(windDirection) select GVAR(currentTarget);
|
|
|
|
private _inclinationAngle = GVAR(inclinationAngle) select GVAR(currentTarget);
|
|
|
|
private _targetSpeed = GVAR(targetSpeed) select GVAR(currentTarget);
|
|
|
|
private _targetRange = GVAR(targetRange) select GVAR(currentTarget);
|
2015-04-06 13:51:59 +00:00
|
|
|
|
2016-12-01 09:23:03 +00:00
|
|
|
GVAR(targetSolutionInput) = [_scopeBaseAngle, _bulletMass, _boreHeight, _airFriction, _muzzleVelocity, _temperature, _barometricPressure, _relativeHumidity, round(_muzzleVelocity),
|
2016-11-02 12:56:59 +00:00
|
|
|
[_windSpeed1, _windSpeed2], _windDirection, _inclinationAngle, _targetSpeed, _targetRange, _bc, _dragModel, _atmosphereModel, false, _stabilityFactor, _twistDirection, _latitude, _directionOfFire];
|
|
|
|
|
|
|
|
private _result = GVAR(targetSolutionInput) 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];
|
2015-04-18 13:08:54 +00:00
|
|
|
GVAR(windage1Output) set [GVAR(currentTarget), (_result select 1) select 0];
|
|
|
|
GVAR(windage2Output) set [GVAR(currentTarget), (_result select 1) select 1];
|
2015-04-08 09:05:28 +00:00
|
|
|
GVAR(leadOutput) set [GVAR(currentTarget), _result select 2];
|
|
|
|
GVAR(tofOutput) set [GVAR(currentTarget), _result select 3];
|
|
|
|
GVAR(velocityOutput) set [GVAR(currentTarget), _result select 4];
|
2016-11-02 12:56:59 +00:00
|
|
|
GVAR(verticalCoriolisOutput) set [GVAR(currentTarget), _result select 6];
|
|
|
|
GVAR(horizontalCoriolisOutput) set [GVAR(currentTarget), _result select 7];
|
|
|
|
GVAR(spinDriftOutput) set [GVAR(currentTarget), _result select 8];
|
2015-04-06 13:51:59 +00:00
|
|
|
|
2015-04-06 18:46:33 +00:00
|
|
|
[] call FUNC(update_result);
|