From 8039aee7f2f0052a1e1aac34d8e3c0577057d865 Mon Sep 17 00:00:00 2001 From: andywiecko Date: Fri, 22 Sep 2023 18:03:32 +0200 Subject: [PATCH] test: constraint triangulation benchmark --- Tests/TriangulatorEditorTests.cs | 63 ++++++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) diff --git a/Tests/TriangulatorEditorTests.cs b/Tests/TriangulatorEditorTests.cs index f787dec..53aff91 100644 --- a/Tests/TriangulatorEditorTests.cs +++ b/Tests/TriangulatorEditorTests.cs @@ -1844,5 +1844,68 @@ public void DelaunayBenchmarkTest((int count, int N) input) Unity.Jobs.LowLevel.Unsafe.JobsUtility.JobDebuggerEnabled = debuggerInitialValue; } + + private static readonly TestCaseData[] constraintBenchmarkTestData = Enumerable + .Range(0, 80) + .Select(i => new TestCaseData((100, 3 * (i + 1)))) + .ToArray(); + + [Test, TestCaseSource(nameof(constraintBenchmarkTestData)), Explicit] + public void ConstraintBenchmarkTest((int count, int N) input) + { + var (count, N) = input; + var debuggerInitialValue = Unity.Jobs.LowLevel.Unsafe.JobsUtility.JobDebuggerEnabled; + Unity.Jobs.LowLevel.Unsafe.JobsUtility.JobDebuggerEnabled = false; + + var points = new List(count * count); + for (int i = 0; i < count; i++) + { + for (int j = 0; j < count; j++) + { + var p = math.float2(i / (float)(count - 1), j / (float)(count - 1)); + points.Add(p); + } + } + + var offset = points.Count; + var constraints = new List(N + 1); + for (int i = 0; i < N; i++) + { + var phi = 2 * math.PI / N * i + 0.1452f; + var p = 0.2f * math.float2(math.cos(phi), math.sin(phi)) + 0.5f; + points.Add(p); + constraints.Add(offset + i); + constraints.Add(offset + (i + 1) % N); + } + + using var positions = new NativeArray(points.ToArray(), Allocator.Persistent); + using var constraintEdges = new NativeArray(constraints.ToArray(), Allocator.Persistent); + + var stopwatch = Stopwatch.StartNew(); + using var triangulator = new Triangulator(capacity: count * count + N, Allocator.Persistent) + { + Input = { Positions = positions, ConstraintEdges = constraintEdges }, + Settings = { + RefineMesh = false, + ConstrainEdges = true, + RestoreBoundary = false, + ValidateInput = false + }, + }; + + var dependencies = default(JobHandle); + var rep = 300; + for (int i = 0; i < rep; i++) dependencies = triangulator.Schedule(dependencies); + dependencies.Complete(); + stopwatch.Stop(); + var log = $"{N} {stopwatch.Elapsed.TotalMilliseconds / rep}"; + UnityEngine.Debug.Log(log); + + // NOTE: Uncomment this to write all the test cases into a file. + //using var writer = new System.IO.StreamWriter("tmp.txt", true); + //writer.WriteLine(log); + + Unity.Jobs.LowLevel.Unsafe.JobsUtility.JobDebuggerEnabled = debuggerInitialValue; + } } }