| #include <Eigen/StdVector> |
| #include <unsupported/Eigen/BVH> |
| #include <iostream> |
| |
| using namespace Eigen; |
| typedef AlignedBox<double, 2> Box2d; |
| |
| namespace Eigen { |
| Box2d bounding_box(const Vector2d &v) { return Box2d(v, v); } // compute the bounding box of a single point |
| } // namespace Eigen |
| |
| struct PointPointMinimizer // how to compute squared distances between points and rectangles |
| { |
| PointPointMinimizer() : calls(0) {} |
| typedef double Scalar; |
| |
| double minimumOnVolumeVolume(const Box2d &r1, const Box2d &r2) { |
| ++calls; |
| return r1.squaredExteriorDistance(r2); |
| } |
| double minimumOnVolumeObject(const Box2d &r, const Vector2d &v) { |
| ++calls; |
| return r.squaredExteriorDistance(v); |
| } |
| double minimumOnObjectVolume(const Vector2d &v, const Box2d &r) { |
| ++calls; |
| return r.squaredExteriorDistance(v); |
| } |
| double minimumOnObjectObject(const Vector2d &v1, const Vector2d &v2) { |
| ++calls; |
| return (v1 - v2).squaredNorm(); |
| } |
| |
| int calls; |
| }; |
| |
| int main() { |
| typedef std::vector<Vector2d, aligned_allocator<Vector2d> > StdVectorOfVector2d; |
| StdVectorOfVector2d redPoints, bluePoints; |
| for (int i = 0; i < 100; ++i) { // initialize random set of red points and blue points |
| redPoints.push_back(Vector2d::Random()); |
| bluePoints.push_back(Vector2d::Random()); |
| } |
| |
| PointPointMinimizer minimizer; |
| double minDistSq = std::numeric_limits<double>::max(); |
| |
| // brute force to find closest red-blue pair |
| for (int i = 0; i < (int)redPoints.size(); ++i) |
| for (int j = 0; j < (int)bluePoints.size(); ++j) |
| minDistSq = std::min(minDistSq, minimizer.minimumOnObjectObject(redPoints[i], bluePoints[j])); |
| std::cout << "Brute force distance = " << sqrt(minDistSq) << ", calls = " << minimizer.calls << std::endl; |
| |
| // using BVH to find closest red-blue pair |
| minimizer.calls = 0; |
| KdBVH<double, 2, Vector2d> redTree(redPoints.begin(), redPoints.end()), |
| blueTree(bluePoints.begin(), bluePoints.end()); // construct the trees |
| minDistSq = BVMinimize(redTree, blueTree, minimizer); // actual BVH minimization call |
| std::cout << "BVH distance = " << sqrt(minDistSq) << ", calls = " << minimizer.calls << std::endl; |
| |
| return 0; |
| } |