From bf610fb91dad7f62aeee7c647ddf43dcbc0fe92e Mon Sep 17 00:00:00 2001 From: rishabh-997 Date: Mon, 17 Aug 2020 02:46:38 +0530 Subject: [PATCH] Added Jarvi algo to find convex hull --- geometry/jarvis_algorithm.cpp | 44 +++++++++++++++++------------------ 1 file changed, 22 insertions(+), 22 deletions(-) diff --git a/geometry/jarvis_algorithm.cpp b/geometry/jarvis_algorithm.cpp index d471a52a4..ae5b1b5a6 100644 --- a/geometry/jarvis_algorithm.cpp +++ b/geometry/jarvis_algorithm.cpp @@ -26,7 +26,6 @@ * @author [Rishabh Agarwal](https://github.com/rishabh-997) */ -#include #include #include #include @@ -54,19 +53,19 @@ namespace geometry { * throughout the code */ class Convexhull { - public: std::vector points; int size; + public: /** * Constructor of given class * * @param pointList list of all points in the space * @param n number of points in space */ - Convexhull(std::vector pointList, int n) { - points = std::move(pointList); - size = n; + explicit Convexhull(const std::vector &pointList) { + points = pointList; + size = points.size(); } /** @@ -120,16 +119,18 @@ namespace geometry { } /** - * + * This function returns the geometric orientation for the three points + * in a space, ie, whether they are linear ir clockwise or + * anti-clockwise * @param p first point selected * @param q adjacent point for q * @param r adjacent point for q - * @returns the geometric orientation for the three points - * 0 -> Linear - * 1 -> Clock Wise - * 2 -> Anti Clock Wise + * + * @returns 0 -> Linear + * @returns 1 -> Clock Wise + * @returns 2 -> Anti Clock Wise */ - static int orientation(Point p, Point q, Point r) { + static int orientation(const Point &p, const Point &q, const Point &r) { int val = (q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y); if (val == 0) { @@ -149,22 +150,21 @@ namespace geometry { */ static void test() { std::vector points = {{0, 3}, - {2, 2}, - {1, 1}, - {2, 1}, - {3, 0}, - {0, 0}, - {3, 3} + {2, 2}, + {1, 1}, + {2, 1}, + {3, 0}, + {0, 0}, + {3, 3} }; - int n = points.size(); - geometry::jarvis::Convexhull hull(points, n); + geometry::jarvis::Convexhull hull(points); std::vector actualPoint; actualPoint = hull.getConvexHull(); std::vector expectedPoint = {{0, 3}, - {0, 0}, - {3, 0}, - {3, 3}}; + {0, 0}, + {3, 0}, + {3, 3}}; for (int i = 0; i < expectedPoint.size(); i++) { assert(actualPoint[i].x == expectedPoint[i].x); assert(actualPoint[i].y == expectedPoint[i].y);