-
Notifications
You must be signed in to change notification settings - Fork 4.8k
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
Add left-handed spherical and cylindrical billboards #109605
Add left-handed spherical and cylindrical billboards #109605
Conversation
Note regarding the
|
1 similar comment
Note regarding the
|
@@ -224,7 +224,7 @@ public Vector3 Translation | |||
public static Matrix4x4 Add(Matrix4x4 value1, Matrix4x4 value2) | |||
=> (value1.AsImpl() + value2.AsImpl()).AsM4x4(); | |||
|
|||
/// <summary>Creates a spherical billboard that rotates around a specified object position.</summary> | |||
/// <summary>Creates a right-handed spherical billboard matrix that rotates around a specified object position.</summary> |
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.
Once this is merged, please also follow up with a PR to update Matrix4x4.xml (dotnet/dotnet-api-docs). Once seeded from the original comments, we don't automatically flow changes over to the API docs repo.
src/libraries/System.Private.CoreLib/src/System/Numerics/Matrix4x4.Impl.cs
Show resolved
Hide resolved
@tannergooding or @michaelgsharp PTAL when you get a chance |
expected.M44 = +1.0f; | ||
|
||
Matrix4x4 actual = CreateLookAt(cameraPosition, cameraTarget, cameraUpVector); | ||
Assert.True(MathHelper.Equal(expected, actual), $"{CreateLookAtMethodName} did not return the expected value."); |
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.
nit: We have existing AssertExtensions.Equal(expected, actual, allowedVariance);
helper that will provide better diagnostic messages in the case of failure.
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.
I've updated this and used 1e-5
for the variance (matches MathHelper.Equals
). I think we can can use tighter errors in some cases where we have numbers with abs < 1 and having 6 sigfigs, but I'll just leave it for now.
src/libraries/System.Numerics.Vectors/tests/Matrix4x4LeftHandChangedBasisTests.cs
Outdated
Show resolved
Hide resolved
src/libraries/System.Numerics.Vectors/tests/Matrix4x4OrientationAwareTests.cs
Outdated
Show resolved
Hide resolved
src/libraries/System.Numerics.Vectors/tests/Matrix4x4RightHandTests.cs
Outdated
Show resolved
Hide resolved
src/libraries/System.Private.CoreLib/src/System/Numerics/Matrix4x4.Impl.cs
Show resolved
Hide resolved
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.
LGTM. Couple small nits that would be nice to cleanup, but don't feel the need to block merging on getting them resolved
* main: (22 commits) Clean up Stopwatch a bit (dotnet#111834) JIT: Fix embedded broadcast simd size (dotnet#111638) Revert potential UB due to aliasing + more WB removals (dotnet#111733) re-enable acceleration of Vector512<long>.op_Multiply (dotnet#111832) Handle OSSL 3.4 change to SAN:othername formatting JIT: Fix stack allocated arrays for NativeAOT (dotnet#111827) JIT: enhance RBO inference for similar compares to constants (dotnet#111766) JIT: Don't run optSetBlockWeights when we have PGO data (dotnet#111764) [Android] Make sure RuntimeFlavor=CoreCLR when clr subset is specified (dotnet#111821) Change empty subject test certificate to include a critical SAN. Fix reversed code offsets in GcInfo (dotnet#111792) Swap some libraries areas between leads (dotnet#111816) Add left-handed spherical and cylindrical billboards (dotnet#109605) JIT: revise `optRelopImpliesRelop` to always set `reverseSense` (dotnet#111803) Fix Zip64ExtraField handling (dotnet#111802) Add build support for Android+CoreCLR (dotnet#110471) arm64: Add bic(s) compact encoding (dotnet#111452) JIT: Ensure `BBF_PROF_WEIGHT` flag is set when we have PGO data (dotnet#111780) Add support for AVX10.2, Add AVX10.2 API surface and template tests (dotnet#111209) JIT: Preliminary for enabling inlining late devirted calls (dotnet#111782) ...
Adds the left-handed
CreateBillboard
andCreateConstrainedBillboard
variants. The code gen and perf for the new variants are very similar to the existing right-handed versions.Closes #93046