3

我正在尝试使用 Boost.Geometry 注册 OGR 几何类,以最终在 Boost.Geometry RTree 中使用它们。为此,我遵循了 Boost.Geometry 文档中的教程/示例,并使用BOOST_GEOMETRY_REGISTER_POINT_2D_GET_SET宏注册了 OGRPoint:

BOOST_GEOMETRY_REGISTER_POINT_2D_GET_SET(
    OGRPoint,
    double,
    boost::geometry::cs::spherical_equatorial<boost::geometry::degree>,
    getX,
    getY,
    setX,
    setY)

我的简单测试驱动程序只是创建了一个带有 Indexable 的 RTree boost::geometry::model::box

typedef bg::model::box<OGRPoint> OGRBox;
typedef std::pair <OGRBox, unsigned> Value;

bgi::rtree<Value, bgi::rstar<16>> rtree;
OGRPoint testP0(12.0, 18.0),
        testP1(1.2, 1.8);

rtree.insert(std::make_pair(OGRBox(testP0, testP0), 0));
rtree.insert(std::make_pair(OGRBox(testP1, testP1), 1));

但是,我遇到了一个编译错误,归结为 Boost 中的一个断言:

../../../../include/boost/geometry/index/rtree.hpp:576:398: note:   cannot convert 'boost::geometry::index::rtree<Value, Options, IndexableGetter, EqualTo, Allocator>::insert(const Range&)::PASSED_OBJECT_IS_NOT_A_RANGE576::assert_arg<std::pair<boost::geometry::model::box<OGRPoint>, int> >()' (type 'mpl_::failed************ (boost::geometry::index::rtree<Value, Options, IndexableGetter, EqualTo, Allocator>::insert(const Range&) [with Range = std::pair<boost::geometry::model::box<OGRPoint>, int>; Value = std::pair<boost::geometry::model::box<OGRPoint>, unsigned int>; Parameters = boost::geometry::index::rstar<16ul>; IndexableGetter = boost::geometry::index::indexable<std::pair<boost::geometry::model::box<OGRPoint>, unsigned int> >; EqualTo = boost::geometry::index::equal_to<std::pair<boost::geometry::model::box<OGRPoint>, unsigned int> >; Allocator = std::allocator<std::pair<boost::geometry::model::box<OGRPoint>, unsigned int> >]::PASSED_OBJECT_IS_NOT_A_RANGE::************)(std::pair<boost::geometry::model::box<OGRPoint>, int>)') to type 'mpl_::assert<false>::type {aka mpl_::assert<false>}'
     BOOST_MPL_ASSERT_MSG((detail::is_range<Range>::value), PASSED_OBJECT_IS_NOT_A_RANGE, (Range));

还有什么我需要做的,比如实施 Boost.Rangeboost::geometry::model::box<OGRPoint>吗?

4

2 回答 2

3

这个问题存在于 Boost 1.56 和更早的版本中。

有 3 个重载rtree::insert()

rtree::insert(value_type const&)
rtree::insert(Iter first, Iter last)
rtree::insert(Range const&) // 1.56 and older

在 Boost 1.56 和更早的版本中,当一个不同于类型的对象value_type被传递给insert()成员函数时,rtree 将其视为 Range(一个适应 Boost.Range 概念的类型的对象)。当参数不是 Range 时,会在编译时生成错误消息。

在 Boost 1.57 中,您的代码应该可以工作,因为该函数现在可以识别可转换为value_type. 现在第三个重载是:

rtree::insert(ConvertibleOrRange const&) // 1.57

如果您有一些建议或发现错误,请随时联系邮件列表上的开发人员或在此处报告错误。

于 2014-12-22T01:01:29.470 回答
1

在那种特殊情况下,我的适配器代码没有错误。实际上,这一切都在错误消息中:

typedef std::pair <OGRBox, unsigned> Value;

注意unsigned.

但是,该错误指出:

std::pair<boost::geometry::model::box<OGRPoint>, int>

是的,int。解决方案是std::pair<OGRBox, unsigned>直接使用的构造函数,或附加u到数字文字,如下所示:

rtree.insert(std::make_pair(OGRBox(testP0, testP0), 0u));

我不敢相信这只是让我搜索了三个小时。我希望它可以帮助某人。

于 2014-12-21T18:53:58.407 回答