-
Notifications
You must be signed in to change notification settings - Fork 217
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
Convex Hull gives wrong output for 3D points. #683
Comments
Thanks for noticing. Could you please add a minimal example to reproduce this behaviour. |
@vissarion , yeah sure. The below example uses a 3D multipoint as an input and gives out a 3D multipoint as an output. The input provided is that contains the corners of a cube and the centroid of it. #include <iostream>
#include <boost/geometry.hpp>
#include <boost/geometry/geometries/polygon.hpp>
#include <boost/geometry/geometries/adapted/boost_tuple.hpp>
BOOST_GEOMETRY_REGISTER_BOOST_TUPLE_CS(cs::cartesian)
int main()
{
typedef boost::tuple<double, double, double> point;
typedef boost::geometry::model::multi_point<point> multi_pt;
multi_pt input;
boost::geometry::read_wkt("multipoint((0 0 0), (1 1 1), (1 1 0), (1 0 1), (0 1 1), (0 0 1), (0 1 0), (1 0 0), (0.5 0.5 0.5))", input);
multi_pt hull;
boost::geometry::convex_hull(input, hull);
using boost::geometry::wkt;
std::cout
<< "input: " << wkt(input) << std::endl
<< "hull: " << wkt(hull) << std::endl
;
return 0;
} The output that we get is:
While the hull should contain all the points except Also in my opinion if the supplied output geometry is multipoint we should not append the start point at the end as it is self implied. it should be added only when a polygon of ring type is provided. Although I am unfamiliar with the design rationale that was there when this was implemented. Since Graham Andrew Strategy cannot be extended to 3D space I would like to implement Chan's Algorithm for cartesian geometry. I am applying for the 2nd Project in GSoC and I think it will be a good base for the project and can be extended to cover non-cartesian systems. What is your opinion on this? |
It probably discards the 3rd coordinate and computes the convex hull of the projection in the first two. However, the user should be notified for this behaviour. This notification should be the same for all algorithms that does not handle correctly the 3d geometries. Regarding, 3D convex hull algorithms. You should do some research on algorithms and implementations if you want to add it to your application or implement it at some point. As far as I know currently one of the best choices (performance-wise) is |
I think we should give a compile time warning stating that As for the 3D convex hull algorithms, after thinking it over I think it better to add Quickhull ( O(n log n), worst case O(n2)) as 3D implementations of it exist widely while implementations of Chan's Algorithm ( O(n log h) ) in 3D are almost non existent. If you give the go ahead I would implement a Quickhull strategy for 2D, 3D and, if I can, 4D convex hulls too. |
Hey, @vissarion I want to work on this issue and implement the Quickhill algorithm for 3D points and also work on other algorithms in general that do not handle 3D geometries correctly. |
Hi @Siddharth-coder13, sure you can create an PR on 3D convex hull algorithm and discuss the details there. |
Hi @Siddharth-coder13 , thanks for your intention! There are many other algorithms not handling 3d (at all, in general in our library). It will be a huge effort. The best is to start with relatively simple ones, and convex hull would, indeed, probably be not the most complex one (though I would start with However, the best first point to start with, is defining a A second point to start with (apart from Volume or ConvexHull) could be So this would be |
Indeed, as @barendgehrels note the output of 3D convex hull cannot be just an ordered list (opposed to 2D) so you need a new geometry. For |
It seems that I have to implement |
Sure, that sounds right! |
Indeed, as @barendgehrels note the output of 3D convex hull cannot be just an ordered list (opposed to 2D) so you need a new geometry. So an alternative starting point could be |
@vissarion will you please explain about defining polyhedral surfaces, I'm not getting any clue on how to start? |
You can start by reading the OGC standard, and see how this is done in
postGIS.
…On Thu, Dec 24, 2020, 12:45 Siddharth Kumar ***@***.***> wrote:
@vissarion <https://github.com/vissarion> will you please explain about
defining polyhedral surfaces, I'm not getting any clue on how to start?
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#683 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AA35UTQZFZYCL67TOML3GNLSWMLTXANCNFSM4LIG2YDA>
.
|
Hey, @vissarion, @barendgehrels I am interested in implementing |
@ayushgupta138 do you have a plan on how to proceed? It seems related/dependent on #789 |
well, I have been working on the polyhedral surfaces for few months, for defining the |
@Siddharth-coder13 what else have been working on implementing? |
Since @Siddharth-coder13 is working on volume implementation, @vissarion can I work on surface area and distance implementation for 3d pointsets after #789 is merged? The implementation of surface area would not require much algorithmic implementation as distance, but for distance implementation I would have to do some research. |
Distance in 3d seems independent from volume and could be a project to work on after #789 is merged. Surface area sounds also useful. Note that there is a connection between surface area and volume for closed polyhedral surfaces (see e.g. 15.2.1 in http://www.csun.edu/~ctoth/Handbook/chap15.pdf). |
The Graham Andrew strategy has been implemented for 2D cartesian geometry but it doesn't assert if the supplied geometry is 2D and gives wrong output when supplied with 3D geometry.
The text was updated successfully, but these errors were encountered: