OpenXcom Forum

OpenXcom => Troubleshooting => Topic started by: Coincident on November 11, 2015, 08:03:09 pm

Title: Possible bug in projectile collision detection
Post by: Coincident on November 11, 2015, 08:03:09 pm
I think I might have found a bug.
I've read about the bug-tracker, but I'm new around here and I'm not sure if this behaviour is intended (???) or has been reported before (couldn't find anything after searching).
Can someone confirm that this is indeed a bug so I can create an issue on the bug-tracker?


I got save-game where you can reproduce the bug twice in a row (check attachment).

How to reproduce the bug:

 1) Go to options and reduce the bullet speed to the minimum
 2) Still in the options: make sure you save-scumming turned off to use the same random seed as the save-game
 3) Load the save-game
 4) The selected soldier has a rifle.
 5) There is a Snakeman at the top-left side of the screen.
 6) Choose snap-shot, target the Snakeman, and fire.
 7) Repeat step 6: take a second snap-shot.

Both shots will very clearly go through the belly of the snakeman, and hit the ground behind him, making no damage.
It only happens sometimes, and in different maps / weapons / aliens, I'm not sure what are the exact circumstances that cause this.
I think it might have to do with shooting next to that side of the wall. It also happens when shooting next to sides of UFO hulls, and also happens to the aliens when shooting at my soldiers, next to a side wall.
Anyway, it is simultaneously frustrating and strange...  ???



PS - I'm using the latest nightly build. No mods are needed to load the game and reproduce the bug.
PS2 - This happens both with or without the UFO Extended Accuracy.
Title: Re: Possible bug in projectile collision detection
Post by: Coincident on November 14, 2015, 02:21:10 pm
I've opened a bug issue with this, so it doesn't get forgotten.

https://openxcom.org/bugs/openxcom/issues/1116
Title: Re: Possible bug in projectile collision detection
Post by: DeltaEpsilon on January 02, 2016, 02:00:17 am
You are correct.
A bullet really goes right through snakemen:
(https://i.imgur.com/O0d8Iej.png)

What's even more interesting is that it's definitely possible to hit that snakemen using autoshot but bullets seem to hit his back.
Title: Re: Possible bug in projectile collision detection
Post by: Countdown on January 24, 2016, 05:58:43 am
This has happened to me a few times as well in different places. Next time I'll save it. I just thought it was a "graphics" issue where it looked like it was hitting the alien, but not really hitting him. When it happened to me, it did very much look like it was going straight through the belly like in the photo above, except it was a Muton for me.
Title: Re: Possible bug in projectile collision detection
Post by: Yankes on January 24, 2016, 01:32:25 pm
You are correct.
A bullet really goes right through snakemen:
(https://i.imgur.com/O0d8Iej.png)

What's even more interesting is that it's definitely possible to hit that snakemen using autoshot but bullets seem to hit his back.
where is shadow? This is 2d pic, it could fly at top of closer tile to screen. If it directly fly to snakeman then shadow of bullet should be cast under it.
Title: Re: Possible bug in projectile collision detection
Post by: Coincident on January 24, 2016, 01:50:21 pm
The shadow is under the Snakeman.

I went back to the save-game and made 2 more screenshots of the 2 snapshots that have this collision problem:

(https://i.imgur.com/P47dBZu.png)

(https://i.imgur.com/sTccrk5.png)

In both shots you can see the shadow from the "head" of the bullet appearing behing the Snakeman.
Title: Re: Possible bug in projectile collision detection
Post by: Yankes on January 24, 2016, 02:35:18 pm
Using voxel dump I can say that you miss by 1 voxel (depending where I put start and end line result will be different).
Title: Re: Possible bug in projectile collision detection
Post by: 7Saturn on January 24, 2016, 02:41:36 pm
Wait, wait, wait! Where did I see something, before? No, no, we don't have a problem with the targeting algorithm, Warboy probably won't see any need to change anything on that. (End of sarcasm.)
Title: Re: Possible bug in projectile collision detection
Post by: Coincident on January 24, 2016, 06:14:12 pm
If it depends on where you choose to put the start and end line, how can you say for sure that I miss by 1 voxel?
Even if that were true for the first shot, which enters the snakeman closer to its right side:
(https://i.imgur.com/P47dBZu.png)

...the second shot is several voxels closer to the center of the snakemen:
(https://i.imgur.com/sTccrk5.png)

I don't know if this has been discussed before, or if there's a problem in the targeting algorithm.

The way I see it, there's either a problem:
1 - Detecting projectile collisions (my initial guess)
2 - Drawing the trajectory of projectiles (those shots did miss but were drawn as a hit)
3 - With the aliens' voxel hit-boxes (is there such a thing?)
4 - Drawing aliens (snakeman too fat? or any alien for that matter; this bug happens with all aliens and humans too)

I believe that 4 makes no sense because the snakemen graphics are identical to vanilla XCom:EU, where I've never seen this bug happen...
So it's either 1, 2, or 3.
Title: Re: Possible bug in projectile collision detection
Post by: 7Saturn on January 24, 2016, 06:31:18 pm
Problem three would be my guess. It's enough, to miss by one voxel. And this specific behavior makes it possible, that in certain situations, where the always present tiny deviation from a perfect shot (even with accuracy 250) sees to it, that you will almost always miss. And this happens in exactly that type of very narrow targeting field, where hits are possible, at all. This shooting almost through a corner, be it a horizontal or vertical one. And this has been reported numerous times, but always was ignored or talked into »I don't care any more. Let's leave it at that.«
Title: Re: Possible bug in projectile collision detection
Post by: R1dO on January 24, 2016, 06:36:02 pm
Your pictures show that you're using quite an advanced scaler. So i wouldn't rule out number 4 just yet.
(if you want, try recreating those shots with scaler ``disabled`` or ``*raw``)
Title: Re: Possible bug in projectile collision detection
Post by: Coincident on January 24, 2016, 06:47:54 pm
I was using the sabr-xcomified scaler for higher-quality graphics.
The scalers should only make the edges smoother (like anti-aliasing), not change the apparent size of units.

Anyway, to leave no doubts open, I took the screenshots again without any scaler:

Snapshot 1:
(https://i.imgur.com/jiTGNL7.png)

Snapshot 2:
(https://i.imgur.com/l7c8M22.png)
Title: Re: Possible bug in projectile collision detection
Post by: Yankes on January 24, 2016, 10:56:14 pm
From perspective of bullet alien is small cylinder that occupy around 1/4 of tile. Snakeman graphic and order of drawing is interrelate in that case.
Look on screen I post. black line is one possible bullet trajectory. It touch real body of snakeman (purple circle). But if you put graphic position then you will see that bullet trajectory hit it (brown line).

This is case where graphic is not aligned with game physic engine. You can't fix it because one use 2d and second 3d.
Title: Re: Possible bug in projectile collision detection
Post by: 7Saturn on January 24, 2016, 10:57:46 pm
The problem with this is (once again): You are pretty much unable to hit the target, at all. Why does the engine allow to aim there, without forcing it to?
Title: Re: Possible bug in projectile collision detection
Post by: Coincident on January 24, 2016, 11:13:19 pm
EditorRUS has already said this before actually. 2nd post on this thread.
What's even more interesting is that it's definitely possible to hit that snakemen using autoshot but bullets seem to hit his back.

I'm sorry, but you guys are mistaken.
There IS a line of fire, and it IS possible to actually hit the Snakeman from that position.

Try it yourselves: load the game, and take 6 snapshots. The 6th snapshot will hit.

You need the following ruleset to test it:
items:
  - type: STR_RIFLE
    tuSnap: 1


You can't fix it
The only things you cannot fix are those you do not want to fix.
Title: Re: Possible bug in projectile collision detection
Post by: Meridian on January 24, 2016, 11:17:43 pm
The only things you cannot fix are those you do not want to fix.

You should also only fix things that need fixing.
Title: Re: Possible bug in projectile collision detection
Post by: Coincident on January 24, 2016, 11:22:08 pm
You should also only fix things that need fixing.
Also true.

Is that just a general observation, or are you implying that it applies to this case?
If so, could you please explain why?
Title: Re: Possible bug in projectile collision detection
Post by: Meridian on January 24, 2016, 11:23:16 pm
Just a general observation.
Title: Re: Possible bug in projectile collision detection
Post by: 7Saturn on January 24, 2016, 11:34:19 pm
Nice of you, to point that out.
Title: Re: Possible bug in projectile collision detection
Post by: Yankes on January 25, 2016, 12:59:40 am
The only things you cannot fix are those you do not want to fix.
How do you want map 2d world to 3d world? One way I see is simply drop all current graphic and use only voxel display. Then you will have perfect match between display and physic. Then you would see that your shoot never hit target only pass him very close by. Of course you have line of fire to target, but most of it is hidden behind wall (from eye perspective its invisible, only gun "see" him).
Title: Re: Possible bug in projectile collision detection
Post by: yrizoud on January 25, 2016, 01:49:57 am
I don't know if it's clear, but this misunderstanding is because the system that shows the result of a shot makes a visual approximation : If you hit a unit, the shot appears to go straight to its center. You've all certainly seen a shot pass through solid things in the way (windows, low obstacles, nearby units...)... This is because this part is for visual feedback only. If the voxel-based calculation says that the shot went from A to B, there was a way.

If somebody can determine a more precise rendering of a voxel/unit hit, I'd be curious to test it, (seriously, I'd be interested). But I'm pretty sure it will introduce new problems that the original UFO and openxcom don't have :
- You will see no difference between shots that hit the foot of an alien (hit) and the ground near it (miss)
- Hits in the back of the screen (usually shots going from top to bottom of screen) will not visible, as they will be drawn behind the character sprites or walls.
Title: Re: Possible bug in projectile collision detection
Post by: Coincident on January 25, 2016, 01:58:11 am
How do you want map 2d world to 3d world?
I did not mean that would need / want to map a 2D world into a 3D world.
I meant that no problem is "impossible" to fix, there are always multiple ways to solve things - some more complicated than others... it's just a matter of "looking outside the box", and finding a different - easier way to fix things. (Unless of course if you can't bother to look.) And sometimes it's just not worth to fix things at all, because some fixes can cause more trouble than improvement, as Meridian was trying to point out...

Anyway, don't get me wrong. All I want is to help make OpenXCom a better game for everyone.
Obviously I don't decide if something should or not be "fixed". For now, all that I want is identify a problem, and understand what's going on. After that, if there's something that can be fixed/changed to improve the game, all the better. If not, I would only like to understand why.

The problem that I've identified is:
 - Occasionally, bullets appear to go inside the aliens but do not hit, which can be frustrating for the player and cause detriment to the overall game-play experience.



Yankes: I have to confess I've had some trouble understanding what you wrote previously, so I went back and read things a few more times. Please correct me if I'm wrong, but to sum things up:

In the 3D voxel world, all units are represented as a fixed-radius cylinder. This cylinder is used for collision detection, correct?
I presume this was made so, for simplification purposes, it would be too much work to support customized voxel hit-boxes for each alien, correct?

This means that all aliens are cylinders, regardless of how they look like to the player.
So I could go and make a custom Super-Fat-Snakeman sprite that is 2 times larger than normal - the cylinder would remain the same size, correct?
Title: Re: Possible bug in projectile collision detection
Post by: Yankes on January 25, 2016, 07:46:46 pm
Yankes: I have to confess I've had some trouble understanding what you wrote previously, so I went back and read things a few more times. Please correct me if I'm wrong, but to sum things up:

In the 3D voxel world, all units are represented as a fixed-radius cylinder. This cylinder is used for collision detection, correct?
I presume this was made so, for simplification purposes, it would be too much work to support customized voxel hit-boxes for each alien, correct?

This means that all aliens are cylinders, regardless of how they look like to the player.
So I could go and make a custom Super-Fat-Snakeman sprite that is 2 times larger than normal - the cylinder would remain the same size, correct?

Yes, No, Yes, Yes. If you want change "fat" of unit you should look for `loftempsSet:`in armor. PirazteZ using it to made untargetable unit.
Title: Re: Possible bug in projectile collision detection
Post by: Arthanor on January 25, 2016, 07:51:21 pm
ninja'd by Yankes in a rather succinct way, so here goes any ways:

All hits and visibility calculations are made in 3D space using loftemps, which define what 3D volume is associated with a unit. These have nothing to do with the graphics displayed to the player, but you can see them using the 1st person screenshot like Yankes displayed.

What you see in game is a bunch of stacked 2D images, which approximates what happens in 3D. In this case, in the 3D world the shot missed the cylinder so kept going. In the 2D world, the 2D rendition of the shot went through the 2D rendition of the snakeman and kept going, because the 3D world said that the shot had to keep going. This happens because the 2D snakeman is wider than its 3D cylinder, so the shot looks like it's going through it instead of going next to it.

This can be solved by:
1 - Fixing the snakemen sprite to be skinnier so it matches its cylinder better
2 - Making the snakemen cylinder larger so it matches its sprite better
3 - Designing an all new 3D volume for snakemen that matches the sprite even better
4 - Understanding that the 2D representation is just a graphical approximation to the 3D game engine and rolling with it

Obviously, option 4 needs much less work and in the spirit of sticking to vanilla, will likely be the one for openxcom. Nothing prevents you from making a mod to implement options 1-2-3 though.
Title: Re: Possible bug in projectile collision detection
Post by: Coincident on January 25, 2016, 09:28:52 pm
I see. I understand the situation now.

`loftempsSet:`in armor
https://www.ufopaedia.org/index.php?title=LOFTEMPS#Template_Tables
This is very interesting, exactly what I was looking for.
I checked the standard armors.rul and noticed that every unit uses template 3 (small cylinder), except Sectoids that use 2 (even smaller), and Silacoids that use 5 (large cylinder, although they have low height).

So this can be modded! Using template 4 (medium cylinder) or 5 for Mutons and Snakemen will make them large enough to make this situation not happen so often, and be less frustrating for the player with these near-misses.
(To be balanced, X-Com Soldiers should be 4 too, since I've seen this bug happen to the aliens shooting at my soldiers. And probably Chrysalids and Zombies, I will try changing a few and test some more)

It's a pity that it won't be changed directly in OpenXcom, but if the argument is sticking faithfully to vanilla, so be it...



Thank you Arthanor and Yankes for the info.  :)
Title: Re: Possible bug in projectile collision detection
Post by: Yankes on January 25, 2016, 10:06:27 pm
I see. I understand the situation now.
https://www.ufopaedia.org/index.php?title=LOFTEMPS#Template_Tables
This is very interesting, exactly what I was looking for.
I checked the standard armors.rul and noticed that every unit uses template 3 (small cylinder), except Sectoids that use 2 (even smaller), and Silacoids that use 5 (large cylinder, although they have low height).

So this can be modded! Using template 4 (medium cylinder) or 5 for Mutons and Snakemen will make them large enough to make this situation not happen so often, and be less frustrating for the player with these near-misses.
(To be balanced, X-Com Soldiers should be 4 too, since I've seen this bug happen to the aliens shooting at my soldiers. And probably Chrysalids and Zombies, I will try changing a few and test some more)

It's a pity that it won't be changed directly in OpenXcom, but if the argument is sticking faithfully to vanilla, so be it...



Thank you Arthanor and Yankes for the info.  :)
This is simply "Call for Modders" :) If you think that something is not right with ruleset you are encourage to change it (and publish on openxcom.org).
I personally think this behavior is not problem but maybe other people think like you?
Title: Re: Possible bug in projectile collision detection
Post by: Solarius Scorch on January 25, 2016, 10:11:43 pm
Yeah, it happens, but in my opinion not frequently enough to make it a problem. It can be tweaked, but I've never felt the need to.

A much more serious problem is that the game very often allows you to shoot when hitting is impossible, due to the difference between position of eyes and weapon. But this cannot be fixed with rulesets.
Title: Re: Possible bug in projectile collision detection
Post by: Coincident on January 25, 2016, 10:27:07 pm
A much more serious problem is that the game very often allows you to shoot when hitting is impossible, due to the difference between position of eyes and weapon. But this cannot be fixed with rulesets.
Yes, I've also come across that, indeed, serious problem. It is related to, but different from the problem being discussed here.

I've also reported that different bug before, with a savegame:
https://openxcom.org/bugs/openxcom/issues/1122
But even for that bug, I'm sure that a easy feasible solution will present itself, eventually.
Title: Re: Possible bug in projectile collision detection
Post by: Cristao on January 27, 2016, 03:16:56 pm
^Happens a lot. Tempted to use the arcing mechanics I see in Dioxine's mod but that is asking for more trouble.