From eb5499e737fc323ac949103a8efe29e1247ba78d Mon Sep 17 00:00:00 2001
From: Florent Lamiraux <florent@laas.fr>
Date: Thu, 29 Nov 2018 17:09:01 +0100
Subject: [PATCH] [detail::GJK] Rename member for clarity

  Simplex::c -> Simplex::vertex.
  Simplex::p -> Simplex::coefficient.
---
 include/hpp/fcl/narrowphase/gjk.h         |   8 +-
 include/hpp/fcl/narrowphase/narrowphase.h |  27 ++---
 src/narrowphase/gjk.cpp                   | 114 +++++++++++++---------
 3 files changed, 88 insertions(+), 61 deletions(-)

diff --git a/include/hpp/fcl/narrowphase/gjk.h b/include/hpp/fcl/narrowphase/gjk.h
index 8ad919ae..b960c042 100644
--- a/include/hpp/fcl/narrowphase/gjk.h
+++ b/include/hpp/fcl/narrowphase/gjk.h
@@ -137,9 +137,9 @@ struct GJK
   struct Simplex
   {
     /// @brief simplex vertex
-    SimplexV* c[4];
+    SimplexV* vertex[4];
     /// @brief weight 
-    FCL_REAL p[4];
+    FCL_REAL coefficient[4];
     /// @brief size of simplex (number of vertices)
     size_t rank;
 
@@ -217,7 +217,7 @@ private:
   {
     Vec3f n;
     FCL_REAL d;
-    SimplexV* c[3]; // a face has three vertices
+    SimplexV* vertex[3]; // a face has three vertices
     SimplexF* f[3]; // a face has three adjacent faces
     SimplexF* l[2]; // the pre and post faces in the list
     size_t e[3];
@@ -300,7 +300,7 @@ public:
 
   bool getEdgeDist(SimplexF* face, SimplexV* a, SimplexV* b, FCL_REAL& dist);
 
-  SimplexF* newFace(SimplexV* a, SimplexV* b, SimplexV* c, bool forced);
+  SimplexF* newFace(SimplexV* a, SimplexV* b, SimplexV* vertex, bool forced);
 
   /// @brief Find the best polytope face to split
   SimplexF* findBest();
diff --git a/include/hpp/fcl/narrowphase/narrowphase.h b/include/hpp/fcl/narrowphase/narrowphase.h
index 7554b56a..b0e8d3a7 100644
--- a/include/hpp/fcl/narrowphase/narrowphase.h
+++ b/include/hpp/fcl/narrowphase/narrowphase.h
@@ -79,7 +79,8 @@ struct GJKSolver_indep
           Vec3f w0 (Vec3f::Zero());
           for(size_t i = 0; i < epa.result.rank; ++i)
           {
-            w0 += shape.support(epa.result.c[i]->d, 0) * epa.result.p[i];
+            w0 += shape.support(epa.result.vertex[i]->d, 0) *
+              epa.result.coefficient[i];
           }
           if(penetration_depth) *penetration_depth = -epa.depth;
           if(normal) *normal = tf2.getRotation() * epa.normal;
@@ -128,7 +129,8 @@ struct GJKSolver_indep
           Vec3f w0 (Vec3f::Zero());
           for(size_t i = 0; i < epa.result.rank; ++i)
           {
-            w0 += shape.support(epa.result.c[i]->d, 0) * epa.result.p[i];
+            w0 += shape.support(epa.result.vertex[i]->d, 0) *
+              epa.result.coefficient[i];
           }
           if(penetration_depth) *penetration_depth = -epa.depth;
           if(normal) *normal = -epa.normal;
@@ -177,7 +179,8 @@ struct GJKSolver_indep
           Vec3f w0 (Vec3f::Zero());
           for(size_t i = 0; i < epa.result.rank; ++i)
           {
-            w0 += shape.support(epa.result.c[i]->d, 0) * epa.result.p[i];
+            w0 += shape.support(epa.result.vertex[i]->d, 0) *
+              epa.result.coefficient[i];
           }
           if(penetration_depth) *penetration_depth = -epa.depth;
           if(normal) *normal = -epa.normal;
@@ -218,9 +221,9 @@ struct GJKSolver_indep
       Vec3f w0 (Vec3f::Zero()), w1 (Vec3f::Zero());
       for(size_t i = 0; i < gjk.getSimplex()->rank; ++i)
       {
-        FCL_REAL p = gjk.getSimplex()->p[i];
-        w0 += shape.support(gjk.getSimplex()->c[i]->d, 0) * p;
-        w1 += shape.support(-gjk.getSimplex()->c[i]->d, 1) * p;
+        FCL_REAL p = gjk.getSimplex()->coefficient[i];
+        w0 += shape.support(gjk.getSimplex()->vertex[i]->d, 0) * p;
+        w1 += shape.support(-gjk.getSimplex()->vertex[i]->d, 1) * p;
       }
 
       if(distance) *distance = (w0 - w1).norm();
@@ -283,9 +286,9 @@ struct GJKSolver_indep
       Vec3f w0 (Vec3f::Zero()), w1 (Vec3f::Zero());
       for(size_t i = 0; i < gjk.getSimplex()->rank; ++i)
       {
-        FCL_REAL p = gjk.getSimplex()->p[i];
-        w0 += shape.support(gjk.getSimplex()->c[i]->d, 0) * p;
-        w1 += shape.support(-gjk.getSimplex()->c[i]->d, 1) * p;
+        FCL_REAL p = gjk.getSimplex()->coefficient[i];
+        w0 += shape.support(gjk.getSimplex()->vertex[i]->d, 0) * p;
+        w1 += shape.support(-gjk.getSimplex()->vertex[i]->d, 1) * p;
       }
 
       if(distance) *distance = (w0 - w1).norm();
@@ -333,9 +336,9 @@ struct GJKSolver_indep
       Vec3f w0 (Vec3f::Zero()), w1 (Vec3f::Zero());
       for(size_t i = 0; i < gjk.getSimplex()->rank; ++i)
       {
-        FCL_REAL p = gjk.getSimplex()->p[i];
-        w0 += shape.support(gjk.getSimplex()->c[i]->d, 0) * p;
-        w1 += shape.support(-gjk.getSimplex()->c[i]->d, 1) * p;
+        FCL_REAL p = gjk.getSimplex()->coefficient[i];
+        w0 += shape.support(gjk.getSimplex()->vertex[i]->d, 0) * p;
+        w1 += shape.support(-gjk.getSimplex()->vertex[i]->d, 1) * p;
       }
 
       if(distance) *distance = (w0 - w1).norm();
diff --git a/src/narrowphase/gjk.cpp b/src/narrowphase/gjk.cpp
index 1a705c61..aa71cbc4 100644
--- a/src/narrowphase/gjk.cpp
+++ b/src/narrowphase/gjk.cpp
@@ -204,8 +204,8 @@ GJK::Status GJK::evaluate(const MinkowskiDiff& shape_, const Vec3f& guess)
   // appendVertex(simplices[0], (ray.squaredNorm() > 0) ? -ray : Vec3f(1, 0, 0));
   if (ray.squaredNorm() > 0) appendVertex(simplices[0], -ray);
   else                       appendVertex(simplices[0], Vec3f(1, 0, 0));
-  simplices[0].p[0] = 1;
-  ray = simplices[0].c[0]->w;
+  simplices[0].coefficient[0] = 1;
+  ray = simplices[0].vertex[0]->w;
   lastw[0] = lastw[1] = lastw[2] = lastw[3] = ray; // cache previous support points, the new support point will compare with it to avoid too close support points
 
   do
@@ -225,7 +225,7 @@ GJK::Status GJK::evaluate(const MinkowskiDiff& shape_, const Vec3f& guess)
     appendVertex(curr_simplex, -ray); // see below, ray points away from origin
 
     // check B: when the new support point is close to previous support points, stop (as the new simplex is degenerated)
-    Vec3f& w = curr_simplex.c[curr_simplex.rank - 1]->w;
+    Vec3f& w = curr_simplex.vertex[curr_simplex.rank - 1]->w;
     bool found = false;
     for(size_t i = 0; i < 4; ++i)
     {
@@ -258,11 +258,19 @@ GJK::Status GJK::evaluate(const MinkowskiDiff& shape_, const Vec3f& guess)
     switch(curr_simplex.rank)
     {
     case 2:
-      project_res = Project::projectLineOrigin(curr_simplex.c[0]->w, curr_simplex.c[1]->w); break;
+      project_res = Project::projectLineOrigin(curr_simplex.vertex[0]->w,
+                                               curr_simplex.vertex[1]->w);
+      break;
     case 3:
-      project_res = Project::projectTriangleOrigin(curr_simplex.c[0]->w, curr_simplex.c[1]->w, curr_simplex.c[2]->w); break;
+      project_res = Project::projectTriangleOrigin(curr_simplex.vertex[0]->w,
+                                                   curr_simplex.vertex[1]->w,
+                                                   curr_simplex.vertex[2]->w); break;
     case 4:
-      project_res = Project::projectTetrahedraOrigin(curr_simplex.c[0]->w, curr_simplex.c[1]->w, curr_simplex.c[2]->w, curr_simplex.c[3]->w); break;
+      project_res = Project::projectTetrahedraOrigin(curr_simplex.vertex[0]->w,
+                                                     curr_simplex.vertex[1]->w,
+                                                     curr_simplex.vertex[2]->w,
+                                                     curr_simplex.vertex[3]->w);
+      break;
     }
       
     if(project_res.sqr_distance >= 0)
@@ -274,12 +282,15 @@ GJK::Status GJK::evaluate(const MinkowskiDiff& shape_, const Vec3f& guess)
       {
         if(project_res.encode & (1 << i))
         {
-          next_simplex.c[next_simplex.rank] = curr_simplex.c[i];
-          next_simplex.p[next_simplex.rank++] = project_res.parameterization[i]; // weights[i];
-          ray += curr_simplex.c[i]->w * project_res.parameterization[i]; // weights[i];
+          next_simplex.vertex[next_simplex.rank] = curr_simplex.vertex[i];
+          // weights[i]
+          next_simplex.coefficient[next_simplex.rank++] =
+            project_res.parameterization[i];
+          // weights[i]
+          ray += curr_simplex.vertex[i]->w * project_res.parameterization[i];
         }
         else
-          free_v[nfree++] = curr_simplex.c[i];
+          free_v[nfree++] = curr_simplex.vertex[i];
       }
       if(project_res.encode == 15) status = Inside; // the origin is within the 4-simplex, collision
     }
@@ -317,14 +328,14 @@ void GJK::getSupport(const Vec3f& d, const Vec3f& v, SimplexV& sv) const
 
 void GJK::removeVertex(Simplex& simplex)
 {
-  free_v[nfree++] = simplex.c[--simplex.rank];
+  free_v[nfree++] = simplex.vertex[--simplex.rank];
 }
 
 void GJK::appendVertex(Simplex& simplex, const Vec3f& v)
 {
-  simplex.p[simplex.rank] = 0; // initial weight 0
-  simplex.c[simplex.rank] = free_v[--nfree]; // set the memory
-  getSupport(v, *simplex.c[simplex.rank++]);
+  simplex.coefficient[simplex.rank] = 0; // initial weight 0
+  simplex.vertex[simplex.rank] = free_v[--nfree]; // set the memory
+  getSupport(v, *simplex.vertex[simplex.rank++]);
 }
 
 bool GJK::encloseOrigin()
@@ -348,7 +359,7 @@ bool GJK::encloseOrigin()
     break;
   case 2:
     {
-      Vec3f d = simplex->c[1]->w - simplex->c[0]->w;
+      Vec3f d = simplex->vertex[1]->w - simplex->vertex[0]->w;
       for(size_t i = 0; i < 3; ++i)
       {
         Vec3f axis(0,0,0);
@@ -368,7 +379,8 @@ bool GJK::encloseOrigin()
     break;
   case 3:
     {
-      Vec3f n = (simplex->c[1]->w - simplex->c[0]->w).cross(simplex->c[2]->w - simplex->c[0]->w);
+      Vec3f n = (simplex->vertex[1]->w - simplex->vertex[0]->w).cross
+        (simplex->vertex[2]->w - simplex->vertex[0]->w);
       if(n.squaredNorm() > 0)
       {
         appendVertex(*simplex, n);
@@ -382,7 +394,9 @@ bool GJK::encloseOrigin()
     break;
   case 4:
     {
-      if(std::abs(triple(simplex->c[0]->w - simplex->c[3]->w, simplex->c[1]->w - simplex->c[3]->w, simplex->c[2]->w - simplex->c[3]->w)) > 0)
+      if(std::abs(triple(simplex->vertex[0]->w - simplex->vertex[3]->w,
+                         simplex->vertex[1]->w - simplex->vertex[3]->w,
+                         simplex->vertex[2]->w - simplex->vertex[3]->w)) > 0)
         return true;
     }
     break;
@@ -441,9 +455,9 @@ EPA::SimplexF* EPA::newFace(SimplexV* a, SimplexV* b, SimplexV* c, bool forced)
     stock.remove(face);
     hull.append(face);
     face->pass = 0;
-    face->c[0] = a;
-    face->c[1] = b;
-    face->c[2] = c;
+    face->vertex[0] = a;
+    face->vertex[1] = b;
+    face->vertex[2] = c;
     face->n = (b->w - a->w).cross(c->w - a->w);
     FCL_REAL l = face->n.norm();
       
@@ -506,21 +520,27 @@ EPA::Status EPA::evaluate(GJK& gjk, const Vec3f& guess)
     status = Valid;
     nextsv = 0;
 
-    if((simplex.c[0]->w - simplex.c[3]->w).dot((simplex.c[1]->w - simplex.c[3]->w).cross(simplex.c[2]->w - simplex.c[3]->w)) < 0)
+    if((simplex.vertex[0]->w - simplex.vertex[3]->w).dot
+       ((simplex.vertex[1]->w - simplex.vertex[3]->w).cross
+        (simplex.vertex[2]->w - simplex.vertex[3]->w)) < 0)
     {
-      SimplexV* tmp = simplex.c[0];
-      simplex.c[0] = simplex.c[1];
-      simplex.c[1] = tmp;
+      SimplexV* tmp = simplex.vertex[0];
+      simplex.vertex[0] = simplex.vertex[1];
+      simplex.vertex[1] = tmp;
 
-      FCL_REAL tmpv = simplex.p[0];
-      simplex.p[0] = simplex.p[1];
-      simplex.p[1] = tmpv;
+      FCL_REAL tmpv = simplex.coefficient[0];
+      simplex.coefficient[0] = simplex.coefficient[1];
+      simplex.coefficient[1] = tmpv;
     }
 
-    SimplexF* tetrahedron[] = {newFace(simplex.c[0], simplex.c[1], simplex.c[2], true),
-                               newFace(simplex.c[1], simplex.c[0], simplex.c[3], true),
-                               newFace(simplex.c[2], simplex.c[1], simplex.c[3], true),
-                               newFace(simplex.c[0], simplex.c[2], simplex.c[3], true) };
+    SimplexF* tetrahedron[] = {newFace(simplex.vertex[0], simplex.vertex[1],
+                                       simplex.vertex[2], true),
+                               newFace(simplex.vertex[1], simplex.vertex[0],
+                                       simplex.vertex[3], true),
+                               newFace(simplex.vertex[2], simplex.vertex[1],
+                                       simplex.vertex[3], true),
+                               newFace(simplex.vertex[0], simplex.vertex[2],
+                                       simplex.vertex[3], true) };
 
     if(hull.count == 4)
     {
@@ -585,17 +605,21 @@ EPA::Status EPA::evaluate(GJK& gjk, const Vec3f& guess)
       normal = outer.n;
       depth = outer.d;
       result.rank = 3;
-      result.c[0] = outer.c[0];
-      result.c[1] = outer.c[1];
-      result.c[2] = outer.c[2];
-      result.p[0] = ((outer.c[1]->w - projection).cross(outer.c[2]->w - projection)).norm();
-      result.p[1] = ((outer.c[2]->w - projection).cross(outer.c[0]->w - projection)).norm();
-      result.p[2] = ((outer.c[0]->w - projection).cross(outer.c[1]->w - projection)).norm();
-
-      FCL_REAL sum = result.p[0] + result.p[1] + result.p[2];
-      result.p[0] /= sum;
-      result.p[1] /= sum;
-      result.p[2] /= sum;
+      result.vertex[0] = outer.vertex[0];
+      result.vertex[1] = outer.vertex[1];
+      result.vertex[2] = outer.vertex[2];
+      result.coefficient[0] = ((outer.vertex[1]->w - projection).cross
+                               (outer.vertex[2]->w - projection)).norm();
+      result.coefficient[1] = ((outer.vertex[2]->w - projection).cross
+                               (outer.vertex[0]->w - projection)).norm();
+      result.coefficient[2] = ((outer.vertex[0]->w - projection).cross
+                               (outer.vertex[1]->w - projection)).norm();
+
+      FCL_REAL sum = result.coefficient[0] + result.coefficient[1] +
+        result.coefficient[2];
+      result.coefficient[0] /= sum;
+      result.coefficient[1] /= sum;
+      result.coefficient[2] /= sum;
       return status;
     }
   }
@@ -607,8 +631,8 @@ EPA::Status EPA::evaluate(GJK& gjk, const Vec3f& guess)
   else normal = Vec3f(1, 0, 0);
   depth = 0;
   result.rank = 1;
-  result.c[0] = simplex.c[0];
-  result.p[0] = 1;
+  result.vertex[0] = simplex.vertex[0];
+  result.coefficient[0] = 1;
   return status;
 }
 
@@ -626,7 +650,7 @@ bool EPA::expand(size_t pass, SimplexV* w, SimplexF* f, size_t e, SimplexHorizon
     // case 1: the new face is not degenerated, i.e., the new face is not coplanar with the old face f.
     if(f->n.dot(w->w) - f->d < -tolerance)
     {
-      SimplexF* nf = newFace(f->c[e1], f->c[e], w, false);
+      SimplexF* nf = newFace(f->vertex[e1], f->vertex[e], w, false);
       if(nf)
       {
         // add face-face connectivity
-- 
GitLab