-
Notifications
You must be signed in to change notification settings - Fork 514
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Simplification could reduce flipped triangles via collinearity check #800
Comments
Thanks, this is interesting. Would you be able to attach the file above as .obj (before simplification)? |
Sure. this zip file contains a .obj file. Thanks for the quick response! |
Well, this is more complicated than I thought. I had to add another check to skip the linearity check for bad triangles due to numerical issues. The linearity check suffers from numerical precision issue for skinny triangles such as in a finely divided cylinder mesh.
|
Yeah there's a set of complications here; in addition to numerical issues, in some cases this seems to overly constrain the simplification process without improving the visual output. The check could be implemented as a separate option, but I'd need to look into various issues around precision. It's also not fully clear which edges to compare - AD vs BD or AB vs AD? And if the source triangle is already skinny it might be worth allowing collapses to extend these; so some questions to work through. |
I find that adding this criterion to hasTriangleFlip significantly reduces the number of flipped or self-intersecting triangles in flat or smooth regions. The idea is taken from another mesh simplification repository https://github.com/sp4cerat/Fast-Quadric-Mesh-Simplification. See src.cmd/Simplify.h function bool flipped(...).
In a triangle ABC, where C is going to be replaced by point D, this check looks for cases where AD and BD are in almost the same direction.
The following is code I added to my local clone of meshoptimizer:
Here is a simple comparison for a mesh output by marching cubes.
data:image/s3,"s3://crabby-images/80def/80defd0719c137b34ef67ac90253e48f031d162b" alt="oldTrack"
data:image/s3,"s3://crabby-images/4ea01/4ea01c33fa9c31ddfc4d96505433f9b24b26c8a9" alt="newTrack"
The text was updated successfully, but these errors were encountered: