Skip to content
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

Implement interaction groups test mode and cofficient combine rule #741

Open
wants to merge 6 commits into
base: master
Choose a base branch
from

Conversation

@Ughuuu
Copy link
Contributor Author

Ughuuu commented Sep 23, 2024

Ok, added this mainly to stop using my fork and to try to use rapier default in godot-rapier. This way I hope to no longer need to maintain that and use this repo as it is. (if this gets merged)

src/geometry/interaction_groups.rs Show resolved Hide resolved
CHANGELOG.md Outdated Show resolved Hide resolved
src/geometry/interaction_groups.rs Outdated Show resolved Hide resolved
src/geometry/interaction_groups.rs Outdated Show resolved Hide resolved
@Ughuuu Ughuuu force-pushed the Add-interaction-or,-increase-to-64-bit-and-add-more-rules-take-2 branch 3 times, most recently from b05dc45 to 1d0db7e Compare September 24, 2024 09:26
@Ughuuu Ughuuu requested a review from Vrixyz September 26, 2024 20:23
update

fix docs

cargo format fix

update feedback

update

Update CHANGELOG.md

ignore line for error docs fix

update
@Ughuuu Ughuuu force-pushed the Add-interaction-or,-increase-to-64-bit-and-add-more-rules-take-2 branch from bb2b387 to 0db7c72 Compare September 27, 2024 08:09
@Ughuuu
Copy link
Contributor Author

Ughuuu commented Sep 27, 2024

Fixed the doc test from CI.

@Vrixyz Vrixyz requested a review from sebcrozet September 27, 2024 13:59
@@ -27,8 +29,10 @@ impl CoefficientCombineRule {

match effective_rule {
0 => (coeff1 + coeff2) / 2.0,
1 => coeff1.min(coeff2),
1 => coeff1.min(coeff2).abs(),
Copy link
Contributor

@Vrixyz Vrixyz Nov 15, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should it be max(0.0) ?

Copy link
Contributor

@Vrixyz Vrixyz Nov 15, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(outside of this PR's scope) @sebcrozet why does this function takes u8 rather than CoefficientCombineRule ?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should it be max(0.0) ?

I think there is some use-case for this in godot but that would be worth clarifying by @Ughuuu.

(outside of this PR's scope) @sebcrozet why does this function takes u8 rather than CoefficientCombineRule ?

I don’t think there is a particular reason for this.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure about the godot use case, this is just the exact code they have right now, so for parity I have that. Their use case is that they also have negative coefficients, and use this with absorbent field.
https://github.com/godotengine/godot/blob/0eadbdb5d0709e4e557e52377fa075d3e2f0ad1f/scene/resources/physics_material.h#L57
Then they do abs here, so the negative one becomes positive:
https://github.com/godotengine/godot/blob/0eadbdb5d0709e4e557e52377fa075d3e2f0ad1f/modules/godot_physics_3d/godot_body_pair_3d.cpp#L259

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should i add a comment in code around that match explaining that the coefficient can be negative in some cases?

Copy link
Contributor

@Vrixyz Vrixyz Nov 29, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should i add a comment in code around that match explaining that the coefficient can be negative in some cases?

Yes ; you can add a link to this discussion so the reader knows where this comes from 👍

Godot documentation for rough and absorbent is also relevant: https://docs.godotengine.org/en/stable/classes/class_physicsmaterial.html#class-physicsmaterial

Copy link
Member

@sebcrozet sebcrozet left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for this PR. Just a couple of clarifications needed and it’s good to go.
(Sorry for the delay for reviewing this.)

src/geometry/interaction_groups.rs Outdated Show resolved Hide resolved
src/geometry/interaction_groups.rs Outdated Show resolved Hide resolved
@@ -27,8 +29,10 @@ impl CoefficientCombineRule {

match effective_rule {
0 => (coeff1 + coeff2) / 2.0,
1 => coeff1.min(coeff2),
1 => coeff1.min(coeff2).abs(),
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should it be max(0.0) ?

I think there is some use-case for this in godot but that would be worth clarifying by @Ughuuu.

(outside of this PR's scope) @sebcrozet why does this function takes u8 rather than CoefficientCombineRule ?

I don’t think there is a particular reason for this.

///
/// See [`InteractionTestMode`] for more info.
#[inline]
pub fn test(self, rhs: Self) -> bool {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I had to remove the const due to rhs not being const. Is it bad?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Feature: Add support for custom friction and bounce CombineRules
3 participants