From 4a8dad3eff1c26f67968eb2e0d49e93ea5554daa Mon Sep 17 00:00:00 2001 From: notgiven688 Date: Sun, 12 May 2024 22:18:20 +0200 Subject: [PATCH] Use Euler characteristic for array bounds --- src/GJKEPA.cs | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/GJKEPA.cs b/src/GJKEPA.cs index 393d907..187dbf4 100644 --- a/src/GJKEPA.cs +++ b/src/GJKEPA.cs @@ -27,7 +27,7 @@ public sealed class GJKEPA { private const double NumericEpsilon = 1e-24d; private const double CollideEpsilon = 1e-6d; - private const int MaxIter = 85; + private const int MaxIter = 84; public struct Statistics { public double Accuracy; public int Iterations; } @@ -112,15 +112,19 @@ public static bool Equals(in Edge a, in Edge b) } } + // (*) Euler-characteristic: V (vertices) - E (edges) + F (faces) = 2 + // We have triangles T instead of faces: F = T + // and every edge shares two triangles -> T = 2*V - 4 private const int MaxVertices = MaxIter + 4; - private const int MaxTriangles = 3 * MaxVertices; + private const int MaxTriangles = 2 * MaxVertices; private readonly Triangle[] Triangles = new Triangle[MaxTriangles]; private readonly JVector[] Vertices = new JVector[MaxVertices]; private readonly JVector[] VerticesA = new JVector[MaxVertices]; private readonly JVector[] VerticesB = new JVector[MaxVertices]; - private readonly Edge[] edges = new Edge[256]; + // see (*) + private readonly Edge[] edges = new Edge[MaxVertices * 3 / 2]; private short vPointer = 0; private short tCount = 0;