-
-
Notifications
You must be signed in to change notification settings - Fork 108
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
Prevent crash in epa2 and epa3 ::closest_points if all is_project #263
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good catch, thanks!
I think I realized why
If I change the body of
Do you think this could work? |
I went ahead and pushed this change. We can always revert the commit if it doesn't make sense. |
We now check whether at least one the proj_inside computations is true, and return None if not. Also rename some variables in epa2 to match the corresponding variables in epa3.
|
@sebcrozet Hello, I wonder if you could review my PR and merge it? I don't want to pressure you, but I've noticed that you recently merged #282 which only partially addresses the fallibility issue, while this one should fix the underlying issue. Also, unlike the recently merged PR, this one addresses the fallibility of epa2 as well. Would you please consider reviewing this? I've depended on these changes for months, and haven't noticed any problems P.S. I've tried to reach you on Discord as well, but perhaps you just haven't been there or haven't noticed |
This looks good, thank you! And sorry for the delay. |
EDIT: I implemented a fix for epa3 that should also make the test case work as expected
Alleviates/fixes these issues:
#253
#246
Related Discord thread:
https://discord.com/channels/507548572338880513/1274773766811160646
EPA::closest_point
crashes at linelet mut best_face_id = *self.heap.peek().unwrap();
becauseheap
is empty. This happens when we reach the second branch ofclosest_point
and all of theproj_inside
variables are false.The measure taken in this PR is to log the problem and return
None
. While the result might be incorrect, it avoids the panic.This is only a half-measure and someone who understands EPA and/or this implementation of it should write a proper fix.
The included unit test is programmed to fail because in reality there should be an intersection.