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 various other simple vector APIs from 93513 #103837

Merged
merged 44 commits into from
Jul 10, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
07e72ed
Update Vector<T> to implement ISimdVector<TSelf, T>
tannergooding Jun 20, 2024
383cc66
Expose various constants for Vector2/3/4
tannergooding Jun 19, 2024
845978c
Expose Exp, Log, and Log2 on the other vector types
tannergooding Jun 19, 2024
10ed01f
Expose CopySign on the vector types
tannergooding Jun 19, 2024
a450767
Expose DegreesToRadians and RadiansToDegrees on the vector types
tannergooding Jun 20, 2024
87e13a0
Expose Hypot on the vector types
tannergooding Jun 20, 2024
5bad72d
Expose Lerp on the vector types
tannergooding Jun 20, 2024
34879f6
Expose Truncate and Round on the vector types
tannergooding Jun 20, 2024
3e304c2
Cleanup some of the implementations to use helper functions where pos…
tannergooding Jun 21, 2024
43d4696
Expose Max, MaxMagnitude, MaxMagnitudeNumber, MaxNumber, Min, MinMagn…
tannergooding Jun 21, 2024
283301d
Expose Clamp on the various vector types
tannergooding Jun 19, 2024
b513e5c
Ensure mono handles the various zero and low-cost vector conversions
tannergooding Jun 21, 2024
0816d54
Apply formatting patch
tannergooding Jun 21, 2024
8e211ce
Ensure that TensorPrimitives uses the in-box vector operations on .NE…
tannergooding Jun 21, 2024
16e27d8
Fix some build failures
tannergooding Jun 21, 2024
753df42
Workaround a MonoJIT assertion
tannergooding Jun 22, 2024
574c15c
Ensure Hypot for double handles insignificant results
tannergooding Jun 22, 2024
d7bf16b
Merge remote-tracking branch 'dotnet/main' into fix-93513
tannergooding Jun 24, 2024
284ad12
Merge remote-tracking branch 'dotnet/main' into fix-93513
tannergooding Jun 27, 2024
79b225a
Remove part of the mono changes that were extracted to a separate PR
tannergooding Jun 27, 2024
50434a6
Apply suggestions from code review
tannergooding Jun 29, 2024
f1bf9b9
Merge remote-tracking branch 'dotnet/main' into fix-93513
tannergooding Jun 29, 2024
3f9bd35
Ensure tests are added for the new vector APIs
tannergooding Jun 29, 2024
dcffeb8
Fix the mono handling for IsNaN, IsNegative, and IsPositive
tannergooding Jun 29, 2024
6804456
Use the right op for WASM
tannergooding Jun 29, 2024
72d2dd6
Fix a round test to correctly expect -0
tannergooding Jun 29, 2024
aaa71b2
Fix some tests where the wrong parameter counts were being passed
tannergooding Jun 30, 2024
304324d
Ensure APIs are correctly handled for Vector<T>
tannergooding Jun 30, 2024
c722402
Fix the mono handling for OP_XCOMPARE_FP
tannergooding Jun 30, 2024
f5f7a31
Have Mono use the proper klass for IsPositive/IsNegative since we're …
tannergooding Jun 30, 2024
b34be17
Ensure Mono looks up the class namespace
tannergooding Jun 30, 2024
10b1513
Ensure mono inserts xcast where required and handles MultiplyAddEstimate
tannergooding Jul 1, 2024
bf3bc42
Add missing underscores to fix the mono build
tannergooding Jul 1, 2024
f114721
Add the if is_element_type_primitive check to MultiplyAddEstimate for…
tannergooding Jul 1, 2024
cbafcb5
Pass the right klass on Mono
tannergooding Jul 1, 2024
6ea941c
Ensure mono sets the metadata for add_ins
tannergooding Jul 1, 2024
5728b80
Ensure mono passes down the cast arg0
tannergooding Jul 1, 2024
a47ea2a
Fix the lerp for Mono to match the managed impl
tannergooding Jul 2, 2024
414b00a
Ensure mono lerp uses ins_amount for scaling y
tannergooding Jul 2, 2024
ea072a7
Merge branch 'main' into fix-93513
tannergooding Jul 3, 2024
3c3ef36
Use gtCloneExpr after the first fgMakeMultiUse if we need another copy
tannergooding Jul 4, 2024
a180caf
Merge branch 'main' into fix-93513
tannergooding Jul 7, 2024
4eabf81
Combine the SN_IsNegative and SN_IsPositive logic
tannergooding Jul 8, 2024
73fda9a
Update src/mono/mono/mini/simd-intrinsics.c
tannergooding Jul 9, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Ensure tests are added for the new vector APIs
  • Loading branch information
tannergooding committed Jun 29, 2024
commit 3f9bd35798dae875bf36c6d18bb843d7a2649bd4
1,687 changes: 1,687 additions & 0 deletions src/libraries/Common/tests/System/GenericMathTestMemberData.cs

Large diffs are not rendered by default.

This file was deleted.

441 changes: 432 additions & 9 deletions src/libraries/System.Numerics.Vectors/tests/GenericVectorTests.cs

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,6 @@
<Compile Include="Matrix4x4Tests.cs" />
<Compile Include="PlaneTests.cs" />
<Compile Include="QuaternionTests.cs" />
<Compile Include="$(CommonTestPath)\System\Runtime\Intrinsics\VectorTestMemberData.cs" Link="Common\System\Runtime\Intrinsics\VectorTestMemberData.cs" />
<Compile Include="$(CommonTestPath)System\GenericMathTestMemberData.cs" Link="Common\System\GenericMathTestMemberData.cs" />
</ItemGroup>
</Project>
189 changes: 182 additions & 7 deletions src/libraries/System.Numerics.Vectors/tests/Vector2Tests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

using System.Globalization;
using System.Runtime.InteropServices;
using System.Runtime.Intrinsics.Tests.Vectors;
using System.Tests;
using Xunit;

namespace System.Numerics.Tests
Expand Down Expand Up @@ -1300,19 +1300,194 @@ private class EmbeddedVectorObject
}

[Theory]
[MemberData(nameof(VectorTestMemberData.MultiplyAddSingle), MemberType = typeof(VectorTestMemberData))]
[MemberData(nameof(GenericMathTestMemberData.ExpSingle), MemberType = typeof(GenericMathTestMemberData))]
public void ExpSingleTest(float value, float expectedResult, float variance)
{
Vector2 actualResult = Vector2.Exp(Vector2.Create(value));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Create(variance));
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.LogSingle), MemberType = typeof(GenericMathTestMemberData))]
public void LogSingleTest(float value, float expectedResult, float variance)
{
Vector2 actualResult = Vector2.Log(Vector2.Create(value));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Create(variance));
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.Log2Single), MemberType = typeof(GenericMathTestMemberData))]
public void Log2SingleTest(float value, float expectedResult, float variance)
{
Vector2 actualResult = Vector2.Log2(Vector2.Create(value));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Create(variance));
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.FusedMultiplyAddSingle), MemberType = typeof(GenericMathTestMemberData))]
public void FusedMultiplyAddSingleTest(float left, float right, float addend)
{
Vector2 actualResult = Vector2.FusedMultiplyAdd(new Vector2(left), new Vector2(right), new Vector2(addend));
AssertEqual(new Vector2(float.FusedMultiplyAdd(left, right, addend)), actualResult, Vector2.Zero);
Vector2 actualResult = Vector2.FusedMultiplyAdd(Vector2.Create(left), Vector2.Create(right), Vector2.Create(addend));
AssertEqual(Vector2.Create(float.FusedMultiplyAdd(left, right, addend)), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(VectorTestMemberData.MultiplyAddSingle), MemberType = typeof(VectorTestMemberData))]
[MemberData(nameof(GenericMathTestMemberData.FusedMultiplyAddSingle), MemberType = typeof(GenericMathTestMemberData))]
public void MultiplyAddEstimateSingleTest(float left, float right, float addend)
{
Vector2 actualResult = Vector2.MultiplyAddEstimate(new Vector2(left), new Vector2(right), new Vector2(addend));
AssertEqual(new Vector2(float.MultiplyAddEstimate(left, right, addend)), actualResult, Vector2.Zero);
Vector2 actualResult = Vector2.MultiplyAddEstimate(Vector2.Create(left), Vector2.Create(right), Vector2.Create(addend));
AssertEqual(Vector2.Create(float.MultiplyAddEstimate(left, right, addend)), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.ClampSingle), MemberType = typeof(GenericMathTestMemberData))]
public void ClampSingleTest(float x, float min, float max, float expectedResult)
{
Vector2 actualResult = Vector2.Clamp(Vector2.Create(x), Vector2.Create(min), Vector2.Create(max));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.CopySignSingle), MemberType = typeof(GenericMathTestMemberData))]
public void CopySignSingleTest(float x, float y, float expectedResult)
{
Vector2 actualResult = Vector2.CopySign(Vector2.Create(x), Vector2.Create(y));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.DegreesToRadiansSingle), MemberType = typeof(GenericMathTestMemberData))]
public void DegreesToRadiansSingleTest(float value, float expectedResult, float variance)
{
AssertEqual(Vector2.Create(-expectedResult), Vector2.DegreesToRadians(Vector2.Create(-value)), Vector2.Create(variance));
AssertEqual(Vector2.Create(+expectedResult), Vector2.DegreesToRadians(Vector2.Create(+value)), Vector2.Create(variance));
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.HypotSingle), MemberType = typeof(GenericMathTestMemberData))]
public void HypotSingleTest(float x, float y, float expectedResult, float variance)
{
AssertEqual(Vector2.Create(expectedResult), Vector2.Hypot(Vector2.Create(-x), Vector2.Create(-y)), Vector2.Create(variance));
AssertEqual(Vector2.Create(expectedResult), Vector2.Hypot(Vector2.Create(-x), Vector2.Create(+y)), Vector2.Create(variance));
AssertEqual(Vector2.Create(expectedResult), Vector2.Hypot(Vector2.Create(+x), Vector2.Create(-y)), Vector2.Create(variance));
AssertEqual(Vector2.Create(expectedResult), Vector2.Hypot(Vector2.Create(+x), Vector2.Create(+y)), Vector2.Create(variance));

AssertEqual(Vector2.Create(expectedResult), Vector2.Hypot(Vector2.Create(-y), Vector2.Create(-x)), Vector2.Create(variance));
AssertEqual(Vector2.Create(expectedResult), Vector2.Hypot(Vector2.Create(-y), Vector2.Create(+x)), Vector2.Create(variance));
AssertEqual(Vector2.Create(expectedResult), Vector2.Hypot(Vector2.Create(+y), Vector2.Create(-x)), Vector2.Create(variance));
AssertEqual(Vector2.Create(expectedResult), Vector2.Hypot(Vector2.Create(+y), Vector2.Create(+x)), Vector2.Create(variance));
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.LerpSingle), MemberType = typeof(GenericMathTestMemberData))]
public void LerpSingleTest(float x, float y, float amount, float expectedResult)
{
AssertEqual(Vector2.Create(+expectedResult), Vector2.Lerp(Vector2.Create(+x), Vector2.Create(+y), Vector2.Create(amount)), Vector2.Zero);
AssertEqual(Vector2.Create((expectedResult == 0.0f) ? expectedResult : -expectedResult), Vector2.Lerp(Vector2.Create(-x), Vector2.Create(-y), Vector2.Create(amount)), Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.MaxSingle), MemberType = typeof(GenericMathTestMemberData))]
public void MaxSingleTest(float x, float y, float expectedResult)
{
Vector2 actualResult = Vector2.Max(Vector2.Create(x), Vector2.Create(y));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.MaxMagnitudeSingle), MemberType = typeof(GenericMathTestMemberData))]
public void MaxMagnitudeSingleTest(float x, float y, float expectedResult)
{
Vector2 actualResult = Vector2.MaxMagnitude(Vector2.Create(x), Vector2.Create(y));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.MaxMagnitudeNumberSingle), MemberType = typeof(GenericMathTestMemberData))]
public void MaxMagnitudeNumberSingleTest(float x, float y, float expectedResult)
{
Vector2 actualResult = Vector2.MaxMagnitudeNumber(Vector2.Create(x), Vector2.Create(y));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.MaxNumberSingle), MemberType = typeof(GenericMathTestMemberData))]
public void MaxNumberSingleTest(float x, float y, float expectedResult)
{
Vector2 actualResult = Vector2.MaxNumber(Vector2.Create(x), Vector2.Create(y));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.MinSingle), MemberType = typeof(GenericMathTestMemberData))]
public void MinSingleTest(float x, float y, float expectedResult)
{
Vector2 actualResult = Vector2.Min(Vector2.Create(x), Vector2.Create(y));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.MinMagnitudeSingle), MemberType = typeof(GenericMathTestMemberData))]
public void MinMagnitudeSingleTest(float x, float y, float expectedResult)
{
Vector2 actualResult = Vector2.MinMagnitude(Vector2.Create(x), Vector2.Create(y));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.MinMagnitudeNumberSingle), MemberType = typeof(GenericMathTestMemberData))]
public void MinMagnitudeNumberSingleTest(float x, float y, float expectedResult)
{
Vector2 actualResult = Vector2.MinMagnitudeNumber(Vector2.Create(x), Vector2.Create(y));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.MinNumberSingle), MemberType = typeof(GenericMathTestMemberData))]
public void MinNumberSingleTest(float x, float y, float expectedResult)
{
Vector2 actualResult = Vector2.MinNumber(Vector2.Create(x), Vector2.Create(y));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.RadiansToDegreesSingle), MemberType = typeof(GenericMathTestMemberData))]
public void RadiansToDegreesSingleTest(float value, float expectedResult, float variance)
{
AssertEqual(Vector2.Create(-expectedResult), Vector2.RadiansToDegrees(Vector2.Create(-value)), Vector2.Create(variance));
AssertEqual(Vector2.Create(+expectedResult), Vector2.RadiansToDegrees(Vector2.Create(+value)), Vector2.Create(variance));
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.RoundSingle), MemberType = typeof(GenericMathTestMemberData))]
public void RoundSingleTest(float value, float expectedResult)
{
Vector2 actualResult = Vector2.Round(Vector2.Create(value));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.RoundAwayFromZeroSingle), MemberType = typeof(GenericMathTestMemberData))]
public void RoundAwayFromZeroSingleTest(float value, float expectedResult)
{
Vector2 actualResult = Vector2.Round(Vector2.Create(value), MidpointRounding.AwayFromZero);
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.RoundToEvenSingle), MemberType = typeof(GenericMathTestMemberData))]
public void RoundToEvenSingleTest(float value, float expectedResult)
{
Vector2 actualResult = Vector2.Round(Vector2.Create(value), MidpointRounding.ToEven);
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}

[Theory]
[MemberData(nameof(GenericMathTestMemberData.TruncateSingle), MemberType = typeof(GenericMathTestMemberData))]
public void TruncateSingleTest(float value, float expectedResult)
{
Vector2 actualResult = Vector2.Truncate(Vector2.Create(value));
AssertEqual(Vector2.Create(expectedResult), actualResult, Vector2.Zero);
}
}
}
Loading
Loading