【发布时间】:2015-09-08 12:30:34
【问题描述】:
Boost rtree 对某些与段查询的交集给出了错误的交集结果。 在这种情况下,边界框是 y=0 处的 y 平面 10x10 正方形。我正在使用从 (2, 1, 0) 到 (2, 1, 10) 的 z 对齐线进行查询。有趣的是,如果我使用框而不是段进行查询,那么它会按预期工作。当盒子不是平面时也会出现这种行为,只需将最小角移动到 (0, -5, 0),它仍然会发生。
是我用错了还是 boost 中的错误?
编辑:已在 Boost 1.56 和 1.59 上尝试过。
#include <vector>
#include "gtest/gtest.h"
#include "gmock/gmock.h"
#include <boost/geometry.hpp>
#include <boost/geometry/geometries/point.hpp>
#include <boost/geometry/geometries/box.hpp>
#include <boost/geometry/geometries/segment.hpp>
#include <boost/geometry/index/rtree.hpp>
#include <vector>
#include <iterator>
#include <memory>
namespace bg = boost::geometry;
namespace bgi = boost::geometry::index;
typedef bg::model::point<double, 3, bg::cs::cartesian> point_def;
typedef bg::model::box<point_def> box;
typedef bg::model::segment<point_def> segment;
typedef std::pair<box, size_t> tri_box;
typedef bgi::rtree< tri_box, bgi::linear<8>> tree_type;
using namespace std;
TEST(boost_rtree, cant_intersect_box_with_segment) {
vector<tri_box> buff(1);
buff[0].first = box{point_def{0, 0, 0}, point_def{10, 0, 10}};
buff[0].second = 1;
tree_type tree(buff);
segment query{point_def{2, 1, 0}, point_def{2, 1, 10}};
// box query{point_def{2, 1, 0}, point_def{2, 1, 10}};
vector<tri_box> out;
size_t count = tree.query(bgi::intersects(query), back_inserter(out));
ASSERT_EQ(0, count); // fails here
ASSERT_EQ(0, out.size());
}
编辑:正在将问题转移到提升邮件列表:lists.boost.org/geometry/2015/09/3472.php
【问题讨论】:
-
是的,正如 sehe 所写,这似乎是不相交/相交中的错误。正如我在列表中的电子邮件中所写的,您可以创建一张票,以便获得有关此错误的更新。或者,如果您愿意贡献,您可以在 GitHub 上创建一个带有修复的拉取请求。
标签: c++ boost r-tree boost-geometry