Add "HighPrecision" collision fidelity to accommodate important gameplay assets

As a Roblox developer, current collision fidelities are not adequate enough, and they block creativity. Which is why I propose a “HighPrecision” collision fidelity.

If this issue is addressed, we will no longer have to strategically split meshes, use invisible parts as fillers, and other tricks to get barely appropriate collisions on complex MeshParts.

Use cases:

  • Complex Roads
  • Custom Terrain
  • Important gameplay assets that need extremely accurate collisions
  • Many more things I can’t think off of the top of my head, I am always running into collision issues
  • Matching competitor game engines(UE4), as they have this feature.

Even if this is to use a lot of CPU, we still need the option available for outlier cases. From what I can tell, Terrain already has accurate collisions, so we should be able to also get this with meshes.

Here is another poster who ran into the same issue:

PreciseConvexDecomposition failing with my low-poly roads



Here is an example with my very jagged terrain, which all collision fidelities fail to accommodate for.



This is using PreciseConvexDecomposition. Particularly, most issues arise in areas with dips. (Do note that this is a sea bed so it’s meant to be extremely large, jagged, and spread out over a large area)

69 Likes

This would be so beautiful. The biggest use case for me would be the ability to make large low poly terrain using modeling programs without having to worry about wonky collision.

4 Likes

Based on my understanding which albeit isn’t perfect, I believe collision detection cannot actually represent a mesh. Collision meshes use special data and that has to be solved for from the visual data. It’s hard to go from triangles > collision data from what I understand because the collision data has to be solid and isn’t made up of triangles, there are probably cases where it is impossible to represent something perfectly because it would take infinite data, or, it might take millions of tiny cells in the collision geometry or something that could kill performance and eat up a lot of memory because of a little tiny detail on something.

It’s probably a similar reason why CSG always seems to do a horrible job with little tiny details, there are lots of cases it can’t perfectly represent a shape because it has to be solved for and sometimes solving for that shape means millions or billions of data points that mean nothing in the big picture.

I think that a feature like this might actually be more complicated than it seems at first glance but I agree that it would be great to have visually accurate collisions.

9 Likes

Yup!

To be more specific, collision works with a very specific kind of mesh, known as convex meshes. These meshes have surfaces that always curve outward, with no holes or tubes or indents of any kind. If you want to build up a collision mesh for a physics simulation, it almost always has to be done using convex meshes only, because the underlying math depends on some useful properties of convex meshes to keep everything performant.

The problem with using visual geometry as collision geometry is that your geometry is most likely not convex - you can have meshes with all the holes and dips you want. To circumvent this problem, Roblox uses a convex mesh decomposition algorithm to turn your visual, non-convex mesh into one or more convex meshes. At the time of writing, there’s four such algorithms:

  • Box - simply uses a single cuboid as your collision mesh, satisfying the convex requirement and performing well, but not a great approximation of the visual geometry

  • Hull - uses the convex hull of your visual mesh as your collision mesh, which is a better approximation, but doesn’t support dips or holes because only one convex mesh is used

  • Default - a more complex decomposition algorithm which attempts to approximate your visual mesh using multiple convex collision meshes - it’s not a precise match but it may be enough for most cases

  • PreciseConvexDecomposition - a complex algorithm like Default, but which attempts to match the visual geometry as close as possible with multiple convex collision meshes.

For the reasons I stated above, it’s impossible to exactly match the visual geometry in all cases, because it’s simply of the wrong format. The four algorithms above are just different trade-offs to reach an appropriate result.

A more actionable feature request in this case might be to improve the accuracy of PreciseConvexDecomposition rather than to supersede it. After all, it is supposed to be the solution to exactly this kind of problem where a tight fit is needed between visual and collision geometry.

26 Likes

Roads were split more, still an issue that needs to be fixed. I’d appreciate if others could showcase similar things happening.



4 Likes

Speaking of which this would be great if you could bake any static objects. These would not move at all and would have better collision, lighting, and physics accuracy at the cost of being forced to be anchored permanently, which also applies to this feature request.

7 Likes

I doubt Roblox would want to allow anything to be baked. I once saw a Roblox employee saying that they didn’t want baked lighting because they want Roblox worlds to be “dynamic”. I do think that them adding baked static objects is more likely than baked lighting, though. So many games have terrain, roads, buildings, etc. that never move and would benefit from some physics improvements. However, I don’t think it would be added for a very long time, if ever, as they probably have other priorities.

Another example on why we need precise collisions:


Mesh


Default CollisionType


PreciseConvexDecomposition

As you can see, none of the collision settings let a player pass through the square hole.

4 Likes

From what I can tell, that mesh is a UV sphere with a face missing, right? Like this:

If that’s the case, then that mesh will never work as collision geometry. Here’s the two reasons why:

  1. The mesh is not a solid enclosed object anymore - back faces are being exposed to the outside of the mesh.

Of course, maybe that’s what you wanted, and you’d like Roblox to interpret this as just a hollow shape, like a kind of dome with an interior. Setting aside all the other problems that could end up creating, there’s one killer issue that means this mesh is physically impossible to simulate:

  1. It has zero thickness, meaning it has zero volume, meaning it has zero mass.

Have you ever tried to accelerate something with zero mass? It’s kinda problematic. In fact, it’s not really physically simulatable. That’s why you can’t use meshes with zero mass for a physics simulation.

For those reasons, what you’re getting with those algorithms is probably the best you could ask for from the Roblox engine. Consider using a different mesh - preferably, one that’s properly closed and which has non-zero thickness.

Blender actually has a modifier that can help with this in some cases - the Solidify modifier. Here’s what the mesh looks like with it applied - notice there’s no more red back faces, which means it’s properly closed off. It also now has some thickness, which can be configured to taste:

You should get much more preferable results from Roblox with these meshes - I suspect this may also help people trying to make triangle terrain in Blender who may accidentally be creating zero-thickness meshes in a similar fashion :slightly_smiling_face:

18 Likes

I’m running into the exact same issue. When building a driving game building realistic roads with parts can be very part consuming and unoptimized, not to mention they often leave little bumps all over the road.

The logical thing to do for a driving game developer would be to use optimized and smooth mesh part roads. But we run into one massive issue and that is ROBLOX collisions. Even when using PreciseConvexDecomposistion the collisions still fail and cause cars to float on top of the road.

PrecisionConvexDecomposistion Collisions failing with my low-poly race track




7 Likes

Bump. This isn’t a case where i already have a good solution, this is a case where this feature is the best solution.

I resorted to mesh terrain for a large map (7000x7000 studs) after noting the lackluster performance of Roblox’s terrain system in this large setting. Visually, everything is perfect, but collisions are abominable even if each chunk is 500x500 studs horizontally.

Smaller chunks equals more meshes to upload, which is more tedious for me and expensive for Roblox, so i don’t think that subdividing any more is an option. Switching to Roblox terrain personally doesn’t look like an option either, so i either get a precise collision fidelity from Roblox, or i make a custom collision generator that makes triangle collision parts from mesh data on any chunks that have physics activity near them.

This sounds more like a bug? PreciseConvexDecomposition should be Precise, if it is generating extremely bad collision geometry, then it’s a problem with the algorithm, and a bug can be reported to help the engineers identify the problem and improve the pre-existing system, helping everyone in the process, instead of trying to implement a whole new one. This is the main problem I have with this thread. I don’t believe these problems need to be inherent to PCD, I think they’re just bugs that can be fixed.

I find it ironic how “PreciseCollisionComposition” is actually not “precise”.

I would assume that someone trying to contribute to a Feature Request thread, has a reason to do so, instead of just chipping in because they can. But not to worry.

I only responded because I had a similar issue a few weeks ago and I found it ironic.

To clarify a slight bit on this, it should be precise enough. Even according to the documentation, the collision geometry won’t always be 100% accurate since, when justified, it may compromise on accuracy (presumably for performance reasons, although I may be wrong in that). Obviously, massively incorrect collision geometry isn’t acceptable anyway, but I just thought I’d flag this slight wording change since small inaccuracies are to be expected even when using this fidelity. Hence, smaller inaccuracies are likely actually intended with the algorithm and that may lead to reason for an even more precise mode for those niche cases. I’m not personally in that boat right now but I thought I’d bring it up regardless.

Collison model uses a convex-hull decomposition of the visual mesh which is computed by a variation of an algorithm called HACD. This option is the most accurate representation of collision geometry for complex objects with built-in tolerances to reduce the total number of convex-hulls by compromising on accuracy when justified.

Source

1 Like

Yes, I am aware. I personally think that, as an algorithm, PCD is about as Precise as you’ll be able to get, unless you implement some inventive method for collision detection that doesn’t rely on convex geometry. Glaring problems shouldn’t be a limitation of the algorithm itself, though.

How do you know that wasn’t a problem with the mesh itself (such as non-manifold geometry, which someone shared in this thread as an example of PCD being unusable)? If more people made bug reports about inaccuracies with PCD, and an engineer figures out it’s a problem with the mesh itself and documented why it occurred, people reading those threads would be made more aware of what to look out for when their collisions are inaccurate.

Or, if it IS a bug with PCD, then it could be fixed instead of people trying to get an entirely new and “better” collision mesh generation system implemented. Nobody at Roblox can know what this new system would even need to handle if nobody’s sharing their meshes, which I haven’t seen a single person in this thread do (if you or anyone else DO have a mesh with really bad collisions, then make a bug report, as I said previously).

at the very least they should allow raycasts to use the mesh’s geometry rather than its collision geometry for those who absolutely need accurate collisions, so people can implement their own collision physics if they really need to, like i do for mesh terrain where using roblox terrain isn’t viable for me.
accurate raycasts are already possible with editable meshes using :RaycastLocal(), but to use it you need to sacrifice your ID + there’s a limit to how many editable meshes you can create

1 Like