2016-11-02 12:56:59 +00:00
|
|
|
/*
|
|
|
|
* Author: Ruthberg
|
|
|
|
* Trues the muzzle velocity
|
|
|
|
*
|
|
|
|
* Arguments:
|
2017-06-08 13:31:51 +00:00
|
|
|
* None
|
2016-11-02 12:56:59 +00:00
|
|
|
*
|
|
|
|
* Return Value:
|
2017-06-08 13:31:51 +00:00
|
|
|
* None
|
2016-11-02 12:56:59 +00:00
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
* call ace_atragmx_fnc_true_muzzle_velocity
|
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
|
|
|
#include "script_component.hpp"
|
|
|
|
|
|
|
|
private _referenceDrop = GVAR(truingDropDropData) select 0;
|
|
|
|
private _actualDrop = GVAR(truingDropDropData) select 1;
|
|
|
|
|
|
|
|
if (Round(_actualDrop * 10) / 10 == Round(_referenceDrop * 10) / 10) exitWith {};
|
|
|
|
|
|
|
|
private _step = 10;
|
|
|
|
if (_actualDrop > _referenceDrop) then {
|
|
|
|
_step = -10;
|
|
|
|
};
|
|
|
|
|
|
|
|
private _solutionInput = +GVAR(targetSolutionInput);
|
2016-12-01 09:23:03 +00:00
|
|
|
_solutionInput set [ 8, 200];
|
2016-11-02 12:56:59 +00:00
|
|
|
_solutionInput set [13, GVAR(truingDropRangeData) select 0];
|
|
|
|
private _muzzleVelocity = _solutionInput select 4;
|
|
|
|
|
|
|
|
{
|
|
|
|
_step = _step * _x;
|
|
|
|
while { _actualDrop * _step < _referenceDrop * _step } do {
|
|
|
|
_muzzleVelocity = _muzzleVelocity + _step;
|
|
|
|
_solutionInput set [4, _muzzleVelocity];
|
|
|
|
private _result = _solutionInput call FUNC(calculate_solution);
|
|
|
|
_referenceDrop = (_result select 0);
|
|
|
|
};
|
|
|
|
} forEach [1, -0.1];
|
|
|
|
|
|
|
|
GVAR(truingDropMuzzleVelocity) = _muzzleVelocity;
|