Jump to content

Mariusz B

Show bullet position every millisecond

Recommended Posts

Hi :)

 

I want my script to report bullet position every milisecond including a moment of fire. However loop occurs every game frame.

player addEventHandler ["Fired", {
    _null = _this spawn {
        _missile = _this select 6;
			
        waitUntil {
            if (isNull _missile) exitWith {true};

             diag_log getPos _missile;
	     
        };    
    };
}];

   this is a player position :[3999.79,999.912,0.00143909]  and this is a first report of bullet  : [3999.97,1016.43,1.35643]  as you can see projectile flew 16 meters before first data, that means Im missing time before fire and next frame. The most importnant for me is a position of bullet in moment of fire. It would be great if script reported data every milisecond. What should I write ? Please help !

 

Thank you.

Share this post


Link to post
Share on other sites

I guess spawn makes that latency. Use diag_log before spawn once.

  • Thanks 1

Share this post


Link to post
Share on other sites
  On 2/11/2018 at 10:26 AM, POLPOX said:

I guess spawn makes that latency. Use diag_log before spawn once.

 

Yup that paritally works :D. I wrote

 

_missile = _this select 6;
 diag_log getPos _missile;

 

before spawn[] in result i am geting data of bullet in moment of shot. After that it still printing position every frame :(. How to overcome this?

Share this post


Link to post
Share on other sites

The bullet's position is updated only once per frame. You'd have to calculate the position between them manually. 

You could slow down the time to get 1/1000s resolution. But why do you need so accurate data?

  • Like 2

Share this post


Link to post
Share on other sites

Why would you need the bullets position for every millisecond? That's 60 positions every second with a 0.02s (20ms) sleep, or even 42227 positions for one second with a plain loop and no sleep in it.

That's quite an amount of data you're shoving into the .rpt...

Snippet with 42227 positions per second (at least on my rig):

GOM_debug = [];
player addEventHandler ["Fired",{

	_projectile = _this select 6;
	systemchat str _projectile;
	GOM_debug pushBack [diag_tickTime,getposatl _projectile];

	_track = [time,_projectile] spawn {
		params ["_time","_projectile"];

		while {time < (_time + 1) AND alive _projectile} do {
			GOM_debug pushBack [diag_tickTime,getposatl _projectile];
		};

		copyToClipboard str GOM_debug;
		_duration = time - _time;
		systemchat str format ["Collected %1 positions over %2 seconds!", count GOM_debug,_duration];
		playsound "click";
		true
	}
}];

With 1ms "sleep":


GOM_debug = [];
GOM_debug_lastTICK = 0;
player addEventHandler ["Fired",{

	_projectile = _this select 6;
	systemchat str _projectile;
	GOM_debug pushBack [diag_tickTime,getposatl _projectile];
	GOM_debug_lastTICK = diag_tickTime;

	_track = [time,_projectile] spawn {
		params ["_time","_projectile"];

		while {time < (_time + 1) AND alive _projectile} do {


			if (diag_tickTime >= GOM_debug_lastTICK + 0.001) then {
				GOM_debug_lastTICK = diag_tickTime;
			GOM_debug pushBack [diag_tickTime,getposatl _projectile];
		}
		};

		copyToClipboard str GOM_debug;
		_duration = time - _time;
		systemchat str format ["Collected %1 positions over %2 seconds!", count GOM_debug,_duration];
		playsound "click";
		true
	}
}];

Output:

  Reveal hidden contents

This will still only track every ~4ms or so.

Not sure if there's a more accurate way to get a measurement exactly every single ms.

 

Edit: Also what @Greenfist said, bullets only get updated every frame, can somewhat see that in the example output above.

 

Cheers

Share this post


Link to post
Share on other sites
  Quote
  On 2/11/2018 at 11:47 AM, Greenfist said:

The bullet's position is updated only once per frame. You'd have to calculate the position between them manually. 

You could slow down the time to get 1/1000s resolution. But why do you need so accurate data?

 

 I wrote app calulating firesolutions. however I'm getting diffrent results  in game. My algorithm used to work perfectly in ACE2 (in vanilla one doesnt use wind though ;) ). However it updates bullet data (position, velocity) every 1ms. Tell me please how often this data is updated in multiplayer (vanilla)? Maybe the problem lays in framework? Is this client side thing? Or server?

Share this post


Link to post
Share on other sites
  On 2/11/2018 at 12:34 PM, Mariusz B said:

 I wrote app calulating firesolutions. however I'm getting diffrent results  in game. My algorithm used to work perfectly in ACE2 (in vanilla one doesnt use wind though ;) ). However it updates bullet data (position, velocity) every 1ms. Tell me please how often this data is updated in multiplayer (vanilla)? Maybe the problem lays in framework? Is this client side thing? Or server?

Fire solutions for what exactly? Rifles?

Artillery basically needs a simple parabola formula and can hit up to 73km (max range with 810m/s muzzle velocity and 45° angle) at pinpoint precision.

Doing 1ms checks on anything isn't really recommended in MP.

 

Cheers

Share this post


Link to post
Share on other sites
  On 2/11/2018 at 12:34 PM, Mariusz B said:

 I wrote app calulating firesolutions. however I'm getting diffrent results  in game. My algorithm used to work perfectly in ACE2 (in vanilla one doesnt use wind though ;) ). However it updates bullet data (position, velocity) every 1ms. Tell me please how often this data is updated in multiplayer (vanilla)? Maybe the problem lays in framework? Is this client side thing? Or server?

 

Yep! good questions. I can't imagine all bullets synced on all PCs... but, if the ballistic calculation is done locally, how does it work for getting the exact same hits, deflections or else? For example, when you make an AI play an animation, there is no real sync between two PCs. when you shoot at it, what's happens on each PCs? I didn't find any clear explanation. If ballistic is well documented (fine video), did you find something about the network sync?

Share this post


Link to post
Share on other sites

Ive run few test and I came to conclusion (cant confirm 100% though). Bullet position is updated with every client frame. However position calculation is with 1ms accuracy. So every frame, algorithm is running number of itterations for missing timeticks. So for 60FPSit  is 17 timeticks and then bullet update. In result every client will get same trajectory no matter lag. But its only my guess based on data Ive gathered :D

 

  • Like 1

Share this post


Link to post
Share on other sites
  On 2/17/2018 at 10:55 AM, Mariusz B said:

Ive run few test and I came to conclusion (cant confirm 100% though). Bullet position is updated with every client frame. However position calculation is with 1ms accuracy. So every frame, algorithm is running number of itterations for missing timeticks. So for 60FPSit  is 17 timeticks and then bullet update. In result every client will get same trajectory no matter lag. But its only my guess based on data Ive gathered :D

 

Sounds about right and makes sense. Wish that the devs would show up and explain stuff like that from time to time, wouldn't hurt.

 

Cheers

Share this post


Link to post
Share on other sites

That's not the calculation for trajectory which makes me perplex. Same parameters will end with the same mathematical results everywhere. It's the fact that some players can have more than 200 ms for ping, some other only 20 ms. If your AIs is moving, how can you get the same hits/damage everywhere? Just with a simple delay due to (a variable!) ping?

I suggested firing on animated Ais (like a guy repairing a vehicle) because it's evident. I tested and I'm sure JIP will not have a synced sequence with others. You can have a ending sequence on server and a starting one locally. If you shoot dead the guy at head (from hosted for example), you kill it but the head can be elsewhere in client animation, even considering the ping delay....

 

read: can have more than 200 ms of ping...

Share this post


Link to post
Share on other sites
  On 2/17/2018 at 4:31 PM, pierremgi said:

That's not the calculation for trajectory which makes me perplex. Same parameters will end with the same mathematical results everywhere. It's the fact that some players can't have more than 200 ms for ping, some other only 20 ms. If your AIs is moving, how can you get the same hits/damage everywhere? Just with a simple delay due to (a variable!) ping?

I suggested firing on animated Ais (like a guy repairing a vehicle) because it's evident. I tested and I'm sure JIP will not have a synced sequence with others. You can have a ending sequence on server and a starting one locally. If you shoot dead the guy at head (from hosted for example), you kill it but the head can be elsewhere in client animation, even considering the ping delay....

I was only considering bullet path. You also raise importnant question. Game mechanics after syncing back has to decide which events to confirm.

Share this post


Link to post
Share on other sites
  On 2/11/2018 at 10:18 AM, Mariusz B said:

Hi :)

 

I want my script to report bullet position every milisecond including a moment of fire. However loop occurs every game frame.

Impossible. Just like you can't tap your finger on something every milliseconds. Your body is just not fast enough for that.

 

  On 2/11/2018 at 12:34 PM, Mariusz B said:

 I wrote app calulating firesolutions. however I'm getting diffrent results  in game. My algorithm used to work perfectly in ACE2 (in vanilla one doesnt use wind though ;) ). However it updates bullet data (position, velocity) every 1ms. Tell me please how often this data is updated in multiplayer (vanilla)? Maybe the problem lays in framework? Is this client side thing? Or server?

It definitely doesn't update every 1ms.

 

Can you explain exactly what you are trying to do? Calculate point of impact with vanilla Arma based on muzzle velocity?
Or ACE3 Advanced ballistics or what exactly.

Share this post


Link to post
Share on other sites
  On 2/19/2018 at 9:23 AM, Dedmen said:

It definitely doesn't update every 1ms.

 

As ppl said and my findings came to same conclusion.

 

  On 2/19/2018 at 9:23 AM, Dedmen said:

Can you explain exactly what you are trying to do? Calculate point of impact with vanilla Arma based on muzzle velocity?
Or ACE3 Advanced ballistics or what exactly.

Vanilla. And its working perfectly :D now when i found out how exactly its simulated. So no further assistance is needed :D

Share this post


Link to post
Share on other sites

Please sign in to comment

You will be able to leave a comment after signing in



Sign In Now

×