Matt Amos
deb9d08914
[extreme_points] Kludge to flip side strategy for CCW polygons and their inners.
2014-10-15 13:55:32 +02:00
Matt Amos
786aac69b7
[point_on_surface] Do multiply & divide as separate steps to preserve as much precision as possible when using integer coordinates.
2014-10-15 13:55:05 +02:00
Barend Gehrels
8528423314
Merge branch 'develop' into feature/buffer
2014-10-15 13:08:39 +02:00
Barend Gehrels
70b722436b
[buffer] Fix rt_u13 but that fix is still commented because causes other issues.
...
get_left_turns/occupation_info are revised
2014-10-15 11:59:01 +02:00
Menelaos Karavelas
54a969212c
[algorithms][closest_feature] follow coding guidelines regarding "if (expr)" statements
2014-10-15 12:22:19 +03:00
Menelaos Karavelas
ba80bae681
[algorithms][distance] follow coding guidelines regarding "if (expr)" statements
2014-10-15 12:20:13 +03:00
Adam Wulkiewicz
47d18eda0b
[from_wkt] Add default template parameters to parsing_assigner.
2014-10-15 03:05:28 +02:00
Adam Wulkiewicz
ce726833f8
[from_wkt] Move the appending logic outside container_appender and dispatch by closure.
2014-10-15 01:19:15 +02:00
Menelaos Karavelas
f58f6a8255
[algorithms][distance] rename beyond to last
2014-10-14 23:38:55 +03:00
Menelaos Karavelas
423ba3d47c
[algorithms][disjoint] remove partition related code
2014-10-14 23:18:13 +03:00
Menelaos Karavelas
5dc90b1ffe
[algorithms][disjoint] factor-out common functionality in disjoint_multirange_segment_or_box
...
and multipoint_constant_size_geometry; simplify implementation of disjoint_segment_areal;
2014-10-14 17:02:06 +03:00
Menelaos Karavelas
ecd30f48b6
[algorithms][closest_feature] add assertion against an empty range
2014-10-14 15:46:21 +03:00
Menelaos Karavelas
b7367b76a9
[algorithms][closest_feature] rename beyond to last
2014-10-14 15:44:57 +03:00
Menelaos Karavelas
1139ca97f7
[algorithms][distance] modify the various classes to do not inherit
...
from closest feature classes, but rather call their public (instead
of protected) interface; optimize the computation of comparable
distances by not re-computing them from closest features
2014-10-14 11:19:18 +03:00
Menelaos Karavelas
d6b9ee59a5
[algorithms][distance] add a boolean metafunction that returns whether
...
a strategy is comparable or not
2014-10-14 11:16:31 +03:00
Menelaos Karavelas
419a5eadd1
[algorithms][closest_feature] modify the public interface to include
...
a version of the apply methods that returns (via a reference) the
minimum distance
2014-10-14 11:15:34 +03:00
Adam Wulkiewicz
2278e697d0
[read_wkt] Don't append duplicated, closing Points in open Rings/Polygons.
...
Note that Points are still appended if there is not enough Points in the input, i.e. the number is < 3 for open Rings.
2014-10-14 01:34:39 +02:00
Menelaos Karavelas
511845ac94
[algorithms][distance] delete obsolete files; code in these files
...
are to be moved to other files, or replaces by more generic functionality;
2014-10-13 15:24:02 +03:00
Menelaos Karavelas
76132d8737
[algorithms][distance] update the algorithms/detail/distance/implementation.hpp
...
file to reflect the new/updated files
2014-10-13 15:23:00 +03:00
Menelaos Karavelas
efd60133dc
[algorithms][distance] update backward compatibility code according to
...
the new design rationale
2014-10-13 15:22:13 +03:00
Menelaos Karavelas
0daeabbe57
[algorithms][distance] re-factor the point range-to-geometry and
...
geometry-to-geometry distance computations: instead of computing distances
directly, first compute the closest features and then compute the distance
as the distance to the closest features; rewrite point range-to-geometry
distance computation so that the range passed can be a range of segments
of the geometry; remove all dispatch code (moved to other more appropriate files,
or replaced by more compact dispatch code);
2014-10-13 15:18:28 +03:00
Menelaos Karavelas
e74accfab9
[algorithms][distance] re-factor point-to-geometry distance computations;
...
include in point_to_geometry.hpp implementation of point-to-multigeometry
distance computations and dispatches; compute, whenever applicable, the closest
feature of the goemetry to the point, and then compute the distance as the
distance of this closest feature to the point; optimize the performance of
point-to-ring and point-to-polygon by not computing both containment and distance
to the boundary: compute the distance to the boundary only if the containment
test fails;
2014-10-13 15:14:23 +03:00
Menelaos Karavelas
e206352d12
[algorithms][distance] modify segment_to_box generic distance computation
...
to compute first the point-segment pair that realizes the minimum comparable
distance, and then use this pair to compute the actual distance; for the
cartesian-specific approach modify the code to work correctly and efficiently
for both comparable and non-comparable strategies, without calling
distance_comparable_to_regular;
2014-10-13 13:48:16 +03:00
Menelaos Karavelas
f660c3e6ab
[algorithms][distance] modify segment_to_segment distance computation
...
to compute first the point-segment pair that realizes the minimum comparable
distance, and then use this pair to compute the actual distance
2014-10-13 13:45:44 +03:00
Menelaos Karavelas
a472441749
[algorithms][distance] add new implementation for computing the distance
...
between a multipoint and a geometry
2014-10-13 12:21:36 +03:00
Menelaos Karavelas
ce57784e1a
[algorithms][distance] add generic implementation for computing the
...
distance between a geometry (linestring, ring, polygon, multipoint,
multilinestring, multipolygon) and a segment or box
2014-10-13 12:18:02 +03:00
Menelaos Karavelas
a3d5fed181
[algorithms][distance] add generic implementation for distance
...
computation between a linear and a linear/areal geometry
2014-10-13 12:16:56 +03:00
Menelaos Karavelas
f0a8086912
[strategies][distance] eliminate the distance_comparable_to_regular class
2014-10-13 12:16:07 +03:00
Menelaos Karavelas
d8bc8c98b3
[algorithms][distance] modify the dispatch mechanism to cast the
...
geometry tag to segment, box, liear and areal
2014-10-13 12:14:36 +03:00
Menelaos Karavelas
547a76a611
[algorithms][distance] add generic R-Tree based implementation for
...
the distance of two linear geometries: there are two versions implemented,
that differ on the type of objects stored in the R-Tree:
* the points of the geometry are stored in the R-Tree, in which case
the two geometries are first checked for intersection, and then,
using the R-Tree we compute the distances of the points of one geometry
to the segments of the other, and vice versa
* the segments of one geometry are stored in the R-Tree and then the
R-Tree is queried with the segments of the second geometry
The second approach is currently the default.
2014-10-13 11:12:49 +03:00
Menelaos Karavelas
5cdec7ddc8
[algorithms][distance] add a utility class that defines an iterator type
...
based on the type of the geometry:
* returns a point iterator for multipoints
* returns a segment iterator for linestrings, rings, polygons,
multilinestrings and multipolygons
the utility class also provides static begin and end methods for accessing
the first and beyond elements of the iterator type it defines
2014-10-13 11:09:48 +03:00
Menelaos Karavelas
cb6686f4b9
[algorithms][closest_feature] add algorithm for computing the element
...
in a range that is closest to a given geometry
2014-10-13 11:07:51 +03:00
Menelaos Karavelas
7d0313ded8
[algorithms][closest_feature] add algorithm for computing the pair of
...
closest features between two ranges, using the R-Tree
2014-10-13 11:07:00 +03:00
Menelaos Karavelas
f07af4a8de
[algorithms][closest_feature] add algorithm for computing the closest
...
feature between a point and an open/closed range of segments (represented
as a range of points
2014-10-13 10:56:22 +03:00
Menelaos Karavelas
d0b424bde2
[algorithms][distance] replace ignore_unused_variable_warning by ignore_unused
2014-10-13 10:38:18 +03:00
Adam Wulkiewicz
95b3fb45d3
[centroid] Disable translation for non-areal Geometries.
2014-10-11 11:57:49 +02:00
Adam Wulkiewicz
5e3656a09a
[centroid] Disable error-reducing translation for other coordinate systems than cartesian.
...
Remove undefined namespace.
Add missing headers.
Add a note about other coordinate systems.
Add copyright info.
2014-10-11 01:42:20 +02:00
Adam Wulkiewicz
d7722e190a
[centroid] Reduce numerical errors by translating the Geometry closer to 0 and then the result back.
...
The first Point of the Geometry is used as the new origin.
During the centroid calculation each Point is translated by subtracting the origin.
At the end the resulting point is translated back by adding the origin.
2014-10-11 00:14:36 +02:00
Adam Wulkiewicz
45029d6cb5
[point_on_surface] Remove unneeded function.
2014-10-10 20:38:17 +02:00
Adam Wulkiewicz
72c838c16d
Merge pull request #153 from awulkiew/feature/refactor_turns
...
Overlay/Turns refactorization
2014-10-10 20:32:55 +02:00
Adam Wulkiewicz
776cc4c731
[point_on_surface] Use arithmetic mean instead of centroid(bashein-detmer).
2014-10-10 13:04:20 +02:00
Adam Wulkiewicz
e539a09278
[overlay] Move signed_index_type to separate file. Clean headers in ring_ and segment_identifier.hpp.
2014-10-09 01:07:14 +02:00
Adam Wulkiewicz
7cf47bb1e5
[overlay][is_valid] Replace int with signed_index_type for segments indexes.
2014-10-08 23:50:16 +02:00
Adam Wulkiewicz
296f137d85
[overlay][relate][is_valid][buffer] Remove other_id from turn_operation.
2014-10-08 20:23:42 +02:00
Adam Wulkiewicz
795bda6abe
[index] Fix unused parameters warnings.
2014-10-08 00:08:40 +02:00
Adam Wulkiewicz
4c192c76ae
[index] Increase readability of redistribute_elements-related code.
...
Convert struct to functions templates (pick_seeds() functions).
Move template parameters from struct level to method level.
Both for automatic type deduction.
2014-10-07 23:37:09 +02:00
Adam Wulkiewicz
b98df446e4
[index] Use in-memory (std::allocator) temporary containers in redistribute_elements.
2014-10-07 23:04:58 +02:00
Adam Wulkiewicz
8e4bc68ed5
[index] Rename "static" nodes to "variant" nodes (it is more clear).
2014-10-05 16:19:18 +02:00
Adam Wulkiewicz
9d7ed2962e
[index] Remove polymorphic nodes. Add the implementation of weak nodes, not included/used yet.
...
The rationale to remove polymorphic nodes:
1. such nodes can't work properly if stored in shared memory due to the way how addresses are calculated (using offsets).
2. the rtree using Variant-based nodes has similar performance and takes less memory.
3. the rtree using newly added weak_nodes (not supported/enabled yet) will be even faster and smaller.
This is the first step to entirely drop the support for polymorphic nodes. After this it should be not needed to explicitly specify the Nodes types in visitors, therefore it should be possible to dispatch the nodes types statically more conveniently, simplify templates by removal of unneeded parameters, write simpler and more maintainable code, etc.
2014-10-05 15:36:50 +02:00
Adam Wulkiewicz
22bd0ea747
[test][index] Change throwing nodes from polymorphic to variant-based.
2014-10-05 14:40:43 +02:00
Adam Wulkiewicz
5531315d98
[index] Move elements-access-related code to separate file, not mixing it with nodes definition.
2014-10-05 12:29:28 +02:00
Adam Wulkiewicz
0db47437f2
[index] Replace levels type size_t with size_types in R*-tree insert visitor.
2014-10-04 01:40:40 +02:00
Adam Wulkiewicz
3069084c15
[index] Replace levels type size_t with size_types in rtree insert visitor.
2014-10-04 01:29:04 +02:00
Adam Wulkiewicz
1f1f663a12
[index] Replace size_t with proper size_types in rtree remove visitor.
2014-10-04 00:59:06 +02:00
Adam Wulkiewicz
6b8aeabbdf
[index] Cosmetic changes.
...
Remove unneeded typedefs in nodes.
Change the order of template parameters in bgidr::get(dynamic_node<>&)
2014-10-04 00:06:21 +02:00
Adam Wulkiewicz
fa7cd296d3
[index] Refactor count rtree visitor.
...
Remove specialization of count visitor for value_type, don't duplicate the same algorithm in 2 places.
Move Value/Indexable-aware parts into smaller helper struct and specialize it.
2014-10-02 23:40:53 +02:00
Adam Wulkiewicz
a9ac57dc8f
[index] Support objects of type convertible to value_type in rtree::count().
2014-10-02 23:37:32 +02:00
Adam Wulkiewicz
d331bf262a
[index] Tweak type, variable names and description of member and free rtree insert() and remove() functions.
2014-10-02 21:44:18 +02:00
Adam Wulkiewicz
d32066530c
[index] Support objects of type convertible to value_type in insert() and remove().
...
In previous implementation such objects was falling into the overload taking Range.
2014-10-02 21:22:32 +02:00
Adam Wulkiewicz
ff98b648ee
[index] Update copyrights info.
2014-10-02 21:22:11 +02:00
Adam Wulkiewicz
3abe3e0b79
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-10-02 20:08:19 +02:00
Adam Wulkiewicz
eabb17b7e4
[index] Replace uses of traits:xxx with geometry::xxx metafunctions.
2014-10-02 20:06:02 +02:00
Adam Wulkiewicz
b2dfd7f0c8
[index] Use default Dimension templ. params in content() and margin() algorithms.
...
Replace traits::dimension<> with geometry::dimension<>.
2014-10-02 19:57:20 +02:00
Adam Wulkiewicz
e6331558a5
Merge pull request #150 from mkaravel/fix/for_each-alternate
...
[algorithms][for_each] Alternative fix
2014-10-02 12:33:47 +02:00
Adam Wulkiewicz
091ddae7db
[convex_hull] Generate "proper" number of Points also when invalid Output is generated.
...
E.g. for 1- or 2-Point MultiPoint input the Output is a 0-area Ring (Point-like or Segment-like respectively). After this change it should contain "proper" number of Points (3 for open, 4 for closed). The additional Point is added by duplication of the first one.
2014-10-01 22:11:52 +02:00
Adam Wulkiewicz
5c582c6aa5
[convex_hull] Generate consistent results for closed and open Geometries.
...
The result differ only for the last Point duplicated for closed.
This code should be faster than the original since any condition isn't checked inside a copying loop and the end iterators are created only once.
2014-10-01 21:48:38 +02:00
Adam Wulkiewicz
44f3408139
[convex_hull] Fix invalid number of Points generated for open OutputGeometry.
2014-10-01 18:31:31 +02:00
Adam Wulkiewicz
add58fec8c
[iterators] Fix the description of closing_iterator<>.
2014-10-01 16:58:29 +02:00
Adam Wulkiewicz
39802e7923
[core] Add MPL_ASSERT for coordinate dimension > 0
2014-10-01 16:49:49 +02:00
Adam Wulkiewicz
1e968c3590
[index] Add default template parameters in the implementation of is_valid. Remove MPL assert
2014-10-01 16:28:15 +02:00
Barend Gehrels
bf7ca70687
Merge branch 'develop' into feature/buffer
2014-10-01 10:26:21 +02:00
Barend Gehrels
cfb66e85b3
[debug] extend operator<< of segment_ratio, now displaying the real value too
2014-10-01 10:24:21 +02:00
Barend Gehrels
5d93d7a116
[debug] fix operator<< of segment_identifier, now using os
2014-10-01 10:23:39 +02:00
Menelaos Karavelas
6e52b356e7
[algorithms][for_each] fix bug in for_each_segment for open geometries
...
without using the closeable_view (so that mutable geometries can also
be supported)
2014-10-01 09:26:46 +03:00
Adam Wulkiewicz
f1ec0715ee
Merge pull request #147 from mkaravel/fix/for_each
...
[algorithms][for_each] fix bug with for_each_segment for open geometries
2014-09-30 17:53:51 +02:00
Menelaos Karavelas
ac32f9dd58
[algorithms][for_each] fix bug with for_each_segment for open geometries:
...
for_each_segment was not considering the last implicit segment of open
geometries; the patch fixes this;
2014-09-30 17:08:15 +03:00
Menelaos Karavelas
f3ee1dedcd
[algorithms][distance] qualify point_iterator by geometry namespace
...
(needed because of the changes in the point_iterator class, namely
the introduction of the bg::detail::point_iterator namespace)
2014-09-30 17:04:34 +03:00
Menelaos Karavelas
fb35d9db7a
[iterators][segment_iterator] update segment_iterator implementation
...
following the changes in the point_iterator implementation design
and file/directory layout
2014-09-30 15:04:10 +03:00
Menelaos Karavelas
60f184e3ce
[iterators][point_iterator] change file/directory structure for
...
point iterator; use detail::point_iterator namespace for the
implementation details of the point iterator;
2014-09-30 15:02:20 +03:00
Menelaos Karavelas
b9c496a1d8
[iterators][point_reverse_iterator] mark methods and constructors as inline
2014-09-30 15:00:42 +03:00
Adam Wulkiewicz
f76671507a
Merge pull request #141 from mkaravel/feature/segment_iterator
...
Feature/segment iterator
2014-09-30 12:45:57 +02:00
Menelaos Karavelas
10ce79898a
[iterators][segment_iterator] update implementation of segment_iterator
...
due to the change of namespace and name of the segment_iterator_type class;
make constructors of bg::segment_iterator class inline; change the return type
of segments_begin and segments_end to be segment_iterator<Geometry const>;
2014-09-30 09:50:47 +03:00
Menelaos Karavelas
404ca1cbe6
[iterators][segment_iterator] move implementation of bg::segment_iterator_type
...
to bg::detail::segment_iterator namespace; rename the class segment_iterator_type
to iterator_type;
2014-09-30 09:49:26 +03:00
Menelaos Karavelas
029cb92952
[iterators][segment_iterator] fix file-inclusion guarding macro to
...
reflect true file path
2014-09-29 17:15:23 +03:00
Menelaos Karavelas
67e418e705
[iterators][segment_iterator] move range_segment_iterator class to
...
detail::segment_iterator namespace; move bg::segment_iterator_value_type
to bg::detail::segment_iterator::value_type;
2014-09-29 17:10:24 +03:00
Menelaos Karavelas
2a0dceece9
[iterators][segment_iterator] correct comments; fix code length to be
...
at most 80 characters;
2014-09-29 17:06:41 +03:00
Menelaos Karavelas
84b54af205
[iterators][segment_iterator] correct comments
2014-09-29 17:05:35 +03:00
Menelaos Karavelas
bffac4a108
[geometries][pointing_segment] initialize member variables in
...
default constructor with NULL; in get/set access methods check
that the pointers of the segment are not NULL (via assertion);
remove copy constructor and assignment operator: they are the
same as those the compiler would produce automatically;
2014-09-27 14:04:35 +03:00
Menelaos Karavelas
6388a43089
[iterators][segment_iterator] change the value type of the segment iterator
...
from referring_segment to pointing_segment
2014-09-26 11:41:20 +03:00
Menelaos Karavelas
8fc8bd9773
[geometries][pointing_segment] introduce a new segment class called
...
pointing segment; this segment is default constructible, copy constructible
and assignable; it stores pointers to points instead of the points themselves
(for efficiency); this segment class is meant to be the value type of the
segment iterator;
2014-09-26 10:07:20 +03:00
Menelaos Karavelas
039f8f7a48
[algorithms][turns] add missing include that causes compilation error
...
when -DBOOST_GEOMETRY_TEST_DEBUG is defined, and re-arrange order of includes
2014-09-26 09:44:21 +03:00
Barend Gehrels
2c84bb4d49
[buffer] block turns instead of discarding them
...
This fixes case rt_u11
New result of recursive_polygons_buffer: 2 errors out of 510372
2014-09-24 10:36:15 +02:00
Menelaos Karavelas
d2be8d47a3
[iterators][segment_iterator] add implementation for the segment_iterator
...
class, as well as for the free functions segments_begin and segments_end
2014-09-24 08:49:19 +03:00
Menelaos Karavelas
6dea5fca84
[iterators][segment_iterator] add implementation for the underlying
...
segment_iterator type
2014-09-24 08:48:43 +03:00
Menelaos Karavelas
3739d79140
[iterators][segment_iterator] add implementation for an iterator over
...
the segments of a range
2014-09-24 08:48:09 +03:00
Menelaos Karavelas
e9aee61734
[iterators][segment_iterator] add basic dispatch definitions for the
...
segment_iterator and segment_iterator_type classes
2014-09-24 08:45:02 +03:00
Menelaos Karavelas
73ec339f7b
[iterators][concatenate_iterator] add one more template parameter for
...
the reference type (previously it was defaulted to Value&)
2014-09-24 08:43:21 +03:00
Menelaos Karavelas
49af3c4c87
[iterators][flatten_iterator] add one more template parameter for the
...
reference type (previously it was defaulted to Value&)
2014-09-24 08:41:42 +03:00
Menelaos Karavelas
6c6c31d1b2
[iterators][point_iterator] add missing include for interior_type
2014-09-24 08:39:45 +03:00
Patrick J. LoPresti
ff24c271a7
[core] Fix signed/unsigned comparison warnings
2014-09-22 14:13:14 -07:00
Adam Wulkiewicz
0f23d2317a
[index] Fix signed/unsigned comparison in is_valid (MPL_ASSERT).
2014-09-22 00:30:08 +02:00
Barend Gehrels
8643a35da3
Merge branch 'develop' into feature/buffer
2014-09-17 16:33:32 +02:00
Barend Gehrels
c55e000eef
[buffer] small changes in comments/test svg
2014-09-17 16:32:25 +02:00
Barend Gehrels
9298ac2a2c
[buffer] fix intersection points on border, equal points should not be checked
...
and correct order in call to side strategy
This fixes case rt_u10
2014-09-17 16:30:03 +02:00
Mario Lang
29006dc748
Fix missing include.
2014-09-17 10:29:25 +02:00
Adam Wulkiewicz
cc1cfbda01
Merge pull request #136 from awulkiew/fix/winding_spherical
...
Fix/winding spherical
2014-09-12 14:58:20 +08:00
Adam Wulkiewicz
585d59fce4
[within] Fix winding strategy MSVC compilation error. Remove the typename keyword from a type definition without dependent type.
2014-09-12 14:57:22 +08:00
Adam Wulkiewicz
f68659ba33
[relate] Fix unused variable warnings
2014-09-11 10:24:00 +08:00
Barend Gehrels
2b9ff190a8
[buffer] add comments
2014-09-10 15:34:30 +02:00
Barend Gehrels
e6043d9a5c
[buffer] fix cases where intersection point falls between robust piece
...
and non-robust original. We now check robust representions of originals
where this cannot happen
This fixes rt_u9
This obsoletes turn_in_input
2014-09-10 15:33:44 +02:00
Barend Gehrels
fcd0c5b768
[buffer] helper_points (formerly called helper_segments) are now optional
...
and we rescale/finish the piece on the fly and not in a separate call
2014-09-10 13:05:13 +02:00
Barend Gehrels
8f0e0fdcb1
[buffer] fix adding piece for side with a range, the intermediate range points were
...
not added (there is not yet a strategy doing this). Share functionality for adding
a range
2014-09-10 12:10:49 +02:00
Barend Gehrels
2cd418167d
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-09-10 11:12:06 +02:00
Barend Gehrels
834be28e27
[overlay] change comment
2014-09-10 11:10:42 +02:00
Barend Gehrels
9a69055b6c
Merge branch 'develop' into feature/buffer
2014-09-10 11:07:53 +02:00
Barend Gehrels
a1f5f50f15
Merge pull request #134 from awulkiew/fix/winding_spherical
...
Fix/winding spherical
2014-09-10 10:55:57 +02:00
Adam Wulkiewicz
8ad3f134b2
[within] Fix non-cartesian points handling in winding strategy, case when Point's latitude is between Segment's Points latitudes.
2014-09-08 22:13:12 +08:00
Menelaos Karavelas
61c33ca109
[algorithms][num_points] remove check for starting-ending point in range_count
2014-09-05 10:19:08 +03:00
Barend Gehrels
e00d204218
[buffer] remove situation_map because for these sides, rescaling does not give added value and
...
can cause rounding errors
2014-09-03 18:09:35 +02:00
Barend Gehrels
95d794e218
[buffer] fix order when multiple turns are colocated on the same point.
...
This replaces get_relative_order which was not effectively used anymore and
(most probably) get_left_turns.
This fixes case rt_u7
2014-09-03 17:53:21 +02:00
Barend Gehrels
c271df6a8b
Merge branch 'feature/buffer' into develop
...
Conflicts:
test/algorithms/buffer/polygon_buffer.cpp
2014-09-03 11:42:30 +02:00
Adam Wulkiewicz
6dafef017e
[distance] Fix compilation error in get_comparable<> specialization for distance_cross_track_point_box<>
2014-08-30 16:33:05 +02:00
Adam Wulkiewicz
6c4c340934
[distance] Optimize cross_track_point_box - calculate courses only once, do not use other strategies than PP
2014-08-30 13:24:48 +02:00
Adam Wulkiewicz
f29f3a821a
[strategies] Add move course() to algorithms/detail and use it in spherical side and distance strategies.
2014-08-30 03:18:58 +02:00
Adam Wulkiewicz
4fa9f38825
[distance] Add preliminary version of Pt/Box spherical strategy.
2014-08-29 23:42:01 +02:00
Adam Wulkiewicz
ee798cdbc6
[distance] Do not use cartesian default strategy for non-cartesian Pt/Box and Box/Box
2014-08-29 22:33:34 +02:00
Adam Wulkiewicz
0c2d526faa
[num_geometries] Add missing includes, variant-related
2014-08-27 13:09:04 +02:00
Barend Gehrels
02ae40805c
[buffer] remove now redundant member m_last_piece_index
2014-08-27 12:28:44 +02:00
Barend Gehrels
c42aeb4447
[buffer][fix] fix neighbour check in calculating turns. This fixes ticket 10398
2014-08-27 12:27:57 +02:00
Barend Gehrels
12b61c6a0f
Merge branch 'develop' into feature/buffer
2014-08-27 11:34:07 +02:00
Adam Wulkiewicz
b51444a928
[num_segments] Add parentheses to suppress the warning about the operators precedence
2014-08-27 02:25:19 +02:00
Adam Wulkiewicz
98900f3ecf
[math] Replace simple rounding with boost::math::round().
...
Due to a recent fix in Boost.Math for corner cases.
PR: https://github.com/boostorg/math/pull/8
Commit: fb835eb029
2014-08-27 02:05:55 +02:00
Adam Wulkiewicz
3560ae1c93
[index] fix varray const rbegin() and rend().
...
non-const reverse iterator type was used internally.
2014-08-25 13:25:46 +02:00
Adam Wulkiewicz
be637c0929
Merge pull request #128 from mkaravel/feature/counting-algorithms
...
Feature/counting algorithms
2014-08-14 12:57:48 +02:00
Menelaos Karavelas
05a0f16ad5
[doc][algorithms][num_segments] remove add_for_open argument from
...
doxygne documentation; update qbk documentataion to reflect that there
is only one argument to the free function
2014-08-14 00:42:17 +03:00
Menelaos Karavelas
fab29b52e2
[algorithms][num_points] in the range_count class, include the test for n == 0
...
inside the same if as AddForOpen (much like the previous implementation for this
class)
2014-08-12 00:33:03 +03:00
Adam Wulkiewicz
f2cad14377
Merge pull request #124 from mkaravel/feature/is_valid
...
Feature/is valid
2014-08-11 20:19:56 +02:00
Adam Wulkiewicz
5654a36552
[overlay] Fix unused variable warnings (with NDEBUG defined) by removal of unneeded asserts.
2014-08-11 15:42:32 +02:00
Adam Wulkiewicz
a4159a2883
[relate] Fix unused variable warning (with NDEBUG defined).
2014-08-11 15:27:54 +02:00
Menelaos Karavelas
c218f32242
[algorithms][distance] add a comment about the usage of boost::ignore_unused
2014-08-11 14:24:25 +03:00
Menelaos Karavelas
d572ee54e0
[algorithms][distance] fix unused variable warning when boost is compiled in release mode
2014-08-11 13:41:27 +03:00
Barend Gehrels
446b4494cf
[buffer] remove taxicab distance, comparable distance is OK
2014-08-11 12:25:05 +02:00
Menelaos Karavelas
e472d4b439
[algorithms][num_points] re-write the num_points code so that the add_for_open
...
boolean argument is passed at the dispatch level as a template parameter; this
enables the firther simplification of the code in detail::counting namespace
2014-08-11 13:20:07 +03:00
Barend Gehrels
024b131f1e
[buffer] removed wrong comments
2014-08-11 12:19:33 +02:00
Menelaos Karavelas
ebedefc1da
[algorithms][num_segments] remove the boolean argument: num_segments
...
will always return the true number of segments of the geometry
2014-08-11 13:19:25 +03:00
Menelaos Karavelas
77f5a5b136
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/counting-algorithms
2014-08-11 13:12:30 +03:00
Barend Gehrels
bcc2273e1c
[overlay][enrich] rename index to turn_index and make indices std::size_t
2014-08-11 11:38:01 +02:00
Barend Gehrels
61d8cb20f6
[overlay][enrich] avoid copies of operation/ids by using const*
2014-08-11 11:34:03 +02:00
Barend Gehrels
d227658122
[overlay] use seg_id instead of other_id in enrich phase
2014-08-11 10:59:34 +02:00
Menelaos Karavelas
01043518b3
[algorithms][num_segments] simplify the computation of num_segments for boxes
2014-08-11 01:45:45 +03:00
Menelaos Karavelas
9bcdfa8c49
[algorithms][num_points] simplify the computation of num_points for boxes
2014-08-11 01:45:12 +03:00
Menelaos Karavelas
43df5efe96
[test,algorithms][util] remove ipower and its unit test
2014-08-11 01:43:37 +03:00
Bruno Lalande
40229f12e6
[union] Remove another unjustified intermediate function
2014-08-10 22:50:33 +01:00
Bruno Lalande
1221b71fc7
[union] Remove unjustified intermediate function
2014-08-10 22:50:27 +01:00
Adam Wulkiewicz
7d58d1d6a0
[index] Add alternative ABL handling - using heap instead of sorted container
...
Code is commented out, left "for the record" as a result of a quick test.
Add some comments about possible improvements.
2014-08-10 18:27:58 +02:00
Adam Wulkiewicz
313408d114
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-08-10 16:21:00 +02:00
Adam Wulkiewicz
8e387e853b
[index] Remove unneeded pushable_array container
2014-08-10 16:20:48 +02:00
Adam Wulkiewicz
70e6700690
[index] Fix unused type warnings in experimental serialization code
2014-08-10 16:15:11 +02:00
Adam Wulkiewicz
17fd9c6fdb
[index] Remove/modify some comments
2014-08-10 16:08:54 +02:00
Barend Gehrels
a7764c1b9e
[buffer][fix] use taxicab distance instead of comparable distance
...
This is faster and avoids overflows. This fixes rt_u6
2014-08-10 15:32:07 +02:00
Barend Gehrels
31abd20829
[buffer][fix] Distinguish between "within" and "within_near_offsetted"
...
The last one might be offsetted by 1 due to integer rounding. It is not
selectable as a starting point but may be used for traversal
2014-08-10 14:15:04 +02:00
Barend Gehrels
6df7738d3a
[buffer][fix] Fix turns which were only on helper-segments, they can be discarded.
...
This fixes rt_u3 and rt_u4 where a false interior ring was generated
2014-08-10 12:49:37 +02:00
Barend Gehrels
b469509bd0
[buffer][fix] Fix accidental removal of == 0
2014-08-10 12:48:22 +02:00
Barend Gehrels
a46e2603d8
[buffer][fix] In rare cases an extra ring was traversed and created. Fixed, that ring is
...
discarded now. This fixes behaviour of assign_parents with positive-rings in positive-rings (when
check_for_orientation is true; normally (for overlay) it is false)
It also reverses a negative-only ring so fixes a linestring_buffer testcase.
For multi-polygon it fixes new testcase rt_u2 found by recursive-polygon-buffer test
2014-08-09 23:51:42 +02:00
Barend Gehrels
bdcdb5717e
[buffer] don't check neighbor for on-border
2014-08-09 23:18:48 +02:00
Barend Gehrels
536f6a6974
[buffer] remove unused variable
2014-08-09 23:06:15 +02:00
Barend Gehrels
9df6901a87
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-08-09 22:56:59 +02:00
Barend Gehrels
f41b90f166
Merge branch 'feature/buffer' into develop
2014-08-09 22:56:36 +02:00
Menelaos Karavelas
50d6739c62
[algorithms][disjoint] rename struct multipoint_geometry to
...
multipoint_constant_size_geometry
2014-08-09 01:14:03 +03:00
Menelaos Karavelas
03705c3df7
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/disjoint-1.57
2014-08-09 01:03:41 +03:00
Menelaos Karavelas
3ecdfc4886
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_valid
2014-08-09 00:48:33 +03:00
Menelaos Karavelas
eaf3634509
[algorithms][num_geometries][num_interior_rings][num_points][num_segments]
...
move concept checking from free function to struct calling the dispatch
class (i.e., after the variant resolution is done)
2014-08-08 23:31:55 +03:00
Menelaos Karavelas
b0c06af00b
[algorithms][num_segments] replace unnecessary "typename" by "inline"
2014-08-08 20:50:51 +03:00
Menelaos Karavelas
66a06a20c4
[algorithms][num_points][num_geometries][num_interior_rings] replace
...
unnecessaty "typename" by "inline"
2014-08-08 20:48:09 +03:00
Menelaos Karavelas
e14c0aa350
[algorithms][num_points][num_interior_rings][num_geometries]
...
coding style change: move curly brace at beginning of next line
2014-08-08 20:43:25 +03:00
Barend Gehrels
b9c3c45902
Merge pull request #127 from mkaravel/fix/buffer-include-header
...
[algorithms][buffer] fix header for inclusion of disjoint
2014-08-08 19:39:27 +02:00
Adam Wulkiewicz
34c0c8940f
[views] Fix compilation error in box_view caused by the change of a detail::assign_box_corners_oriented() body.
...
This function requires Range but was using operator[] which isn't a part of Range concept.
And box_view passed a raw pointer into this function.
So now a temporary range std::pair<> is created and passed, this might be changed if point_view stored boost:array<>.
It could be directly passed into the assign_box_corners_oriented.
2014-08-08 18:17:15 +02:00
Adam Wulkiewicz
0c78ad8489
[assign_box_corners] Fix Range concept usage.
2014-08-08 17:21:14 +02:00
Adam Wulkiewicz
800f174e28
[convert] Fix Range concept usage.
2014-08-08 17:18:06 +02:00
Adam Wulkiewicz
0101ba37c5
[append] Fix interior rings and multi Range concept usage.
2014-08-08 17:15:17 +02:00
Adam Wulkiewicz
daf4c5ac2b
[index] Fix compilation error - invalid variable name in assert.
2014-08-08 17:00:56 +02:00
Adam Wulkiewicz
bd4a66ddd3
[range_by_section] Fix Range concepts conformance for interior rings and multi ranges.
2014-08-08 16:59:21 +02:00
Adam Wulkiewicz
6df273f5e7
[convert] Replace index type to unsigned
2014-08-08 16:54:34 +02:00
Adam Wulkiewicz
4089337045
[overlay] Fix Range concepts conformance for interior rings and multi ranges.
2014-08-08 16:46:27 +02:00
Adam Wulkiewicz
183124057e
[index] Update copyright info
2014-08-08 15:04:10 +02:00
Adam Wulkiewicz
f24430c300
[index] Optimize R* choose_next_node - remove sort() and cleanup
2014-08-08 14:59:15 +02:00
Menelaos Karavelas
4444dd1824
[algorithms][multi][num_points] move code from multi/algorithms/ directory
...
to algorithms/ directory
2014-08-08 13:23:04 +03:00
Menelaos Karavelas
ba5e60fd25
[algorithms][num_segments]
...
* move code common to other counting algorithms in namespace
detail::counting (in file algorithms/detail/counting.hpp)
* implement algorithm for boxes of any dimension
2014-08-08 13:20:48 +03:00
Menelaos Karavelas
d2e7bc17e8
[algorithms][num_points]
...
* move code common to other counting algorithms in namespace
detail::counting (in file algorithms/detail/counting.hpp)
* implement detail::range_count using detail::num_segments::range_count
* implement algorithm for boxes of any dimension
2014-08-08 13:17:26 +03:00
Menelaos Karavelas
c6c2b1a1bd
[algorithms][num_geometries]
...
* add variant support
* use common functionality in namespace detail::counting for implementing this free function
2014-08-08 13:03:31 +03:00
Menelaos Karavelas
34273f2dea
[algorithms][num_interior_rings]
...
* add variant support
* add concept checking for the geometry
* use code in geometry::detail::counting for implementing this function
2014-08-08 13:01:29 +03:00
Menelaos Karavelas
c94443d3d4
[util] add compile-time Boost.MPL-based implementation for computing
...
the power of an integral constant; this is used for computing (at
compile-time) the number of points and segments of a box in any dimension;
2014-08-08 12:54:08 +03:00
Menelaos Karavelas
f49f321700
[algorithms][detail][counting algorithms] move common functionality of
...
all counting algorithms in one place and in new namespace:
geometry::detail::counting
2014-08-08 12:51:42 +03:00
Menelaos Karavelas
ac4dd2c2f7
[algorithms][buffer] fix header for inclusion of disjoint: it is
...
the point-box and not the box-box version that is needed; also
the call to disjoint is not done via the free function but rather
using the disjoint dispatch struct
2014-08-08 12:25:31 +03:00
Adam Wulkiewicz
8d7b70c3e0
[index] Change the condition and asserts in R*-tree redistribute_elements nth_element
2014-08-08 02:06:26 +02:00
Adam Wulkiewicz
34dcb881d1
[index] Replace partial_sort() with nth_element() in R*-tree redistribute_elements.
2014-08-08 01:38:39 +02:00
Adam Wulkiewicz
5e5044c9d3
[index] Optimize R*-tree choose_next_node by nearly minimum overlap cost - replace partial_sort() with nth_element() and sort()
2014-08-08 00:54:27 +02:00
Adam Wulkiewicz
0728c799dc
[follow] Fix msvc size_t to int conversion warnings
2014-08-07 00:52:40 +02:00
Adam Wulkiewicz
df40ef3bc7
[follow] Fix msvc size_t to int conversion warnings
2014-08-07 00:34:00 +02:00
Adam Wulkiewicz
74a38b84dd
Merge pull request #126 from mkaravel/feature/num_segments
...
Feature/num segments
2014-08-06 23:10:35 +02:00
Adam Wulkiewicz
3148a3bda5
[intersection] Move from multi directory.
2014-08-06 20:29:35 +02:00
Adam Wulkiewicz
64f6eac9b5
[num_interior_rings] Move from multi directory.
2014-08-06 19:39:49 +02:00
Adam Wulkiewicz
9796c27b8a
[append] Move the code from multi directory
2014-08-06 19:22:06 +02:00
Barend Gehrels
e1fc427e30
[buffer][fix] Mark points in buffered areas as not startable instead of discarding them
...
Within can have in rare cases a rounding issue. We don't discard this
point, so it can be used to continue started rings in traversal. But
will never start a new ring from this type of points.
This fixes p17
2014-08-06 13:27:52 +02:00
Menelaos Karavelas
c81e8ac430
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/num_segments
2014-08-06 14:13:46 +03:00
Menelaos Karavelas
c9b5e09fff
[algorithms][convert, extreme_points] add missing typename
2014-08-06 14:08:46 +03:00
Menelaos Karavelas
be586b5947
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/num_segments
2014-08-06 14:02:26 +03:00
Menelaos Karavelas
f4aeb4f7c6
[algorithms][is_valid] use bg::partition to test whether polygons
...
(not associated with any turns) do not intersect/overlap each other
2014-08-06 13:37:08 +03:00
Menelaos Karavelas
9641372738
[algorithms][is_valid] make the visitor for partition more generic
...
(semantically) so that it fits the semantics of the visitor needed
for partition in the multipolygon case
2014-08-06 13:35:35 +03:00
Menelaos Karavelas
5cf1371594
[algorithms][is_valid] fix bug in collecting ring iterators not
...
associated with turns; rename overlaps_ring to overlaps_box;
rewrite expand_box and overlaps_box in a more generic way (the
arguments are considered now as generic iterators, not necessarily
iterators or rings);
2014-08-06 13:17:28 +03:00
MarekKurdej
a65a94afbc
Fix warnings about narrowing conversions on 64-bit systems with 32-bit int.
2014-08-06 11:55:31 +02:00
Menelaos Karavelas
94ebb3bf72
[algorithms][is_valid] use bg::partition to check whether the interior
...
rings of a polygon (that are disjoint from each other and from the
exterior ring) do not overlap with each other
2014-08-06 12:36:20 +03:00
Adam Wulkiewicz
15fa1ed063
[distance] Fix unused variable MSVC warning in segment/box and replace ignore_unused_variable_warning() with ignore_unused().
2014-08-01 18:04:57 +02:00
Menelaos Karavelas
9c96fc5e94
[algorithms][disjoint] add alternate implementation for
...
disjoint(multipoint, multipoint) that uses BG's partition;
2014-07-31 15:40:58 +03:00
Menelaos Karavelas
7cceafa252
[algorithms][disjoint] implement disjoint for the following combinations:
...
* multipoint / point
* multipoint / segment
* multipoint / box
* multipoint / multipoint
2014-07-31 11:41:00 +03:00
Barend Gehrels
df5326b5ad
[partition] changed wrong assert
2014-07-30 15:06:27 +02:00
Barend Gehrels
41a20cd657
Merge pull request #119 from mkaravel/fix/set_tp-point-types
...
[algorithms][get_turn_info] fix bug reported by Jeremy Murphy on the boost mailing list
2014-07-30 10:46:30 +02:00
Menelaos Karavelas
2d96f3ced9
[algorithms][get_turn_info] fix bug reported by Jeremy Murphy on
...
the boost mailing list; in collinear_opposite the set_tp method
was assuming that all point types passed to it are the same; this
is not the case: there are two different point types; the problem
appeared when using point_xy in rtree and running intersects queries;
in this case get_turn_info was instantiated with two different point types,
the one used by the user and the one used by the rtree to store boxes,
which were different.
2014-07-30 11:20:39 +03:00
Menelaos Karavelas
e1dfe2e594
[algorithms][intersects] change robustness policy to no_rescale_policy
2014-07-29 15:20:59 +03:00
Adam Wulkiewicz
a73a1c4a1f
[strategies] Add missing include to point_in_poly_winding
2014-07-29 00:17:23 +02:00
Menelaos Karavelas
e98bfaca4a
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/num_segments
2014-07-29 00:34:33 +03:00
Barend Gehrels
25c1f722a7
Merge branch 'develop' into prepare
...
Conflicts:
extensions/test/gis/projections/projection_epsg.cpp
include/boost/geometry/extensions/gis/projections/impl/pj_ell_set.hpp
include/boost/geometry/extensions/gis/projections/proj/lcca.hpp
2014-07-28 22:48:16 +02:00
Barend Gehrels
d892855b79
[fix] For the approximation in segment_ratio, change int to double
2014-07-28 22:43:25 +02:00
Adam Wulkiewicz
ce98415c26
[geometry] Change the order of io and views includes - alphabetical asc
2014-07-28 18:29:25 +02:00
Adam Wulkiewicz
b2c71e5694
Merge pull request #117 from mkaravel/doc/include-headers
...
[doc][include headers] add a few more headers in geometry.hpp
2014-07-28 18:11:19 +02:00
Adam Wulkiewicz
93f64b2ae4
[index] redistribute_elements - use temporary container differently (R*) and add some comments
2014-07-28 18:05:30 +02:00
Menelaos Karavelas
9a2c6d3a43
[doc][include headers] add a few more headers in geometry.hpp
...
so that the documentation lists boost/geometry.hpp as an alternative
include header for the corresponding functionality; these headers
are related to some core functionality, views and i/o
2014-07-28 11:12:48 +03:00
Adam Wulkiewicz
3ee120efce
[index] Add some notes about exceptions.
2014-07-28 00:37:07 +02:00
Barend Gehrels
8a29842df2
[buffer][fix] Don't add piece if strategy returns false
2014-07-27 18:47:49 +02:00
Barend Gehrels
76bebeee6c
[buffer][fix] don't check within concave helper pieces
2014-07-27 18:12:04 +02:00
Barend Gehrels
d99d6edfa6
[buffer][fix] Avoid check neighbors on the border for inside, that
...
should not be the case (but might, by rounding errors)
2014-07-27 17:41:32 +02:00
Barend Gehrels
9467d5d060
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-07-27 17:13:13 +02:00
Barend Gehrels
60e6456c52
[side] removed unused method
2014-07-27 17:09:14 +02:00
Barend Gehrels
cb4b5dafe0
[comments] fixed typos
2014-07-27 17:08:55 +02:00
Barend Gehrels
feccd380ee
[buffer][fix] Fix limit for consideration as continue, as it was too high
...
(for Aimes test or in general cases using lat long)
Including addition of unit test (aimes181)
2014-07-27 17:07:32 +02:00
Adam Wulkiewicz
289645037d
[get_turns] Remove unneeded condition in get_turn_info_helpers
2014-07-26 17:46:45 +02:00
Barend Gehrels
dd3c59272f
Merge pull request #111 from mkaravel/doc/assign
...
Fix header includes for assign_values documentation
2014-07-25 18:02:19 +02:00
Adam Wulkiewicz
940bef67dc
[algorithms] Remove extra semicolons in check_iterator_range
2014-07-25 16:27:15 +02:00
Adam Wulkiewicz
b7c855022d
[extensions][proj] Remove unused variable in lcca
2014-07-25 15:30:12 +02:00
Adam Wulkiewicz
c4e442fffe
[extensions][proj] Fix compilation error
2014-07-25 15:04:20 +02:00
Menelaos Karavelas
ef6598e7d5
[algorithms][assign] move assign_values free functions from
...
detail/assign_values.hpp to assign.hpp; done in order to have the
documentation for assign_values in the assign.hpp file;
2014-07-25 12:59:35 +03:00
Barend Gehrels
f4203db687
[buffer][fix] syntax of defines
2014-07-23 17:41:38 +02:00
Barend Gehrels
1fa87bcbba
[buffer][fix] to get a proper rescale policy, the buffer distance must be added
2014-07-23 15:13:16 +02:00
Barend Gehrels
f09387fabb
[buffer][fix] Fixed detection of difference spike/continue
2014-07-23 13:32:24 +02:00
Barend Gehrels
b83bd46243
[buffer] use promoted types in buffer_join_round
2014-07-23 13:16:40 +02:00
Barend Gehrels
c863a0dfca
[buffer][fix] remove unintended minus signes uncatched earlier
...
(they come from a git gui copy/paste)
This is quite a difference (in the aimes_test case)
2014-07-23 12:52:37 +02:00
Menelaos Karavelas
8704854033
[algorithms][relate] add missing includes; qualify binary_search with std:: namespace
2014-07-22 15:16:42 +03:00
Barend Gehrels
573c21f933
Merge branch 'develop' into prepare
...
Conflicts:
extensions/example/gis/io/shapelib/shapelib.cpp
include/boost/geometry/extensions/algorithms/detail/overlay/dissolver.hpp
include/boost/geometry/extensions/algorithms/offset.hpp
include/boost/geometry/extensions/gis/io/wkb/detail/parser.hpp
include/boost/geometry/extensions/gis/projections/impl/pj_auth.hpp
include/boost/geometry/extensions/gis/projections/impl/pj_ell_set.hpp
2014-07-21 22:58:40 +02:00
Barend Gehrels
5e99fb4987
[point_in_geometry] remove todo item - it should stay -1, 0, 1, these
...
numbers can be used in calculations
2014-07-20 16:55:57 +02:00
Barend Gehrels
d66b7a0ee1
[buffer] remove obsolete todo items
2014-07-20 16:55:09 +02:00
Barend Gehrels
2cd7615435
[buffer] side_straight strategy, promote type
2014-07-20 16:52:26 +02:00
Barend Gehrels
77b2723935
[buffer] make miter_limit flexibel and correct IP to exactly that limit
2014-07-20 16:38:32 +02:00
Barend Gehrels
804fea10e3
[buffer][fix] avoid warning
2014-07-20 15:58:20 +02:00
Barend Gehrels
384632c572
[buffer] change default constructors for round strategies and
...
changed corresponding samples (often omitting the number for non relevant
strategies)
2014-07-20 15:51:49 +02:00
Barend Gehrels
487609b233
[buffer][doc] Enhance doc
2014-07-20 13:45:58 +02:00
Barend Gehrels
d945001bbf
[buffer][doc] Add documentation for side_straight, extended doc for buffer with strategies
2014-07-20 13:29:07 +02:00
Barend Gehrels
6100b695be
[buffer][doc] Enhancements, cross-links, doc-fixes
2014-07-20 11:32:02 +02:00
Barend Gehrels
0e77ef5342
[buffer] rename buffer_side to side_straight to make it consistent with other buffer strategies
...
and buffer is already part of the namespace
2014-07-20 10:52:48 +02:00
Barend Gehrels
0b635e342d
[buffer] rename buffer_circle to point_circle to have it consistent with other strategies,
...
and buffer is already in the namespace. same for buffer_square -> point_square
2014-07-20 10:38:40 +02:00
Barend Gehrels
62c821297e
[buffer][doc] Avoid having apply and other buffer-strategy members in the doc
...
They are not relevant for the user. They should only be relevant for users developing
their own strategies, but that should be documented in the (upcoming) strategy concepts
2014-07-20 10:13:32 +02:00
Barend Gehrels
c12701bb40
[buffer] documentation of 6 distance strategies
2014-07-19 23:05:45 +02:00
Barend Gehrels
46068123b9
[buffer] create documentation about PointStrategy (buffer_circle)
...
add buffer_square as alternative
2014-07-19 14:36:39 +02:00
Barend Gehrels
bfa80944ec
[buffer] avoid compiler warnings
2014-07-18 21:56:11 +02:00
Barend Gehrels
e4d40a2287
[buffer] rename CircleStrategy template argument to PointStrategy because
...
it might also generate squares etc.
2014-07-18 21:29:59 +02:00
Barend Gehrels
d3b135a939
[buffer] use promoted type and made variables const
2014-07-18 20:57:56 +02:00
Menelaos Karavelas
42e16b463f
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/num_segments
2014-07-17 09:28:56 +03:00
Adam Wulkiewicz
6ea0517b38
Merge pull request #96 from mkaravel/feature/distance
...
Optimize distance computations for multi-to-multi and single-to-multi
2014-07-17 02:38:57 +02:00
Menelaos Karavelas
428e010146
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/num_segments
2014-07-17 03:29:16 +03:00
Menelaos Karavelas
1a266ba996
[geometry] include algorithm num_segments
2014-07-17 03:02:30 +03:00
Menelaos Karavelas
3fe14e1df5
[algorithms][num_segments] add doxy/qbk documentation
2014-07-17 03:01:33 +03:00
Menelaos Karavelas
fa203789db
[algorithms][distance] check distance against 0 only when the minimum
...
distance is updated
2014-07-17 02:30:21 +03:00
Adam Wulkiewicz
9dfc90f151
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-07-16 20:50:12 +02:00
Adam Wulkiewicz
36da684609
[winding] Add winding_side_equal optimized for cartesian CS.
2014-07-16 20:44:07 +02:00
Barend Gehrels
5df31ddd0e
[buffer] add documentation for buffer with 5 strategies
2014-07-16 17:01:50 +02:00
Barend Gehrels
97fd8f5332
[buffer] move buffer_inserter to namespace detail::buffer, add overload using 5 strategies
2014-07-16 16:58:02 +02:00
Menelaos Karavelas
2e8e6d6f4a
[algorithms][num_segments] add num_segments algorithm: computes
...
the number of segments in a geometry (including geometry variants)
2014-07-16 17:36:35 +03:00
Barend Gehrels
038253e8f5
[buffer] remove end_skip strategy
2014-07-16 15:21:11 +02:00
Barend Gehrels
61ed918240
[buffer] add side/circle strategies to include
2014-07-16 15:12:52 +02:00
Barend Gehrels
bac1ac66af
[buffer] avoid having point types in strategies which can be deferred
2014-07-16 15:11:55 +02:00
Barend Gehrels
4966ff5359
[buffer] removed many unnecessary includes from buffer_side
2014-07-16 11:39:13 +02:00
Barend Gehrels
fc0819b8ae
[buffer] removed non-used phase parameter
2014-07-16 11:36:06 +02:00
Barend Gehrels
2bdca94e52
[buffer] changed comments
2014-07-16 11:35:29 +02:00
Barend Gehrels
0f027b5ff9
[buffer] add buffer_circle strategy for points and multi-points, and pass
...
it all the way through the dispatches
2014-07-16 11:31:35 +02:00
Barend Gehrels
57854c2765
[buffer] optionally simplify using ax strategy
2014-07-16 10:45:14 +02:00
Barend Gehrels
dc46575175
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-07-15 22:37:41 +02:00
Adam Wulkiewicz
e3f778511b
Merge pull request #95 from awulkiew/feature/point_in_geometry
...
Fix for within() - ticket https://svn.boost.org/trac/boost/ticket/9628
2014-07-14 23:20:16 +02:00
Adam Wulkiewicz
2ba3e9a95b
[strategies][winding] Replace Points creation using copy-ctors with default-ctors + set<>()
...
Also add some comments about what's going on in the code.
2014-07-14 23:17:09 +02:00
Barend Gehrels
9ed4d83441
[extensions][offset] Let offset compile again.
...
Note: it does not generate correct offsets!
2014-07-14 22:00:57 +02:00
Barend Gehrels
c5241dd8ee
[distance] added missing include file
2014-07-14 21:54:01 +02:00
Adam Wulkiewicz
edf2c00db6
[within][winding] Add more robust calculation of sides in winding strategy.
...
This commit fixes the ticket https://svn.boost.org/trac/boost/ticket/9628 .
The side is calculated always WRT the vertical segment if the p<1> is "equal" to one of the segment endpoint's <1>.
For more information see the comment in the code.
2014-07-14 16:05:26 +02:00
Menelaos Karavelas
9164a5bc0c
[multi][algorithms][num_points] add include for std::size_t;
...
qualify with std:: an occurrence of unqualified size_t;
2014-07-14 14:44:22 +03:00
Adam Wulkiewicz
3e9f1296c5
[relate] Add 'const' keyword to declarations of not modified variables.
2014-07-13 01:16:19 +02:00
Marcel Raad
ca96640521
Fix MSVC compiler warnings
...
This removes unused variables and redundant re-declarations to silence
warnings about variable shadowing. Tested on MSVC 14 CTP2.
2014-07-12 13:18:47 +02:00
Barend Gehrels
96d8f53fbc
[buffer] Avoid accessing pieces if no pieces were added
2014-07-12 11:42:27 +02:00
Menelaos Karavelas
350ca25ccd
[algorithms][distance] add dispatch for the three multigeometry-to-ring combinations
2014-07-11 17:10:14 +03:00
Menelaos Karavelas
8df21c677e
[algorithms][distance] add dispatch for the ring/ring combination
2014-07-11 17:09:15 +03:00
Adam Wulkiewicz
2a6da93c85
[core][doc] Improve template parameter name and add the description.
2014-07-11 02:44:55 +02:00
Adam Wulkiewicz
03a1fbc91b
[arithmetic][doc] Improve functions parameters types names and their description.
2014-07-11 02:41:54 +02:00
Adam Wulkiewicz
bd76327102
Merge pull request #84 from mkaravel/feature/distance
...
Feature/distance
2014-07-10 23:35:37 +02:00
Adam Wulkiewicz
fbe09296fb
Merge pull request #86 from mkaravel/feature/length_perimeter_result
...
Feature/length perimeter result
2014-07-10 23:35:26 +02:00
Adam Wulkiewicz
b9fecf0887
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-07-10 16:41:50 +02:00
Adam Wulkiewicz
02cfd55510
[centroid][doc] Add description for centroid_exception member functions.
2014-07-10 16:40:45 +02:00
Menelaos Karavelas
b37ea9c8b4
[algorithms][comparable distance] implement variant support as in
...
all other algorithms
2014-07-10 11:30:47 +03:00
Menelaos Karavelas
9dff7bae4b
[algorithms][distance] polish code (among other things, keep lines
...
up to 80 characters long)
2014-07-10 11:29:58 +03:00
Menelaos Karavelas
a3d1f1ce73
[strategies][comparable distance (result)] implement comparable distance
...
result variant support as in all other algorithms
2014-07-10 11:28:29 +03:00
Menelaos Karavelas
ac30cfc6f5
[strategies][distance (result)] eliminate default_comparable_strategy;
...
qualify variant by boost:: namespace;
2014-07-10 11:26:20 +03:00
Menelaos Karavelas
5640586f39
[algorithms][perimeter] replace result_of::length by default_length_result
2014-07-10 10:10:19 +03:00
Menelaos Karavelas
dacff470ee
[algorithms][length] replace result_of::length by default_length_result
2014-07-10 10:09:46 +03:00
Menelaos Karavelas
927cbc9f01
[strategies][length (result)] eliminate result_of namespaces
2014-07-10 10:09:07 +03:00
Adam Wulkiewicz
2912e1b199
[strategies] Add more robust check in projected_point_ax_less
2014-07-09 17:30:38 +02:00
Menelaos Karavelas
e1093bc4a3
[strategies][distance (result)] add missing include
2014-07-09 15:02:33 +03:00
Adam Wulkiewicz
a6ed7d86ea
Merge branch 'develop' into feature/projected_point
2014-07-09 13:59:23 +02:00
Adam Wulkiewicz
8c20242948
[strategies] Modify handling of 0-length segments in projected_point_ax.
...
For 0-length segments assume that the segment is perpendicular to the Pt->ProjPt vector.
In other words ATD = 0.
2014-07-09 13:37:29 +02:00
Adam Wulkiewicz
c55cee5dd3
[strategies] Fix projected_point_ax+douglass_peucker compilation errors.
...
Add again operator< for projected_point_ax_result needed to compare the distance with 0 (explicitly converted into the same type).
Remove template parameter from projected_point_ax_less::operator().
Add tests for simplify() and detail::simplify_insert().
2014-07-09 12:58:02 +02:00
Barend Gehrels
64f0380591
[buffer] move simplify call to separate function to apply using ax-strategy
2014-07-09 12:26:32 +02:00
Barend Gehrels
0315125492
[simplify] fix double, replaced by template parameter
2014-07-09 11:21:40 +02:00
Adam Wulkiewicz
e49434ec6c
[strategies] Add less-comparator for projected_point_ax result in detail::douglas_peucker
2014-07-08 21:16:18 +02:00
Adam Wulkiewicz
282a2536a3
[strategies] Add douglas_peucker version taking LessCompare
2014-07-08 20:52:11 +02:00
Menelaos Karavelas
8820e7e266
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/distance
2014-07-08 12:44:32 +03:00
Menelaos Karavelas
f33e90b916
[strategies][comaprable distance] add default_comparable_strategy:
...
this is a placeholder for comparable distance strategies used for
resolving strategies during the resolve variant stages
2014-07-08 12:40:53 +03:00
Menelaos Karavelas
77e4f4b472
[strategies][comparable distance (result)] implement variant-aware
...
comparable distance result
2014-07-08 12:39:36 +03:00
Menelaos Karavelas
325dbe203b
[strategies][distance (result)] polish code a bit;
...
eliminate result_of namespaces; replace result_of::distance by
distance_result; add support for comparable distances (i.e., add
specializations for default_comparable_strategy);
qualify occurences of variant with boost:: ;
fix bug: when resolving strategies, pass actual geometries instead
of their point types (important in order to return the actual/correct
strategy return type);
2014-07-08 12:34:56 +03:00
Menelaos Karavelas
6681aefa22
[algorithms][comparable distance] make comparable distance algorithm
...
variant-aware
2014-07-08 12:32:00 +03:00
Menelaos Karavelas
3d17b42a12
[algorithms][distance] eliminate result_of namespaces; replace
...
result_of::distance by distance_result;
2014-07-08 12:26:29 +03:00
Adam Wulkiewicz
f20303af2f
[buffer][test] Fix bugs in get_left_turns and some in the robustness test
2014-07-08 02:57:29 +02:00
Adam Wulkiewicz
869cff7004
[is_simple][is_valid] Remove non-ASCII characters
2014-07-08 02:01:46 +02:00
Adam Wulkiewicz
78ac419c2a
[extensions][gis] Replace assert with BOOST_ASSERT
2014-07-08 01:49:30 +02:00
Barend Gehrels
b6b49f5308
[buffer] fix check of buffer_flat_end for inside
2014-07-06 20:22:04 +02:00
Adam Wulkiewicz
0b677ae1aa
[strategies] projected_point_ax strategy relocated to separate file
2014-07-05 19:57:41 +02:00
Adam Wulkiewicz
0170ebe9ca
[strategies] Remove inconsistent (and for now not needed) operators in projected_point_ax_result
2014-07-04 19:04:04 +02:00
Adam Wulkiewicz
3855610e05
Add projected_point_ax cartesian distance strategy.
2014-07-04 17:14:15 +02:00
Barend Gehrels
da1323716a
[buffer] Pass side strategy
2014-07-03 19:59:28 +02:00
Adam Wulkiewicz
4c2e23611e
Merge pull request #87 from mkaravel/feature/is_simple
...
[algorithms][is_valid] declare debug_complement_graph as inline
2014-07-03 14:54:38 +02:00
Menelaos Karavelas
be9a9ea8f5
[algorithms][is_valid] declare debug_complement_graph as inline
...
(should fix clang-darwin-{asan,asan11,tot,tot11} errors in
develop regression matrix)
2014-07-03 13:03:17 +03:00
Menelaos Karavelas
4b013a12d3
[algorithms][perimeter] change perimeter return type to default_length_result<...>::type
2014-07-03 01:41:19 +03:00
Menelaos Karavelas
28806c9095
[algorithms][length] change length return type to default_length_result<...>::type
2014-07-03 01:40:08 +03:00
Menelaos Karavelas
244d11da3f
[strategies][length] make the default length result variant aware
2014-07-03 01:39:36 +03:00
Menelaos Karavelas
2a16d6a554
[strategies][distance] replace variant.hpp include by variant_fwd.hpp
2014-07-03 01:12:10 +03:00
Menelaos Karavelas
730213814c
[strategies][distance] simplify implementation of distance_result
2014-07-03 00:51:20 +03:00
Menelaos Karavelas
79b4dd94d4
[util][compress variant] fix a typo in the comments
2014-07-03 00:34:27 +03:00
Menelaos Karavelas
8f4de21822
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/distance
2014-07-02 23:44:23 +03:00
Menelaos Karavelas
55a7922e1a
[algorithms][distance] polish includes; move code in resolve_strategy::result_of
...
and resolve_variant::result_of namespaces to strategies/distance_result.hpp;
change return type for the distance free function to distance_result<...>::type
or default_distance_result<...>::type (depending on whether a strategy is
passed or not, respectively)
2014-07-02 23:32:22 +03:00
Menelaos Karavelas
efd21367ab
[algorithms][comparable distance] change the return type of
...
comparable_distance to comparable_distance_result<...>::type
2014-07-02 23:30:20 +03:00
Menelaos Karavelas
baf0be47da
[strategies][comparable distance] re-implement default_comparable_distance_result
...
using comparable_distance_result
2014-07-02 23:29:04 +03:00
Menelaos Karavelas
8e22379623
[strategies][distance] re-implement default_distance_result using
...
distance_result
2014-07-02 23:28:34 +03:00
Menelaos Karavelas
f7cfb6a259
[strategies][comparable distance] implement the class
...
comparable_distance_result
2014-07-02 23:28:03 +03:00
Menelaos Karavelas
86c96deaaf
[strategies][distance] implement the class distance_result
2014-07-02 23:26:56 +03:00
Barend Gehrels
7727ce921e
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-07-02 14:21:12 +02:00
Barend Gehrels
5a008767ae
[buffer] restructure buffer_range such that tag is not necessary
...
and behaviour per geometry-type is done in the dispatch itself.
This also avoids generating side on perpendicular side for linestrings once
(the second one cannot easily be avoided in the current structure)
2014-07-02 14:20:02 +02:00
Barend Gehrels
c9880fbdff
[buffer] use range instead of two points as output for buffer_side strategy
2014-07-02 13:04:16 +02:00
Barend Gehrels
c94d6d469d
[buffer] use strategy buffer_side instead of generate_side
2014-07-02 12:45:57 +02:00
Barend Gehrels
f933be730d
[buffer] move buffer_side to strategies
2014-07-02 12:33:04 +02:00
Barend Gehrels
01151cacf5
[buffer] copy inserter to buffer_side
2014-07-02 12:29:34 +02:00
Adam Wulkiewicz
6e673af06f
Merge pull request #81 from mkaravel/feature/is_simple
...
Feature/is simple
2014-07-02 11:50:58 +02:00
Menelaos Karavelas
a87c68b62f
[algorithms][is_valid] remove obsolete comment
2014-07-02 11:53:49 +03:00
Menelaos Karavelas
a1710c2bd3
[doc][algorithms] add documentation for the comparable_distance free
...
function that takes a strategy
2014-07-02 11:50:04 +03:00
Menelaos Karavelas
bda78a8153
[algorithms][is_valid] fix bug in initialization of DFS data for
...
detecting cycles
2014-07-02 02:30:24 +03:00
Adam Wulkiewicz
e9178b6a80
Merge pull request #75 from mkaravel/feature/is_simple
...
Feature/is simple
2014-07-01 17:27:01 +02:00
Menelaos Karavelas
fc14209d5f
[algorithms][is_valid] replace TurnPoint const& by TurnPoint const*
...
in complement graph vertex
2014-07-01 17:50:25 +03:00
Menelaos Karavelas
104aafd05d
[algorithms][is_valid] make the complement graph vertex id an unsigned
...
integer (to avoid conversion warnings)
2014-07-01 09:57:55 +03:00
Menelaos Karavelas
df3da8aa66
[algorithms][is_valid] re-design the complement graph: store neighbors
...
in the graph instead of at each vertex; store DFS data for detecting
cycles outside the vertices;
2014-07-01 00:05:02 +03:00
Barend Gehrels
bc2edc4eea
Merge branch 'develop' into prepare
2014-06-30 21:08:59 +02:00
Barend Gehrels
9fc3b36d25
Merge pull request #77 from mkaravel/feature/doc-strategies
...
Feature/doc strategies
2014-06-30 21:04:44 +02:00
Barend Gehrels
000979883d
Merge branch 'develop' into prepare
2014-06-30 20:55:45 +02:00
Barend Gehrels
a1bde8e927
Merge pull request #72 from mkaravel/fix/graham_andrew
...
[strategies][agnostic] fix bug in Graham-Andrew strategy:
2014-06-30 20:51:11 +02:00
Barend Gehrels
0b2cc3a1ae
Merge branch 'develop' into prepare
2014-06-30 19:31:26 +02:00
Menelaos Karavelas
5e94f07ec0
[iterators][point_iterator] remove free functions points_front and points_back
2014-06-30 12:18:03 +03:00
Menelaos Karavelas
31361135dc
[algorithms][is_valid] re-structure and polish code a bit;
...
check relative containment of rings only for rings that are not
associated with turns
2014-06-27 13:36:48 +03:00
Menelaos Karavelas
9930615207
[strategies][distance] update doxygen documentation for pythagoras
...
point-box and box-box strategies
2014-06-27 03:35:31 +03:00
Menelaos Karavelas
ac17fdcbdc
[algorithms][is_simple,is_valid] add doxygen documentation for is_simple and is_valid
2014-06-27 02:38:21 +03:00
Menelaos Karavelas
7ec752d5ea
[geometry] add is_simple and is_valid algorithms in geometry.hpp
2014-06-27 02:28:17 +03:00
Menelaos Karavelas
274c64c5d8
[algorithms][is_simple] add missing include
2014-06-27 02:27:28 +03:00
Menelaos Karavelas
f0f037df2b
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-26 22:52:43 +03:00
Barend Gehrels
7baf1a29e5
[buffer] We have to simplify the ring before to avoid very small-scaled
...
features in the original (convex/concave/convex) being enlarged
in a very large scale and causing issues (IP's within pieces).
This might be reconsidered later. Simplifying with a very small
distance will never be visible in the result,
if it is using round joins. For miter joins they are even more
sensitive to small scale input features, however the result will
look better.
A distance strategy can change behaviour (make larger - set simplify
distance to 0.0 to avoid simplification)
This fixes the parcel issue(s)
2014-06-25 13:32:42 +02:00
Menelaos Karavelas
15773cbf93
[algorithms][is_valid] fix some wrong usages of std::size_t (should
...
have been int)
2014-06-25 09:34:53 +03:00
Menelaos Karavelas
bcaf4a374a
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-25 01:54:15 +03:00
Barend Gehrels
7f3b509fb5
[buffer] use endcap strategy for spikes. Check jointype also (again)
...
for line-line intersection because it is based on buffered segments.
2014-06-24 22:48:04 +02:00
Menelaos Karavelas
9059f73d54
[algorithms][is_valid] remove USE_INTERRUPT_POLICY macro
2014-06-24 19:43:32 +03:00
Menelaos Karavelas
ec2417f701
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-24 14:08:06 +03:00
Menelaos Karavelas
e3d0b1e6e4
[algorithm][is_valid] Re-design complement graph implementation:
...
* complement graph is now templated by turn points rather than vertices
* vertices get the vertex_handle type from the graph now
* simplify DFS algorithm to use only parent vertex id instead of parent
vertex (only the parent id is really needed)
The last change also solves incomplete type compilation errors on
darwin/linux clang++, when -stdlib=libc++ is set.
2014-06-24 12:29:04 +03:00
Menelaos Karavelas
5a316f6c7e
[algorithms][is_valid] include is_valid for multi-polygons (coming
...
from a separate file now)
2014-06-24 12:19:42 +03:00
Menelaos Karavelas
69594408ad
[algorithms][is_valid] move multi-polygon implementation to separate file
2014-06-24 12:19:04 +03:00
Menelaos Karavelas
59ffebd794
[algorithms][is_valid] re-structure polygon's is_valid algorithm (for
...
readability and possible usage by is_valid for multi-polygons);
move code to sepatate files (to be used for multi-polygons as well);
move multi-polygon implementation to separate file;
2014-06-24 12:17:28 +03:00
Menelaos Karavelas
e25fb28d71
[algorithms][is_valid] implement predicate class that determines
...
whether a polygon or multi-polygon turn is acceptable (code partially
moved from algorithms/detail/is_valid/polygon.hpp)
2014-06-24 12:15:38 +03:00
Menelaos Karavelas
b3932db092
[algorithms][is_valid] factor-out in a separate file self turns computation
...
code (used by polygons and multi-polygons)
2014-06-24 12:13:47 +03:00
Barend Gehrels
9b6aa189bd
[buffer] changes in includes/defines
2014-06-23 22:40:03 +02:00
Barend Gehrels
aa307b5ad2
[buffer] add join_selector and use it before generating the join.
...
This moves responsibility of generation to the calling code, removes it
from the join strategies. It also enables using the end-strategy for the
spikes
2014-06-23 22:39:29 +02:00
Barend Gehrels
d8a4d12c8e
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-06-23 19:34:51 +02:00
Menelaos Karavelas
eb9fb19816
[algorithms][is_valid] remove commented variable names
2014-06-22 23:56:53 +03:00
Adam Wulkiewicz
edff6503c4
[is_valid] Prefix GEOMETRY_TEST_DEBUG macro with BOOST_
2014-06-22 22:45:03 +02:00
Adam Wulkiewicz
3deeeecc25
[is_valid] Fix unused variable warnings.
2014-06-22 22:41:42 +02:00
Menelaos Karavelas
a58ee873dc
[algorithms][is_valid] print multi-index as well
2014-06-22 23:22:03 +03:00
Menelaos Karavelas
e7e7f958fb
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
...
Conflicts:
include/boost/geometry/algorithms/detail/is_simple/debug_print_boundary_points.hpp
include/boost/geometry/algorithms/detail/is_valid/polygon.hpp
2014-06-22 23:09:47 +03:00
Barend Gehrels
86a2adef88
[buffer] pass points instead of segments to line_line_intersection
2014-06-22 22:01:43 +02:00
Barend Gehrels
51121c1e35
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-06-22 21:07:36 +02:00
Barend Gehrels
4ac5267e69
[buffer] use robust policy to check equality
2014-06-22 21:06:50 +02:00
Barend Gehrels
a057d23a24
[buffer] use passed first
2014-06-22 20:49:26 +02:00
Barend Gehrels
80b0ae169c
[buffer] pass robust policy through the buffer_inserter structs
2014-06-22 20:42:10 +02:00
Barend Gehrels
a6cfda7c41
[buffer] Refactor duplicate functionality into one function
2014-06-22 20:30:16 +02:00
Barend Gehrels
5c3f1f2006
[buffer] fix limit which was too low for LatLong coordinates. Also fix in test
...
for tolerance which was too high. Added unit test
2014-06-22 19:54:13 +02:00
Barend Gehrels
ddf4acf351
[buffer] skip the type-check for adjacent pieces and side-pieces,
...
because now sides around a concave vertex have a piece in between
2014-06-22 18:49:34 +02:00
Barend Gehrels
8e74d052ea
[buffer] rename variables
2014-06-22 16:05:20 +02:00
Adam Wulkiewicz
92b236fda6
[range] Calculate the iterator distance in erase() only when necessary.
2014-06-22 15:42:51 +02:00
Adam Wulkiewicz
17f08e3ac4
Merge pull request #66 from mkaravel/feature/debug_macro
...
Feature/debug macro
2014-06-22 15:29:16 +02:00
Adam Wulkiewicz
19a8455f54
Merge pull request #71 from mkaravel/fix/unused_include
...
[algorithms][overlay] remove usused include
2014-06-22 15:27:50 +02:00
Adam Wulkiewicz
5da7133f9f
Merge pull request #73 from awulkiew/feature/range
...
[range] Optimize range::erase() in C++11
2014-06-22 15:27:08 +02:00
Adam Wulkiewicz
ba0906369e
[range] Add support for invalidating resize() and workarounds for MSVC and MinGW.
...
Using of the iterator returned by erase() caused assertion failures (false positive) on MSVC with iterator debugging enabled.
MSVC std::vector can't store non-movable objects if rvalue references are supported.
MinGW std::vector can't store pointers.
2014-06-22 15:17:49 +02:00
Barend Gehrels
3628e85a25
[buffer] fix non-intersecting sides around concave points
...
there was no segment in between generated, therefore if the side-segments
did not intersect (e.g. donut_diamond in polygon_buffer.cpp unit test),
there was no intersection at all. Now a helper piece is generated and it
will intersect.
2014-06-22 15:12:40 +02:00
Adam Wulkiewicz
81ea76fdb9
[range] Remove unneeded code and comments
2014-06-22 13:33:19 +02:00
Adam Wulkiewicz
cd2e17b102
[range] Optimize erase() in C++11 - use std::move() instead of std::copy() if possible.
2014-06-21 22:08:51 +02:00
Adam Wulkiewicz
a0a296877f
[range] Fix the return type of range::erase() and add tests.
2014-06-21 18:18:25 +02:00
Barend Gehrels
4ae8804b1d
[buffer] make constants const
2014-06-20 22:35:20 +02:00
Barend Gehrels
7df029b176
[buffer] make buffer (miter, round) around spike possible
...
including unit testcase. For miters, the limit is enlarged (after
visual inspection of spike_simplex_miter)
2014-06-20 22:34:40 +02:00
Menelaos Karavelas
5a71e83bd5
[algorithms][is_valid] remove all explicit usages of debug macro;
...
clean-up/polish debug-related code;
2014-06-20 13:41:00 +03:00
Menelaos Karavelas
36def7632c
[algorithms][is_valid] move complement graph debug-related printing
...
code to separate function
2014-06-20 13:39:57 +03:00
Menelaos Karavelas
357a818cea
[algorithms][is_valid] helper class for debugging the various phases
...
of the validity algorithms; currently implemented only for polygons;
2014-06-20 13:38:39 +03:00
Menelaos Karavelas
ab67385c68
[algorithms][is_valid] move debugging-related printing of turns in
...
is_valid/debug_print_turns.hpp
2014-06-20 13:37:28 +03:00
Menelaos Karavelas
1a0e2519da
[algorithms][is_simple] update debugging-related includes
2014-06-20 13:36:48 +03:00
Menelaos Karavelas
100af837ec
[algorithms][is_simple] rename debug_linear.hpp to debug_print_boundary_points.hpp;
...
remove code related to printing turns (to be put in another file);
2014-06-20 13:35:57 +03:00
Menelaos Karavelas
75f254efc3
[algorithms][overlay] remove usused include (which also creates a
...
dependence with <iostream>)
2014-06-20 12:32:19 +03:00
Menelaos Karavelas
2eea41b82e
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-20 12:30:18 +03:00
Menelaos Karavelas
c3d401164a
[strategies][agnostic] fix bug in Graham-Andrew strategy:
...
last is used again after two calls to pop_back() which can invalidate
the reference;
patch: make last a true point rather than a reference
bug reported/patch suggested by David Zhao
2014-06-20 12:17:44 +03:00
Barend Gehrels
52c41b9d34
[overlay] reverted change of returning left seg_id < right seg_id
...
because it is already tested before as beging equal in these cases
2014-06-19 21:46:50 +02:00
Menelaos Karavelas
b58dfe57c8
[algorithms][turns] guard include with the BOOST_GEOMETRY_DEBUG_TURN
...
macro; polish code a bit
2014-06-19 22:15:26 +03:00
Adam Wulkiewicz
844616d8fa
Merge pull request #64 from awulkiew/fix/erase
...
Replace the explicit call to Range::erase()
2014-06-19 20:46:27 +02:00
Adam Wulkiewicz
a9babd113f
[overlay] Change the placement of const modifier (guidelines).
2014-06-19 20:45:56 +02:00
Barend Gehrels
24b503212e
[buffer] In case of the same contents, compare just seg_ids
...
to have a reliable order
2014-06-19 19:11:22 +02:00
Barend Gehrels
3261c52976
[buffer] Avoid warnings
2014-06-19 19:10:49 +02:00
Barend Gehrels
c5de26945b
[overlay] use uniform robust policy, this obsoletes zoom_to_robust
2014-06-19 19:10:28 +02:00
Menelaos Karavelas
faab25232f
[algorithms][detail] make sure we are not going to get an unused
...
variable warning (on MSVC)
2014-06-19 17:07:37 +03:00
Menelaos Karavelas
46ae61138a
[algorithms][detail] polish comment phrasing
2014-06-19 16:42:02 +03:00
Menelaos Karavelas
67397491fc
[algorithms][is_valid] make the policy passed to self turns for polygons
...
a stateless policy
2014-06-19 16:36:07 +03:00
Menelaos Karavelas
4052cc85f9
[algorithms][is_simple] multi-linestring simplicity check:
...
pass an appropriate predicate based interrupt policy to self turns,
so that when an unacceptable turn is found, self turn stops and returns
2014-06-19 16:33:56 +03:00
Menelaos Karavelas
62dc84e14f
[policies] rename predicate_based_interrupt_policy to
...
stateless_predicate_based_interrupt_policy; added a new version
of predicate_based_interrupt_policy that takes a predicate object
(possibly with state) at construction;
2014-06-19 16:31:37 +03:00
Menelaos Karavelas
d67bad5925
[algorithms][detail] add version that takes as argument a predicate object
...
(possibly with state)
2014-06-19 16:30:39 +03:00
Menelaos Karavelas
70d22970e2
[algorithms][is_valid] optimize call to self turns:
...
replace the no_interrupt_policy used in self turns by a custom
interrupt policy that stops when a non-acceptable turn is found
2014-06-19 14:56:30 +03:00
Menelaos Karavelas
50c3185417
[policies] add a predicate-based interrupt policy: the policy
...
is passed a predicate (that has a static apply method) and reports
that intersections exist if at least one of the turns in the checked
range is not acceptable according to the predicate
2014-06-19 14:53:24 +03:00
Menelaos Karavelas
59099bf721
[algorithms][detail,is_simple,is_valid] change the valud of the
...
AllowEmptyRange template parameter of check_iterator_range from
false to true
2014-06-19 14:03:49 +03:00
Menelaos Karavelas
1f56d9c04b
[algorithms][is_simple] fix usage of BOOST_GEOMETRY_TEST_DEBUG macro
2014-06-19 12:29:21 +03:00
Menelaos Karavelas
92dfc0a4b5
[algorithms][overlay] remove occurences of macro GEOMETRY_TEST_DEBUG
...
that are not needed
2014-06-19 12:26:05 +03:00
Menelaos Karavelas
7689e17b09
[geometry] prefix macro GEOMETRY_TEST_DEBUG with BOOST_
2014-06-19 12:24:53 +03:00
Adam Wulkiewicz
6a969b2b49
[overlay] Add missing copyright info.
2014-06-19 02:43:46 +02:00
Adam Wulkiewicz
43d0ef60f3
[range] Add erase() taking non-mutable iterators (in-line with C++11 std::vector) + tests.
2014-06-19 02:40:39 +02:00
Adam Wulkiewicz
a552a0de67
[overlay] Replace *begin(rng) with front(rng)
2014-06-19 01:11:53 +02:00
Adam Wulkiewicz
66c1acb9c5
Merge pull request #65 from mkaravel/feature/is_simple
...
[algorithms][is_valid] attempt to fix MSVC compilation errors
2014-06-19 01:01:48 +02:00
Menelaos Karavelas
0e18e8ec8c
[algorithms][is_valid] attempt to fix MSVC compilation errors
2014-06-18 23:16:13 +03:00
Adam Wulkiewicz
9f7828b7ec
[overlay][range] Replace the explicit call to Range::erase() with version using std::copy() and traits::resize<>
2014-06-18 19:42:44 +02:00
Barend Gehrels
ea222cd5b3
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-06-18 14:24:53 +02:00
Barend Gehrels
e4e948753b
[turns] remove is_discarded() function
2014-06-18 14:24:42 +02:00
Barend Gehrels
4415da952b
[buffer] For clusters (occuption), avoid using turns as starting point
...
This enables the "get_occupation" again, but skips the get_left_turns function
2014-06-18 14:18:43 +02:00
Barend Gehrels
fccd2c2b7f
[buffer][fix] add required parameter for visit policy
2014-06-18 14:13:57 +02:00
Barend Gehrels
2ba27734e4
[buffer] remove unused segment-map
2014-06-18 14:05:53 +02:00
Barend Gehrels
bbfe279782
[buffer] disable enlarged-cluster approach
...
temporary disabled with a define - if everything OK it will go completely
2014-06-18 14:04:24 +02:00
Barend Gehrels
84d240ee9d
[buffer][test] visit collection twice for mapping
2014-06-18 14:02:18 +02:00
Barend Gehrels
54c59c2665
[overlay] remove unused MSM approach
...
This drops the reported MSM dependancy
2014-06-18 14:01:11 +02:00
Menelaos Karavelas
52ab626f69
[algorithms][is_valid] in polygon validity algorithm, replace
...
the robustness policy used from no_rescale_policy to the
appropriate rescale_policy type
2014-06-18 14:27:13 +03:00
Menelaos Karavelas
dbbcf4c1ff
[algorithms][is_simple] implement the new directory/file structure
2014-06-18 14:04:50 +03:00
Menelaos Karavelas
89c5113bce
[algorithms][is_valid] implement the new directory/file structure
2014-06-18 14:00:05 +03:00
Menelaos Karavelas
092a8633e2
[algorithms][detail,is_valid] rename number_of_distinct_values to
...
num_distinct_consecutive_points and move it to namespace
boost::geometry::detail; also rename and move corresponding file
to boost/geometry/algorithms/detail;
2014-06-18 13:23:48 +03:00
Menelaos Karavelas
27ea2de6ab
[algorithms][is_valid] rename N to MaximumNumber
2014-06-18 13:10:58 +03:00
Menelaos Karavelas
ec63be14e2
[algorithms][is_valid] in number_of_distinct_values, make size const
2014-06-18 13:06:10 +03:00
Menelaos Karavelas
c94ecdbb4d
[algorithms][is_simple] add variant support
2014-06-18 12:54:09 +03:00
Menelaos Karavelas
b0a5adc503
[algorithms][is_valid] add variant support
2014-06-18 12:53:53 +03:00
Menelaos Karavelas
d92960154a
[algorithms][is_valid] make implementation of number_of_distinct_points
...
more generic: number_of_distinct_values for ranges that also takes an
additional template parameter to indicate how many distinct values
to search for
2014-06-18 04:36:20 +03:00
Menelaos Karavelas
6cecfeea9f
[algorithms][is_valid] move implementation of number_of_distinct_points
...
in separate file; re-design implementation of is_valid for linestrings;
2014-06-18 04:34:45 +03:00
Menelaos Karavelas
332eb42789
[algorithms][is_valid] remove trailing space
2014-06-18 03:47:02 +03:00
Adam Wulkiewicz
a9e4957800
[geometries] Added tests, also for Boost.Assign
2014-06-17 13:52:33 +02:00
Adam Wulkiewicz
81bcdc34ed
[geometries] Define assignment operators taking initializer lists.
...
Add constructor taking initializer list for multi_point.
2014-06-16 23:54:16 +02:00
Barend Gehrels
8102c48d65
Merge branch 'develop' into prepare_1_56_june16
...
Conflicts:
doc/doxy/doxygen_output/html/doxygen.css
doc/doxy/doxygen_output/html/doxygen.png
doc/doxy/doxygen_output/html/tabs.css
doc/html/index.html
doc/index/rtree/query.qbk
doc/make_qbk.py
doc/quickbook/quickref.xml
doc/quickref.xml
doc/release_notes.qbk
doc/src/docutils/tools/doxygen_xml2qbk/configuration.hpp
doc/src/docutils/tools/doxygen_xml2qbk/doxygen_xml2qbk.cpp
example/07_b_graph_route_example.cpp
example/c11_custom_cs_transform_example.cpp
example/ml02_distance_strategy.cpp
extensions/example/gis/io/shapelib/shapelib.cpp
extensions/example/gis/latlong/distance_example.cpp
extensions/example/gis/latlong/point_ll_example.cpp
extensions/example/gis/projections/p03_projmap_example.cpp
extensions/example/gis/projections/p04_example.cpp
extensions/example/gis/projections/p05_example.cpp
extensions/test/algorithms/Jamfile.v2
extensions/test/algorithms/dissolve.cpp
extensions/test/algorithms/offset.cpp
extensions/test/gis/latlong/andoyer.cpp
extensions/test/gis/latlong/cross_track.cpp
extensions/test/gis/latlong/distance_mixed.cpp
extensions/test/gis/latlong/vincenty.cpp
extensions/test/gis/projections/projections.cpp
extensions/test/nsphere/Jamfile.v2
extensions/test/nsphere/nsphere-access.cpp
extensions/test/nsphere/nsphere-area.cpp
extensions/test/nsphere/nsphere-circle.cpp
extensions/test/nsphere/nsphere-disjoint.cpp
extensions/test/nsphere/nsphere-index_content.cpp
extensions/test/nsphere/nsphere-index_margin.cpp
extensions/test/nsphere/nsphere-multi_within.cpp
extensions/test/nsphere/nsphere-nsphere_in_box.cpp
extensions/test/nsphere/nsphere-point_in_nsphere.cpp
extensions/test/nsphere/nsphere-point_type.cpp
extensions/test/nsphere/nsphere-within.cpp
include/boost/geometry/algorithms/detail/buffer/buffer_inserter.hpp
include/boost/geometry/algorithms/detail/buffer/buffer_policies.hpp
include/boost/geometry/algorithms/detail/buffer/buffered_ring.hpp
include/boost/geometry/algorithms/detail/buffer/line_line_intersection.hpp
include/boost/geometry/algorithms/detail/disjoint.hpp
include/boost/geometry/algorithms/detail/multi_modify.hpp
include/boost/geometry/algorithms/detail/overlay/append_no_dups_or_spikes.hpp
include/boost/geometry/algorithms/detail/overlay/copy_segments.hpp
include/boost/geometry/algorithms/detail/overlay/enrichment_info.hpp
include/boost/geometry/algorithms/detail/overlay/get_turns.hpp
include/boost/geometry/algorithms/detail/overlay/self_turn_points.hpp
include/boost/geometry/algorithms/detail/overlay/traverse.hpp
include/boost/geometry/algorithms/detail/point_is_spike_or_equal.hpp
include/boost/geometry/algorithms/detail/sections/sectionalize.hpp
include/boost/geometry/algorithms/disjoint.hpp
include/boost/geometry/algorithms/distance.hpp
include/boost/geometry/algorithms/num_points.hpp
include/boost/geometry/algorithms/simplify.hpp
include/boost/geometry/extensions/algebra/algebra.hpp
include/boost/geometry/extensions/algebra/algorithms/convert.hpp
include/boost/geometry/extensions/algebra/algorithms/detail.hpp
include/boost/geometry/extensions/algebra/algorithms/rotation.hpp
include/boost/geometry/extensions/algorithms/connect.hpp
include/boost/geometry/extensions/algorithms/detail/overlay/dissolver.hpp
include/boost/geometry/extensions/algorithms/dissolve.hpp
include/boost/geometry/extensions/algorithms/offset.hpp
include/boost/geometry/extensions/algorithms/remove_holes_if.hpp
include/boost/geometry/extensions/algorithms/remove_marked.hpp
include/boost/geometry/extensions/algorithms/selected.hpp
include/boost/geometry/extensions/contrib/ttmath_stub.hpp
include/boost/geometry/extensions/gis/geographic/strategies/andoyer.hpp
include/boost/geometry/extensions/gis/geographic/strategies/distance_cross_track.hpp
include/boost/geometry/extensions/gis/geographic/strategies/vincenty.hpp
include/boost/geometry/extensions/gis/io/shapelib/shp_create_object_multi.hpp
include/boost/geometry/extensions/gis/projections/impl/pj_fwd.hpp
include/boost/geometry/extensions/gis/projections/new_projection.hpp
include/boost/geometry/extensions/gis/projections/projection_point_type.hpp
include/boost/geometry/extensions/multi/algorithms/dissolve.hpp
include/boost/geometry/extensions/nsphere/algorithms/disjoint.hpp
include/boost/geometry/extensions/nsphere/algorithms/within.hpp
include/boost/geometry/extensions/nsphere/core/radius.hpp
include/boost/geometry/extensions/nsphere/core/tags.hpp
include/boost/geometry/extensions/nsphere/index/detail/algorithms/bounds.hpp
include/boost/geometry/extensions/nsphere/index/detail/algorithms/comparable_distance_near.hpp
include/boost/geometry/extensions/nsphere/index/detail/algorithms/content.hpp
include/boost/geometry/extensions/nsphere/index/detail/rtree/linear/redistribute_elements.hpp
include/boost/geometry/extensions/nsphere/nsphere.hpp
include/boost/geometry/extensions/nsphere/strategies/cartesian/nsphere_in_box.hpp
include/boost/geometry/extensions/nsphere/strategies/cartesian/point_in_nsphere.hpp
include/boost/geometry/extensions/nsphere/views/center_view.hpp
include/boost/geometry/index/detail/rtree/utilities/gl_draw.hpp
include/boost/geometry/index/rtree.hpp
include/boost/geometry/multi/algorithms/distance.hpp
include/boost/geometry/multi/geometries/concepts/multi_linestring_concept.hpp
include/boost/geometry/multi/geometries/concepts/multi_point_concept.hpp
include/boost/geometry/multi/geometries/concepts/multi_polygon_concept.hpp
include/boost/geometry/multi/io/wkt/read.hpp
include/boost/geometry/strategies/agnostic/buffer_distance_asymmetric.hpp
include/boost/geometry/strategies/agnostic/buffer_distance_symmetric.hpp
include/boost/geometry/strategies/agnostic/buffer_end_skip.hpp
include/boost/geometry/strategies/buffer.hpp
include/boost/geometry/strategies/cartesian/buffer_end_flat.hpp
include/boost/geometry/strategies/cartesian/buffer_end_round.hpp
include/boost/geometry/strategies/cartesian/buffer_join_miter.hpp
include/boost/geometry/strategies/cartesian/buffer_join_round.hpp
include/boost/geometry/strategies/cartesian/buffer_join_round_by_divide.hpp
include/boost/geometry/strategies/cartesian/distance_projected_point.hpp
include/boost/geometry/strategies/cartesian/distance_pythagoras.hpp
include/boost/geometry/strategies/concepts/distance_concept.hpp
include/boost/geometry/strategies/default_distance_result.hpp
include/boost/geometry/strategies/spherical/distance_cross_track.hpp
include/boost/geometry/strategies/spherical/distance_haversine.hpp
include/boost/geometry/util/math.hpp
index/example/benchmark_experimental.cpp
index/example/glut_vis.cpp
index/example/serialize.cpp
index/test/rtree/interprocess/Jamfile.v2
index/test/rtree/test_rtree.hpp
test/algorithms/Jamfile.v2
test/algorithms/buffer/Jamfile.v2
test/algorithms/buffer/multi_linestring_buffer.cpp
test/algorithms/buffer/multi_point_buffer.cpp
test/algorithms/buffer/multi_polygon_buffer.cpp
test/algorithms/buffer/point_buffer.cpp
test/algorithms/buffer/polygon_buffer.cpp
test/algorithms/difference.cpp
test/algorithms/intersection.cpp
test/algorithms/intersects.cpp
test/algorithms/overlay/overlay_cases.hpp
test/algorithms/overlay/robustness/Jamfile.v2
test/algorithms/test_intersection.hpp
test/algorithms/test_simplify.hpp
test/algorithms/test_union.hpp
test/algorithms/union.cpp
test/geometry_test_common.hpp
test/multi/algorithms/Jamfile.v2
test/multi/algorithms/multi_difference_spike.cpp
test/multi/algorithms/multi_distance.cpp
2014-06-16 19:57:43 +02:00
Adam Wulkiewicz
9aaffa5f78
[geometries] Add support for std::initializer_list
2014-06-16 19:06:19 +02:00
Barend Gehrels
56d163fe1e
[is_valid] fix unit test linkage problem with two/three_or_more
2014-06-16 19:04:05 +02:00
Menelaos Karavelas
b05dd041a6
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-16 14:30:58 +03:00
Adam Wulkiewicz
76b13c42bc
[util][math] Add the conversion to double (C++11 approach) before passing the integral argument to std::sqrt()
2014-06-16 13:04:22 +02:00
Menelaos Karavelas
1f07f292ec
[algorithms][is_valid] add include that is missing if GEOMETRY_TEST_DEBUG is defined
2014-06-16 13:45:38 +03:00
Menelaos Karavelas
2438af55b3
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-16 12:20:38 +03:00
Menelaos Karavelas
1163128748
[algorithms][is_valid] templatize is_valid dispatch class with
...
one more boolean template parameter to control the behavior with
respect to allowing duplicate points; modify algorithm for rings
polygons and multi-polygons to take the additional template parameter
that controls behavior with respect to duplicate points;
2014-06-16 12:12:20 +03:00
Adam Wulkiewicz
76917a4e70
[within][covered_by][test][doc] Support Point in Segment.
...
Add tests and update implementation status.
Add the test for intersects(Point, Segment).
2014-06-16 03:49:51 +02:00
Menelaos Karavelas
a4566ad92d
[algorithms][is_simple] replace inclusion of detail/is_simple/pointlike.hpp
...
by inclusion of detail/is_simple/multipoint.hpp
2014-06-16 03:38:14 +03:00
Menelaos Karavelas
a4b42e8bbc
[algorithms][is_valid] re-implement has_spikes to return false if
...
the range has one or two distinct points (instead of calling
BOOST_ASSERT)
2014-06-16 03:30:53 +03:00
Menelaos Karavelas
8200c0c0a7
[algorithms][is_valid] re-implement has_duplicates to return false,
...
instead of calling BOOST_ASSERT, for geometries with no points;
2014-06-16 03:27:55 +03:00
Menelaos Karavelas
7d6f54539b
[algorithms][is_simple] fix bug for closed linestrings (they do not
...
have boundary points); re-implement is_simple for linear geometries
assuming they are valid;
2014-06-16 03:26:10 +03:00
Menelaos Karavelas
be66dfe3f8
[algorithms][is_simple] print boundary points instead of endpoints
...
of linear geometries
2014-06-16 03:24:54 +03:00
Menelaos Karavelas
987cf6ee1e
[algorithms][is_simple] re-arrange code:
...
rename detail/is_simple/pointlike.hpp to detail/is_simple/multipoint.hpp;
move code for geometries that are always simple to detail/is_simple/always_simply.hpp;
for areal geometries (rings, polygons, multi-polygons) implement
simpliciality check by checking for duplicate points;
2014-06-16 02:44:37 +03:00
Menelaos Karavelas
c81046000e
[algorithms][is_valid] avoid calling interior_rings(polygon) twice;
...
polish code;
2014-06-16 02:40:14 +03:00
Menelaos Karavelas
5914fb2958
[algorithms][is_valid] change order of includes
2014-06-16 01:56:08 +03:00
Menelaos Karavelas
789eb04ba0
[algorithms][is_valid] change default behavior for linear geometries
...
to allow spikes
2014-06-15 21:47:02 +03:00
Menelaos Karavelas
34f3e31e8e
[algorithms][is_valid] fix bug occuring when linestring has two
...
distinct points and spikes are allowed
2014-06-15 21:46:08 +03:00
Adam Wulkiewicz
7e71bdfbbb
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-06-15 02:40:42 +02:00
Adam Wulkiewicz
b9ff3a7fc4
[index][strategies][test] Modify some of the header includes.
...
The purpose of this is to allow the compilation of the rtree without the need of including the geometry.hpp ond require only index/rtree.hpp or to make the order of includes irrelevant.
Furthermore, this is backward compatible.
Add missing variant include in the intersection tests.
Fix the unused typedefs in the pythagoras_point_box test.
2014-06-15 02:29:57 +02:00
Menelaos Karavelas
975fefef0b
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-15 00:05:12 +03:00
Menelaos Karavelas
e8ef531436
[algorithms][is_valid] add implementation for free space connectivity
...
graph of a polygon; this graph is used to test whether the interior
of a polygon is connected;
algorithmic modeling: given a polygon, define its free space connectivity
graph as follows:
* add a graph vertex for the exterior of the polygon
* add a graph vertex for every hole
* add a graph vertex for each point of contact between two polygon rings
* add a graph edge between every free space component (exterior or hole)
and every point of contact on the boundary of this component
* determining whether the polygon has connected interior amounts to
testing whether the graph is acyclic
2014-06-14 23:52:24 +03:00
Menelaos Karavelas
970016f9dc
[algorithms][is_valid] add implementation for validity of polygons
...
(and partial implementation for validity of multi-polygons)
2014-06-14 23:51:45 +03:00
Menelaos Karavelas
29052c3d0b
[algorithms][is_simple] polish order of includes
2014-06-14 23:20:27 +03:00
Menelaos Karavelas
122d4e6e3e
[algorithms][is_valid] move code to proper files under detail/is_valid;
...
fix includes;
2014-06-14 22:36:40 +03:00
Adam Wulkiewicz
35b2f91ee4
[extensions][offset] Update #includes to include the moved buffer code
2014-06-14 17:34:10 +02:00
Menelaos Karavelas
28ed3e4e59
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-14 16:04:24 +03:00
Barend Gehrels
264e9676f0
[buffer] avoid unused variable warnings
...
and replace BOOST_TYPEOF by iterator_traits
2014-06-14 11:53:50 +02:00
Barend Gehrels
1e7a631379
[buffer] rename check_original to turn_in_input
...
comparable to point_in_geometry.
This removes multi_buffer_inserter
2014-06-14 11:39:49 +02:00
Barend Gehrels
9db3329fe5
[buffer] move (dispatch) code for multi to buffer_inserter itself
...
This also tags the cast to multi_tag
2014-06-14 11:38:39 +02:00
Barend Gehrels
4a388f855d
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-06-14 11:03:44 +02:00
Barend Gehrels
723435de6c
[buffer] remove debug functionality
...
The lines which are warnings are now protected by BOOST_GEOMETRY_DEBUG_BUFFER_WARN
2014-06-14 11:03:23 +02:00
Barend Gehrels
e00e307f2f
[buffer] remove unused functionality
2014-06-14 11:01:42 +02:00
Barend Gehrels
cee0903f2d
[buffer] Remove buffer_piece_collection_with_mapper
...
this was a debugging tool. It is now replaced by a visiting policy (like
in partition), and implemented in the unit test itself
2014-06-14 10:57:59 +02:00
Menelaos Karavelas
c962616ff5
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/math-sqrt
...
Conflicts:
include/boost/geometry/algorithms/detail/buffer/buffer_inserter.hpp
2014-06-14 01:58:01 +03:00
Barend Gehrels
fdd983ce72
[buffer] Changes in (folder)locations of strategies, and
...
moved buffer_side_selector and piece_type used by strategies.
2014-06-13 21:30:53 +02:00
Barend Gehrels
c96d6394a9
[buffer] update include guards/copyright info
2014-06-13 20:45:34 +02:00
Barend Gehrels
31af14453a
[buffer] Move from extensions to algorithms/detail
2014-06-13 20:26:33 +02:00
Adam Wulkiewicz
327819b687
[extensions][nsphere][test] Remove unused typedefs. Rename tests.
2014-06-13 18:06:07 +02:00
Adam Wulkiewicz
3edeaeb2af
[algorithms][io][test] Fix some rather harmless conversions warnings and add /bigobj for some tests for VS.
2014-06-13 16:13:35 +02:00
Menelaos Karavelas
2adf68f94b
[algorithms][is_simple] remove unused typedef
2014-06-13 15:54:46 +03:00
Menelaos Karavelas
c79a8da5a5
[algorithms][is_valid] add missing include
2014-06-13 15:40:11 +03:00
Menelaos Karavelas
c0a38f87ae
[algorithms][is_valid, is_simple] make a template parameter
...
the run time parameter/argument that determines whether linear
geometries with spikes are allowed
2014-06-13 15:29:50 +03:00
Menelaos Karavelas
03dd7cad6a
[aldotihms][is_valid, is_simple] move has_duplicates from is_simple
...
namespace to is_valid namespace; move has_duplicates.hpp from
detail/is_simple directory to detail/is_valid;
2014-06-13 15:16:05 +03:00
Menelaos Karavelas
97c14576d5
[algorithms][is_valid] finish implementation for rings:
...
add missing includes; check more conditions; poslish code;
2014-06-13 15:08:39 +03:00
Menelaos Karavelas
ecd3853193
[algorithms][is_valid] merge code from linestring.hpp and
...
multi_linestring.hpp into linear.hpp
2014-06-13 14:58:09 +03:00
Menelaos Karavelas
eeaf906ffe
[algorithms][is_valid] merged code in linestring.hpp and
...
multi_linestring.hpp into linear.hpp
2014-06-13 14:56:09 +03:00
Menelaos Karavelas
dec48c51ee
[algorithms][is_simple] for rings return the result of validity testing
2014-06-13 14:32:08 +03:00
Menelaos Karavelas
6d1770352e
[algorithms][is_simple] make has_duplicates closure-aware;
...
rename is_simple_range to is_simple_linestring (it is used
for linestrings only);
2014-06-13 14:30:58 +03:00
Menelaos Karavelas
d89a073d19
[algorithms][is_simple] make has_duplicates closure-aware
2014-06-13 14:30:31 +03:00
Menelaos Karavelas
7246b5e0e7
[algorithms][is_valid] add missing include
2014-06-13 14:07:28 +03:00
Menelaos Karavelas
ac0bff45df
[algorithms][is_valid] optimize detection of small number of distinct
...
point in linestrings; polish code; fix includes;
2014-06-13 14:04:44 +03:00
Menelaos Karavelas
4375dd04c3
[algorithms][is_valid] has_spikes: re-factor and polish implementation
2014-06-13 13:11:45 +03:00
Menelaos Karavelas
39e1fac547
[algorithms][is_simple] remove unused code and includes
2014-06-13 12:46:13 +03:00
Menelaos Karavelas
8b67536dc3
[algorithms][is_simple] remove include of multi/core/tags.hpp
2014-06-13 12:38:47 +03:00
Menelaos Karavelas
574a6b4154
[algorithms][is_valid] remove include of multi/core/tags.hpp
2014-06-13 12:35:08 +03:00
Menelaos Karavelas
2e01ce5173
[alhorithms][is_valid] rename detail/is_valid/multi_range.hpp file to
...
detail/is_valid/multi_linestring.hpp; in there: fix includes;
re-factor code;
2014-06-13 12:33:20 +03:00
Menelaos Karavelas
49acae2ed8
[algorithms][is_simple] add file with debug code for is_simple of
...
linear geometries
2014-06-13 12:27:48 +03:00
Menelaos Karavelas
0161c06b93
[algorithms][is_simple] main file: polish code; removed unused includes;
2014-06-13 12:26:01 +03:00
Menelaos Karavelas
9e84593d48
[algorithms][is_simple] code for linear geometries:
...
polish and re-factor code; remove usused code; fix includes;
move debug code to separate file; optimize has_same_endpoints check;
use bg::range functions;
2014-06-13 12:19:53 +03:00
Menelaos Karavelas
756a6f2e86
[algorithms][detail] add struct with static apply method for checking
...
whether a predicate is satisfied by all elements in an iterator range
2014-06-13 12:18:03 +03:00
Menelaos Karavelas
163357c315
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-13 11:43:45 +03:00
Barend Gehrels
5085c749b1
[has_self_intersections] bugfix (did not return true when exception found) and
...
added optional parameter for non-throwing behaviour.
Use this from test_buffer instead
2014-06-12 23:00:57 +02:00
Barend Gehrels
0ecc80a10a
[buffer] disable get_occupation, remove commented left_turn handling
2014-06-12 22:43:09 +02:00
Barend Gehrels
5a345ae2d4
[buffer] performance improvement - only consider overlapping pieces
2014-06-12 22:41:41 +02:00
Barend Gehrels
bdd2cc1ac6
[buffer] revert replacement of covered_by with within
2014-06-12 22:41:11 +02:00
Barend Gehrels
7531e541b2
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-06-12 18:51:44 +02:00
Barend Gehrels
d06c25bc5f
[buffer] Remove helper functions now not used/need anymore
2014-06-12 18:50:47 +02:00
Adam Wulkiewicz
e277cce32f
Merge pull request #57 from awulkiew/fix/boost_polygon
...
Fix/boost polygon
2014-06-11 16:57:38 +02:00
Barend Gehrels
0f930efb21
[buffer] enhanced (a bit) check for within piece / original
...
and renamed classify functions / moved code
2014-06-11 15:55:09 +02:00
Barend Gehrels
da1a8da80b
[buffer] use partition to check relation turn/piece
2014-06-11 15:53:31 +02:00
Barend Gehrels
fd4f0abb1d
various minor things, remove redundant static, fix capitals, typo
2014-06-11 15:16:29 +02:00
Barend Gehrels
623f2896e0
[buffer] Update robust_envelope at inserting robust intersection point
2014-06-11 14:25:28 +02:00
Barend Gehrels
0287c1d3bb
[partition] support heterogenous collections
2014-06-11 14:17:09 +02:00
Barend Gehrels
88db68b6f7
[buffer][get_piece_turns] comments/layout changes
2014-06-11 13:01:11 +02:00
Barend Gehrels
22a8870012
[buffer] remove specific assign for buffer and is_opposite
...
opposite information is not used anymore
2014-06-11 12:55:55 +02:00
Barend Gehrels
14f3d76505
[buffer] move calculate_turns to get_piece_turn visitor where it is used from
...
this also uses the standard assign-policy for get_turn_info
2014-06-11 12:55:21 +02:00
Barend Gehrels
36708948c9
[buffer] use partition algorithm to calculate turns in piece-offsets
2014-06-11 10:51:21 +02:00
Barend Gehrels
4c7b5d3fa4
[buffer] Add robust envelope per piece
...
to support partition
2014-06-11 10:38:41 +02:00
Barend Gehrels
f6c5f69495
[buffer] split rescaling piece rings / turns
...
to support coming use of partition for calculate turns
2014-06-11 10:15:36 +02:00
Adam Wulkiewicz
a2c00c1774
[comparable_distance] Remove unneeded header include
2014-06-10 16:32:32 +02:00
Menelaos Karavelas
82bb00ed40
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-10 10:07:39 +03:00
Menelaos Karavelas
ef1a257242
[util][math] fix return type for math::sqrt; fix implementation
...
for sqrt for non-fundamental types (use the using mechanism);
2014-06-10 09:18:28 +03:00
Adam Wulkiewicz
afd0656747
[for_each] Remove unused typedefs
2014-06-10 00:20:32 +02:00
Adam Wulkiewicz
400eec193b
[adapted] Specialize resize<> trait for polygon_data required by Ring concept
2014-06-10 00:17:12 +02:00
Barend Gehrels
425e1f6bb1
[buffer] remove BOOST_AUTO_TPL dependancy
2014-06-09 18:50:40 +02:00
Barend Gehrels
21382dfa1d
[buffer] update copyright
2014-06-09 18:39:40 +02:00
Barend Gehrels
4ac94c1230
[buffer] Removed unused function
2014-06-09 18:37:20 +02:00
Barend Gehrels
a0c78403e2
[buffer] Enable negative buffer for polygons (deflate)
...
Update testcases for linestring (including Aimes-list now working)
Fix test for distance (right.distance was only done for SVG)
2014-06-09 18:37:01 +02:00
Barend Gehrels
10f6753a82
[buffer] block cluster (in occupation map) if one is blocked
...
Also reverse iteration order avoiding get_left_turns called more than once per cluster
Also classify IP's on helper segments as within
2014-06-09 16:32:36 +02:00
Barend Gehrels
447fd7edd2
[buffer] get occupation vectors by rescaled offsetted points
...
This fixes the last case rt_p20
Check if the occupation vectors are short (length 1). This indicates a rounding issue.
If so, map again but use neighbouring cells.
Alas we have to do this, but still better than the former FP implementation.
Also, we map only points on offsetted borders now, and return if the map is empty,
to improve performance.
2014-06-09 15:07:47 +02:00
Barend Gehrels
cfbecc9935
[buffer] remove more unused functionality
2014-06-09 12:39:58 +02:00
Barend Gehrels
f822df3545
[buffer] remove uu processing which is redundant
2014-06-09 12:16:16 +02:00
Barend Gehrels
c836fab395
[buffer] remove more now unused functionality
2014-06-09 12:05:55 +02:00
Barend Gehrels
0e666541e7
[buffer] skip within check where not necessary
2014-06-09 11:52:39 +02:00
Barend Gehrels
17d027ec2d
[buffer] remove now unused functionality
2014-06-09 11:51:01 +02:00
Barend Gehrels
4002e3d36a
[buffer] update svg-mapping debug class
2014-06-09 11:16:10 +02:00
Barend Gehrels
432d62809d
[buffer] remove old left-turn approach
2014-06-09 11:15:13 +02:00
Barend Gehrels
11c71d161a
[occupation_info] add once instead of twice
...
preparing for new get_left_turns
2014-06-08 21:57:24 +02:00
Barend Gehrels
a746e7323d
[buffer] Remove occupation_map, use std::map instead
...
turn_indices from occupation_map were not used anymore
2014-06-08 20:21:31 +02:00
Barend Gehrels
5a85076f4b
[get_left_turns] reimplement using integer arithmetic
...
including unit test
2014-06-08 19:03:11 +02:00
Barend Gehrels
5e6d542d81
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-06-08 17:19:08 +02:00
Adam Wulkiewicz
928f1aad70
[algorithms/detail] Rename const_conformant<> to copy_const<> and implement it without MPL and TypeTraits
2014-06-08 16:31:20 +02:00
Adam Wulkiewicz
1e6f7164e1
[algorithms] Drop TypeOf dependency
2014-06-08 13:32:00 +02:00
Adam Wulkiewicz
e52a297c98
[io] Drop TypeOf dependency. Add detail::interior_ring_iterator<>.
2014-06-08 13:05:44 +02:00
Barend Gehrels
79cbf6f18c
[buffer] Occupation map now makes use of robust points
...
(this adds one failing testcase, to be investigated,
but further simplifies/enhances all code)
2014-06-08 12:46:41 +02:00
Barend Gehrels
aec2b7801e
[buffer] Cleanup comments/unused functionality
2014-06-08 10:58:47 +02:00
Adam Wulkiewicz
4626d53ead
[algorithms/detail] Add interior_iterator<> tool and use it in places where BOOST_AUTO_TPL was used to get rid of unreadable, long types
2014-06-08 02:23:59 +02:00
Adam Wulkiewicz
18746a4293
[within] Remove not needed TypeOf header
2014-06-08 01:13:26 +02:00
Adam Wulkiewicz
3b9d4eba02
[point_in_geometry] Fix compilation error - replace BOOST_AUTO_TPL - drop TypeOf dependency
2014-06-08 00:27:35 +02:00
Adam Wulkiewicz
86c91f4b53
[algorithms][multi] Move the code of some algorithms from multi/ dir and drop TypeOf dependency.
...
Modified algorithms: area, centroid, clear, convert, length, perimeter, simplify.
Update included headers paths to reflect the changes.
2014-06-08 00:03:14 +02:00
Adam Wulkiewicz
52ece6c0e4
[algorithms] Move the code of some algorithms from multi/ and drop TypeOf dependency.
...
Algorithms moved: correct, envelope, equals, length, num_geometries, perimeter, remove_spikes.
2014-06-07 22:48:20 +02:00
Adam Wulkiewicz
68e7bacb7e
[reverse] Move the code from multi/ and drop TypeOf dependency
2014-06-07 18:16:06 +02:00
Adam Wulkiewicz
2460f51614
[transform] Move the code from multi/ and drop TypeOf dependency
2014-06-07 18:01:23 +02:00
Adam Wulkiewicz
c2d00d8619
[unique] Move from multi/ and drop TypeOf dependency
2014-06-07 17:43:07 +02:00
Adam Wulkiewicz
f0b119141a
[for_each] Move from multi/ and drop TypeOf dependency
2014-06-07 16:54:37 +02:00
Barend Gehrels
9c30fd698a
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-06-07 12:39:48 +02:00
Barend Gehrels
8a417e6fa9
[buffer] Classify turn-points using rescaled rings
...
This makes side_on_convex_range and intersection_side redundant
It fixes all but one (p20) remaining cases for polygons
2014-06-07 12:38:02 +02:00
Menelaos Karavelas
73bcb4a54e
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-06 01:48:13 +03:00
Menelaos Karavelas
8d542abeeb
Merge branch 'feature/math-sqrt' of github.com:mkaravel/geometry into feature/math-sqrt
2014-06-06 01:47:35 +03:00
Menelaos Karavelas
4f32a51cfa
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/math-sqrt
2014-06-06 01:47:07 +03:00
Adam Wulkiewicz
f6ba62a43a
[comparable_distance][test][extensions] Break comparable_distance into interface and implementation.
...
Also remove geometry.hpp header include from comparable_distance test and nsphere header included in all tests.
2014-06-06 00:29:31 +02:00
Adam Wulkiewicz
7cdbcf5fee
[extensions/nsphere] Enable commented-out tests and change point_in_nsphere strategy WRT areal_tag removal workaround
2014-06-05 19:25:45 +02:00
Adam Wulkiewicz
55a8ad35f8
[extensions] Fix NSphere compilation issues.
...
The fixes are rather temporary workarounds (see comments in the code).
2014-06-05 19:06:06 +02:00
Adam Wulkiewicz
51fc37e43b
[extensions][offset] Fix compilation errors
2014-06-05 18:03:14 +02:00
Menelaos Karavelas
aa5a37277a
[util][math] fix return type of sqrt for fundamental number types
2014-06-05 18:04:51 +03:00
Adam Wulkiewicz
46b46ee080
Merge pull request #55 from awulkiew/refactor_multi
...
Moving geometry/multi/ into geometry/
2014-06-05 16:16:08 +02:00
Adam Wulkiewicz
d8baba40bd
[multi] Remove multi-geometries concepts from multi/multi.hpp since they are included in geometries/concepts/check.hpp
2014-06-05 15:24:01 +02:00
Adam Wulkiewicz
5903c5a292
[extensions] Replace includes of headers moved from multi/ directory.
2014-06-04 19:39:26 +02:00
Adam Wulkiewicz
2a86cf0c20
[geometry] Replace includes of headers from algorithms/detail moved from multi/ directory.
2014-06-04 18:43:42 +02:00
Adam Wulkiewicz
1d4a73cc89
[algorithms/detail] Fix for_each_range backward compatibility.
...
In the specialization for Box remove_const before creating box_view<> and passing the object of this type into the Actor::apply().
2014-06-04 18:15:05 +02:00
Adam Wulkiewicz
3f872f1621
[algorithms/detail] Refactor for_each_range and move it from multi/directory.
2014-06-04 17:10:17 +02:00
Adam Wulkiewicz
2c7da5eb1f
[multi] Move algorithms details used only by multi/algorithm from multi/ directory.
2014-06-04 16:06:21 +02:00
Barend Gehrels
89b2fb4d6a
[buffer] use intersection_side for checking side on convex range
...
This fixes many of the issues (in multi_polygon_buffer). However, some
new cases now fail because of this and should be fixed later
2014-06-04 15:58:53 +02:00
Adam Wulkiewicz
55e684c64c
[multi][algorithm/detail] Move most of the code of details from multi/ directory.
...
This commit doesn't move for_each_range.
Details used only by multi/algorithms aren't moved as well.
2014-06-04 15:53:46 +02:00
Adam Wulkiewicz
320f796b9d
[geometry] Replace headers of parts moved from multi/ directory.
2014-06-04 14:52:28 +02:00
Menelaos Karavelas
e81c0b9e23
[extensions][algorithms][offset] remove obsolete include (file no
...
longer exists)
2014-06-04 14:32:48 +03:00
Barend Gehrels
77969d4194
[buffer] merged implementations of side_on_convex_range
2014-06-04 13:30:45 +02:00
Menelaos Karavelas
86991b358d
[extensions] replace calls to ::sqrt by calls to bg::math::sqrt;
...
change has not been applied to projections and ttmath;
2014-06-04 14:27:47 +03:00
Barend Gehrels
1a2a2f4de1
[buffer] remove RobustPolicy from side_on_convex_range
...
because side of a point w.r.t. a segment cannot be done with rescaling,
due to rounding the point can be located on the other side of the segment
This adds 4 more failing testcases, but it has to be done first because
the solution is not reliable
2014-06-04 13:26:26 +02:00
Adam Wulkiewicz
0bec8e26c3
[multi] Include headers of moved parts from geometry/ directory.
2014-06-04 13:24:29 +02:00
Menelaos Karavelas
d125c79586
[algorithms][equals] fix copyright years; replace call to ::sqrt
...
by call to bg::math::sqrt
2014-06-04 14:16:41 +03:00
Menelaos Karavelas
3453d2ec5c
[strategies] fix unused typedef warningy
2014-06-04 14:13:41 +03:00
Menelaos Karavelas
48bb75137d
[strategies] replace calls to ::sqrt by calls to bg::math::sqrt
2014-06-04 14:13:11 +03:00
Menelaos Karavelas
058ea9624f
[util][math] update copyright header
2014-06-04 12:56:46 +03:00
Menelaos Karavelas
b8f0c9de94
[util][math] add sqrt function in bg::math namespace; this function
...
calls std::sqrt for fundamental number types and ::sqrt for everything
else; it helps avoiding implicit conversions for fundamental number
types when ::sqrt is called (in particular, we avoid the conversion
from long double to double when ::sqrt is called);
2014-06-04 12:53:59 +03:00
Menelaos Karavelas
ed956a4eaf
Merge branch 'feature/is_simple' of github.com:mkaravel/geometry into feature/is_simple
2014-06-04 12:10:38 +03:00
Adam Wulkiewicz
b0a1704779
[multi][io] Move wkt and dsv implementation for Multi Geometries from multi/ directory
2014-06-04 03:25:07 +02:00
Adam Wulkiewicz
f63fabcbb7
[multi][geometries] Move models, concepts and register macros from multi/ directory
2014-06-04 02:20:23 +02:00
Adam Wulkiewicz
82a2b50b0c
[multi][strategies] Move centroid_average from multi/ directory
2014-06-03 22:17:56 +02:00
Adam Wulkiewicz
676090691f
[multi][views] Move range_type<> from multi/ directory.
...
Also tweak the parameters of the dispatched implementation - reverse the order and add default Tag.
2014-06-03 21:54:01 +02:00
Adam Wulkiewicz
da20d7c409
[multi][core] Move functionalities of multi/core into core
2014-06-03 21:21:03 +02:00
Adam Wulkiewicz
948208a485
[strategies] Fix unused typedefs warnings.
2014-06-03 12:55:49 +02:00
Menelaos Karavelas
7e0652ef69
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-06-03 08:54:02 +03:00
Barend Gehrels
dfd38081bc
[extensions][distance] fix default_strategy extra tag
2014-06-02 23:04:29 +02:00
Barend Gehrels
d10a487bec
Merge pull request #51 from mkaravel/feature/distance-default-strategy
...
Feature/distance default strategy
2014-06-02 22:40:09 +02:00
Adam Wulkiewicz
b48748a3d3
[remove_spikes] Fix unused typedef warning
2014-05-30 15:20:36 +02:00
Adam Wulkiewicz
cbb408b7d5
[transform] Fix unused typedef warnings
2014-05-30 15:19:12 +02:00
Adam Wulkiewicz
9f814ae1ba
[simplify] Fix unused typedef warning
2014-05-30 15:17:46 +02:00
Adam Wulkiewicz
c9b975f556
[overlay] Fix unused typedef warning
2014-05-30 14:29:11 +02:00
Adam Wulkiewicz
8d4a61d496
[index/rtree] Fix unused typedef warnings
2014-05-30 14:26:44 +02:00
Adam Wulkiewicz
01a34d6b71
[index/varray] Fix unused typedef warnings
2014-05-30 14:23:47 +02:00
Adam Wulkiewicz
cda70f4326
[touches] Fix unused typedef warning
2014-05-30 14:21:19 +02:00
Adam Wulkiewicz
f614512cfa
[reverse] Fix unused typedef warning
2014-05-30 14:19:16 +02:00
Adam Wulkiewicz
81e0d3fac4
[overlay] Fix unused typedef warnings
2014-05-30 14:16:17 +02:00
Menelaos Karavelas
b970646722
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-05-30 15:12:51 +03:00
Adam Wulkiewicz
694fbffdeb
[relate] Fix unused typedef warnings
2014-05-30 14:12:14 +02:00
Menelaos Karavelas
779e05c292
[strategies][distance] fix names of template parameters to better
...
reflect the corresponding objects
2014-05-30 15:09:20 +03:00
Menelaos Karavelas
4d16a2112a
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/distance-default-strategy
2014-05-30 15:06:52 +03:00
Adam Wulkiewicz
a40a86b532
[intersects] Fix unused typedef warning
2014-05-30 14:04:42 +02:00
Adam Wulkiewicz
2265430625
[disjoint] Fix unused typedef warnings
2014-05-30 13:55:51 +02:00
Adam Wulkiewicz
9881f4f56d
[get_turns] Fix unused typedef warnings
2014-05-30 13:53:57 +02:00
Adam Wulkiewicz
b670b37643
[sectionalize] Fix unused typedef warnings
2014-05-30 13:52:43 +02:00
Adam Wulkiewicz
d8e46d3f85
[within] Use normalized_view in point_in_geometry and fix unused typedef warning
2014-05-30 13:45:18 +02:00
Adam Wulkiewicz
471fabab88
Merge pull request #52 from mkaravel/feature/distance
...
[strategies][distance] change template parameters' names to reflect the objects they represent
2014-05-30 12:57:44 +02:00
Sam Spilsbury
be3ee10849
[geometry][test] Fix concept check failures.
...
The functions in arithmetic.hpp would check the concepts Point and ConstPoint
on Point2, instead of checking Point on Point1 and ConstPoint on Point2.
This would cause concept check failures when attempting to operate from
a ConstPoint.
2014-05-30 00:04:20 +08:00
Menelaos Karavelas
f3f131db35
[strategies][distance] change template parameters' names to reflect
...
the objects they represent
2014-05-29 15:05:56 +03:00
Menelaos Karavelas
e15cbf41a4
[strategies] make default_strategy class commutative with respect
...
to the order of the geometry tags
2014-05-29 14:53:51 +03:00
Menelaos Karavelas
63dea88967
[disjoint] remove unecessary include
2014-05-28 17:30:59 +03:00
Menelaos Karavelas
4a59061e0e
[disjoint] avoid BOOST_AUTO_TPL
2014-05-28 17:23:57 +03:00
Barend Gehrels
3333ee09b1
Merge pull request #47 from mkaravel/feature/distance-default-strategy
...
Feature/distance default strategy
2014-05-28 15:30:45 +02:00
Barend Gehrels
d799a9a6b5
Merge pull request #44 from mkaravel/feature/distance
...
Feature/distance
2014-05-28 15:28:59 +02:00
Menelaos Karavelas
68e0584f26
[strategies][distance] update copyright header and default_strategy
...
struct inline doc
2014-05-28 16:07:28 +03:00
Menelaos Karavelas
bb20a1c1c7
[distance] fix order of template parameters for default strategy:
...
the two geometry tags should be the first two template parameters
2014-05-28 16:07:20 +03:00
Barend Gehrels
76d94f4f24
[minimum_ring_size] changed to size_t
...
(change was proposed by Menelaos #45 which is not merged in the end)
2014-05-28 13:57:37 +02:00
Menelaos Karavelas
3b4e63b2b7
[distance][segment-box] alternative implementation that does not use forward declarations
2014-05-28 14:25:25 +03:00
Barend Gehrels
398d7d7981
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-05-28 12:57:56 +02:00
Barend Gehrels
4453f7bd6d
[rescale] fix unit test and avoid BOOST_AUTO_TPL
...
Unit test is reworked. BOOST_AUTO_TPL is avoided using two specific methods
2014-05-28 12:57:35 +02:00
Barend Gehrels
a1882009e7
[simplify] fix Minimum case and avoid BOOST_AUTO_TPL
...
BOOST_AUTO_TPL is avoided by providing specific loop on iterator types
The change also avoids some typedefs and variables
2014-05-28 12:53:42 +02:00
Menelaos Karavelas
8d7c448315
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-05-28 11:09:59 +03:00
Menelaos Karavelas
be6ea95a9c
[disjoint] fix bug in segment-box disjointness check (algorithm
...
is not always working properly when segment degenerates to a point,
or when segment was parallel to the y-axis)
2014-05-28 03:35:34 +03:00
Menelaos Karavelas
25661874a2
[disjoint] fix compilation error on darwin gcc 4.2.1
2014-05-28 03:32:55 +03:00
Menelaos Karavelas
b77e545b8f
[distance] fix compilation errors with darwin gcc 4.2.1 and msvc-12.0
2014-05-28 03:13:33 +03:00
Menelaos Karavelas
b5c16d7371
[extensions][dissolve] remove empty comment line
2014-05-26 22:59:06 +03:00
Menelaos Karavelas
4e6abef7d4
[extensions][dissolve] remove unnecessary include
2014-05-26 22:54:57 +03:00
Menelaos Karavelas
70a431f7ef
[distance] remove inner template parameter that shadows global
...
template parameter; qualify template method call with template keyword;
fix return type of variant visitors;
2014-05-26 14:05:12 +03:00
brunolalande
5697607195
Merge pull request #40 from sdebionne/variant/intersection
...
[intersection] Add variant support
2014-05-23 23:32:48 +01:00
brunolalande
34f7fb1d19
Merge pull request #37 from sdebionne/variant/assign
...
[assign] Add variant support
2014-05-23 23:30:55 +01:00
brunolalande
ba53f02d54
Merge pull request #38 from sdebionne/variant/crosses
...
[crosses] Add variant support
2014-05-23 23:29:32 +01:00
Adam Wulkiewicz
4f69224c35
Merge pull request #35 from mkaravel/feature/disjoint
...
Feature/disjoint
2014-05-24 00:09:07 +02:00
Adam Wulkiewicz
985596fe97
Merge pull request #36 from mkaravel/feature/distance
...
Feature/distance
2014-05-24 00:08:43 +02:00
brunolalande
d563f3706d
Merge pull request #39 from sdebionne/variant/expand
...
[expand] Add variant support
2014-05-23 23:03:55 +01:00
Menelaos Karavelas
4c1bf7b28f
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/disjoint
2014-05-23 20:47:39 +03:00
Menelaos Karavelas
939517e198
[disjoint] remove obsolete file algorithms/detail/disjoint.hpp
2014-05-23 20:47:06 +03:00
Menelaos Karavelas
0d6b757832
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/distance
2014-05-23 18:22:11 +03:00
brunolalande
8f2a516cc6
Merge pull request #26 from sdebionne/develop
...
[distance] Add variant support
2014-05-23 16:13:59 +01:00
Samuel Debione
c9edff5e31
[distance] Remove global is_implemented
2014-05-23 17:00:03 +02:00
Samuel Debione
6f2848819f
[intersection] Removes duplicate concept check
2014-05-23 16:36:42 +02:00
Samuel Debione
0cb4494e20
[crosses] Remove duplicate concept check
2014-05-23 16:35:24 +02:00
Samuel Debione
97508183e1
[assign] Move concept check
2014-05-23 16:34:17 +02:00
Samuel Debione
74d36cd5b3
[expand] Move concept check
2014-05-23 16:32:53 +02:00
Samuel Debione
b8a581f3ad
Revert "[expand] Adds support for variant box"
...
This reverts commit 52ce484c7f
.
2014-05-23 16:26:54 +02:00
Samuel Debione
52ce484c7f
[expand] Adds support for variant box
2014-05-23 15:02:46 +02:00
Adam Wulkiewicz
5cc480d2c2
[index] Remove unneeded template keyword from member function call
2014-05-23 14:18:47 +02:00
Samuel Debione
79cd3df923
[distance] Support different variant type
...
Add support for different variant type as parameters
2014-05-23 14:09:23 +02:00
Menelaos Karavelas
21b7851381
[disjoint][segment-box] factor-out common code in disjoint_segment_box_impl
2014-05-23 14:12:01 +03:00
Samuel Debione
158433af6f
[intersection] Add test for variant
2014-05-23 12:35:52 +02:00
Menelaos Karavelas
04bf50afc1
[distance][segment-box] eliminate unused variable (pp_strategy) in method call;
...
initialize result with 0;
2014-05-23 12:52:05 +03:00
Menelaos Karavelas
1b327f6910
[distance][segment-box] qualify all calls to get<I> with the geometry namespace
2014-05-23 12:41:51 +03:00
Samuel Debione
8f2addce33
[expand] Add tests for variant
2014-05-23 10:55:06 +02:00
Samuel Debione
4b32473630
[crosses] Add tests for variants
2014-05-23 10:37:49 +02:00
Samuel Debione
55e54692b9
[assign] Rename the variant template parameters
...
Was T1 and T2 but that could eventually be a problem if the user defines
BOOST_VARIANT_LIMIT_TYPES > 10.
2014-05-23 10:24:13 +02:00
Samuel Debione
999fdff2eb
[assign] Add copyright notice
2014-05-23 10:12:39 +02:00
Menelaos Karavelas
c4af782c0c
[distance] eliminate more useless code in segment-box computation
2014-05-23 00:35:44 +03:00
Menelaos Karavelas
a6acea282c
[distance] re-factor segment-box code
2014-05-23 00:23:49 +03:00
Adam Wulkiewicz
3474244d0a
[index] Varian-based nodes used in the rtree by default.
...
This should fix the crash when the rtree is used in the shared memory reported in this thread: http://boost-geometry.203548.n3.nabble.com/rtree-crash-when-used-with-inter-process-td4026037.html
2014-05-22 17:24:31 +02:00
Samuel Debione
594add5e1b
[assign] Add tests for variants
2014-05-22 16:32:47 +02:00
Samuel Debione
82abc509df
Merge remote-tracking branch 'boostorg/geometry/develop' into develop
2014-05-22 12:15:04 +02:00
Samuel Debione
04693e50c0
Merge remote-tracking branch 'boostorg/geometry/develop' into variant/intersection
2014-05-22 12:10:45 +02:00
Samuel Debione
421abd19c6
Merge remote-tracking branch 'boostorg/geometry/develop' into variant/expand
2014-05-22 12:10:14 +02:00
Samuel Debione
38c373b909
Merge remote-tracking branch 'boostorg/geometry/develop' into variant/crosses
2014-05-22 12:10:02 +02:00
Samuel Debione
a417fa3623
Merge remote-tracking branch 'boostorg/geometry/develop' into variant/assign
2014-05-22 12:09:23 +02:00
Samuel Debionne
c5b3acb70c
[expand] Add variant support
2014-05-21 21:02:53 +02:00
Samuel Debionne
ddc649a492
[assign] Fix compiler errors
2014-05-21 20:02:30 +02:00
Samuel Debionne
2031415390
[crosses] Fix compile errors
2014-05-21 19:47:48 +02:00
Samuel Debionne
d968f26bae
[intersection] Add variant support
2014-05-21 19:36:44 +02:00
Menelaos Karavelas
0df67aa716
[disjoint] add missing include of basic dispatch
2014-05-21 17:33:33 +03:00
Menelaos Karavelas
8e03f95ec8
[multi][get turns] remove unused include
2014-05-21 17:26:27 +03:00
Menelaos Karavelas
57921a7e89
[disjoint] clean-up code in detail/disjoint/interface.hpp;
...
create and add proper includes in detail/disjoint/implementation.hpp;
re-create algorithms/disjoint.hpp and add the above two includes;
2014-05-21 17:18:38 +03:00
Menelaos Karavelas
b6522c4e74
[disjoint] move main file to detail/disjoint/interface.hpp
2014-05-21 17:14:56 +03:00
Menelaos Karavelas
e3512fc622
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/disjoint
2014-05-21 17:09:56 +03:00
Menelaos Karavelas
90ac851e4e
[disjoint] add missing includes
2014-05-21 17:06:36 +03:00
Menelaos Karavelas
c29c4cd246
[strategies] replace inclusion of algorithms/detail/disjoint/point_point.hpp by algorithms/detail/equals/point_point.hpp
2014-05-21 16:56:57 +03:00
Menelaos Karavelas
050bedec65
[relate] replace inclusion of algorithms/detail/disjoint/point_point.hpp by algorithms/detail/equals/point_point.hpp
2014-05-21 16:55:02 +03:00
Menelaos Karavelas
1035533676
[within] replace inclusion of algorithms/detail/disjoint/point_point.hpp by algorithms/detail/equals/point_point.hpp
2014-05-21 16:53:39 +03:00
Menelaos Karavelas
c2cf7215f0
[overlay] replace include of algorithms/detail/disjoint.hpp by algorithms/detail/disjoint/box_box.hpp
2014-05-21 16:51:55 +03:00
Menelaos Karavelas
531127252c
[overlay] replace inclusion of algorithms/detail/disjoint.hpp by algorithms/detail/equals/point_point.hpp
2014-05-21 16:49:09 +03:00
Menelaos Karavelas
957addb5e2
[set ops P/P] replace inclusion of algorithms/detail/disjoint.hpp by algorithms/detail/equals/point_point.hpp
2014-05-21 16:47:45 +03:00
Menelaos Karavelas
a7323f79f4
[point on border] replace inclusion of algorithms/detail/disjoint.hpp by algorithms/detail/equals/point_point.hpp
2014-05-21 16:44:43 +03:00
Menelaos Karavelas
1d3432f83c
[has self intersections] include header with disjoint interrupt policy
2014-05-21 16:43:32 +03:00
Menelaos Karavelas
0d4eccd510
[buffer] remove inclusion of algorithms/detail/disjoint.hpp
2014-05-21 16:42:42 +03:00
Menelaos Karavelas
4eca302164
[extensions][ttmath] add unary operator-() for ttmath_big (needed for
...
boost::geometry::math::abs) and also add binary operator-() (needed
because of the unary overlaod)
2014-05-21 16:37:53 +03:00
Menelaos Karavelas
f8c0b46d43
[disjoint] move code from multi/algorithms/disjoint.hpp to files
...
in algorithms/disjoint/detail; move code from algorithms/distance.hpp
also to algorithms/disjoint/detail and in algorithms/dispatch/disjoint.hpp
2014-05-21 16:35:40 +03:00
Menelaos Karavelas
7f1bb277ab
[disjoint] add files in algorithms/detail/disjoint with existing code
...
and new code (for new geometry combinations); clean-up/simplify
dispatch using tag_cast and clean-up dispatch specializations;
2014-05-21 16:33:17 +03:00
Menelaos Karavelas
cf517dcb2e
[disjoint] add dispatch and fix copyright headers
2014-05-21 16:12:02 +03:00
Menelaos Karavelas
b39c46575c
[disjoint] add dispatch specialization for point-point and point-box;
...
move equals::point_point code to proper place;
2014-05-21 15:45:35 +03:00
Menelaos Karavelas
ce750e15ae
[disjoint] move disjoint_interrupt_policy from algorithms/detail/disjoint.hpp
...
to a separate file under policies
2014-05-21 15:37:51 +03:00
Menelaos Karavelas
5afdb4acbb
[disjoint] add error message in algorithms/detail/disjoint.hpp to check
...
whether this file is included somewhere or not; this file will go away
2014-05-21 15:36:22 +03:00
Menelaos Karavelas
d71975878f
[disjoint/equals] move equals::point_point from algorithms/detail/disjoint/point_point.hpp
...
to algorithms/detail/equals/point_point.hpp
2014-05-21 15:34:05 +03:00
Menelaos Karavelas
001fa94c76
[disjoint] move basic disjoint dispatch in algorithms/dispatch/disjoint.hpp; use tag_cast to simplify dispatching
2014-05-21 14:58:53 +03:00
Barend Gehrels
30a4bc3990
[buffer] rename m_rescale_policy to m_robust_policy
2014-05-21 12:39:14 +02:00
Barend Gehrels
089a9841c6
[rescale] fix for points / empty boxes
2014-05-21 12:33:11 +02:00
Barend Gehrels
6d6c472d74
[buffer] fix for changed name geometry_multi_within_coe to point_in_geometry
2014-05-21 12:32:40 +02:00
Barend Gehrels
157b9237ec
[buffer] fix for update get_turns
2014-05-21 12:32:07 +02:00
Samuel Debionne
2a819b81ef
[assign] Add variant support
2014-05-21 08:31:22 +02:00
Samuel Debionne
1c99e515b6
[crosses] Add variant support
2014-05-21 08:29:23 +02:00
Menelaos Karavelas
7a25e39129
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/disjoint
2014-05-20 04:12:02 +03:00
Barend Gehrels
86259f78a7
[doc][wkt] Fixed WKT doc / extended WKT doc (in progress)
2014-05-19 23:10:06 +02:00
Menelaos Karavelas
7445898e77
[distance] fix bugs in segment-to-box distance computation;
...
add generic algorithm for computing segment-to-box distances:
the algorithm first checks the segment and the box for intersection,
then if no intersection is found, it returns the minimum distance
over all point-segment combinations from the two geometries; for
computing a point-box distance the algorithm either calls the default
point-box strategy, or calls the detail::distance::point_to_range
algorithm; this alternate segment-box distance computation algorithm
is currently used in unit tests of segment-box distances to verify
results with the cartesian-specific approach
2014-05-19 16:49:35 +03:00
Menelaos Karavelas
86563682b3
[distance] modify the range-to-segment/box code, so that in the case
...
of computing the distance of a point of the range from the box, the
point-to-range code in point_in_geometry.hpp is used
2014-05-19 16:45:44 +03:00
Menelaos Karavelas
bacf060256
[distance] modify the point-to-range code so that a container/range
...
of points can be passed as an argument (e.g., a vector of points)
2014-05-19 16:44:27 +03:00
Samuel Debione
09a8ba53a7
[distance] Use transform_variant
...
Remove dependency to is_implemented. Update transform_variant to support
MPL sequence input.
2014-05-19 13:52:09 +02:00
Adam Wulkiewicz
1e8358c0df
Merge pull request #33 from mkaravel/develop
...
[distance] fix bug in point-box distance computation in range-to-segment/box code
2014-05-19 02:34:30 +02:00
Adam Wulkiewicz
ba8d1b471d
[index][example] Improve the rtree visualization.
...
Add support for rtrees storing Points and Segments.
Add the support for Segments in print_indexable() and gl_draw_indexable() index utilities.
2014-05-19 01:10:36 +02:00
Menelaos Karavelas
949691799f
[distance] fix bug in point-box distance computation in range-to-segment/box code
2014-05-19 01:38:39 +03:00
Adam Wulkiewicz
e6fccafd40
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-05-18 00:21:38 +02:00
Adam Wulkiewicz
c4ca605bab
[overlay][relate][within][test] Fix unused variable warnings.
2014-05-18 00:20:36 +02:00
Barend Gehrels
e79e6c9e2e
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-05-18 00:02:56 +02:00
Barend Gehrels
5007f1debb
[extensions][dissolve] repaired dissolve w.r.t. turn changes
2014-05-17 21:09:07 +02:00
Adam Wulkiewicz
d0cf100a65
[get_turns][relate][test][index] Fix unused variable warnings.
...
In the rtree/pack_create replace (void)variable to boost::ignore_unused_variable_warning().
2014-05-17 14:10:34 +02:00
Menelaos Karavelas
a7f555b862
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/disjoint
2014-05-16 23:48:45 +03:00
Samuel Debione
595f6fe457
[distance] Fix some typo and add more tests
2014-05-16 16:14:50 +02:00
Samuel Debione
e07e5052ee
[distance] Merge from upstream
2014-05-16 15:57:48 +02:00
Samuel Debione
11e2d964d3
Merge from upstream
2014-05-16 13:34:41 +02:00
Menelaos Karavelas
3fbfd2474d
[distance] implement the new file/directory structure fully:
...
move the free function and reverse dispatch in algorithms/distance/interface.hpp
move the details of the implementation in algorithms/distance/implementation.hpp
keep only these two headers in algorithms/distance.hpp
2014-05-16 14:14:26 +03:00
Menelaos Karavelas
96a2f382a2
[distance] implement the new file/directory structure fully:
...
move the free function and reverse dispatch in algorithms/distance/interface.hpp
move the details of the implementation in algorithms/distance/implementation.hpp
keep only these two headers in algorithms/distance.hpp
2014-05-16 13:58:43 +03:00
Menelaos Karavelas
7a7a75245d
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/distance
2014-05-15 19:20:27 +03:00
Adam Wulkiewicz
672384be00
[index] Remove unneeded #includes from the rtree.hpp
2014-05-15 17:18:24 +02:00
Adam Wulkiewicz
f41ef36258
[index] Update description and parameters names of nearest() predicate
2014-05-15 03:21:38 +02:00
Adam Wulkiewicz
8aa3ef425e
[equals][index/examples] Optimize equals(Seg,Seg) and fix index/examples
...
Use less comparisions in equals(Seg,Seg) - suggested by Menelaos Karavelas
Add missing include to examples - caused by the recent change of the distance/rtree
2014-05-15 02:56:15 +02:00
Menelaos Karavelas
46763d34ca
[strategies] fix conversion issue in projected_point strategy:
...
Problem:
when p1 (2nd argument of apply) has float as coordinate type, then
the result of the differences u-p1 and w-p1 is a double (because
the calculation type is double), which then is implicitly converted
to float (because the result of the difference is implicitly
converted to the type of the second operand), which means that we
may loose precision.
Solution:
convert p1 to the correct point type (fp_point_type), and then
perform the subtractions (p1 is anyways converted later on, so
just do then conversion a bit earlier).
Note:
This problem was generated as a warning on VS2010, and also appears
as a warning in clang++ and g++ if the -Wconversion option is used.
2014-05-15 02:24:42 +03:00
Adam Wulkiewicz
02df2d788f
[index][equals] Add the support for Segments as Indexables in the rtree.
...
This commit also adds the support for equals(Segment, Segment).
During the creation of the rtree all metrics are calculated for Segments viewed as bounding Boxes.
During the querying Segments are passed into the BG algorithms.
This commit also fixes a compilation error related to the calculation of the Box/Box intersection in the index::detail::intersection_content().
Add indexed_point_view<> which allows to see Boxes and Segments as one of the Points.
Move normalized_view<> to views/detail.
Add index::detail::bounded_view<> which allows to see simple Geometry e.g. a Segment as its bounding Geometry e.g. a Box.
TODO/RECONSIDER:
1. This commit adds return_ref_or_bounds() which returns const& for Points and Boxes and bounding Box view for Segment. The resulting object is then passed into various algorithms like covered_by() or within(). Whenever possible the algorithms should be implemented for the input parameters and the call to return_ref_or_bounds() removed.
2. It's possible that for Segments metrics (like the amount of overlap in the leaf node) could be calculated differently than for Boxes and naiive conversion to bounding Boxes is not fully correct.
3. The way how bounded_view<> works may be not correct for non-cartesian CS. Now, for Segments it just picks MIN and MAX coordinates on the fly which may not be ok e.g. for Segments defined in the spherical CS because of the "winding" of the coordinates.
2014-05-14 23:30:35 +02:00
Samuel Debione
3d528db92c
[distance] First step to fix tests
2014-05-14 16:27:55 +02:00
Menelaos Karavelas
04455dc1ce
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-05-14 16:29:50 +03:00
Menelaos Karavelas
24d553a91a
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/disjoint
2014-05-14 16:29:28 +03:00
Adam Wulkiewicz
59b68ad2da
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-05-14 15:14:09 +02:00
Adam Wulkiewicz
8dcd329db7
[index] Use default_comparable_distance_result whenever possible
2014-05-14 15:13:01 +02:00
Menelaos Karavelas
3307029805
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/disjoint
2014-05-14 15:52:06 +03:00
Menelaos Karavelas
a9fd41e355
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-05-14 15:42:25 +03:00
Barend Gehrels
4f19973453
[centroid] removed redundant distance include causing circular reference
...
for unit test "geometries/adapted"
2014-05-14 14:41:24 +02:00
Menelaos Karavelas
453a2c3784
[set ops L/L] fix unused variable warnings produced with clang++ with -Wextra
2014-05-14 15:39:12 +03:00
Menelaos Karavelas
277dcdba59
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/distance-for-merge
2014-05-14 15:29:12 +03:00
Menelaos Karavelas
f6d0b4054a
[distance] fix unused variable warnings produced by clang++ with -Wextra and warnings by VS (reported by Adam)
2014-05-14 15:20:57 +03:00
Barend Gehrels
07696d76fd
[overlay] Added missing include / removed obsolete include,
...
causing unit test troubles after distance merge
2014-05-14 13:46:22 +02:00
Barend Gehrels
c995031337
[intersection] avoid circulare reference in index/intersection/distance
2014-05-14 13:22:48 +02:00
Barend Gehrels
06346ee2ea
Merge pull request #24 from mkaravel/feature/distance-for-merge
...
Feature/distance for merge
2014-05-14 12:35:59 +02:00
Menelaos Karavelas
a500a12726
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/disjoint
2014-05-14 10:20:53 +03:00
Samuel Debione
124f783d3b
[distance] Add variant tests
...
No finished yet
2014-05-13 16:40:41 +02:00
Menelaos Karavelas
b8eaf21fb5
[comparable distance] make comparable_distance(g1, g2) return default_comparable_distance_result
2014-05-13 10:53:25 +03:00
Samuel Debione
122a6344ff
[distance] Add variant support
...
Add variant dispatch layer to the distance algorithm
2014-05-12 17:23:02 +02:00
Menelaos Karavelas
cea8dd1b0d
[distance] polish code; make clear when the result of comparable or regular strategy is used;
2014-05-11 23:21:22 +03:00
Menelaos Karavelas
15c711cf53
[distance] polish code; make clear when the result of comparable or regular strategy is used;
...
re-write geometry_to_geometry_rtree class so that is uses comparable distances for internal computations;
2014-05-11 23:16:17 +03:00
Menelaos Karavelas
d6b3abcfc1
[distance] re-write segment-box distance code without strategy::distance::services::strategy_point_point;
...
fix bug in segment-box comparable distance when the segment degenerates to a point;
2014-05-09 23:05:20 +03:00
Menelaos Karavelas
54ff519466
[stategies][distance] remove strategy::distance::services::strategy_point_point from distance strategies and distance strategy concept
2014-05-09 23:02:39 +03:00
Menelaos Karavelas
5777fd5b8d
[overlay] the specialization of intersection_insert for linestring/box computes the intersection, but pretends as if it works for difference as well;
...
quick fix: further specialize this specialization of intersection insert so that it works only for overlay_intersection;
problem and quick fix related to boost trac ticket #10019 ;
2014-05-09 09:33:32 +03:00
Menelaos Karavelas
a7d02e0391
[distance][test] enable segment-segment distance computations
2014-05-09 00:20:24 +03:00
Menelaos Karavelas
226dcc4e6c
[comparable distance] fix comments so that they make sense wrt to the code they refer to
2014-05-09 00:02:17 +03:00
Menelaos Karavelas
47c1cfe9b6
[strategies][distance] re-implement the dfeault distance result using the default strategy from detail::distance::default_strategy
2014-05-08 23:59:11 +03:00
Menelaos Karavelas
73858fc359
[comparable distance] simplify the definition of the default comparable strategy using the class detail::distance::default_strategy
2014-05-08 23:56:55 +03:00
Menelaos Karavelas
4598228ea0
[distance] re-implement the default strategy type in free function distance(g1, g2); remove inclusion of unused headers;
2014-05-08 23:50:28 +03:00
Menelaos Karavelas
cd77588326
[strategies] implement default_comparable_distance_result class
2014-05-08 23:48:38 +03:00
Menelaos Karavelas
e729f37bbe
[distance] perform reverse-dispatch for default strategy
2014-05-08 23:47:22 +03:00
Menelaos Karavelas
3d25114c8e
[distance] remove inclusion of default_distance_result (not used)
2014-05-08 22:33:56 +03:00
Menelaos Karavelas
06ebf17a8d
[disjoint] add alternative (more robust) implementation of segment-box disjointness test; the alternative implementation does not use any divisions
2014-05-08 22:24:01 +03:00
Menelaos Karavelas
aecc7c8015
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/distance-for-merge
2014-05-08 17:29:00 +03:00
Menelaos Karavelas
1a2ef5c2bc
[disjoint] add specializations for linestring/multilinestring, multilinestring/multilinestring; fixed specialization for polygon/multilinestring
2014-05-08 16:39:09 +03:00
Menelaos Karavelas
23f8b97fac
[index] include comparable_distance algorithm
2014-05-08 15:59:15 +03:00
Menelaos Karavelas
8a7a14bc53
[index] replace call to comparable_distance_near by bg::comparable_distance
2014-05-08 15:52:53 +03:00
Menelaos Karavelas
203aa991ae
[index] replace #include <boost/geomerty/geometry.hpp> by the necessary includes
2014-05-08 15:46:25 +03:00
Adam Wulkiewicz
9ea4b6bf6c
[index] Add the support for std::pair<> and boost/std::tuple<> registered as Indexable
2014-05-08 14:42:45 +02:00
Menelaos Karavelas
d289118bd9
[strategies] add the point-box and box-box pythagoras strategies in strategies/strategies.hpp
2014-05-08 15:26:57 +03:00
Menelaos Karavelas
752de3060a
[iterators] add free function has_one_element, that tests whether an iterator range has a unique element (has size 1)
2014-05-08 15:15:16 +03:00
Menelaos Karavelas
b1eaf94bfe
[strategies][distance] add a template parameter to default distance strategy corresponding to the second geometry of the distance strategy
2014-05-08 15:12:59 +03:00
Menelaos Karavelas
3c64533d7d
[distance] add primary dispatch definition under algorithms/dispatch
2014-05-08 15:11:54 +03:00
Menelaos Karavelas
55f63b77df
[distance] update distance.hpp: primary dispatch is under algorithms/dispatch/, details are under algorithms/detail/distance/
2014-05-08 15:10:24 +03:00
Menelaos Karavelas
0600a3419f
[strategies][distance] add tags for point-box and box-box strategies
2014-05-08 15:08:09 +03:00
Menelaos Karavelas
cfc4e7a3c9
[multi][distance] move multi/algorithms distance code under algorithms/ keep the file as a placeholder and include algorithms/distance.hpp
2014-05-08 15:06:19 +03:00
Menelaos Karavelas
ddc5ddf0ff
[comparable distance] add free function for comparable distance that takes a strategy
2014-05-08 15:04:23 +03:00
Menelaos Karavelas
e783d7ca2e
[distance] dispatches for various geometry combinations with the point-point strategy;
...
the point-point strategy is not the natural distance strategy for these geometry pairs;
the dispatches have been added for backward compatibility;
2014-05-08 15:01:03 +03:00
Menelaos Karavelas
ab6588f9b2
[distance] implementation for distance(multi-point,range)
2014-05-08 15:00:07 +03:00
Menelaos Karavelas
8553124d37
[distance] base cose for distance computations using the R-Tree
2014-05-08 14:58:05 +03:00
Menelaos Karavelas
e1e227c022
[distance] segment-box distance computation
2014-05-08 14:57:44 +03:00
Menelaos Karavelas
3051652a5b
[distance] add implementation for distance computation between a polygon and a segment or a box
2014-05-08 14:57:11 +03:00
Menelaos Karavelas
26dfb26d69
[distance] add implementation for distance computation between a range and a segment or a box
2014-05-08 14:53:21 +03:00
Menelaos Karavelas
5d04ac7c92
[distance] segment-to-segment distance computation
2014-05-08 14:52:51 +03:00
Menelaos Karavelas
22142c9040
[distance] add distance code for multi-to-multi geometry combinations and dispatch specializations;
...
some of the code in this file originated from multi/algorithms/distance.hpp
2014-05-08 14:52:13 +03:00
Menelaos Karavelas
6bac8b43a1
[distance] add distance code for single-to-multi geometry combinations and dispatch specializations;
...
some of the code in this file originated from multi/algorithms/distance.hpp
2014-05-08 14:49:27 +03:00
Menelaos Karavelas
ad2fbc9e5b
[distance] add helper classes for choosing default strategies
2014-05-08 14:49:01 +03:00
Menelaos Karavelas
17d3f0e78e
[strategies][distance] add class to convert a distance result from comparable to regular distance result if needed;
...
add implementation of this for cartesian coordinates (applies sqrt);
2014-05-08 14:47:19 +03:00
Menelaos Karavelas
f9825be6bf
[distance] add implementation of distance(point, geometry); most of the origina code was in algorithms/distance.hpp; the point-box combination was added;
...
point_to_range takes only one strategy now; all intermediate distance computations done with comaprable distances (conversion happens at the end);
2014-05-08 14:43:38 +03:00
Menelaos Karavelas
ebc8d5cf63
[distance] add distance(box, box) detail implementation
2014-05-08 14:43:10 +03:00
Menelaos Karavelas
affc4340c2
[strategies][distance] add cartesian strategy for point-box and box-box distance computation
2014-05-08 13:49:24 +03:00
Menelaos Karavelas
cdd4bbc1aa
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-05-08 02:01:53 +03:00
Menelaos Karavelas
1e3041e748
[overlay][P/P, L/L] replace BOOST_AUTO_TPL by the exact type
2014-05-08 01:28:09 +03:00
Barend Gehrels
899c94b148
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-05-07 13:15:22 +02:00
Adam Wulkiewicz
dffd4a4f64
Merge pull request #22 from mkaravel/feature/setops
...
Feature/setops
2014-05-07 11:58:11 +02:00
Adam Wulkiewicz
6407199617
Merge pull request #21 from mkaravel/feature/point_iterator
...
Feature/point iterator
2014-05-07 11:57:20 +02:00
Barend Gehrels
22f3c65b5d
[doc] Added doc for parameters Doxygen was missing
2014-05-07 11:40:57 +02:00
Menelaos Karavelas
51c601bb49
[point_iterator_type] replace #include of type traits by the specific one used (is_const)
2014-05-06 22:02:26 +03:00
Menelaos Karavelas
793a6321c6
[copy segments] replace generic #include of type traits by the specific one used (integral_constant)
2014-05-06 21:51:15 +03:00
Adam Wulkiewicz
8eefe4d3ba
[equals] Add missing copyright info
2014-05-06 19:00:28 +02:00
Adam Wulkiewicz
8bb1d98aaf
[equals][relate] Add equals() Ls/MLs, MLs/MLs. Fix relate(L/L).
...
Also use relate() in equals(Ls,Ls) because collect_vectors() approach doesn't work properly for non-simple or even opposite/reversed Linestrings.
Fix how 'u' is handled in relate() in the edge case when there are more 'u' operations in the same point, also when 'u' is on the first endpoint followed by 'i' on the same IP.
Add tests for equals() and relate().
2014-05-06 16:18:05 +02:00
Menelaos Karavelas
826045c3a1
[set ops L/L] remove commented code in assign_policy; add template parameter to control the behavior of intersection wrt whether isolated points are followed or not;
2014-05-05 12:10:20 +03:00
Menelaos Karavelas
a73ce5fbd6
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-05-05 10:23:45 +03:00
Menelaos Karavelas
99dbc5082e
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/point_iterator
2014-05-05 10:22:25 +03:00
Menelaos Karavelas
6adb2e9d51
[point_reverse_iterator] implement reverse iterator for geometries
2014-05-05 09:51:22 +03:00
Menelaos Karavelas
0648b7293e
[flatten_iterator] implement decrement operation for flatten iterator
2014-05-05 09:50:42 +03:00
Menelaos Karavelas
cd1d490d2e
[point_iterator] add free functions points_front and points_back that return the first and last point of a geometry
2014-05-05 09:50:04 +03:00
Adam Wulkiewicz
aea578c602
[get_turns] Fix turn operation is_collinear values for L/L and L/A.
...
is_collinear for the first endpoint of L is now unified and is always equal to FALSE.
Add tests of is_collinear. It is tested by passing 4th and 5th char in the expected turn string (= means collinear, + means non-collinear), e.g. "mxi=+" for L/L means that L1 ends in this IP and was collinear before meeting the Point, L2 is going "inside" intersection and wasn't collinear before.
Replace method_and_operation_replacer with turn_transformer.
2014-05-04 22:31:13 +02:00
Adam Wulkiewicz
e6ef0b0328
[get_turns] Use RobustPolicy in a unified way in all three get_turn_info* policies (A/A, L/A, and L/L).
...
Newly introduced intersection_info containing IntersectionResult, SideCalculator and Point refs is used also in get_turn_info for A/A.
Robust points are stored only if RobustPolicy is not no_rescale_policy.
This commit also fixes an error in get_turn_info - swapped_side_calc created for method_touch_interior ('m') should use robust points just like the original one.
2014-05-04 01:26:12 +02:00
Barend Gehrels
bff1c65b0a
fixed comment
2014-05-03 14:41:47 +02:00
Barend Gehrels
7b2a4cb589
[intersection] fix segments_intersection_ratios
...
adding the new one_degenerate method
2014-05-03 14:41:33 +02:00
Adam Wulkiewicz
6abe245eb7
[get_turns] Fix invalid condition get_turn_info_la
2014-05-03 02:47:58 +02:00
Adam Wulkiewicz
d4d7bf9657
[get_turns] Fix the generation of some special cases of touch-spike-turns for L/L and L/A
2014-05-03 02:40:21 +02:00
Adam Wulkiewicz
93c5c4a329
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-05-01 12:38:07 +02:00
Adam Wulkiewicz
288c7e6980
[get_turns] Fix for L/L spike vs. endpoint for the same direction segments. Add failing test cases for spikes touching internal point
2014-05-01 12:37:54 +02:00
Menelaos Karavelas
75488e0988
[point_iterator] fix constructor calls for concatenate_iterator
2014-05-01 01:42:24 +03:00
Menelaos Karavelas
5a2993d30f
[concatenate_iterator] make the iterator bidirectional
2014-05-01 01:37:35 +03:00
Menelaos Karavelas
7d2d0d9169
[is_valid] remove code for rings (moved to detail/is_valid/ring.hpp
2014-04-30 22:26:44 +03:00
Menelaos Karavelas
6e384c3c5e
[is_valid] file for is_valid ring implementation (on-going)
2014-04-30 22:25:32 +03:00
Menelaos Karavelas
a61be76a19
[is_valid] file for polygon is_valid implementation (no code yet)
2014-04-30 22:25:10 +03:00
Menelaos Karavelas
178696d511
[is_valid] rename {not_}equal_point to {not_}equal_to and use point as the outer template parameter object instead of iterator
2014-04-30 22:22:01 +03:00
Menelaos Karavelas
542278e42c
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-04-30 22:06:13 +03:00
Menelaos Karavelas
c2bf14e1c3
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-04-30 22:05:09 +03:00
Barend Gehrels
9f1b9ff7ba
[overlay] Calculate ratio for segment intersection where one segment is degenerate
2014-04-30 17:33:58 +02:00
Menelaos Karavelas
98e6dd3783
[overlay] add template parameter to follow and action_selector about removing spikes; the default behavior is to remove them; this is backward compatible with the
...
code before the changes in copy_segments
2014-04-30 15:57:51 +03:00
Menelaos Karavelas
c5c22d720c
[is_valid / is_simple] move files one directory level up (ommit the ogc directory);
...
move code one namespace up (ommit the ogc namespace);
2014-04-30 12:34:52 +03:00
Menelaos Karavelas
65e1118669
[algorithms][overlay] allow for spikes in output likestrings; this modifies the behavior of existing set ops and allows to support linear geometries with spikes;
...
change copy_segments for linestrings to take a template parameter to control whether spikes are accepted or not; by default they are not accepted
(but the follow code now explicitly allows for them in places where it wasn't;
2014-04-30 12:12:27 +03:00
Menelaos Karavelas
a5056728b7
[copyright headers] unify the way they look
2014-04-30 12:11:13 +03:00
Menelaos Karavelas
f605bbc7d1
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-04-30 01:27:23 +03:00
Menelaos Karavelas
c9e33bbd50
[is_simple] add missing includes; fix coding style;
2014-04-30 00:47:58 +03:00
Menelaos Karavelas
a712981e28
[is_simple] implementation of is_simple for pointlike and linear geometries
2014-04-30 00:12:05 +03:00
Menelaos Karavelas
737eb681c1
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-04-29 23:02:05 +03:00
Menelaos Karavelas
4e14afc71f
[is_valid] fix wrong result for empty multi-geometries
2014-04-29 23:00:38 +03:00
Menelaos Karavelas
d4c0f9d626
[is_simple] basic dispatch for is_simple
2014-04-29 20:05:57 +03:00
Menelaos Karavelas
e68f3b512c
[is_simple] update code; fix includes;
2014-04-29 20:05:16 +03:00
Menelaos Karavelas
dfa427e83a
[is_valid] fix includes
2014-04-29 20:04:35 +03:00
Adam Wulkiewicz
c88767bf2a
Merge pull request #20 from sdebionne/develop
...
check_result_type is missing inline qualifier
2014-04-29 14:06:40 +02:00
Samuel Debione
118a750e9e
check_result_type is missing inline qualifier
...
Function check_result_type is missing inline qualifier.
2014-04-29 13:47:09 +02:00
Adam Wulkiewicz
d682a74c1b
[extensions/dissolve] Fix compilation error - pass segment_ratio<> to traversal_turn_info<>. Remove mistankenly commited test change
2014-04-29 13:19:11 +02:00
Adam Wulkiewicz
d44e1a1e01
[get_turns][extensions/dissolve] Fix VS compilation error (STATIC_ASSERT + template). Add not_implemented<> info to extensions/dissolve.
2014-04-29 13:06:04 +02:00
Menelaos Karavelas
f5589c6ebf
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-04-28 18:11:38 +03:00
Menelaos Karavelas
b4774ff964
[is_valid] implementation of OGC's is_valid for pointlike and linear geometries; moved unit tests to test/algorithms/ogc directory;
2014-04-28 18:08:47 +03:00
Adam Wulkiewicz
bf918c15d0
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-04-28 12:22:37 +02:00
Adam Wulkiewicz
2349c817e2
[get_turns] Fix turns generation for double collinear spikes.
...
Add check if a spike Point is realy an IP.
2014-04-28 12:21:06 +02:00
Menelaos Karavelas
333cfdccfb
[turns] rename less functor from less_seg_dist_other_op to less_seg_fraction_other_op (to indicate that the fraction comparison is now used)
2014-04-28 10:29:45 +03:00
Menelaos Karavelas
65c57c4bfb
[policies][robustness] properly initialize m_approximation in default segment_ratio constructor
2014-04-28 10:15:05 +03:00
Barend Gehrels
0311b165ab
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-04-27 20:54:46 +02:00
Barend Gehrels
ac913b5a67
Replaced #ifdef with extra parenthesis to solve macro/comma problems
2014-04-27 20:54:31 +02:00
Adam Wulkiewicz
294b888f76
[test][sectionalize] Fix GCC4.4 compilation error.
...
Explicitly use namespace geometry in sectionalize() overload used in the test.
2014-04-27 18:48:35 +02:00
Adam Wulkiewicz
d41be62461
[relate] refactor relate helpers.
...
Remove unused, commented-out code.
Improve the names.
2014-04-27 16:08:30 +02:00
Adam Wulkiewicz
6bbabf9867
[views][relate] Add detail::normalized_view<> and use it in relate_linear_areal.
...
It's a view connecting reversible_view and closeable_view, allowing to view a subrange of a Geometry as reversed and/or closed if necessary.
Polygons and similar Geometries are always CW, closed.
2014-04-27 04:11:22 +02:00
Adam Wulkiewicz
bcd64d3e40
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-04-26 15:28:33 +02:00
Adam Wulkiewicz
7615ac3392
[get_turns] Add template parameters to side_calculator<> defining types of all points.
...
It is possible to use side_calculator<> with Points of various types without the conversion.
2014-04-26 15:27:53 +02:00
Barend Gehrels
7e775f8d35
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-04-26 14:49:51 +02:00
Barend Gehrels
c33abbd521
[rescale] avoid rescaling boxes (as long as box_tag derives from areal_tag)
2014-04-26 14:49:28 +02:00
Adam Wulkiewicz
edfb2c29c0
[get_turns] Change parameters of intersection_info::is_spike_of_collinear()
2014-04-26 03:21:10 +02:00
Adam Wulkiewicz
f697aa85aa
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-04-26 03:04:40 +02:00
Adam Wulkiewicz
f671b5830f
[get_turns] Refactor get_turns for L/L and L/A.
...
This change prevents duplication and decreases the number of parameters that must be passed to various functions and makes the code more readable.
Enclose parts of the code used in both implementations in one class - intersection_info. Move there IntersectionsResult, sides_calculator, spikes checks. Use this class in get_turn_info_linear_*. Provide convenient i_info() and d_info() to allow replacing result.template get<0>() and result.template get<1>() calls.
2014-04-26 03:03:58 +02:00
Barend Gehrels
b007b85c17
removed debug statement
2014-04-25 23:05:31 +02:00
Barend Gehrels
6a23b0ff80
[overlay] added metafunction rescale_overlay_policy_type to use rescaling
...
only for areal/areal
2014-04-25 22:57:55 +02:00
Adam Wulkiewicz
80654aea65
[get_turns] Refactor get_turn_info_for_endpoint::handle_segment(), remove unused variables.
...
The code was moved outside get_turn_info_for_endpoints, to linear_intersections.
The code in the caller is more clear and safer since all variables are initialized and stored in linear_intersections.
2014-04-25 19:34:11 +02:00
Adam Wulkiewicz
83f375fc96
[get_turns] Fix side_calculator Points order in get_turn_info_ll and get_turn_info_la
2014-04-25 12:44:59 +02:00
Samuel Debione
c0df65a209
Fix get_turn_info
...
Fix template parameter order in side_calculator call (would fail with
different point types).
2014-04-25 12:19:46 +02:00
Adam Wulkiewicz
17faeadaa6
[get_turns][relate] fix assert in get_turn_info, remove enriched_operation from relate/turns - additional distance is no longer needed
2014-04-25 01:01:00 +02:00
Adam Wulkiewicz
d59e66e6d2
Merge branch 'develop' into feature/relate
2014-04-25 00:31:42 +02:00
Adam Wulkiewicz
1da9113046
[relate][get_turns] Support spikes for Linear in relate(L/A). Fix errors in get_turns for L/L and L/A.
...
relate_linear_areal:
handle non-endpoint x-c turns pair generated for a collinear spike.
relate/follow helpers:
fix turn_on_the_same_ip to use fraction instead of dimension.
get_turns:
L/L and L/A - use base_turn_handler::assign_point() to set fractions properly for collinear-opposite spikes.
L/A - fix the condition in calculate_spike_operation() used to check if a spike goes into the interior or exterior.
2014-04-24 23:49:36 +02:00
Barend Gehrels
30f4bd08b0
[overlay] removed unused distance_type
2014-04-24 22:35:34 +02:00
Barend Gehrels
2455677196
[intersect] Make calculations similar form, added const
2014-04-24 22:31:27 +02:00
Barend Gehrels
6bc9252c6a
[intersect] Removed unused calculation
2014-04-24 22:30:45 +02:00
Barend Gehrels
d11d84c10d
[intersect] Removed debug statements and adapted comments
2014-04-24 22:30:13 +02:00
Adam Wulkiewicz
b4b902ac85
[get_turns] Add the support for spikes for Linear Geometry in get_turns_linear_areal
2014-04-24 18:41:37 +02:00
Adam Wulkiewicz
5412c3bcf2
[strategies] remove register keyword
2014-04-24 11:41:07 +02:00
Adam Wulkiewicz
5d90c2449d
Merge branch 'develop' into feature/relate
2014-04-24 02:00:22 +02:00
Adam Wulkiewicz
10ed56670d
Merge pull request #17 from mkaravel/develop
...
[recalculate] add missing include for boost typeof
2014-04-24 01:59:50 +02:00
Adam Wulkiewicz
2ac24d446a
Merge pull request #16 from mkaravel/feature/setops
...
Feature/setops: fixes/changes due to recent changes in develop branch
2014-04-24 01:59:30 +02:00
Adam Wulkiewicz
d74deb998d
[relate] Partially fix Point-sized Linestrings support in relate(L/L).
...
The latest robustness upgrade introduced changes that broke the support:
1. degenerated turns are now method_none+c/c. This is fixed by this commit.
2. ratios aren't calculated for degenerated turns (proviously distances were calculated by AssignPolicy).
2014-04-24 01:55:21 +02:00
Menelaos Karavelas
3c910ee528
[recalculate] add missing include for boost typeof; needed because of BOOST_AUTO_TPL;
2014-04-24 02:20:23 +03:00
Menelaos Karavelas
9d293c8c03
[set ops] degenerate turns have now method_none; update test for isolating points to check for this method
2014-04-24 02:01:39 +03:00
Menelaos Karavelas
680c826f58
[turns][debug] output the fraction value as part of the debug output
2014-04-24 02:00:34 +03:00
Menelaos Karavelas
31fd0797cc
[set ops][turns] compare turns using the fraction instead of the distance
2014-04-24 01:59:42 +03:00
Adam Wulkiewicz
85b7589bb1
[geometry] Merge develop with feature/relate, resolve conflicts
2014-04-24 00:37:46 +02:00
Adam Wulkiewicz
babe91b210
[relate][get_turns] Add the support for spikes in relate(L/L). Fix errors in get_turns L/L.
...
Some asserts are invalid when 'x' operation can be somewhere in the middle (boundary_checker).
boundary_checker::is_boundary() function removed since it's not used anywhere.
Errors in get_turns are related to the handling of touches turn. t,i/i must be handled and is_collinear must be set in operations for spikes.
2014-04-23 23:43:00 +02:00
Adam Wulkiewicz
973e5a58bc
[get_turns] Add handling of spikes for L/L for endpoints
2014-04-23 22:09:00 +02:00
Adam Wulkiewicz
9e78d642e9
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-04-23 16:35:09 +02:00
Adam Wulkiewicz
db318225f3
[touches] Add the implementation for Box/Box
2014-04-23 16:33:43 +02:00
Barend Gehrels
13cfa67d75
cleanup: RescalePolicy -> RobustPolicy, and removed corresponding define
2014-04-23 16:22:16 +02:00
Barend Gehrels
ed1f680e6d
[get_rescale_policy] follow up, avoid casts, use numeric constants for ttmath
2014-04-23 15:37:51 +02:00
Barend Gehrels
cc71c5dbfb
[get_rescale_policy] processed review comments and avoid type "double"
2014-04-23 15:31:51 +02:00
Barend Gehrels
1ebe08921d
[segment_ratio] added spaces
2014-04-23 15:15:51 +02:00
Barend Gehrels
c032c2799f
[segment_ratio] processed review comments
2014-04-23 15:02:41 +02:00
Adam Wulkiewicz
e351063b9d
Merge branch 'develop' of github.com:boostorg/geometry into develop
2014-04-23 14:53:11 +02:00
Adam Wulkiewicz
f9c51246c2
[touches][relate] Replace use_relate with relate_base<> for automatic support generation. Also implement static_mask_touches_type<> as 2 parameter template.
2014-04-23 14:53:04 +02:00
Barend Gehrels
edc2c04c3d
commented calculating distance policy
2014-04-23 13:32:46 +02:00
Barend Gehrels
8af53613b9
added no_rescale_policy for follow linear/linear
2014-04-23 13:32:32 +02:00
Barend Gehrels
d228fb8523
added robust_policy which is, for linear/linear or pointlike/pointlike,
...
not used in the end
2014-04-23 13:31:23 +02:00
Barend Gehrels
b0b9503f81
renamed variable which was not detected by the merge
2014-04-23 13:28:20 +02:00
Barend Gehrels
1ef54cd00a
Added missing includes which are now necessary
2014-04-23 13:27:55 +02:00
Barend Gehrels
dc2993ae3a
Merge branch 'develop' into rescale_to_integer
...
Conflicts:
include/boost/geometry/algorithms/detail/relate/turns.hpp
include/boost/geometry/algorithms/touches.hppq
2014-04-23 13:26:59 +02:00
Adam Wulkiewicz
9ee78e4686
[get_turns] Handle m spike for L/L, add more tests
2014-04-23 12:53:36 +02:00
Adam Wulkiewicz
3fc8acc3f9
[get_turns] Add the generation of spike IPs for L/L non-endpoint touching and collinear-opposite segments
2014-04-22 16:11:04 +02:00
Barend Gehrels
c3bd204708
[remove_spikes] Fixed polygons consisting only of a spike.
...
If so, spike is now removed and only one point is left.
2014-04-21 19:44:42 +02:00
Adam Wulkiewicz
12797dbfb7
[get_turns][relate] Handle spikes for L/L !opposite collinear and equal turns.
...
2 Turns are generated for a spike, one with operation_blocked the second one with operation_intersection.
relate_linear_linear is not working yet, for now it is only ensured that boundaries will not be checked for those turns, which would result with assert failure.
TODO: opposite collinear and equal, touches c/c and endpoints intersecting a spike + the adaptation of relate(L,L).
2014-04-20 01:36:08 +02:00
Barend Gehrels
2077f81164
Merge branch 'rescale_to_integer' of github.com:boostorg/geometry into rescale_to_integer
2014-04-19 20:01:16 +02:00
Barend Gehrels
d54ced58d4
Use smallest of the segment_ratios to calculate the intersection point,
...
w.r.t. either segment a or segment b.
This results in small differences in the unit test for difference, which are
checked visually and/or compared with other output. In these cases it is
an enhancement
2014-04-19 19:59:14 +02:00
Adam Wulkiewicz
d05e7397f0
[get_turns] Set position front/back for L in L/A for degenerated turn - for consistency with L/L
2014-04-18 18:30:48 +02:00
Adam Wulkiewicz
a99fda5362
[relate] Fix L/L : handling of MLs containing overlapping, collinear Linestrings.
...
It's also consistent with the behavior for Point-like Linestrings.
E.g. some MultiLinestring may have boundary and interior in the same point:
Ls1:
|--------------|
MLs2:
|------------|
|------|
In this case the current version of the algorithm will set BB=0 and BI=0.
2014-04-18 14:43:07 +02:00
Adam Wulkiewicz
89955b787b
[get_turns][relate] Handle Point-size Linestrings
...
Point-size Linestring is a linestring containing exactly 2 equal points.
Add generation of positions for degenerated turns, non-degenerated segments in get_turns_linear_linear.
The code should be polished after the addition of info about the degeneration of segments into Turns.
2014-04-18 02:22:33 +02:00
Adam Wulkiewicz
d4bcf8dcc8
[iterators][relate] Fix Intel 11 compilation errors.
2014-04-17 12:09:07 +02:00
Adam Wulkiewicz
a7f1521756
[relate] Fix GCC 4.4 and 4.5 compilation errors
...
Explicitly define namespace for the call relate::set<> in implementations of relate().
2014-04-17 01:53:55 +02:00
Adam Wulkiewicz
08cc83be49
[geometry] Fix compilation errors
...
point_in_geometry - Intel 11 probably can't handle BOOST_STATIC_ASSERT() inside which some template is directly instiantated - replace by intermediate value + BOOST_MPL_ASSERT_MSG for better error message.
multi_touches test - include missing header
2014-04-17 01:42:48 +02:00
Adam Wulkiewicz
5ab27a4594
Merge branch 'develop' into feature/relate
2014-04-15 17:04:49 +02:00
Adam Wulkiewicz
23081a7c06
[point_on_surface] Fix GCC4.4 compilation error and polish the interface.
...
Explicitly define the namespace geometry.
Add doxygen description to return_point_on_surface().
2014-04-15 17:02:44 +02:00
Adam Wulkiewicz
aacf2618b9
[touches] added missing #include
2014-04-15 16:43:48 +02:00
Adam Wulkiewicz
4a4dbf4512
[relate][touches] Implement touches() for L/L and L/A using relate(), fix error in L/A.
...
Enable touches() for other pairs of Geometries.
Implement ready-to-use in the implementations of relate() less comparators of operations.
Change the less comparator for L/A.
Fix: handling of the entry/interior for some turn with MultiID which comes before union for some other turn with different MultiID.
Finish the support for boost::mpl::vector<> as a complex StaticMask.
2014-04-15 16:28:35 +02:00
Adam Wulkiewicz
eb11e26e14
Merge pull request #12 from mkaravel/feature/setops
...
[set ops] polish code and use std::find_if (suggestions by Adam);
2014-04-15 01:06:33 +02:00
Menelaos Karavelas
7ff3f1089d
[set ops] polish code and use std::find_if (suggestions by Adam);
2014-04-15 01:53:55 +03:00
Adam Wulkiewicz
b5a1d2fd98
Merge pull request #11 from mkaravel/feature/setops
...
Feature/setops
2014-04-14 21:39:38 +02:00
Menelaos Karavelas
1da360a8f3
[iterators] add missing includes; rename InnerRange to inner_range (coding standards);
2014-04-14 11:09:57 +03:00
Menelaos Karavelas
fffc55d677
[set ops] polish/simplify follow L/L code; change some vairable names that are confusing;
2014-04-14 10:00:08 +03:00
Menelaos Karavelas
2427b4a904
[set ops] remove #ifdef/#endif block used for debugging
2014-04-14 09:59:36 +03:00
Menelaos Karavelas
1c301e7503
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-04-14 03:05:01 +03:00
Adam Wulkiewicz
7d028ab2d9
Merge pull request #9 from mkaravel/feature/setops
...
[set ops][follow L/L] fix bug appearing in regression tests
2014-04-12 11:26:02 +02:00
Menelaos Karavelas
b10bf20996
[set ops][follow L/L] fix bug appearing in regression tests regarding dereferencing a non-dereferencable iterator
2014-04-12 11:49:58 +03:00
Adam Wulkiewicz
18d28c3839
[geometry] fix invalid #include
2014-04-12 02:46:13 +02:00
Adam Wulkiewicz
f689693b80
Merge branch 'feature/relate' into develop
2014-04-12 02:10:13 +02:00
Adam Wulkiewicz
7f150855eb
[within][covered_by] enable default relate strategy for cases other than P/P and P/* as far as CS is the same
2014-04-12 02:08:38 +02:00
Adam Wulkiewicz
d7b7df8614
[within][covered_by] Add the support for Areal geometries for within() and all OGC geometries for covered_by().
...
Also the specializations for Multi Geometries was moved from geometry/multi/algorithms to geometry/algorithms. They're now in one place.
The default strategies are point_in_point for PointLike, winding<> for PointLike/AnyGeometry, relate for L/L, L/A and A/A.
Point/MultiGeometry version now uses point_in_geometry directly which implements the correct behavior - this fixes the wrong handling of MultiLinestrings (boundary point of a Linestring may not be a boundary point of a MultiLinestring which contains it).
2014-04-12 01:40:27 +02:00
Adam Wulkiewicz
51c7957e69
[convex_hull] fix uninitialized pointers in ConvexHullStrategy concept check
2014-04-10 22:38:47 +02:00
Adam Wulkiewicz
93a2a5bc48
[relate][overlaps][crosses] Add unified way to implement the default dispatch of spatial relation
...
Add relate_base derived from not_implemented<> if necessary for the purpose of support_status check.
This class is derived from not_implemented<> if either StaticMaskTrait or detail_dispatch::relate::relate is derived from nyi::not_implemented_tag.
Use this technique in crosses() and overlaps().
2014-04-10 18:09:54 +02:00
Menelaos Karavelas
22274430b4
[set ops] remove #ifndef/#endif commands (not needed any more);
2014-04-10 15:13:48 +03:00
Menelaos Karavelas
6646470a55
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops-develop
2014-04-10 10:03:43 +03:00
Menelaos Karavelas
9f5252be0e
[set ops] Barend's review: (1) fix #includes; (2) remove //===.. lines; (3) rename AssignPolicy to assign_policy (not a template parameter);
2014-04-10 09:19:45 +03:00
Menelaos Karavelas
dd11061f81
[set ops] Barend's review: (1) fix #includes; (2) remove //===... comment lines; (3) put struct pointlike_pointlike_point in detail_dispatch namespace;
...
Other: remove difference_intersection_pointlike_pointlike_point struct (not used)
2014-04-10 09:15:30 +03:00
Menelaos Karavelas
d7bcd44974
[set ops] remove unused code in #if 0/#endif block; remove some obvious comments;
2014-04-10 09:13:20 +03:00
Menelaos Karavelas
17f3b3be58
[set ops] Barend's review: (1) remove unused variables; (2) fix #includes; (3) remove Linestring const*;
...
Other: remove unused argument in process_turn;
2014-04-10 09:10:22 +03:00
Menelaos Karavelas
193bca333b
[set ops] add missing includes; remove unnecessary ones
2014-04-10 08:57:25 +03:00
Menelaos Karavelas
caadd6ce00
[set ops] replace included unit test by unit test
2014-04-10 08:45:38 +03:00
Adam Wulkiewicz
ccc40d3a0b
[relate] cleanup, increase the readability of relate() dispatching, remove unneeded code
2014-04-09 21:53:12 +02:00
Adam Wulkiewicz
edf8a613ff
[doc][crosses][overlaps] add crosses() to make_qbk.py script, add parameters info to crosses() and overlaps()
2014-04-09 03:26:07 +02:00
Adam Wulkiewicz
0374154930
[relate] fix GCC compilation error caused by a missing #include
2014-04-09 01:52:41 +02:00
Adam Wulkiewicz
2753f5e30a
[crosses] add missing files required by bg::crosses() algorithm
2014-04-09 01:34:34 +02:00
Adam Wulkiewicz
d3f8ea2f6b
[crosses] add bg::crosses() algorithm
2014-04-09 01:33:37 +02:00
Adam Wulkiewicz
c1d4a09ec7
[overlaps] add support for P/P, L/L and A/A to overlaps()
2014-04-09 00:23:26 +02:00
Adam Wulkiewicz
9e00853dfa
[relate] fix: add missing handling of single geometries for which no IPs were generated (exterior ring inside, hole outside)
2014-04-08 15:33:18 +02:00
Adam Wulkiewicz
1c7fa89626
[relate] Fix warnings (unused variables)
2014-04-08 00:16:21 +02:00
Adam Wulkiewicz
d76c94d643
[relate] add optimization for L/L ommitting parts of the algorithm if the result mustnot be updated
2014-04-07 23:52:40 +02:00
Adam Wulkiewicz
cce6c71782
[relate] Add optimizations for L/A disabling parts of the code if the result mustnot be updated
2014-04-07 21:20:20 +02:00
Adam Wulkiewicz
eca27bc8af
Merge branch 'develop' into feature/relate
2014-04-07 14:31:16 +02:00
Adam Wulkiewicz
e7e0083428
[relate] Add optimization to A/A skipping parts of the algorithm if it's not possible to change the final result.
...
Add may_update() funcionality which may be used if it's possible to change the result for the specified matrix fields and overlap dimension.
Initialize flags in no_turns_aa_pred and uncertain_rings_analyser with values calculated using this functionality.
Add manual checks around the parts of areal_areal::apply() where IPs are sorted and analysed.
2014-04-07 14:18:34 +02:00
Menelaos Karavelas
3604f45e88
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-04-07 12:27:44 +03:00
Menelaos Karavelas
091bccbcff
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/is_simple
2014-04-07 12:25:44 +03:00
Menelaos Karavelas
a307bec090
[point iterator][concatenate iterator] replace enable_if mechanism by static assert; add templated assignment operator; make dereference and increment inline;
...
templatize equal for comparison against other concatenate iterator (needed for interoperability between const/non-const versions);
2014-04-07 11:31:42 +03:00
Menelaos Karavelas
cb3a103256
[point iterator] replace enable_if mechanism by static assert;
2014-04-07 11:30:20 +03:00
Menelaos Karavelas
0316b64019
[point iterator][flatten iterator] replace enable_if mechanism in copy constructor by static asserts;
...
add static assert to assignment operator; make dereference inline;
2014-04-07 11:27:46 +03:00
Adam Wulkiewicz
8c2ee6152a
[relate] Fix wrong type in interrupt_policy for A/A.
...
Add tests for MLs/MLs, Ring/Poly, Ring/Ring.
2014-04-07 01:30:05 +02:00
Adam Wulkiewicz
7bde891d7a
[relate] Add the support for IPs generated for "real" and "fake" holes.
...
Rename turns::less_seg_dist_op<> to relate::turns::less<>
It now takes the Comp defining how operations are sorted if segment and distance are equal.
Add 2 different operations comparators for L/L,L/A and A/A.
Add tests.
2014-04-07 01:08:24 +02:00
Adam Wulkiewicz
09ab2351f9
[relate] Add support for rings with no turns and some special cases in A/A.
...
Add support for:
- single geometries for which no turns were generated
- rings for which no turns were generated
- i/i and u/u turns
TODO: some cases where turns are generated for the intersection of a "real" hole and a "fake" hole (self-touching exterior ring).
2014-04-06 02:52:24 +02:00
Menelaos Karavelas
082adbb655
[point_iterator] fix errors and warnings for g++ and clang++ with C++11 enabled
2014-04-06 01:43:25 +03:00
Menelaos Karavelas
dfc3785d48
[feature/is_simple] implement OGC is_simple test for points, segments, multi-points, linestrings and multi-linestrings
2014-04-04 16:16:43 +03:00
Adam Wulkiewicz
47747938a6
[relate] add for now commented out ignoring of u/u turns in A/A, add some tests
2014-04-04 01:16:27 +02:00
Adam Wulkiewicz
d0dab345a8
Merge branch 'develop' into rescale_to_integer
2014-04-04 00:23:36 +02:00
Menelaos Karavelas
d08a0b1ad3
[set ops] removing duplicate turns is disabled now; no need for this, after Adam's fix;
2014-04-03 13:12:11 +03:00
Adam Wulkiewicz
8cb6366bb4
Merge branch 'develop' into feature/relate
2014-04-03 12:11:22 +02:00
Menelaos Karavelas
91d094673b
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-04-03 13:05:16 +03:00
Adam Wulkiewicz
ca0c8b97df
[get_turns] Fix turns dumplication for L/L.
...
Change the ignoring check calculation in get_turn_info_for_endpoint.
Add additional parameters to the second version of collinear_opposite<>::apply() defining if the pk and/or qk are valid (in other words current segment is NOT the last one).
Also make ignoring check for last endpoint in L/A more clear.
2014-04-03 11:58:50 +02:00
Menelaos Karavelas
6eed104318
[set ops] removed my name from the copyright header
2014-04-03 08:48:48 +03:00
Menelaos Karavelas
b49a67fd29
[set ops] remove code for removing extra points
2014-04-03 04:02:04 +03:00
Menelaos Karavelas
8f46bb45e8
[set ops] remove debug code; code is called from unit tests
2014-04-03 03:55:04 +03:00
Menelaos Karavelas
dd13023f5f
[set ops] remove print-outs inside the file
2014-04-03 03:46:37 +03:00
Menelaos Karavelas
2d1eaf2ef3
[set ops] better/shorter implementation for follow of L/L geometries; fix bug in previous code (linestrings in multilinestrings that had no turns where not reported in difference)
2014-04-03 02:54:33 +03:00
Menelaos Karavelas
db2079834f
[set ops] make some stylistic changes and code re-arrangement
2014-04-03 02:54:14 +03:00
Menelaos Karavelas
27921c5a14
[set ops] remove include of multi-point geometry
2014-04-03 02:51:55 +03:00
Menelaos Karavelas
52b0018eaa
[set ops] add missing include
2014-04-03 01:04:20 +03:00
Menelaos Karavelas
4ceea13cf4
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-04-02 21:47:09 +03:00
Adam Wulkiewicz
2f9f454334
[get_turns] fix for MultiLinestrings containing Ls with equal points
...
In this case no sections were generated for those "empty" Linestrings but if there were some sections already generated they could be marked as last_non_duplicated.
2014-04-02 20:21:32 +02:00
Adam Wulkiewicz
47da24242c
[relate] add code ignoring i/i turns, comment out some unneeded code in areal_areal
2014-04-02 20:14:34 +02:00
Adam Wulkiewicz
8c700e9f31
[relate] handle non-simple Polygons in A/A, NOT FULLY SUPPORTED
...
Not supported: i/i, non-intersecting rings
2014-04-02 14:10:36 +02:00
Menelaos Karavelas
598b6a51cf
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-04-02 11:09:17 +03:00
Adam Wulkiewicz
0c6a0d1890
[relate] Add HandleOtherTag to turns::less_seg_dist_op<>, change TurnAnalyser concept.
...
HandleOtherTag can be used to define how should the seg_id of the other geometry be used in comparison.
TurnAnalyser now must have two versions of apply(). One is called for it != last and the other one for it == last.
2014-04-02 01:38:19 +02:00
Adam Wulkiewicz
8774426417
[relate] rearrange updates of result in interrupt policy for A/A to show the handling pattern
2014-04-01 22:39:23 +02:00
Adam Wulkiewicz
f2fea86f7e
[relate] fix special case of L/L and L/A - going out and in on the same point but with different segment.
...
Linestring going into the exterior of the second geometry and then going inside on the same point. In this case the exterior wasn't taken into account. Now in addition to the Point, seg_id is checked. The check should also be faster since integral segment ids are checked before Points.
exit_watcher methods now take Turn instead of Point, seg_id and other_id.
Also added some tests for non-simple A/A.
2014-04-01 22:20:29 +02:00
Menelaos Karavelas
ffdb1d34f0
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
...
Conflicts:
include/boost/geometry/algorithms/detail/relate/less.hpp
2014-04-01 04:05:50 +03:00
Adam Wulkiewicz
759258563e
Merge branch 'feature/relate' of github.com:boostorg/geometry into feature/relate
2014-04-01 00:12:22 +02:00
Adam Wulkiewicz
0a49cb1e3e
[relate] support simple, equal geometries in currently used, simplified interrupt_policy
2014-04-01 00:11:57 +02:00
Adam Wulkiewicz
c27671336c
Merge pull request #4 from mkaravel/feature/point_iterator
...
Merge feature/point_iterator into develop
2014-04-01 00:07:20 +02:00
Adam Wulkiewicz
2fc1ca4e9c
[relate] Fix for_each_disjoint_geometry_if return value for Multi Geometries
...
Fix GCC warnings.
2014-03-31 09:41:17 +02:00
Barend Gehrels
b46222df9b
Removed unused includes
2014-03-30 14:12:09 +02:00
Barend Gehrels
fc595715e1
Removed temporary BOOST_GEOMETRY_CHECK_RATIO information and define
2014-03-30 13:52:46 +02:00
Barend Gehrels
46125dccb5
Removed distance (replaced by fraction) and calculate_distance_policy file, not used anymore
2014-03-30 13:50:20 +02:00
Barend Gehrels
a4804287e8
Removed unused #include of file just removed
2014-03-30 13:24:19 +02:00
Barend Gehrels
a5646a9295
Fixed typo
2014-03-30 13:24:00 +02:00
Barend Gehrels
cfaa628017
Removed unused headerfile
2014-03-30 13:23:50 +02:00
Adam Wulkiewicz
b6bf7038c9
Merge branch 'develop' into feature/relate
2014-03-29 23:46:22 +01:00
Adam Wulkiewicz
df8ecf627c
[get_turns] Fix after merge: use base_turn_handler::assign_point() instead of bg::convert() in L/L and L/A
...
The new function must be used because besides the copying of an intersection point fractions must be set in turns.
Apply the change in get_turn_info_for_endpoints and get_turn_info_linear_areal.
2014-03-29 23:18:37 +01:00
Adam Wulkiewicz
a444b5f85f
Merge branch 'develop' into rescale_to_integer
2014-03-29 22:43:16 +01:00
Adam Wulkiewicz
b0221bcda1
[get_turns] fix invalid equal<> use (convert() for uninitialized Point) in get_turn_info_for_endpoints and get_turn_info_linear_areal
2014-03-29 14:08:11 +01:00
Adam Wulkiewicz
8f7e0a39e4
[relate] fix GCC compile errors - hiding of template parameters and unknown identifier in not used part of the code
2014-03-29 13:36:51 +01:00
Adam Wulkiewicz
2a30c8ac0d
[geometry] Fixes after merge in get_turns - use of arrivals, compilation fixes in relate, use of fractions for sorting turns in relate
2014-03-28 14:55:28 +01:00
Menelaos Karavelas
e1f39cd065
[point_iterator] minor and stylistic changes; in concatenate_iterator use enable_if_c instead of enable_if (shorter code);
2014-03-28 00:30:50 +02:00
Menelaos Karavelas
5e96c27c84
[point_iterator] make private the constructor of point_iterator that takes the base class as argument;
2014-03-28 00:11:16 +02:00
Menelaos Karavelas
c127c56871
[point_iterator] changes due to new location of files and namespaces used;
2014-03-27 23:32:05 +02:00
Menelaos Karavelas
25e746cd2a
[point_iterator] move code to new namespace; remove comments; points_begin/point_end now return point_iterator<Geometry> class (suggested by Adam);
2014-03-27 23:29:37 +02:00
Menelaos Karavelas
88264401a1
[point_iterator] change namespace from core_dispatch to dispatch; fix macros of files due to new location;
2014-03-27 23:28:07 +02:00
Menelaos Karavelas
5d27f4f301
[point_iterator][flatten_iterator] polish code a bit; fix problems with copy constructor;
2014-03-27 23:27:23 +02:00
Menelaos Karavelas
f5d48b3798
[point_iterator][concatenate_iterator] fix issues in copy constructor;
2014-03-27 23:26:25 +02:00
Menelaos Karavelas
8a8132e6c0
[point_iterator] moved files to proper directories
2014-03-27 23:23:51 +02:00
Adam Wulkiewicz
438494e045
[relate] add result interrupt check to no_turns_xxx predicates
2014-03-27 16:50:15 +01:00
Adam Wulkiewicz
7df83d69a7
[relate] add support for no-IP casesin A/A, fix for_each_disjoint_geometry_if for Multi Geometries.
...
Fix a bug in for_each_disjoint_geometry_if resulting in assert failure if no turns are generated. This affects L/L, L/A and A/A.
Enable all combinations of Areal geometries.
Add ignoring of empty disjoint geometries in L/A and A/A.
Add tests for disjoint geometries.
2014-03-27 16:35:43 +01:00
Menelaos Karavelas
64c11353be
[point_iterator] move flatten and concatenate iterator implementation in iterators/ directory;
2014-03-27 02:25:38 +02:00
Menelaos Karavelas
555947d8e2
[point_iterator] define points_{begin,end} as inline free functions;
2014-03-27 02:11:02 +02:00
Adam Wulkiewicz
d4418204ec
[relate] add support for non-simple non-equal Polygons in A/A.
...
Currently simple interrupt policy is used.
This approach works is there are IPs, Polygons are simple and not equal.
2014-03-27 00:30:43 +01:00
Adam Wulkiewicz
77c7317cb1
[relate][get_turns] move single_geometry to bg::detail, fix get_turn_info test
...
also create a preliminary version of relate::areal_areal (copied from linear_areal)
in get_turn_info test mutable begin() and end() because it seems that Range can't handle immutable Ranges
2014-03-26 18:37:31 +01:00
Barend Gehrels
fc85b868b5
[geometry] Fixes after merge: added rescale policy argument
2014-03-26 14:17:05 +01:00
Barend Gehrels
ba5ed78fd3
[geometry] Fixes after merge: propagate SegmentRatio template argument
2014-03-26 13:47:25 +01:00
Barend Gehrels
2bd9a0f7e8
[geometry] Fixed compilation errors after merge
...
(part 1: trivial changes)
2014-03-26 13:35:01 +01:00
Barend Gehrels
da7c741eb8
Merge branch 'develop' into rescale_to_integer
...
Conflicts:
include/boost/geometry/algorithms/detail/overlay/get_intersection_points.hpp
include/boost/geometry/algorithms/detail/sub_geometry.hpp
include/boost/geometry/algorithms/disjoint.hpp
include/boost/geometry/algorithms/touches.hpp
include/boost/geometry/algorithms/within.hpp
include/boost/geometry/policies/relate/intersection_points.hpp
test/algorithms/intersection.cpp
test/algorithms/overlay/get_turn_info.cpp
2014-03-26 13:33:15 +01:00
Menelaos Karavelas
7abe47876b
[feature/point iterator] implementation of point iterator for most geometries (not yet for point, segment & box);
2014-03-26 10:22:31 +02:00
Adam Wulkiewicz
830a073c0d
Merge branch 'feature/relate' into develop
2014-03-25 15:10:48 +01:00
Adam Wulkiewicz
3a29d3a90c
[relate] fix MinGW compilation error - add includes missing in relate/result.hpp
2014-03-25 03:16:40 +01:00
Adam Wulkiewicz
ccbc15b8a1
[get_turns][relate] handle doubled points in relate L/L and L/A
...
add info about the first/last non-doubled section to sectionalize
modify get_turns() to pass info about the first/last segment to TurnPolicy::apply()
modify parameters of TurnPolicy::apply()
add searching for the next non-equal point in relate L/A when the segment of Linear must be checked if it starts in the interior or exterior of the Areal
add tests for relate and within
add relate L/A to Jamfile
2014-03-25 00:29:25 +01:00
Adam Wulkiewicz
b6fc144de7
[relate][within] add tests for Linestrings with duplicated points
2014-03-24 19:27:35 +01:00
Adam Wulkiewicz
3b91c7ed34
[relate] fix compile errors (use of old names)
2014-03-23 17:54:52 +01:00
Adam Wulkiewicz
5316d1f2ad
[geometry] replace sub_geometry::get() by sub_range(), fix invalid #includes
2014-03-23 17:16:56 +01:00
Adam Wulkiewicz
bddaadd8bc
[geometry] round() moved to util/math, added doxygen info to round() and range utils
2014-03-23 16:34:06 +01:00
Adam Wulkiewicz
e99574f1ed
[relate][get_turns] add missing brackets
2014-03-23 15:21:36 +01:00
Adam Wulkiewicz
025bd3b2bc
[relate] overall cleanup, group_dim replaced by topological_dimension, group_tag by tag_cast, range moved to util/range.hpp, some temporary code commented out
2014-03-23 15:17:05 +01:00
Adam Wulkiewicz
5eec228f10
[relate][get_turns] the code from handle_spike from get_turn_info_ll enclosed in spike detector (NOT FULLY WORKING)
2014-03-22 11:21:49 +01:00
Barend Gehrels
5ec0912daa
[geometry] scoped namespace detail_dispatch, necessary since using that
...
namespace from robust_type
2014-03-21 22:30:03 +01:00
Adam Wulkiewicz
21c42ed87e
[within][get_turns] implement within() using relate() for L/L and L/A. Add some basic/NOT_FULLY_WORKING handling of collinear spikes for get_turns(L/L)
2014-03-21 17:24:21 +01:00
Menelaos Karavelas
44827bdb28
[set ops] update linear-linear set op computation based on Adam's modification of turn info that now contains the is_collinear member;
2014-03-21 13:46:49 +02:00
Menelaos Karavelas
2394873328
[turns] fix error in print_turns; now print_turns also prints the value of is_collinear in turn info;
2014-03-21 13:45:25 +02:00
Menelaos Karavelas
61322d5679
[turns] add function for printing debug info for turns;
2014-03-21 13:43:40 +02:00
Menelaos Karavelas
e65e0718ad
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-03-20 11:21:00 +02:00
Adam Wulkiewicz
b79b857d1e
[relate][get_turns] fixed (GCC) compilation errors (missing include, typename keyword, shadowing of template parameters)
2014-03-20 01:59:33 +01:00
Adam Wulkiewicz
9d49d802e9
[relate] group_dim util moved to separate file
2014-03-20 01:45:27 +01:00
Adam Wulkiewicz
f9c0a09c38
[relate] implement proper handling of multiple rings while checing for equality with the linestrings, enable relate() for all ls- and poly-based geometries
2014-03-20 01:03:34 +01:00
Adam Wulkiewicz
3e926cb818
[relate] implement the check for boundaries of Areal equal to Linear geometries in L/A
2014-03-19 19:50:54 +01:00
Barend Gehrels
616e678ef1
[geometry] added first version of detail intersection_side function
...
To be used for buffer where robust info is needed of side of IP's
2014-03-19 17:01:02 +01:00
Menelaos Karavelas
0a2f52ad93
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
...
Conflicts:
include/boost/geometry/algorithms/detail/overlay/get_turn_info_for_endpoint.hpp
include/boost/geometry/algorithms/detail/relate/turns.hpp
2014-03-19 17:25:19 +02:00
Menelaos Karavelas
8c2e7ea282
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-03-19 17:12:41 +02:00
Adam Wulkiewicz
e0179e67e0
[relate] support ccw and open geometries, use closeable_view and reversable_view if needed
2014-03-18 23:27:18 +01:00
Adam Wulkiewicz
8cf2cfacc3
[get_turns] fix is_collinear calculation for methods t and m for L/L and L/A
2014-03-18 12:33:25 +01:00
Adam Wulkiewicz
6106fe6d1b
[relate] change less_seg_dist_op comparator to support multipolygons
2014-03-18 11:43:35 +01:00
Adam Wulkiewicz
173371265f
[relate] fix II for LS on boundary going out and in to the boundary of another ring on the same IP
2014-03-18 00:52:20 +01:00
Adam Wulkiewicz
e461f1003b
[relate] fix duplication of points for BACK in L/A
2014-03-17 23:45:28 +01:00
Adam Wulkiewicz
3336212aaa
[relate] fix sorting by distance in less_seg_dist_op
2014-03-17 15:52:32 +01:00
Adam Wulkiewicz
d5935134ef
[relate] add interrupt policy for L/A
2014-03-17 15:23:35 +01:00
Adam Wulkiewicz
b4417c40ad
[relate] add basic get_turns interrupt policy for L/L
2014-03-17 14:16:25 +01:00
Menelaos Karavelas
79bbb5a408
[geometry][append] updated copyright headers
2014-03-17 09:51:37 +02:00
Menelaos Karavelas
971247df04
updated the documentation wrt multi-linestrings and multi-polygons
2014-03-17 09:42:14 +02:00
Adam Wulkiewicz
ac8d628b8e
[relate] fix error in static handler set dispatch, require const boundary checkers in algorithms
2014-03-17 00:52:37 +01:00
Menelaos Karavelas
429b5e0037
implementation and unit test for bg::append for multi-linestring and multi-polygon
2014-03-14 23:04:01 +02:00
Adam Wulkiewicz
19837bbe03
[relate] L/A: fix generation of matrix elements for L collinear to boundary of A
2014-03-14 17:54:17 +01:00
Adam Wulkiewicz
8bd4efbc26
[relate] add support for non-simple polygons
2014-03-14 16:57:10 +01:00
Adam Wulkiewicz
80b1c54b65
[relate][get_turns] fix turn generation for last LS endpoint in get_turns(L,A), in relate(L,A) handle Linestrings starting from the inside
2014-03-14 13:05:51 +01:00
Menelaos Karavelas
29b3b46e30
prototype implementation for set operations for pointlike-linear geometries;
2014-03-14 10:12:06 +02:00
Menelaos Karavelas
f934a3aa5f
moved code to separate files;
...
added template parameter for enabling/disabling functionality wrt filtering turns, removing turns, and the parameters of the assign policy;
2014-03-14 10:11:02 +02:00
Adam Wulkiewicz
a6b0a32846
[relate] handle simple polygons in relate(L,A), remove some redundant code from L/L and L/A, add tests
2014-03-13 14:54:42 +01:00
Adam Wulkiewicz
4f32a3743f
[relate][get_turns] added not yet finished support for relate(L,A), changed operations generated by get_turns(L,A) for collinear segments of Areal geometry, fixed errors in relate(L,A)
2014-03-13 01:08:57 +01:00
Adam Wulkiewicz
3c4ed4e396
Merge branch 'feature/relate' of github.com:boostorg/geometry into feature/relate
2014-03-12 19:18:20 +01:00
Adam Wulkiewicz
924d222e7f
[relate][get_turns] fixed relate(L/L) error for collinear segments and a self-intersection in the middle, added is_collinear to turn_operation_linear, added setting of is_collinear to get_turns(L/L), fixed logic error in turns generation for endpoint-internal IP
2014-03-12 19:18:11 +01:00
Menelaos Karavelas
0fc2b5cbeb
fixed issue with ambiguous partial specialization;
2014-03-12 16:51:36 +02:00
Adam Wulkiewicz
3142975b72
[relate] supported ORed run-time masks
2014-03-12 12:39:20 +01:00
Menelaos Karavelas
39ccab7622
added one more template parameter (dimension for second point);
...
used to make sure that less is not called for points of different dimensions;
2014-03-12 11:23:09 +02:00
Menelaos Karavelas
d9e741c106
implemented set operations for pointlike-pointlike geometry combinations;
...
added unit tests for union, intersection and difference for pl-pl pairs;
2014-03-12 11:19:44 +02:00
Adam Wulkiewicz
8e9a59bac3
[relate] helpers like segment_watcher, exit_watcher, etc. moved to a separate file, implemented preliminary version of L/A (commented out for now), found bug in L/L, added failing tests
2014-03-11 18:06:47 +01:00
Adam Wulkiewicz
fe0e34bff6
[relate][get_turns] fixed incorrect dispatching of static masks, tag_base<> replaced by group_tag<> and moved to namespace detail, added group_dim<>
2014-03-11 01:51:23 +01:00
Adam Wulkiewicz
4182cb916b
[relate] TODOs regarding predefined masks added
2014-03-10 17:25:11 +01:00
Adam Wulkiewicz
d91db3a2e0
[relate] added ready-to-use static masks for various spatial relations
2014-03-10 15:03:57 +01:00
Adam Wulkiewicz
d209b4fbd2
[relate] added functions check() and interrupt(), added parameter EnableInterrupt to static_interrupt for consistency
2014-03-10 12:08:16 +01:00
Adam Wulkiewicz
4987e8d13d
relate() implemented support for complex static masks as a MPL sequences
2014-03-10 03:02:11 +01:00
Adam Wulkiewicz
5f0ab7962f
relate() static_mask_handler::update() dispatching fixed
2014-03-09 22:29:27 +01:00
Adam Wulkiewicz
9ca11feb90
relate() static_mask and static_mask_handler implemented
2014-03-09 22:24:09 +01:00
Barend Gehrels
511605369a
[geometry] Use robust-policy in side-related-functions
...
Functions: side_on_convex_range and get_side
2014-03-09 15:24:59 +01:00
Barend Gehrels
340fbc61d6
[geometry] buffer cleanup, removed dead code
2014-03-09 15:18:40 +01:00
Barend Gehrels
124012019a
[geometry] Test point-equality using rescale policy
2014-03-09 14:56:35 +01:00
Barend Gehrels
ed572055be
[geometry] buffer: fixed code inside BOOST_GEOMETRY_DEBUG_WITH_MAPPER for
...
new changes for rescale strategies
2014-03-09 12:51:49 +01:00
Barend Gehrels
ed78d7027d
[geometry] Fixed the changed copy_segments signature for buffer
2014-03-09 12:19:03 +01:00
Adam Wulkiewicz
09c41cb171
relate() - const MatrixOrMask may be passed to the function, the actual matrix is now stored in the result handler
2014-03-08 19:59:39 +01:00
Adam Wulkiewicz
1e6da76527
relate() implemented different interface, added support for complex masks passed in boost::tuple
2014-03-08 19:31:06 +01:00
Adam Wulkiewicz
b6ad82a0c2
relate() naming of results changed, added de4im matrix
2014-03-07 19:41:54 +01:00
Barend Gehrels
61c7999cdd
[geometry] added missing includes for recent changes
2014-03-05 22:49:02 +01:00
Menelaos Karavelas
f9bc59a423
proper implementation of the erase-remove idiom;
2014-03-05 13:40:35 +02:00
Barend Gehrels
f3fd9084ea
[geometry] moved zoom_to_robust to algorithms/detail
2014-03-05 12:04:56 +01:00
Barend Gehrels
921c7d2f14
[geometry] splitted file zoom_to_robust.hpp into several files:
...
- get_max_size
- rescale_policy
- robust_type
- get_rescale_policy
2014-03-05 12:01:43 +01:00
Adam Wulkiewicz
9ff0624b41
relate(L,A) added preliminary implementation, for now working only for disjoint geometries
2014-03-04 17:37:12 +01:00
Adam Wulkiewicz
38147c2fc7
relate() for_each_disjoint_linestring_if utility now works for all geometries, renamed to for_each_disjoint_geometry_if
2014-03-04 16:55:18 +01:00
Adam Wulkiewicz
8ae3b591d3
relate(L,L) unused code commented out
2014-03-04 15:37:34 +01:00
Menelaos Karavelas
9bbac740b7
stylistic changes according to Barend's review;
2014-03-04 16:24:38 +02:00
Menelaos Karavelas
1c318af64a
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-03-03 21:37:40 +02:00
Menelaos Karavelas
6a87866339
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-03-03 21:37:30 +02:00
Adam Wulkiewicz
02cdc305d3
get_turns(L,A) - fixed turns generation for endpoints of collinear front/back segments, added some tests
2014-03-03 19:21:12 +01:00
Adam Wulkiewicz
325b2e2bb0
get_turns(L,L) - TODO comment added
2014-03-03 18:19:37 +01:00
Adam Wulkiewicz
4fd21c2fa7
get_turns(L,A) - handled the back endpoint of the Linestring
2014-03-03 18:16:02 +01:00
Adam Wulkiewicz
ebaf26c0ff
get_turns(L,A) handled front endpoint
2014-03-03 13:36:23 +01:00
Adam Wulkiewicz
be1ac99a82
get_turns(L,A) added, the endpoints are NOT properly set yet!
2014-02-28 18:59:30 +01:00
Adam Wulkiewicz
ad201710c7
generation of turns for linestrings endpoints moved from get_turn_info_ll.hpp to separate file, some run-time parameters replaced by compile-time parameters
2014-02-28 16:51:57 +01:00
Adam Wulkiewicz
1234e21c53
[geometry][index] rtree packing algorithm optimized, partial_sort replaced by nth_element, thanks to Lu Wang
2014-02-28 14:00:33 +01:00
Menelaos Karavelas
1c4ecf5b94
new implementation for union, following discussion with Barend;
...
updated unit test for union a bit;
2014-02-27 16:46:22 +02:00
Adam Wulkiewicz
040f9ed6e9
some comments changed in relate/turns.hpp
2014-02-27 15:31:11 +01:00
Adam Wulkiewicz
e8b5e64f2b
added empty test for get_turns(L,A) and some small changes like naming, comments. to_svg() (test debug helper tool) is now using turn_info defined in relate::turns, also traversal info output commented out.
2014-02-27 15:20:51 +01:00
Adam Wulkiewicz
629d6b1246
relate/less.hpp copyrights fixed
2014-02-27 02:18:12 +01:00
Adam Wulkiewicz
9ad7ec98a8
detail::relate::less moved to separate file
2014-02-27 02:17:08 +01:00
Barend Gehrels
4211a2b1e9
[geometry] Use robust_policy in append_no_dups_or_spikes
...
Only if robust_policy would make any difference, so we added an "enabled"
boolean into the policy
2014-02-26 12:05:48 +01:00
Adam Wulkiewicz
9ed47574e1
relate(L,L) readability of some parts of the code improved
2014-02-25 18:11:11 +01:00
Adam Wulkiewicz
6f4094ec2a
relate(L,L) some comments added
2014-02-25 17:59:02 +01:00
Adam Wulkiewicz
37db735b38
relate(L,L) recently introduced turn position info used to optimize boundary points detection
2014-02-25 17:37:00 +01:00
Adam Wulkiewicz
736f26db4a
get_turns(L,L) turn_position now indicates the global position in linestring, not local in segment, for consistency - this was set only for the first and the last segment
2014-02-25 16:47:18 +01:00
Adam Wulkiewicz
261b35a323
get_turns(L,L) got rid of the duplicated part of the code
2014-02-25 16:38:06 +01:00
Adam Wulkiewicz
0a70310124
get_turns(L,L) added turn_operation_linear containing info about the position of the IP in the segment
2014-02-25 13:39:09 +01:00
Menelaos Karavelas
bd736c2e69
added end-of-namespace comment
2014-02-25 02:10:03 +02:00
Menelaos Karavelas
5bf941aa2e
added stronger type checking for geometries passed to linear geometry set op algorithm code;
2014-02-25 02:08:00 +02:00
Menelaos Karavelas
ea421976c5
added doxygen-related macro
2014-02-25 01:46:59 +02:00
Menelaos Karavelas
835c0fce1d
added proper copyright header
2014-02-24 23:20:11 +02:00
Menelaos Karavelas
b7c939cc8a
added implementation for union of linear geometries
2014-02-24 23:13:33 +02:00
Menelaos Karavelas
4030dd7c4b
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-02-24 22:20:35 +02:00
Adam Wulkiewicz
00941b7d50
Implemented relate(MultiPoint, MultiPoint), added detail::relate::less comparing Point types with different coordinate_type, added some TODO notes regarding possible optimizations
2014-02-24 17:47:29 +01:00
Adam Wulkiewicz
39d0d3bd75
Merge branch 'feature/relate' of github.com:boostorg/geometry into feature/relate
2014-02-24 15:17:20 +01:00
Adam Wulkiewicz
7033337149
IP coordinates rounded to the nearest value instead of a cast in segments_intersection_points if coordinate_type is integer
2014-02-24 15:16:37 +01:00
Menelaos Karavelas
9393ff10b5
moved follow_linear_linear.hpp to detail/overlay directory;
...
moved linear/linear geometry follow functionality in bg::detail::overlay::follow::linear namespace;
2014-02-24 05:57:53 +02:00
Menelaos Karavelas
8509f3668a
changed follow_linear_linear dispatch a bit;
...
added a small optimization in process_turn;
2014-02-24 05:44:59 +02:00
Menelaos Karavelas
671a28aed4
updated copyright year for Barend;
2014-02-23 11:48:50 +02:00
Menelaos Karavelas
e11dcd9bbf
intersection now includes isolated intersection points; exact behavior depends on the definition of related macros;
...
updated unit test to test for isolated intersection points as well;
2014-02-23 11:47:13 +02:00
Menelaos Karavelas
0cd6e23494
added code for detecting isolated intersection points;
...
no action implemented yet;
2014-02-22 16:10:55 +02:00
Menelaos Karavelas
ba809a838c
removed unused function parameters;
2014-02-22 15:42:14 +02:00
Menelaos Karavelas
c00f46550b
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-02-22 15:24:55 +02:00
Menelaos Karavelas
b0e5a71464
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-02-22 15:24:24 +02:00
Adam Wulkiewicz
684b29cbe3
relate() - fixed clang warnings
2014-02-22 12:38:04 +01:00
Adam Wulkiewicz
a68d9f5855
fixed GCC compilation errors
2014-02-22 04:29:11 +01:00
Menelaos Karavelas
c13877c69e
re-activated code that removes duplicate turns (needed again for now);
...
code can be disabled by defining the appropriate macro;
2014-02-22 00:13:01 +02:00
Menelaos Karavelas
a7e2d325f0
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-02-22 00:10:30 +02:00
Adam Wulkiewicz
0fd875fb63
relate() added Point-MultiPoint, point_point moved to the separate file, Geometries sequence is reversed if needed to not duplicate the code - for this Transpose is also used as the parameter to set<>(result)
2014-02-21 19:25:27 +01:00
Adam Wulkiewicz
89e412f5b4
added test for relate(Pt,Pt), added a TODO in relate::linear_linear
2014-02-21 17:56:40 +01:00
Adam Wulkiewicz
6482716689
relate() Finished the implementation for Point/Geometry, added topology_check util, added tests
2014-02-21 17:51:37 +01:00
Adam Wulkiewicz
93b82b734d
relate() added interruption_enabled flag to policy which can be used to create optimized mask type not checking for interuption per each set<>()
2014-02-21 15:34:52 +01:00
Adam Wulkiewicz
a03f554e27
relate() Added the interruptable mask Result, handled arbitrary Result type in relate(), added tests for masks and interruption, fixed warning in get_turns_ll
2014-02-21 00:40:09 +01:00
Adam Wulkiewicz
47b958ec53
relate()/get_turn_info_ll added TODO and commented out unused code
2014-02-20 23:29:39 +01:00
Adam Wulkiewicz
d13ff170be
relate(L,L) code refactored, tests added
2014-02-20 23:10:16 +01:00
Adam Wulkiewicz
9b16fdcf23
relate(L,L) handled case when several BLOCK operations were generated for the same point, fixed an error for BLOCK generated for a geometry touching the other one from the "outside"
2014-02-20 22:47:23 +01:00
Menelaos Karavelas
76e9e33924
changed the namespace where the linear/linear set-ops code lives from difference to overlay
2014-02-20 23:32:52 +02:00
Menelaos Karavelas
7450b64706
moved file linear_linear.hpp from detail/difference to detail/overlay
2014-02-20 13:41:53 +02:00
Menelaos Karavelas
c5048bd8f9
updated implementation so that it works for the intersection of linear geometries
2014-02-20 13:37:43 +02:00
Menelaos Karavelas
b66e411200
added dispatch for linear geometries' difference
2014-02-20 13:37:06 +02:00
Menelaos Karavelas
e56ca86a03
added parentheses in order to remove compiler warning
2014-02-20 12:57:57 +02:00
Menelaos Karavelas
4ad18efba9
minor stylistic change
2014-02-20 08:54:34 +02:00
Menelaos Karavelas
ed5852b282
replaced BOOST_CHECK by BOOST_ASSERT
2014-02-20 08:39:00 +02:00
Adam Wulkiewicz
a125811d56
relate(L,L) the ref to perviously analysed turn and operation added to turn_analyser<>
2014-02-19 15:45:02 +01:00
Adam Wulkiewicz
c2e1331270
relate(L,L) handling of 1-point linestrings replaced by simple ignoring (for now) since those are not valid geometries, the code was not removed though in case we wanted to e.g. enable it with some macro check.
2014-02-19 14:42:05 +01:00
Menelaos Karavelas
8412e9f3ba
simplified dispatch for difference of linear geometries
2014-02-19 13:45:38 +02:00
Menelaos Karavelas
0ca5d2f13a
re-arranged code so that linestrings are not transformed to multilinestrings;
...
added implementations for all four pairs of LS/MLS combinations;
added unit tests that were missing for new combinations;
2014-02-19 13:37:04 +02:00
Barend Gehrels
6269c5f4c1
[geometry] Simplified copy_segments template signature,
...
now that we also added RobustPolicy
2014-02-19 12:31:40 +01:00
Barend Gehrels
3ec7162957
[geometry] Added RobustPolicy to copy_segments and append_no_dups_or_spikes
...
- and moved typedefs inside function two times
- no other actions
2014-02-19 12:18:16 +01:00
Barend Gehrels
13aa0b07db
[geometry] Append without duplicates, fixed 3 calls
2014-02-19 11:18:20 +01:00
Menelaos Karavelas
1f9ccb6698
rearranged and simplified test code for differences of linear geometries;
...
added test cases for the LS/MLS difference;
polished debug macros a bit;
2014-02-19 09:25:30 +02:00
Menelaos Karavelas
7d3fef405e
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-02-19 09:00:09 +02:00
Adam Wulkiewicz
b03601fab8
get_turns(L,L) fixed 2x IPs generation for a special case of collinear, opposite last Ls segment
2014-02-19 02:26:15 +01:00
Menelaos Karavelas
1fdf91064c
added support for the LS/MLS difference; need to add tests as well
2014-02-18 18:02:02 +02:00
Adam Wulkiewicz
1e871f8ae6
relate() result refactored, result concept crystalized, prepared for compile-time interruptable result types
2014-02-17 17:37:46 +01:00
Adam Wulkiewicz
99610ca124
relate(L,L) handled the rest of cases with 1-point linestrings involved, added interrupt member to relate result - it may be used to break the calculation
2014-02-16 22:23:14 +01:00
Barend Gehrels
17356d7d7d
[geometry] Fix for integer-distance-point-to-polygon,
...
submitted by Menelaos Karavelas
2014-02-16 21:53:00 +01:00
Adam Wulkiewicz
9f54142896
relate(L,L) handled some cases with 1-point linestrings involved (if 1-PtLS is disjoint or there are other Ls in the other MLs)
2014-02-16 18:26:41 +01:00
Adam Wulkiewicz
4815e00048
relate(L,L) disjoin linestrings contained in multilinestring properly handled. In the case of disjoint linestrings almost all special cases are handled non-simple linear rings, 1-point linestrings. Linestrings containing >1 equal points are for now treated as normal linear rings, this should probably be changed.
2014-02-15 21:51:47 +01:00
Adam Wulkiewicz
25ce65b28a
relate(L,L) has_disjoint_sub_geometries simple check replaced by for_each_disjoint_linestring_if taking predicate checking linestrings
2014-02-15 19:00:26 +01:00
Adam Wulkiewicz
00e69bbea3
relate(L,L) - restored asserts in boundary_checker, added proper calculation of seg_ids for the first and last point of a range
2014-02-15 01:21:57 +01:00
Adam Wulkiewicz
551069e555
relate() added has_disjoint_sub_geometries check - not working for all special cases, should be replaced with e.g. for_each_disjoint_sub_geometry
2014-02-14 18:44:14 +01:00
Adam Wulkiewicz
2437538ccd
added point_in_point agnostic strategy and point_in_geometry() for Point and MultiPoint
2014-02-14 15:07:02 +01:00
Adam Wulkiewicz
868b54c644
relate() boundary_checker moved to separate file
2014-02-14 14:01:20 +01:00
Adam Wulkiewicz
1f2041594a
relate(L,L) added asserts to boundary_checker
2014-02-14 13:52:27 +01:00
Menelaos Karavelas
b1d78e1a85
Merge branch 'develop' of https://github.com/boostorg/geometry into feature/setops
2014-02-14 09:40:41 +02:00
Menelaos Karavelas
734dcb7930
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-02-14 09:39:46 +02:00
Adam Wulkiewicz
790c0027a0
relate(L,L) fixed some compilation errors for MultiLinestrings, some parts of the code temporarily commented out, added failing test - currently used algorithm is analysing only those Linestrings which are intersecting the other geometry, other ones are NOT taken into account
2014-02-14 00:30:10 +01:00
Adam Wulkiewicz
b114b814d4
relate(L,L) the algorithm analysing one turn enclosed within turn_analyser
2014-02-14 00:10:39 +01:00
Barend Gehrels
8af588045e
[geometry] Fixed results for distance of integer point types point-segment
...
or point-linestring
2014-02-13 22:18:39 +01:00
Adam Wulkiewicz
0aa1ca08d9
relate(L,L) added exit_operation to exit_watcher
2014-02-13 17:15:05 +01:00
Adam Wulkiewicz
9fe9d7259c
relate(L,L) handled G1 last range point boundary in the exterior of G2
2014-02-13 01:08:08 +01:00
Menelaos Karavelas
2c3713270f
added code that removes duplicate turns;
2014-02-13 01:48:56 +02:00
Adam Wulkiewicz
7429694b54
relate(L,L) added checks for boundaries for the first points of ranges of G1 which are in the exterior of G2
2014-02-13 00:12:39 +01:00
Barend Gehrels
52fc96ccc1
[geometry] Get buffer in compileable state w.r.t. rescale policies
2014-02-12 22:44:28 +01:00
Menelaos Karavelas
a1ac024c5b
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-02-12 18:06:37 +02:00
Adam Wulkiewicz
b943f3de26
get_turns(L,L) another special case handled
2014-02-12 16:53:06 +01:00
Barend Gehrels
832ea52015
[geometry] removed "distance" from enhanced_info
...
(now protected by ifdef). Also removed calculate_distance_policy, and "r".
All these are now obsolete.
This also removes the verify_r in cart_intersect
2014-02-12 16:38:42 +01:00
Barend Gehrels
bb60749540
[geometry] Use fraction instead of distance for "follow" and enrichment
2014-02-12 16:36:58 +01:00
Barend Gehrels
02deb84786
[geometry] Fixes for new MSVC issues
2014-02-12 12:54:26 +01:00
Barend Gehrels
2a85b339f1
[geometry] Fix compile errors w.r.t. changed turn_info in touches
2014-02-12 12:14:23 +01:00
Menelaos Karavelas
a366f120f7
changes in code for linear-linear geometries difference
2014-02-12 13:03:35 +02:00
Barend Gehrels
8d202fd319
[geometry] Verified compatibility with/without robust rescaling
...
We now have the define BOOST_GEOMETRY_NO_ROBUSTNESS to avoid rescaling
(probably should be renamed)
2014-02-12 11:45:02 +01:00
Barend Gehrels
664bd2b488
[geometry] Rescaling, build-fixes, changed assert's in conditions,
...
comment changes, handle_tangencies: now skip overlap_info
2014-02-12 11:43:50 +01:00
Adam Wulkiewicz
c5cbf5e6f2
relate() - added BoundaryQuery parameter to boundary_checker, makes possible to specify if the boundary should be at the first point, last or might be on both, etc.
2014-02-12 03:38:26 +01:00
Barend Gehrels
f3147001b5
[geometry] Splitted file rescale.hpp into different files:
...
segment_ratio_type
robust_point_type
no_rescale_policy
2014-02-11 23:08:32 +01:00
Menelaos Karavelas
0848049a10
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-02-12 00:02:27 +02:00
Adam Wulkiewicz
5bb4c45ff5
get_turns(L,L) fixed another case for opposite linestrings
2014-02-11 17:06:43 +01:00
Menelaos Karavelas
a0e56a6157
current implementation for difference of linear geometries (still a prototype);
...
added some copyright headers and made minor fixes;
2014-02-11 16:22:39 +02:00
Menelaos Karavelas
9418d4b3e3
added copyright headers
2014-02-11 10:39:26 +02:00
Menelaos Karavelas
773331f6d9
implementation of follower for linear geometries;
...
added test files for difference of linear geometries;
2014-02-11 10:37:45 +02:00
Menelaos Karavelas
e3ce00473d
Merge branch 'feature/relate' of https://github.com/boostorg/geometry into feature/setops
2014-02-11 08:38:01 +02:00
Adam Wulkiewicz
4a4acf00cb
[get_turns] fixed error in get_turn_info_linear_linear - invalid operations generated for the endpoint-internal IP for opposite segments
2014-02-11 02:57:39 +01:00
Adam Wulkiewicz
21dfef6f05
get_turn_info_linear_linear<>::handle_first_last() method moved to better reflect calling dependency
2014-02-11 01:30:22 +01:00
Menelaos Karavelas
e87d9ccb55
added helper function to print turns
2014-02-10 11:06:19 +02:00
Menelaos Karavelas
7abd905013
added custom turn comparison functors
2014-02-10 10:56:33 +02:00
Barend Gehrels
f6ce9e2c91
[geometry] Moved robustness policies to policies folder
...
Also added unit-test to develop/test behaviour of different policies
2014-02-09 19:29:01 +01:00
Barend Gehrels
547ed12024
[geometry] Changes for segment_ratio
...
Removed as default parameter, removed default type-defs for robust_point_type
and for segment_ratio_type
2014-02-09 19:05:40 +01:00
Adam Wulkiewicz
e36c2027ec
relate(L,L) handled one special case, still not fully working
2014-02-08 23:40:42 +01:00
Adam Wulkiewicz
d56a7bcc2e
relate(L,L) algorithm without preliminary boundaries analisys - work in progress
2014-02-07 18:58:53 +01:00
Barend Gehrels
83703aac99
[geometry] removed/changed comment
2014-02-06 22:28:01 +01:00
Barend Gehrels
99b3e8a24d
[geometry] Allow different types for Cramers rule
2014-02-06 22:27:15 +01:00
Barend Gehrels
03c8f6822f
[geometry] explicitly specify SegmentRatio type for turn_info
2014-02-06 22:26:55 +01:00
Adam Wulkiewicz
5e3223e467
fixed error in relate(), entry points seg_id replaced by other_seg_id - required for MultiLinestrings
2014-02-06 01:27:52 +01:00
Adam Wulkiewicz
4881b94ee6
added a comment
2014-02-06 00:47:16 +01:00
Adam Wulkiewicz
c0598807db
handled non-simple Linestrings, for now without spikes
2014-02-06 00:22:54 +01:00
Barend Gehrels
7c6ba53e59
[geometry] Added RescalePolicy (to get SegmentRatio) to strategy_intersection
...
Some creations/instances of rescale policy had therefore to be moved
2014-02-05 14:06:00 +01:00
Barend Gehrels
1b23e260d5
[geometry] Removed commented unused code
2014-02-05 14:02:07 +01:00
Barend Gehrels
05e9c7905d
[geometry] Use side strategy only in relative order
...
(preparing next commit changing strategy_intersection)
2014-02-05 14:01:50 +01:00
Barend Gehrels
24a11fe984
[geometry] Added comparisons for segment_ratio's based on float
2014-02-05 11:37:13 +01:00
Barend Gehrels
336f73e276
[geometry] made SegmentRatio as a template argument for turn_operations,
...
and therefore for turn_info and many more
2014-02-05 11:36:42 +01:00
Adam Wulkiewicz
2e4bafa27c
fixed #define, added some comments
2014-02-03 19:45:07 +01:00
Adam Wulkiewicz
2fff49a684
fixed compilation error - missing namespaces
2014-02-03 18:43:41 +01:00
Adam Wulkiewicz
b7054cffc2
front() and back() helper functions moved to separate file, updated copyright info
2014-02-03 18:38:04 +01:00
Adam Wulkiewicz
30f06fede7
added relate(Point, Box), added transpose() to relate result, update_dimension renamed to update, optimized - runtime parameters of set and update replaced by template parameters, added static_assert checking dimension
2014-02-02 18:29:42 +01:00
Adam Wulkiewicz
2804514b3a
removed invalid point_in_geometry() implementation for Box, geometry::within() reverted in distance() and disjoint()
2014-02-02 15:31:10 +01:00
Adam Wulkiewicz
fe09a6dc2e
fixed some warnings (unused variables, signed-unsigned comparison)
2014-02-02 00:58:44 +01:00
Adam Wulkiewicz
c0fdceee0d
added missing parameters to get_turn_without_info - new GetTurnPolicy interface
2014-02-02 00:05:30 +01:00
Adam Wulkiewicz
87ab6f8ece
fixed VS compilation errors (overlay:: removed), removed relate()-related code from get_turns_linear_linear.cpp test
2014-02-01 23:43:54 +01:00
Adam Wulkiewicz
a739ebe714
fixed a compilation error in point_in_geometry called for non-polygon Geometry
2014-02-01 23:24:55 +01:00
Adam Wulkiewicz
1c021516de
fixed compilation error in get_turns_cs - new interface of TurnPolicy
2014-02-01 22:31:54 +01:00
Adam Wulkiewicz
a412070362
used the old turn policy in default get_turns() for backward compatibility
2014-02-01 21:17:30 +01:00
Adam Wulkiewicz
51d9641505
get_turn_info_linear_linear policy and related code moved from namespace relate to overlay/get_turns and connected with the official get_turns()
2014-02-01 19:05:58 +01:00
Adam Wulkiewicz
ff9596578f
Merge branch 'develop' into feature/relate
2014-02-01 13:41:53 +01:00
Adam Wulkiewicz
89f7ce15b0
fixed compilation errors
2014-02-01 13:37:41 +01:00
Adam Wulkiewicz
8a31265497
Added template parameters to less_seg_dist_op<>, it is now possible to define operations order and geometry id in place
2014-02-01 01:19:12 +01:00
Adam Wulkiewicz
b9d7d7f975
changed relate() to use new turns info for linestrings, the same implementation state - does not work for self-touching Linestrings or MultiLinestrings
2014-01-31 22:13:13 +01:00
Adam Wulkiewicz
459bb46dff
detail::relate::relate() result now contains correct dim(E(A) and E(B)), T is put for dimensions > 9
2014-01-29 23:37:49 +01:00
Adam Wulkiewicz
3e99412c02
[index] varray: templated rvref workaround replaced with the fixed Boost.Move macro
2014-01-29 20:19:41 +01:00
Adam Wulkiewicz
0874a880b5
Added methods replacement for some cases of non-endpoint IPs, e.g. touching c or e is replaced by m or t. Methods are set WRT IPs, not segments, i.e. if points of both intersecting segments are equal to the IP the method is e. In addition to this x/x was handled, e.g. t+x/x is replaced by e+c/c.
2014-01-29 17:24:46 +01:00
Adam Wulkiewicz
9c63a58412
added proper operations generation for non-endpoint IPs
2014-01-29 15:09:54 +01:00
Adam Wulkiewicz
9d1a1011c2
added calculation of methods t or m for endpoints
2014-01-29 13:54:53 +01:00
Adam Wulkiewicz
06f0c0e418
removed two equal_point_point() calls
2014-01-28 13:32:19 +01:00
Adam Wulkiewicz
abbbcf73ab
removed most of equal_point_point() calls by simpler checks using IntersectionResult
2014-01-28 00:58:04 +01:00
Adam Wulkiewicz
b70c886f2e
IP duplicates handled for endpoints
2014-01-27 16:44:11 +01:00
Adam Wulkiewicz
b83d88476c
added missing typename keyword
2014-01-26 01:36:09 +01:00
Adam Wulkiewicz
f24f7e2e1b
implemented more consistent segments intersections (is_last used also for non-collinear segments), not needed checks for duplicated IPs commented out
2014-01-25 03:01:36 +01:00
Adam Wulkiewicz
e7992832a9
added a few test cases
2014-01-24 20:33:51 +01:00
Adam Wulkiewicz
37b6383474
a few more duplicated endpoints handled
2014-01-24 17:48:02 +01:00
Adam Wulkiewicz
bd686badd7
most of the duplicated endpoints handled
2014-01-24 16:58:11 +01:00
Adam Wulkiewicz
506b83ea42
handled some of the duplicated IPs
2014-01-24 00:58:29 +01:00
Adam Wulkiewicz
a9f1c8e00a
handled all endpoints, for now method is not set, IPs may be duplicated and invalid value is returned from handle_first_last()
2014-01-23 18:23:12 +01:00
Adam Wulkiewicz
af6aeb77db
fixed comments with the segments intersection result analysis
2014-01-23 01:19:20 +01:00
Adam Wulkiewicz
33f9c05258
added small optimization in range_collect_vectors - erase() replaced by copy from back and pop_back()
2014-01-22 22:14:09 +01:00
Adam Wulkiewicz
50fe5a7e67
added copyrights
2014-01-22 22:02:22 +01:00
Adam Wulkiewicz
7e3d0571f9
fixed error in collect_vectors - vectors previously gathered for other rings were removed based on the direction of the last vector of currently analysed ring
2014-01-22 22:00:29 +01:00
Adam Wulkiewicz
3f667361d6
get_turns() for endpoints L/L started from the beginning, added copyrights info, added comments regarding segment intersection results analysis
2014-01-22 21:42:44 +01:00
Barend Gehrels
41f9c94e31
[geometry] Fixed unit test for collinear intersections w.r.t new parameters
2014-01-19 22:33:58 +01:00
Barend Gehrels
9dd4eaff7f
[geometry] Use segment_ratio_type metafunction in handle_tangencies,
...
disjoint, add policy_type to intersection strategy with 2 segments
2014-01-19 22:13:52 +01:00
Barend Gehrels
011815a80d
[geometry] Extracted segment_ratio_type as a metafunction
...
just like robust_point_type
2014-01-19 22:02:01 +01:00
Barend Gehrels
9ea637265e
[geometry] Merged rescale policy and (rudimentary) robustness policy.
...
We should decide how we call this thing (probably RobustnessPolicy as it
decides for types, ratio-types, rescaling and other behaviour related to
robustness)
2014-01-19 15:34:15 +01:00
Barend Gehrels
c7111355cc
[geometry] Made SegmentRatio a template parameter as was intended.
...
Still TODO: it should come from a robustness-policy
2014-01-19 15:06:07 +01:00
Barend Gehrels
ca6280c9af
[geometry] Added (probably temporary) comment
2014-01-19 14:48:55 +01:00
Barend Gehrels
2851b50fc3
[geometry] Removed now redundant template parameters from segment-intersection
...
strategies.
2014-01-19 14:48:39 +01:00
Barend Gehrels
fe207c73da
[geometry] Removed now unused method
2014-01-19 14:40:35 +01:00
Barend Gehrels
482c9a3a62
[geometry] Added static assert
2014-01-18 21:33:20 +01:00
Barend Gehrels
3eadfb2549
[geometry] Comment change
2014-01-18 21:33:10 +01:00
Barend Gehrels
7d8342093a
[geometry] Removed unnecessary includes
2014-01-18 21:32:45 +01:00
Barend Gehrels
e76936025c
[geometry] Bugfix get point-type instead of segment-type
2014-01-18 21:32:19 +01:00
Barend Gehrels
175032c841
[geometry] Integer coordinates are now not rescaled
...
which fixes corresponding tests
2014-01-17 19:58:31 +01:00
Barend Gehrels
fc681ba236
[geometry] fixes in unit tests w.r.t. rescale policy
2014-01-17 18:53:29 +01:00
Barend Gehrels
683267e3e5
[geometry] Bugfix in new code, arrival value should be -1 if not on segment
2014-01-16 18:46:03 +01:00
Barend Gehrels
90b75b7640
Merge branch 'develop' into rescale_to_integer
2014-01-16 14:19:01 +01:00
Adam Wulkiewicz
594d025e95
overlay:: equal<> and collinear<> used to calculate the operations for the first point of P LS in adequate cases
2014-01-09 19:36:31 +01:00
Bruno Lalande
cfba8409c5
Made transform variant-aware.
2014-01-09 09:09:56 +00:00
Adam Wulkiewicz
0b50ebc2e8
added preliminary version of the new algo for the first point of P LS
2014-01-08 18:45:19 +01:00
Adam Wulkiewicz
a326d7a258
small changes of methods/operations and comments to generation of turns for the first points
2014-01-08 17:09:59 +01:00
Barend Gehrels
fd781b79d5
[geometry] Rescale to integer: changed types to make them consistent
...
w.r.t. integer/float input points. IP calculation is now always based on
ratios.
2014-01-08 13:47:18 +01:00
Barend Gehrels
cd0ec07f64
[geometry] Minor - pass ringtype separately
...
(further this change was part of a non-committed change)
2014-01-08 13:26:00 +01:00
Adam Wulkiewicz
518156a727
[geometry] begined the new implementation of handling of first and last LS point in get_turns(), for now considered cases when both LSs starts on the same segment
2014-01-07 21:46:46 +01:00
Bruno Lalande
6646a16d7f
Added strategy resolution stage to transform algorithm.
2014-01-05 17:53:08 +00:00
Adam Wulkiewicz
2799cb867b
[geometry] handled IP on the last point of LS for equal and collinear case, for the first point method may now be set to equal or collinear
2014-01-05 17:27:31 +01:00
Bruno Lalande
8d58aaf8b9
Made touches (1 param version) variant aware.
2014-01-05 15:54:14 +00:00
Adam Wulkiewicz
c1530d41f9
[geometry] handled IP for the first point of a LS when IP is equal to the second point of the first segment of the other LS to avoid generation of 2 IPs for the same point
2014-01-04 23:51:12 +01:00
Adam Wulkiewicz
def187c977
added generation of IP for the first point of a Linestring - c+c/c, c+i/u or c+u/i
2014-01-04 01:11:43 +01:00
Bruno Lalande
87a5a242f4
Made touches (2 params version) variant aware.
2014-01-02 09:34:31 +00:00
Bruno Lalande
ea3cf83bf8
Fixed how resolve_strategy::simplify_insert is called from the public functions
2013-12-24 22:27:38 +00:00
Bruno Lalande
4919e00e2d
Made simplify variant-aware
2013-12-24 22:15:15 +00:00
Bruno Lalande
2ddcf5dccf
Added resolve_strategy stage for simplify_insert.
2013-12-23 12:19:25 +00:00
Bruno Lalande
5e946a1c1e
Added resolve_strategy stage for simplify.
2013-12-22 23:18:29 +00:00
Adam Wulkiewicz
eba7d26db4
[geometry] in relate() called dispatch::get_turns instead of higher level one to avoid geometries switching, added generation of SVGs for some special cases
2013-12-22 23:35:18 +01:00
Barend Gehrels
b889923619
[geometry] Take care that FP ratio (which is still used) is between 0-1 too.
...
If not we take the robust ratio.
This fixes case ticket_9081_15 where the intersection point was far outside
the belonging segment (causing a new spike)
2013-12-22 14:16:15 +01:00
Barend Gehrels
1a1cb4cff0
[geometry] Moved debug string
2013-12-22 14:14:37 +01:00
Barend Gehrels
9cd79d8033
[geometry] Instead of (non-rescaled) append, we clean rescaled dups afterwards.
...
We don't do it on the fly to avoid additional rescaling, it is done only once per point
This also changes occasionally some number-of-points in testcases (now more cleaned)
2013-12-22 14:12:40 +01:00
Barend Gehrels
2c2c384652
[geometry] Remove sanity check as planned
2013-12-22 13:43:55 +01:00
Barend Gehrels
50f8696aaf
[geometry] Let has_intersections also rescale
2013-12-22 13:42:51 +01:00
Adam Wulkiewicz
4f07087db5
[geometry] handled more cases in relate(Ls, Ls)
2013-12-22 04:00:15 +01:00
Barend Gehrels
f467f6ff31
[geometry] Avoid using Boost.Rational for all comparisons
...
Only if values are close, we resort to Boost.Rational (for int) for exact comparisons.
This avoids most conversions.
2013-12-21 17:58:59 +01:00
Barend Gehrels
0333e7c313
[geometry] replaced boost::rational with segment_ratio which is more specialized for our needs.
...
segment_ratio contains specific methods (on a segment the ratio is [0..1]) and
can be based on double or float too (Boost.Rational cannot do that).
Boost.Rational is still used under the hood for comparisons (which will be
made more efficient later)
2013-12-21 17:35:44 +01:00
Adam Wulkiewicz
106f3da5ae
[geometry] fixed some errors in relate(Ls, Ls): checked terminal points of both linestrings, treated touch with x/x as ii
2013-12-21 02:41:48 +01:00
Adam Wulkiewicz
382e975f2f
[geometry] added test file for relate(), fixed error in linear_linear, added tag-dispatched detail::relate()
2013-12-21 01:49:40 +01:00
Bruno Lalande
dffb4db8ce
Break circular dependency get_turns->disjoint->covered_by->within->get_turns
2013-12-21 00:49:16 +00:00
Adam Wulkiewicz
02a32dee32
[geometry] relate code divided into several files
2013-12-21 00:55:22 +01:00
Adam Wulkiewicz
da524695c6
[geometry] added relate() test implementation for Point-Geometry, Geometry-Point and Linestring-Linestring. The least one is not finished yet.
2013-12-20 19:58:08 +01:00
Barend Gehrels
ef3992a921
[geometry] big cleanup removed old code from cart_intersect
2013-12-20 19:10:42 +01:00
Barend Gehrels
b00311f502
[geometry] Removed (need for) arrangment and moved disjoint.
...
Disjoint is now based on ratios too. All is now based on ratios, greatly
simplifying the original code with many lines and conditions.
2013-12-20 19:06:05 +01:00
Barend Gehrels
e0d9036aef
[geometry] removed segment_equal, now all collinear go to one fuction.
...
Function now renamed to segments_collinear, and the other to segments_crosses
We calculate opposite now only in "direction", where it is used to pass through.
That one also checks on equality
Test 5103 now (or with previous action for touches) also passes again.
2013-12-20 18:50:08 +01:00
Adam Wulkiewicz
907a260b01
[geometry] added within(Ls, Ls)
2013-12-20 01:28:32 +01:00
Barend Gehrels
4a5b85c870
[geometry] Collinear touch now also uses new unified method
...
This fixes the holes_intersect_and_touch case
NOTE: method should now be renamed, not ...two_intersection_points
2013-12-19 22:38:52 +01:00
Barend Gehrels
06b03d534c
[geometry] Let rescale derive from not_implemented as is new style
2013-12-19 22:36:38 +01:00
Barend Gehrels
f3d1fb4736
[geometry] Bugfix in rescaling, points may not be const& (of course)
...
They were initialized from local variables and returned
2013-12-19 22:35:54 +01:00
Barend Gehrels
9a9efcff89
[geometry] Work in progress: factor (rational) instead of distance
...
This is a large commit. It replaces enriched.distance with factor. Factor
is based on integer calculations, calculated in cart_intersect, from the
passed robust points, so always trustable.
We had to do this because without certain tests failed because of FP
problems with distance (calculated with FP).
This commit also greatly simplifies relate_collinear, where most things and checks
are replaced by simple unified calculations. This is also based on robust
fractions (but could have been done earlier).
Many (but not all) testcases commented in previous commit are now uncommented
again, they now work thanks to the fractions. There are also testcases
uncommented which now work correctly using clang/Linux
This commit breaks compiling disjoint (because of rescale), and running buffer
(also because of rescale), and some more (probably all because or rescaling),
this has to be fixed soon after.
2013-12-18 19:19:10 +01:00
Adam Wulkiewicz
2462177a7c
[geometry] changed point_in_geometry behaviour for 1-point linestring - treated like point - not within
2013-12-16 00:54:36 +01:00
Adam Wulkiewicz
2b2ceadfc6
[geometry] fixed within(Box, Box) for Boxes with overlapping boundaries - OGC conformance
2013-12-16 00:42:15 +01:00
Adam Wulkiewicz
8f5aa8f236
[geometry] 2-parameter touches() properly dispatched for non-areal geometries, fixed sub_geometry::get() for multi geometries - const correctness
2013-12-15 03:43:07 +01:00
Barend Gehrels
107621943d
[geometry] Use robust determinant for comparisons
...
This breaks one extra testcase which should be verified later
2013-12-14 19:49:35 +01:00
Barend Gehrels
c173233efa
[geometry] Propagated rescale_policy further / from earlier phase
2013-12-14 19:45:21 +01:00
Adam Wulkiewicz
b05fe92549
[geometry] fixed multi within and covered_by - new namespace hierarchy (point_in_geometry)
2013-12-14 19:43:27 +01:00
Adam Wulkiewicz
39484599bc
[geometry] recently added detail::XXX::YYY_dispatch structs moved/renamed to detail_dispatch::XXX::YYY
2013-12-14 19:34:54 +01:00
Adam Wulkiewicz
bc0dee97d2
[geometry] not_implemented used instead of MPL_ASSERT in point_in_geometry and sub_geometry
2013-12-14 19:11:55 +01:00
Adam Wulkiewicz
4fca624a32
Merge branch 'develop' of github.com:boostorg/geometry into develop
2013-12-14 17:16:13 +01:00
Adam Wulkiewicz
5940d4acb8
[geometry] parameters names changed in within_no_turns
2013-12-14 17:15:08 +01:00
Adam Wulkiewicz
dca7cb060d
[geometry] parameters names changed in point_in_geometry
2013-12-14 17:06:06 +01:00
Barend Gehrels
a77aef8d16
Merge branch 'develop' into rescale_to_integer
2013-12-14 16:54:04 +01:00
Barend Gehrels
ce38ea7072
[geometry] Adapted buffer for recent changes in within
2013-12-14 16:52:47 +01:00
Barend Gehrels
ff7cb5c21e
Merge branch 'develop' into rescale_to_integer
2013-12-14 13:38:28 +01:00
Barend Gehrels
d988e1ac93
[geometry] Work in progress: rescaling to robust-type
...
A robust type is integer for float/double. The rescaled points will only
be used for side-information and equality and distance-comparisons, not
to calculate the intersection points themselves.
Currently the code is #ifdefed
2013-12-14 13:25:46 +01:00
Adam Wulkiewicz
a238da019b
[geometry] added touches(Ls, Poly), added details for other combinations of linear-areal geometries
2013-12-14 04:01:32 +01:00
Adam Wulkiewicz
5ce07d86f6
[geometry] touches generic_interrupt_policy fixed to not update the state if non-touching turn was found earlier
2013-12-12 03:33:48 +01:00
Adam Wulkiewicz
f78626b0f2
[geometry] added parameters reversal for touches()
2013-12-11 17:28:52 +01:00
Adam Wulkiewicz
5b417cc66b
[geometry] touches(Ls,Ls) algorithm modified
2013-12-11 11:47:16 +01:00
Adam Wulkiewicz
a0cca4848a
[geometry] removed a condition in touches(Ls, Ls) for consistency
2013-12-11 02:14:05 +01:00
Adam Wulkiewicz
8d690ff164
[geometry] added touches(Ls, Ls) + tests
2013-12-11 02:08:54 +01:00
Adam Wulkiewicz
f95efb34ee
[geometry] added tests for touches(Pt, MLs) and touches(Pt, MPoly), fixed error in point_in_geometry(Pt, MLs), fixed error in within(Pt, MLs) tests
2013-12-11 01:42:25 +01:00
Adam Wulkiewicz
437c94ad77
added touches(Point, Geometry)
2013-12-11 00:24:16 +01:00
Adam Wulkiewicz
54434f6e82
[geometry] generic touches implementation moved to detail::touches::generic_touches, added dispatch::touches used in bg::touches
2013-12-10 21:39:39 +01:00
Adam Wulkiewicz
9d34be1c09
[geometry] optimization: equals::has_only_turns() replaced by interrupt policy
2013-12-10 21:26:23 +01:00
Adam Wulkiewicz
7fae091c72
added point_in_geometry_dispatch for Box
2013-12-09 22:44:02 +01:00
Adam Wulkiewicz
c211dd01db
Merge branch 'develop' of github.com:boostorg/geometry into develop
2013-12-09 22:39:37 +01:00
Barend Gehrels
f999c1b1a7
[geometry] added ring/polygon rescaling
2013-12-09 22:11:25 +01:00
Barend Gehrels
24fddebe8c
[geometry] handle unhandled iu/iu case
2013-12-09 22:02:46 +01:00
Adam Wulkiewicz
4d195e28b0
[geometry] types renamed in within_no_turns
2013-12-09 04:20:29 +01:00
Adam Wulkiewicz
ffa81b45e0
[geometry] added tests for intersects()
2013-12-08 14:42:17 +01:00
Adam Wulkiewicz
8ef20f9f88
added disjoint() for previously non-supported Geometries
2013-12-08 13:20:01 +01:00
Adam Wulkiewicz
5436fb2cfa
added within() and covered_by() for Pt-Ls and Pt-MLs, fixed error in point_in_geometry for MLs
2013-12-08 12:36:31 +01:00
Adam Wulkiewicz
004908caf9
[geometry] added support for MultiLinestrings in copy_segment_point, point_on_border, range_by_section, sectionalize, ring_return_type, ring_type
2013-12-08 02:28:46 +01:00
Adam Wulkiewicz
a34c03ff3b
[geometry] compilation errors fixed in point_in_geometry/within/covered_by for multi geometries
2013-12-08 02:23:56 +01:00
Adam Wulkiewicz
72205cf03e
[geometry] added point_in_geometry() and used in within() and covered_by(), also added within_no_turns()
2013-12-08 00:41:39 +01:00
Barend Gehrels
c06e55af16
[geometry] Minor trivial change
2013-12-07 11:37:12 +01:00
Barend Gehrels
32eb7090d5
[geometry] Use rescale_policy in enrich_intersection_points and sectionalize
...
Also in get_turns forward them further up to point-comparison
2013-12-07 11:36:42 +01:00
Barend Gehrels
f100acae4e
[geometry] Silenced (some) warnings in extension code
2013-12-07 11:28:41 +01:00
Barend Gehrels
f9469b91f1
[geometry] Fixed projection example/test
2013-12-07 11:24:21 +01:00
Barend Gehrels
59969ce883
[geometry] removed parameters in private functions which were unused
...
(They are unused because we now pass the "sides" struct with this information).
This also makes the corresponding parameters for the main entry redundant,
so we can remove them too, later
2013-12-05 22:50:43 +01:00
Barend Gehrels
6bdc8c0d02
[geometry] Remove unused parameters in get_turn_info and direction
2013-12-05 22:31:17 +01:00
Barend Gehrels
88c365a45d
[geometry] Remove all trailing spaces (extensions)
2013-12-05 19:42:44 +01:00
Barend Gehrels
eb3260708e
[geometry] Remove all trailing spaces (algorithms)
2013-12-05 19:36:58 +01:00
Barend Gehrels
960915dfa7
[geometry] Remove all trailing spaces (arithmetic, iterators, views)
2013-12-05 19:35:35 +01:00
Barend Gehrels
442680a51f
[geometry] Remove all trailing spaces (core, geometries, util)
2013-12-05 19:34:19 +01:00
Barend Gehrels
9ca5bb333d
[geometry] Remove all trailing spaces (strategies)
2013-12-05 19:32:32 +01:00
Barend Gehrels
6336ee4799
[geometry] Remove all trailing spaces in multi
2013-12-05 19:31:18 +01:00
Barend Gehrels
626ed1a0e7
[geometry] Remove trailing spaces.
...
For the rest this commit contains nothing.
2013-12-05 19:22:36 +01:00
Barend Gehrels
75d078aaed
[geometry] added RescalePolicy template-parameter.
...
Where that was applied and possible, moved template-parameter to methods
instead of to classes.
This is a large commit, but contains no functional changes.
2013-12-05 19:20:54 +01:00
Barend Gehrels
e5340158ac
[geometry] Moved template parameters in sectionalize, preparing for following changes
2013-12-04 12:27:22 +01:00
Barend Gehrels
c4bb879d79
[geometry] Add check on duplicate sections to avoid them being intersected,
...
unless the only one
2013-12-04 10:41:27 +01:00
Bruno Lalande
fb3ec9de1f
Made reverse algorithm variant-aware.
...
[SVN r86678]
2013-11-13 14:53:37 +00:00
Bruno Lalande
128ebab54c
Made remove_spikes variant-aware.
...
[SVN r86634]
2013-11-12 07:52:06 +00:00
Barend Gehrels
1088afb1be
[geometry] Fixed self-turn points, neighboring function in get_turns did have the wrong meta-function. Also cleaned corresponding unit tests / added test cases for reported error (reported by Joan on mailing list)
...
[SVN r86627]
2013-11-11 22:36:57 +00:00
Bruno Lalande
d951f4ea72
Made perimeter algorithm variant-aware.
...
[SVN r86619]
2013-11-11 16:29:00 +00:00
Bruno Lalande
1799ee4777
Made within algorithm variant-aware.
...
[SVN r86606]
2013-11-10 23:07:59 +00:00
Bruno Lalande
98aa16b3f2
Added 2 utility metafunctions for variants. Necessary to make some algos variant aware.
...
[SVN r86584]
2013-11-08 08:14:51 +00:00
Barend Gehrels
359703e933
[geometry] avoid warnings for multi-line comments and unused var in new sources
...
[SVN r86581]
2013-11-07 21:18:57 +00:00
Barend Gehrels
1bb3745741
[geometry] added extreme_points for multi-polygon to fix compilation in disjoint for multi polygon. Also fixed bug in multi by using within, we have to use rings_containing, that one is restored. It is now duplicated (temporary) in touches because that one has to use point_on_border still (somehow), to be found out
...
[SVN r86580]
2013-11-06 23:27:02 +00:00
Barend Gehrels
42c3e28ff7
[geometry] fixed ticket 8310, disjoint did give the wrong results. Fixed using point_on_surface. Added unit test. Also tests for overlay algorithms because they might suffer from the same problem
...
[SVN r86579]
2013-11-06 22:42:02 +00:00
Barend Gehrels
ee6140f274
[geometry] point_on_surface, update for linux/clang
...
[SVN r86555]
2013-11-03 21:11:54 +00:00
Barend Gehrels
cbafc2398a
[geometry] added point_on_surface, developed last summer to SVN
...
[SVN r86554]
2013-11-03 21:00:34 +00:00
Barend Gehrels
fbdf22bb72
[geometry] avoid warnings for member order
...
[SVN r86541]
2013-11-01 21:19:46 +00:00
Barend Gehrels
3b51da2d6f
[geometry] added the (not yet finished) distance_info to extensions
...
[SVN r86538]
2013-11-01 19:49:06 +00:00
Barend Gehrels
f0dbf7905a
[geometry] fixed strategy type, reported by Menelaos on the list
...
[SVN r86534]
2013-11-01 14:54:34 +00:00
Bruno Lalande
982c60d4f1
Made envelope variant-aware.
...
[SVN r86531]
2013-10-31 21:01:21 +00:00
Bruno Lalande
cfeaaf0cab
Made disjoint variant-aware.
...
[SVN r86523]
2013-10-30 12:03:54 +00:00
Bruno Lalande
f8408c546f
Made covered_by variant-aware.
...
[SVN r86461]
2013-10-26 21:37:49 +00:00
Barend Gehrels
4600b79a68
[geometry] added remove_spikes.hpp to all-include file
...
[SVN r86452]
2013-10-26 13:25:55 +00:00
Barend Gehrels
cee8a0506c
[geometry] Added remove_spikes as an algorithm. The first version was already in extensions (for years), that is removed now. The new version works using the recent point_is_spike_or_equal
...
[SVN r86450]
2013-10-26 13:18:11 +00:00
Bruno Lalande
73e9c494b7
Made 'correct' variant-aware.
...
[SVN r86414]
2013-10-24 06:10:34 +00:00
Bruno Lalande
e2f11f015d
Converted convex_hull to the multi-stage approach and made it variant-aware.
...
[SVN r86401]
2013-10-23 10:13:28 +00:00
Barend Gehrels
3a6ae0bacb
[geometry] revised solution for robustness, we don't go to integer which was shortly done. This is partly a revert of r85867, where we scaled to integer. Now we make side information consistent by iteratively selecting a larger epsilon. This will be moved into a separate class. All tests pass now, also the complete ticket_9081 test which failed before
...
[SVN r86368]
2013-10-20 15:30:21 +00:00
Barend Gehrels
8ea1f1000b
[geometry] avoid referencing *(end-1) if size <=1
...
[SVN r86359]
2013-10-18 20:57:15 +00:00
Adam Wulkiewicz
a915999ac1
[geometry] added missing header defining disjoint() to wkt/write.hpp
...
[SVN r86355]
2013-10-18 15:35:28 +00:00
Adam Wulkiewicz
05ccc90461
[geometry] header file defining clear() included in follow.hpp
...
[SVN r86354]
2013-10-18 15:34:22 +00:00
Bruno Lalande
c47d0b85fc
Converted all devarianted_xxx classes to the new resolve_variant approach.
...
[SVN r86345]
2013-10-18 08:14:13 +00:00
Bruno Lalande
75305ec823
Removed check_input stage - merged into resolve_variant.
...
[SVN r86338]
2013-10-17 06:21:28 +00:00
Adam Wulkiewicz
69a2fd6c58
[geometry] replaced size() and removed clear() call in overlay/follow.hpp.
...
[SVN r86334]
2013-10-16 15:43:02 +00:00
Adam Wulkiewicz
f07f5fe6cf
[geometry] fixed errors in overlay/follow.hpp related to proper usage of Linestring concept.
...
[SVN r86333]
2013-10-16 15:36:32 +00:00
Bruno Lalande
90dd0bf7d5
Default strategy placeholder class forgotten in previous commit.
...
[SVN r86332]
2013-10-16 15:35:52 +00:00
Bruno Lalande
c35effb15c
Made centroid variant-aware. This implied a refactoring - we're clearly heading towards a multi-stage algorithm call resolution as previously foreseen. Will align other variant-aware algorithms to this.
...
[SVN r86305]
2013-10-14 20:04:54 +00:00
Bruno Lalande
e6f57e7523
Made the buffer algorithm variant aware.
...
[SVN r86240]
2013-10-11 21:47:28 +00:00
Barend Gehrels
8b1343cb67
[geometry] discard turn points without turn info
...
[SVN r86239]
2013-10-11 20:49:05 +00:00
Bruno Lalande
560fd46dfd
Bug fix - wrong template parameter in buffer algorithm
...
[SVN r86235]
2013-10-11 09:30:52 +00:00
Mateusz Loskot
5f6f6212d6
[geometry] Impose closed rings of any polygon output in WKT (ticket #9217 )
...
[SVN r86233]
2013-10-10 23:07:03 +00:00
Adam Wulkiewicz
af9e45a7c6
[geometry][index]: BOOST_NO_* deprecated macros replaced.
...
[SVN r86175]
2013-10-06 12:39:17 +00:00
Mateusz Loskot
3c866f927b
[geometry] Correct pointlike_tag name in a comment
...
[SVN r86145]
2013-10-03 15:12:38 +00:00
Adam Wulkiewicz
ed61f8d08e
[geometry] added #ifndef DOXYGEN_NO_DETAIL in touches.hpp
...
[SVN r85908]
2013-09-25 15:43:53 +00:00
Barend Gehrels
951f213e2a
[geometry] added missing template keyword, not catched by clang 3.0 but catched by 3.2
...
[SVN r85890]
2013-09-25 10:26:59 +00:00
Adam Wulkiewicz
1f170a3a7c
[geometry] fixed error in touches() for CCW Rings/Polygons.
...
[SVN r85869]
2013-09-24 14:28:51 +00:00
Barend Gehrels
ac40228b07
[geometry] Major bugfix: intersection problem(s) caused by robustness, reported in ticket 9081. Causes were inconsistent side information by floating point precision. We now switch to integer for a specific region (6 points) to have the side information consistent. This removes many separate robustness checks previously done in cart_intersect, which is now more simple and ~200 lines shorter. And it removes also some robustness checks in get_turn_info (probably more were actually needed by old approach). It also uses this system in handle_tangencies and enrich_intersection_points.
...
It now also used the passed side information in direction.hpp, which saves calculations and is shorter.
In the end the performance is similar.
One (of many) situations in ticket 9081 is added in multi unit tests.
[SVN r85867]
2013-09-24 14:18:13 +00:00
Barend Gehrels
6567f7fab9
[geometry] merged to release
...
[SVN r85862]
2013-09-23 21:54:07 +00:00
Adam Wulkiewicz
ce10039377
[geometry][index]: added iterators test implementation using Boost.Function. Fixed compilation errors in benchmark_experimental.
...
[SVN r85693]
2013-09-16 00:25:37 +00:00
Adam Wulkiewicz
64730165b5
[geometry][index] experimental serialization routines implemented as free functions instead of rtree member functions and moved to separate file, added private_view(s).
...
[SVN r85647]
2013-09-11 01:21:57 +00:00
Adam Wulkiewicz
d31d73ed62
[geometry] query iterators described in docs + some fixes of the chapter describing queries.
...
[SVN r85637]
2013-09-10 11:54:34 +00:00
Adam Wulkiewicz
d9b6f89d64
[geometry]: iterative queries simplified, docs updated, added qbegin() and qend() free functions, added new functions to the reference matrix, release notes updated.
...
[SVN r85630]
2013-09-09 22:37:55 +00:00
Adam Wulkiewicz
597f121798
[geometry][index] docs updated.
...
[SVN r85617]
2013-09-09 00:02:53 +00:00
Adam Wulkiewicz
d063118a3f
[geometry] docs: added description of contains() and covers() predicates.
...
[SVN r85566]
2013-09-04 19:44:19 +00:00
Barend Gehrels
154e4504e9
[geometry] added traits::clear, resize, push_back to multi concepts
...
[SVN r85565]
2013-09-04 15:16:29 +00:00
Adam Wulkiewicz
bfff854c0c
[geometry][index] Fixed the description of rtree class.
...
[SVN r85564]
2013-09-04 11:58:33 +00:00
Barend Gehrels
fd4bfbcc8c
[geometry] use concept instead of .erase for recent append_no_dups_or_spikes
...
[SVN r85561]
2013-09-04 11:11:14 +00:00
Adam Wulkiewicz
08690f20f0
[geometry] segment-box intersects() tweaked to support boost::rational<>, not fully supported because of lack of std::numeric_limits<> specialization.
...
[SVN r85558]
2013-09-04 01:44:15 +00:00
Adam Wulkiewicz
8c65e8b6d3
[geometry] segment/linestring-box intersection moved to detail/disjoint, compilation error fixed.
...
[SVN r85557]
2013-09-04 00:16:50 +00:00
Adam Wulkiewicz
1566048ae2
[geometry] added n-dimensional segment-box and linestring-box intersects()/disjoint() implementation.
...
[SVN r85556]
2013-09-03 23:55:17 +00:00
Barend Gehrels
bb8e187931
[geometry] fixed clear/back calls for cases reported by Renaud on 2013-09-02 on mailing list
...
[SVN r85554]
2013-09-03 20:08:30 +00:00
Barend Gehrels
fb74bfbe26
[geometry] Fixed ticket 9047 (recursive inclusion) and unit test for ticket 8652
...
[SVN r85552]
2013-09-03 18:45:18 +00:00
Adam Wulkiewicz
7d0393eb4a
[geometry][index] added covers() and contains() predicates to the official interface.
...
[SVN r85520]
2013-08-30 02:31:31 +00:00
Adam Wulkiewicz
425d370d1a
[geometry][index] type-erased query iterators move semantics implemented using Boost.Move replaced by c++11 rval refs if supported. Error in move assign fixed.
...
[SVN r85517]
2013-08-29 22:59:02 +00:00
Adam Wulkiewicz
242ef41cf1
[geometry][index] query iterators added to the rtree official interface.
...
[SVN r85507]
2013-08-29 00:33:54 +00:00
Adam Wulkiewicz
86273a3c7f
[geometry][index] added conditional move semantics to type-erased query iterators, for test purposes
...
[SVN r85503]
2013-08-28 19:05:53 +00:00
Adam Wulkiewicz
2e81515795
[geometry][index] added one more implementation of experimental type-erased query iterator
...
[SVN r85500]
2013-08-28 13:53:16 +00:00
Adam Wulkiewicz
3c8eca3df2
[geometry][index] implemented alternative version of type-erased query iterators (still experimental).
...
[SVN r85495]
2013-08-28 00:51:14 +00:00
Barend Gehrels
78f88c752a
[geometry] avoid error on geometry::math::abs for MSVC and long long
...
[SVN r85479]
2013-08-26 21:02:18 +00:00
Barend Gehrels
bd79d311c9
[geometry] avoid clang warning about unused ublas function
...
[SVN r85478]
2013-08-26 20:18:27 +00:00
Barend Gehrels
d1c4cb7b6d
[geometry] avoid generation of spikes in overlays, this fixes ticket 8364 and 8365. Added unit tests for these tickets. These changes result in (at about 3 places) changes in the output-number-of-points, this is verified visually
...
[SVN r85451]
2013-08-24 22:53:43 +00:00
Barend Gehrels
2c7ab5b8d4
[geometry] small fixes/typos in documentation for strategies
...
[SVN r85413]
2013-08-20 20:39:33 +00:00
Barend Gehrels
52db334352
[geometry] fixed documentation: removed template parameters, made pythagoras back to a class, remove xml files in make_qbk to avoid using old ones
...
[SVN r85412]
2013-08-20 20:22:33 +00:00
Barend Gehrels
fa2c9e373b
[geometry] cleanup: removed unused typedefs as warned for by gcc 4.8
...
[SVN r85411]
2013-08-20 19:42:20 +00:00
Barend Gehrels
7a71993c6f
[geometry][extension] fixed clang compilation problem, qualifying baseclass
...
[SVN r85398]
2013-08-19 19:55:19 +00:00
Barend Gehrels
250384a591
[geometry] ticket #8969 , fixed: constructor of model::point should be explicit
...
[SVN r85383]
2013-08-17 20:04:23 +00:00
Barend Gehrels
81db2ee699
[geometry] robustness-tests added Jamfile and fixed gcc compilation errors
...
[SVN r85380]
2013-08-17 17:10:35 +00:00
Barend Gehrels
2676eea111
[geometry][extensions] fixed offset unit test by fixing offset compiler errors and commenting failing tests. Offset was never finished but is especially broken since I took another approach for buffer. At least the test is green now so we can monitor future regressions
...
[SVN r85372]
2013-08-17 12:29:13 +00:00
Barend Gehrels
87edb13129
[geometry][extensions] fixed multi_within test which missed a default_strategy, this was the same for within so uncommented the relevant lines there (and added polygon/box)
...
[SVN r85371]
2013-08-17 11:14:14 +00:00
Barend Gehrels
9881aa96c0
[geometry] removed register as noted as deprecated by clang
...
[SVN r85370]
2013-08-17 10:19:28 +00:00
Barend Gehrels
176a774a26
[geometry] fixed cross-track (missed comparable_type), vincenty (missed radius), cross-track-course (now supports different point-types), distance_mixed unit test which uses all these things
...
[SVN r85361]
2013-08-15 22:01:16 +00:00
Barend Gehrels
ca7750bab1
[geometry] fixed dissolve-extension, which was broken for quite some time, however it was only missing an extra parameter in assign_parents
...
[SVN r85360]
2013-08-15 21:03:59 +00:00
Barend Gehrels
409be79e03
[geometry] added centroid calculation for segment type
...
[SVN r85346]
2013-08-14 15:31:46 +00:00
Barend Gehrels
018502c52c
[geometry] adapted transform strategies, they have points now as member-template, and calculation-type as template. Similar to what was done for Distane. This commit includes updated tests/doc/examples
...
[SVN r85325]
2013-08-12 21:22:53 +00:00
Adam Wulkiewicz
5af7da4f86
[geometry][index] varray elements move construction and assignment dispatched using has_trivial_move_xxx, clang ambiguity fixed
...
[SVN r85210]
2013-08-04 21:37:45 +00:00
Barend Gehrels
6118d09c50
[geometry][extension] adapted nsphere/within to new distance strategy structure
...
[SVN r85150]
2013-07-24 13:14:00 +00:00
Barend Gehrels
8468c22c03
[geometry] fixed bug of MSVC. It apparently cannot pass function pointers of template functions by reference (with non-template, it could...)
...
[SVN r85142]
2013-07-23 21:18:09 +00:00
Barend Gehrels
224b9786c7
[geometry] fixed bug of MSVC. This provable bug is postponed by MSVC. See https://connect.microsoft.com/VisualStudio/feedback/details/715626/msvc-needs-namespace-even-if-it-is-hoisted#
...
[SVN r85141]
2013-07-23 21:11:38 +00:00
Barend Gehrels
86b8a5f755
[geometry] fixed pythagoras calculation for Windows (MSVC), the problem was that std::sqrt(int) is ambiguous. Previous version did it in two steps, we now use boost::numeric_cast
...
[SVN r85140]
2013-07-23 21:03:35 +00:00
Adam Wulkiewicz
5ee7c2d5b1
[geometry][index] internal_node_pointer type removed from Allocators and not used in visitors
...
[SVN r85098]
2013-07-21 16:23:06 +00:00
Barend Gehrels
83cf372b18
[geometry][extension] adapted connect extension to new structure
...
[SVN r85069]
2013-07-17 22:08:10 +00:00
Barend Gehrels
dd1c53da69
[geometry][extension] Commented concept-check for MSVC, adapted (partially) distance_cross_track
...
[SVN r85067]
2013-07-17 21:41:12 +00:00
Barend Gehrels
c4d60d094d
[geometry][extension] Updated andoyer/vincenty adaption (added radius_type for distance_cross_track)
...
[SVN r85066]
2013-07-17 21:34:46 +00:00
Barend Gehrels
29a03318a3
[geometry][extension] Updated andoyer adaption (comments, removed redundant namespace, fixed default_strategy template parameter)
...
[SVN r85065]
2013-07-17 21:24:33 +00:00
Barend Gehrels
06876ec32c
[geometry][extension] adapted selected to new strategy structure
...
[SVN r85064]
2013-07-17 21:16:34 +00:00
Barend Gehrels
a222a54135
[geometry][extension] adapted vincenty to new strategy structure
...
[SVN r85063]
2013-07-17 21:08:38 +00:00
Barend Gehrels
209062a655
[geometry] adapted extension andoyer to new structure strategies
...
[SVN r85057]
2013-07-17 13:32:12 +00:00
Bruno Lalande
4246ea4217
Distance strategies no longer need to be parameterized with the point type(s).
...
[SVN r85040]
2013-07-14 22:54:43 +00:00
Adam Wulkiewicz
18783cb9b0
[geometry][index]: added names to serialized objects to support xml archives, fixed error in loading of rstar parameters.
...
[SVN r85038]
2013-07-14 19:05:00 +00:00
Adam Wulkiewicz
7e755d5823
[geometry][index]: serialization of node type removed - currently there are only 2 types which may be deduced from leafs_level, check of the number of loaded values added.
...
[SVN r85037]
2013-07-14 18:18:26 +00:00
Adam Wulkiewicz
c38abef50c
[geometry][index]: experimental rtree serialization support added.
...
[SVN r85026]
2013-07-14 01:59:26 +00:00
Bruno Lalande
5c01967f86
Move some template parameters from class level to function level in assign_value.
...
[SVN r84920]
2013-06-30 21:01:02 +00:00
Adam Wulkiewicz
aa166010a3
[geometry][index]: removed non-c++03 header from statistics additional utility
...
[SVN r84907]
2013-06-26 22:05:28 +00:00
Adam Wulkiewicz
49597be2de
[geometry][index]: errors fixed in additional rtree utilities.
...
[SVN r84906]
2013-06-26 21:45:17 +00:00
Adam Wulkiewicz
90d1c2485f
[geometry][extensions]: Added required includes to nsphere.hpp, missing if rtree.hpp wasn't included.
...
[SVN r84899]
2013-06-24 12:25:33 +00:00
Adam Wulkiewicz
4108135c62
[geometry][index]: error fixed in iterative spatial query visitor - because of the error, the first return value in the query performed for a tree with only one node (root==leaf) was omitted. iterative distance query visitor modified for consistency.
...
[SVN r84896]
2013-06-24 00:44:41 +00:00
Barend Gehrels
9cc6d295c3
[geometry] merged for 1.54 release
...
[SVN r84889]
2013-06-23 20:59:55 +00:00
Adam Wulkiewicz
fbc4b3de6a
[geometry]: [index] some unused variables removed. [extensions] added support for nsphere in rstar algorithm
...
[SVN r84872]
2013-06-22 00:36:31 +00:00
Adam Wulkiewicz
fb42b6453c
[geometry][extensions]: added Matrix and Quaternion concepts.
...
[SVN r84868]
2013-06-21 19:30:38 +00:00
Adam Wulkiewicz
e7d6a62ddc
[geometry][index]: Added a note regarding implementation of various Indexable types in linear pick_seeds.
...
[SVN r84865]
2013-06-21 16:23:00 +00:00
Adam Wulkiewicz
10aa36c29c
[geometry][index]: Added a comment regarding implementation of various Indexable types in linear find_greatest_normalized_separation.
...
[SVN r84862]
2013-06-21 15:53:09 +00:00
Adam Wulkiewicz
43439fedf3
[geometry]: [index] rtree linear algorithm can now handle nspheres, [extensions] linear find_greatest_normalized_separation implemented for nsphere.
...
[SVN r84861]
2013-06-21 15:09:08 +00:00
Adam Wulkiewicz
17934592b5
[geometry][index]: clang compile errors fixed.
...
[SVN r84859]
2013-06-21 14:34:52 +00:00
Adam Wulkiewicz
3391f24b18
[geometry]: added boost::ignore_unused_variable_warning in covered_by, [index]: BOOST_GEOMETRY_INDEX_DETAIL_USE_PARAM removed, boost::ignore_unused_variable_warning used instead.
...
[SVN r84855]
2013-06-20 22:56:09 +00:00
Adam Wulkiewicz
469bc03afa
[geometry][extensions]: added missing covered_by algorithm for Point and NSphere.
...
[SVN r84854]
2013-06-20 21:57:28 +00:00
Adam Wulkiewicz
f0b813285f
[geometry][extensions]: added cartesian strategy point_in_nsphere, added base classes of nsphere_tag, used strategy in within(pt,sph).
...
[SVN r84852]
2013-06-20 21:39:12 +00:00
Adam Wulkiewicz
9676629bcc
[geometry]: [index] added detail::bounds(ind, box) function, quadratic algorithm is able to handle nspheres as Indexables. [extensions] added algorithms required by rtree to handled nspheres as Indexables: centroid(sph), covered_by(sph,box), equals(sph,sph), expand(box,sph), [i]comparable_distance_near(pt,sph), [i]bounds(sph,box), cartesian nsphere_in_box strategy, center_view<Sph> registered as Point.
...
[SVN r84847]
2013-06-20 16:30:05 +00:00
Adam Wulkiewicz
27160ad98e
[geometry][extensions]: nsphere modified with respect to changes made for index.
...
[SVN r84842]
2013-06-19 23:12:22 +00:00
Adam Wulkiewicz
45970c5696
[geometry][index]: implemented version of linear find_greatest_normalized_separation optimized for Points. Removed index::detail::traits, the official ones used instead.
...
[SVN r84840]
2013-06-19 23:00:12 +00:00
Adam Wulkiewicz
de8a2e8e45
[geometry][index]: added covers and contains spatial predicates, as experimental for now, removed experimental reversing of spatial predicates.
...
[SVN r84838]
2013-06-19 18:00:27 +00:00
Adam Wulkiewicz
8e11107a2c
[geometry]: [index] improved margin and content, [extensions] nsphere - fixed disjoint/intersects, added content, margin, is_valid.
...
[SVN r84830]
2013-06-18 22:51:33 +00:00
Adam Wulkiewicz
c583fb2eb5
[geometry][index]: added contains() and touches() predicates generators as experimental features.
...
[SVN r84827]
2013-06-18 16:31:34 +00:00
Adam Wulkiewicz
815f14df0b
[geometry][index]: boost::swap() for unsigned ints changed to std::swap() because of error C2872: 'swap' : ambiguous symbol in msvc 8 and 9.
...
[SVN r84821]
2013-06-18 00:16:01 +00:00
Adam Wulkiewicz
6fdc73a452
[geometry][index]: added reversed spatial predicates as experimental feature.
...
[SVN r84819]
2013-06-17 22:21:13 +00:00
Adam Wulkiewicz
744f2b5454
[geometry][extensions]: disjoint/intersects implemented for nsphere, ball removed.
...
[SVN r84811]
2013-06-16 22:24:12 +00:00
Adam Wulkiewicz
f0cdd03609
[geometry][index]: spatial query fixed - output iterator dereferenced.
...
[SVN r84808]
2013-06-16 19:36:41 +00:00
Adam Wulkiewicz
3f7b22f572
[geometry][index]: compilation error fixed - removed #ifdef not including required file - pack_create.hpp
...
[SVN r84786]
2013-06-14 23:48:12 +00:00
Adam Wulkiewicz
a754c180a6
[geometry][index]: cosmetic change - fix needed by exceptions tests.
...
[SVN r84784]
2013-06-14 23:09:30 +00:00
Adam Wulkiewicz
db239f03d3
[geometry][index]: R*tree choose_next_node significantly optimized.
...
[SVN r84783]
2013-06-14 23:03:37 +00:00
Adam Wulkiewicz
67d3f47852
[geometry][index]: added small optimization of overlap difference calculation in r* choose_next_node.
...
[SVN r84778]
2013-06-14 13:05:30 +00:00
Adam Wulkiewicz
b00696a043
[geometry][index]: packing algorithm enabled.
...
[SVN r84752]
2013-06-12 23:23:08 +00:00
Adam Wulkiewicz
7f1b251e25
[geometry][index] sort replaced by partial_sort in R* choose_next_node.
...
[SVN r84749]
2013-06-12 11:38:56 +00:00
Adam Wulkiewicz
865fc5621d
[geometry][index] small fix in r* choose_next_node
...
[SVN r84748]
2013-06-12 10:11:02 +00:00
Adam Wulkiewicz
ac4b789c88
[geometry][index]: added modification of other than root rtree internals after packing.
...
[SVN r84735]
2013-06-10 22:24:10 +00:00
Adam Wulkiewicz
e06868a53b
geometry.index: potential memleak fixed in pack.
...
[SVN r84733]
2013-06-10 21:48:58 +00:00
Adam Wulkiewicz
9812fde716
geometry.index: packer naming error fixed in rtree, auto_removers added in pack.
...
[SVN r84731]
2013-06-10 20:34:58 +00:00
Adam Wulkiewicz
bfd0052905
geometry.index: packer replaced by pack, various tweaks added.
...
[SVN r84730]
2013-06-10 15:55:45 +00:00
Mateusz Loskot
7c4ee689bc
[geometry] Add message missing in BOOST_ASSERT_MSG
...
[SVN r84727]
2013-06-10 15:10:49 +00:00
Mateusz Loskot
d9b740ddd1
[geometry] Iterator difference is not always std::size_t
...
[SVN r84726]
2013-06-10 15:08:04 +00:00
Adam Wulkiewicz
1f8a6c1331
geometry.index: packer - nodes counts container removed. counts are calculated when needed, subtree_counts pair replaced by struct with descriptive members and trivial copy.
...
[SVN r84724]
2013-06-10 13:53:07 +00:00
Adam Wulkiewicz
ef4ef2acfb
geometry.index: pack_create - non-VC-compiler compilation errors fixed, small optimization added.
...
[SVN r84722]
2013-06-10 11:59:52 +00:00
Adam Wulkiewicz
c44de29d5e
geometry.index: added experimental packing algorithm, some varray warnings fixed.
...
[SVN r84720]
2013-06-10 03:43:10 +00:00
Barend Gehrels
300c7ccbfd
[geometry] fixed documentation of return_buffer and exterior_ring
...
[SVN r84697]
2013-06-08 17:49:41 +00:00
Barend Gehrels
1277d8e51b
[geometry] fixed documentation of convex_hull
...
[SVN r84692]
2013-06-08 17:12:44 +00:00
Adam Wulkiewicz
abd33fbab2
geometry.index: varray replaced by optimized, advanced varray with move semantics and emplace support, developed by: Andrew Hundt and Adam Wulkiewicz.
...
[SVN r84675]
2013-06-07 17:34:58 +00:00
Adam Wulkiewicz
b4288c4a4d
geometry.index: geometry.index: wrong condition fixed in rstar/choose_next_node.
...
[SVN r84670]
2013-06-07 02:41:25 +00:00
Adam Wulkiewicz
aa4933856d
geometry.index: wrong condition fixed in quadratic/redistribute_elements. Comment added in rstar/redistribute_elements.
...
[SVN r84669]
2013-06-07 02:29:41 +00:00
Adam Wulkiewicz
43c3838e10
geometry.index: handled floating point types comparison and unsigned types difference calculation in linear/redistribute_elements.
...
[SVN r84667]
2013-06-07 01:29:19 +00:00
Adam Wulkiewicz
ae7a4129af
geometry.index: info and test visitors + functions moved to detail::rtree::utilities. Added detail::rtree::utilities::view<>. Definition of BOOST_GEOMETRY_INDEX_DETAIL_ENABLE_DEBUG_INTERFACE no longer needed.
...
[SVN r84661]
2013-06-06 22:52:19 +00:00
Mateusz Loskot
921b6b2d52
[geometry] Add index::rtree visitor collecting basic tree statistics.
...
[SVN r84649]
2013-06-05 23:10:19 +00:00
Mateusz Loskot
1a27aa6c37
[geometry] Remove superfluous semi-colon
...
[SVN r84616]
2013-06-03 00:37:35 +00:00
Adam Wulkiewicz
754989b0ae
geometry extensions: added experimental clear() and reverse() for translations/vectors (assigning zeros and negating) and rotations (assigning identity and calculating invese/conjugate)
...
[SVN r84615]
2013-06-02 23:53:12 +00:00
Adam Wulkiewicz
6aad0216e8
geometry extensions: added convert(), removed assign_zero() and added assign_identity() for rotations.
...
[SVN r84614]
2013-06-02 21:16:59 +00:00
Adam Wulkiewicz
81fb61af69
geometry extensions: implemented assign_zero() for algebra.
...
[SVN r84612]
2013-06-02 19:56:47 +00:00
Adam Wulkiewicz
2340347956
geometry extensions: fixed error in rotation_quaternion, removed translate().
...
[SVN r84610]
2013-06-02 18:18:58 +00:00
Adam Wulkiewicz
78069a375f
geometry extensions: fixed some compile errors.
...
[SVN r84588]
2013-06-01 00:44:12 +00:00
Adam Wulkiewicz
11ddd4b117
geometry extensions: quaternion_rotate moved to detail::algebra
...
[SVN r84585]
2013-05-31 19:43:38 +00:00
Mateusz Loskot
9cc6036ba3
[geometry]
...
Wrap debug facility with #ifdef BOOST_GEOMETRY_DEBUG_INTERSECTION.
Include missing <cmath>.
[SVN r84574]
2013-05-31 13:53:22 +00:00
Adam Wulkiewicz
1800788823
geometry extensions: Added basic description of some functions.
...
[SVN r84563]
2013-05-30 19:57:16 +00:00
Adam Wulkiewicz
e42c9009d7
geometry extensions: added generation of 2d rotation matrix.
...
[SVN r84562]
2013-05-30 19:51:47 +00:00
Adam Wulkiewicz
c7add5afce
index extensions: added rotation matrix, for now rotation() implemented only for 3d.
...
[SVN r84561]
2013-05-30 19:24:46 +00:00
Adam Wulkiewicz
f0bfb3c7dd
geometry extensions: Added rotation_quaternion, rotation(), transform_geometrically(), etc.
...
[SVN r84549]
2013-05-29 23:18:08 +00:00
Adam Wulkiewicz
4534b5add4
geometry extensions: fixed compile error in box translation.
...
[SVN r84543]
2013-05-28 23:01:58 +00:00
Adam Wulkiewicz
146c827f9d
geometry extensions: Added Vector concept, implemented assign(), clear(), num_points.hpp(), implemented translations for Point and Box. Fixed includes in extensions/ball.
...
[SVN r84542]
2013-05-28 22:45:57 +00:00
Adam Wulkiewicz
033aa9c3ed
geometry extensions: changed ball's geometry_id.
...
[SVN r84523]
2013-05-26 23:24:32 +00:00
Adam Wulkiewicz
f5c34db895
geometry extensions: fixed error in nsphere num_points, added ball concept implementation - nsphere using indexed access.
...
[SVN r84522]
2013-05-26 23:10:58 +00:00
Barend Gehrels
a2afadf701
[geometry] merged up to 84394 into Release branch
...
[SVN r84395]
2013-05-20 20:31:45 +00:00
Barend Gehrels
4efb54c25d
[geometry] SVG (mainly svg_mapper) documentation
...
[SVN r84394]
2013-05-20 18:04:29 +00:00
Adam Wulkiewicz
a8c6c4bad6
geometry::index: wrong result_type in calculate_distance for path predicate fixed
...
[SVN r84344]
2013-05-18 10:59:21 +00:00
Adam Wulkiewicz
a5695c8311
geometry.index: added handling of Segments to path queries.
...
[SVN r84292]
2013-05-15 23:24:56 +00:00
Barend Gehrels
485923d149
[geometry] merge of Boost.Geometry into release branch
...
[SVN r84242]
2013-05-12 10:58:26 +00:00
Barend Gehrels
6d62650bad
[geometry] creating branch of index
...
[SVN r84240]
2013-05-12 10:48:57 +00:00
Adam Wulkiewicz
5703291505
geometry.index: path_intersection optimized for 2-point linestrings.
...
[SVN r84237]
2013-05-11 22:37:03 +00:00
Barend Gehrels
edca638dfc
[geometry] Moved SVG from extensions to main tree, to release it
...
[SVN r84233]
2013-05-11 12:27:43 +00:00
Adam Wulkiewicz
6fd3616601
geometry.index: added compile-time Range type check.
...
[SVN r84230]
2013-05-10 23:06:55 +00:00
Adam Wulkiewicz
1363ad17d2
geometry.index: added rtree parameters Min default = 0.3*Max.
...
[SVN r84217]
2013-05-10 12:03:44 +00:00
Adam Wulkiewicz
cf9edb967e
geometry.index: negation of satisfies() predicate added.
...
[SVN r84215]
2013-05-09 23:33:52 +00:00
Adam Wulkiewicz
38e29d62fc
geometry.index: nearest_query.cpp renamed to distance_query.cpp
...
[SVN r84214]
2013-05-09 22:32:29 +00:00
Adam Wulkiewicz
609528d426
geometry.index: Deprecated BOOST_NO_RVALUE_REFERENCES replaced by BOOST_NO_CXX11_RVALUE_REFERENCES in distance_query_incremental.
...
[SVN r84212]
2013-05-09 18:52:19 +00:00
Adam Wulkiewicz
72e2ee5ade
geometry.index: introduced distance query - a generalized nearest query. distance calculation simplified. nearest query implemented using distance query. added path() predicate and query implemented using distance query as well.
...
[SVN r84209]
2013-05-09 18:01:25 +00:00
Adam Wulkiewicz
03da86e962
geometry.index: nearest() predicate point relations shielded by BOOST_GEOMETRY_INDEX_DETAIL_EXPERIMENTAL.
...
[SVN r84170]
2013-05-06 16:15:38 +00:00
Adam Wulkiewicz
66f91c3578
geometry.index: added path_intersection algorithm.
...
[SVN r84131]
2013-05-04 02:08:21 +00:00
Adam Wulkiewicz
e4e7bd4a28
geometry.index: added segment_intersection algorithm.
...
[SVN r84129]
2013-05-03 20:36:29 +00:00
Adam Wulkiewicz
44084345b9
geometry.index: compile errors fixed in experimental iterators.
...
[SVN r84122]
2013-05-03 01:03:32 +00:00
Adam Wulkiewicz
00c66c3277
geometry.index: added experimental end_query_iterator which may be compared with spatial_query_iterator or nearest_query_iterator to check if query is finished.
...
[SVN r84120]
2013-05-03 00:14:33 +00:00
Adam Wulkiewicz
ba57344359
geometry.index: query_visitor_incremental - index to current value replaced by pair of iterators
...
[SVN r84108]
2013-05-02 12:23:01 +00:00
Adam Wulkiewicz
2fdd1c6ab6
geometry.index: rtree methods/functions descriptions improved.
...
[SVN r84095]
2013-04-30 20:49:29 +00:00
Adam Wulkiewicz
3236a7546e
geometry.index: fixed error for BOOST_NO_EXCEPTION.
...
[SVN r84093]
2013-04-30 14:02:54 +00:00
Adam Wulkiewicz
d51e39bae9
geometry.index: added rtree's max and min parameters checks.
...
[SVN r84092]
2013-04-30 14:00:50 +00:00
Adam Wulkiewicz
a17bf4a6c7
geometry.index: edge values of some parameters handled more safely, changed order of rstar parameters.
...
[SVN r84087]
2013-04-29 20:50:00 +00:00
Adam Wulkiewicz
92aa63a684
geometry.index: added includes to some detail/algorithms to make possible using them without including rtree.
...
[SVN r84085]
2013-04-29 12:51:49 +00:00
Adam Wulkiewicz
13458e4de4
geometry.index: fixed errors preventing copy-assigning query iterators in C++03 (caused by container::vector and Boost.Move limitation).
...
[SVN r84078]
2013-04-28 23:04:58 +00:00
Adam Wulkiewicz
72e5b48bba
geometry.index: added stl container-like typedefs in rtree (reference, pointer, etc.), added type-erased iterator - currently may be enabled by define.
...
[SVN r84071]
2013-04-28 17:06:28 +00:00
Adam Wulkiewicz
7c43145cf8
geometry.index: fixed GCC compilation error related to initialization of pointer to function wrapped in the 'satisfies' predicate.
...
[SVN r84059]
2013-04-27 23:22:04 +00:00
Adam Wulkiewicz
28578fe932
geometry.index: made changes required to allow copying of query iterators - geometries objects are now wrapped in predicates instead of const references, pointers to const translator instead of const references are stored in queries incremental visitors.
...
[SVN r84057]
2013-04-27 22:59:37 +00:00
Adam Wulkiewicz
d1881e788f
geometry.index: supported environments with disabled exceptions (BOOST_NO_EXCEPTIONS) - committed missed file.
...
[SVN r84047]
2013-04-25 14:13:16 +00:00
Adam Wulkiewicz
affba8cc35
geometry.index: supported environments with disabled exceptions (BOOST_NO_EXCEPTIONS)
...
[SVN r84045]
2013-04-25 13:55:19 +00:00
Adam Wulkiewicz
c20734b705
geometry extensions: tabs replaced by spaces.
...
[SVN r84044]
2013-04-25 10:41:03 +00:00
Adam Wulkiewicz
1d1a4778b6
geometry.index: changed exception type thrown when the allocator returns null node and doesn't throw an exception.
...
[SVN r84043]
2013-04-25 10:37:58 +00:00
Adam Wulkiewicz
97aea19565
geometry: tabs replaced by spaces in non-extensions code.
...
[SVN r84038]
2013-04-24 14:22:21 +00:00
Adam Wulkiewicz
4c6a1e4de3
geometry.index: fixed numeric_limits max() calls in iterative nearest visitor.
...
[SVN r84037]
2013-04-24 14:08:49 +00:00
Adam Wulkiewicz
dfd201146b
geometry.index: experimental iterative query visitor increment() simplified.
...
[SVN r84030]
2013-04-24 12:35:30 +00:00
Adam Wulkiewicz
06e93d3f0e
geometry.index: experimental nearest iterative visitor optimized (different data structures, less complex algorithm).
...
[SVN r84029]
2013-04-24 11:22:36 +00:00
Barend Gehrels
d1036cf417
[geometry] fix for clang
...
[SVN r83998]
2013-04-21 11:59:05 +00:00
Barend Gehrels
ed62b34402
[geometry] Added (draft) versions of point_buffer, multi_point_buffer, end-caps, rounded endcap
...
[SVN r83996]
2013-04-21 10:43:22 +00:00
Adam Wulkiewicz
187c5cf3f7
geometry.index.rtree: added condition in nearest query iterative visitor for safety reasons.
...
[SVN r83975]
2013-04-20 01:52:26 +00:00
Adam Wulkiewicz
7a8e2735cd
geometry.index.rtree: removed unneeded prune_nodes() method from nearest query visitor.
...
[SVN r83974]
2013-04-20 01:21:20 +00:00
Adam Wulkiewicz
e8dabbaf9f
geometry.index.rtree: unclear condition in nearest query iterative visitor replaced by shorter and cleaner one.
...
[SVN r83973]
2013-04-20 00:56:19 +00:00
Adam Wulkiewicz
76af7b64c2
geometry.index.rtree: fixed error in nearest query iterative visitor.
...
[SVN r83972]
2013-04-20 00:41:14 +00:00
Adam Wulkiewicz
d3e83c3818
geometry.index.rtree: removed unused variable
...
[SVN r83971]
2013-04-19 23:01:01 +00:00
Adam Wulkiewicz
6307d5b3a4
geometry.index.rtree: added experimental nearest query iterator, rtree::qbegin() and rtree::qend() methods modified to support it, cosmetic change in spatial query iterator (addressof() instead of &)
...
[SVN r83968]
2013-04-19 22:27:54 +00:00
Adam Wulkiewicz
8b7e59b3ec
geometry.index.rtree: Removed distance predicates member unnecessarily stored in nearest visitor.
...
[SVN r83964]
2013-04-19 12:57:12 +00:00
Adam Wulkiewicz
3f7df7c85e
geometry.index rtree: dependency removed - node_auto_ptr base class noncopyable - implemented manually.
...
[SVN r83946]
2013-04-18 00:20:40 +00:00
Adam Wulkiewicz
8d002db8a9
geometry.index rtree: error fixed in linear redistribute_elements, errors fixed in experimental spatial query iterator and visitor.
...
[SVN r83945]
2013-04-18 00:06:35 +00:00
Adam Wulkiewicz
fcc99ddbcb
geometry.index: added experimental spatial query iterator and rtree::qbegin() and rtree::qend() methods, added allocator_type to Allocators.
...
[SVN r83935]
2013-04-16 22:08:55 +00:00
Adam Wulkiewicz
5aa6c7d487
geometry.index rtree: Added commented out preliminary version of incremental spatial query visitor.
...
[SVN r83912]
2013-04-15 00:47:46 +00:00
Mateusz Loskot
182dac69e0
[geometry] Add missing words in doc sentences
...
[SVN r83911]
2013-04-14 23:36:05 +00:00
Adam Wulkiewicz
6bf7e0dbe0
geometry::index: commented out explicit copy ctor and assignment of ptr_pair.
...
[SVN r83879]
2013-04-13 18:28:41 +00:00
Barend Gehrels
8145047dc5
[geometry] Ticket #7465 Fixed, made 2 constructors public
...
[SVN r83787]
2013-04-06 23:03:38 +00:00
Barend Gehrels
b2e3b33250
[geometry] Tickets #8403 and #8405 -> silenced various warnings using MSVC /W4.
...
We have to use the #pragma's to not destroy the sources.
[SVN r83786]
2013-04-06 22:46:54 +00:00
Barend Gehrels
7fce3396e2
[geometry] Ticket #8405 -> silenced various warnings using MSVC /W4
...
[SVN r83780]
2013-04-06 21:28:38 +00:00
Adam Wulkiewicz
7fd1f8c88f
geometry.index: doxygen group description tweaked
...
[SVN r83751]
2013-04-03 19:03:25 +00:00
Adam Wulkiewicz
dd5d6ff393
rtree: members of equal_to and indexable documented.
...
[SVN r83731]
2013-04-03 00:21:04 +00:00
Barend Gehrels
c8475204e6
[geometry] Fixes for Doxygen: we go back to ifdef DOXYGEN... for parameters which should not be documented, instead of qbk_skip. This because the newer versions of Doxygen did not support the qbk_skip construction anymore.
...
Also removed <em> from the comment because it complained about the end (there was a /2, meaning divide by two in between)
[SVN r83714]
2013-04-02 17:53:51 +00:00
Adam Wulkiewicz
806c11d710
rtree: msvc warnings suppressed in utilities
...
[SVN r83711]
2013-04-02 14:11:42 +00:00
Adam Wulkiewicz
d490cec151
rtree: fixed error in move assignment (allocators comparison), some comments added
...
[SVN r83709]
2013-04-02 14:00:57 +00:00
Adam Wulkiewicz
a18bb704d3
rtree: added allocator propagation test in swap()
...
[SVN r83706]
2013-04-02 02:35:03 +00:00
Adam Wulkiewicz
03ffa0f35f
rtree: added Allocators copy assignments for C++11, warning disabled.
...
[SVN r83704]
2013-04-02 00:13:51 +00:00
Adam Wulkiewicz
11d4f2294b
rtree: added missing returns
...
[SVN r83671]
2013-03-31 20:23:52 +00:00
Adam Wulkiewicz
e28cf9a69b
rtree: MSVC warning 4996 disabled in varray
...
[SVN r83663]
2013-03-31 13:56:49 +00:00
Adam Wulkiewicz
58f2526bdc
rtree: fixed template parameter types and MPL_ASSERT parameters
...
[SVN r83659]
2013-03-31 01:28:13 +00:00
Adam Wulkiewicz
a73d6c0b2e
rtree move ctor and assignment rearranged.
...
[SVN r83658]
2013-03-31 00:02:15 +00:00
Adam Wulkiewicz
cd7109025c
rtree error fixed: Allocators copy/move assignment defined explicitly.
...
rtree warning fixed: conversion from size_t to Allocators::size_type.
[SVN r83655]
2013-03-30 21:34:31 +00:00
Adam Wulkiewicz
ab56aa37b2
index copied from branches to trunk
...
[SVN r83638]
2013-03-30 01:20:27 +00:00
Barend Gehrels
cad4707a7d
[geometry] Fix ticket 7462, degenerate union for float. This was caused by two distances being wrong (by floating point precision). We now use earlier the alternative sort method (sorting on left/right), using relaxed_epsilon. This fixes the cause.
...
[SVN r83481]
2013-03-17 21:26:01 +00:00
Barend Gehrels
8fbc112550
[geometry] fixed issue (found myself with testcase #buffer_mp2) where, in double precision, a false intersection point was inserted. This was a robustness issue, an inconsistent side-value in colinear-opposite handler of get_turn_info
...
[SVN r83475]
2013-03-17 16:28:15 +00:00
Barend Gehrels
c992eb61e8
[geometry] fixed issue (found myself with testcase #buffer_mp1) where two specific circle-like polygons were not overlayed correctly. This was caused by sections not containing all points. We now make the section boxes a little smaller, such that they are not disjoint (10 * epsilon). This margin is a little fuzzy, but that is not harmful, they only influence might be some more comparisons. But that is intentional, we missed now one.
...
[SVN r83474]
2013-03-17 16:26:34 +00:00
Adam Wulkiewicz
f850426692
rtree: margin() renamed to comparable_margin(), other/simpler algorithm used, 3d_benchmark added
...
[SVN r83449]
2013-03-15 18:49:46 +00:00
Adam Wulkiewicz
453af42c4b
Added indexable<> and equal_to<> specialized for std::tuple<> if the compiler supports c++11 tuples and variadic templates.
...
[SVN r83438]
2013-03-15 17:17:54 +00:00
Adam Wulkiewicz
2db7f67b56
rtree: cosmetic changes
...
allocator passed to ctors by const ref instead of a value,
some parameters names changed,
docs updated.
[SVN r83315]
2013-03-05 18:26:56 +00:00
Adam Wulkiewicz
6fc96171f8
Added commented out specializations of insexable<>, equal_to<> and tests for std::tuple.
...
Removed unneeded variant node get<> function.
[SVN r83302]
2013-03-05 02:42:02 +00:00
Adam Wulkiewicz
f2f41d8b74
rtree: errors in indexable_get() and value_eq() fixed,
...
indexable_get() and value_eq() used in rtree tests instead of translator().
[SVN r83289]
2013-03-04 01:06:58 +00:00
Adam Wulkiewicz
cfb4911630
rtree: indexable<>, equal_to<> and translator<> relocated:
...
translator<>, indexable_type<>, result_type<> moved to detail namespace.
indexable<> and equal_to<> are now defined in separate files.
detail::translator namespace removed.
[SVN r83288]
2013-03-03 23:41:22 +00:00
Adam Wulkiewicz
5e2db81daf
rtree: indexable_getter and value_equal description added.
...
[SVN r83280]
2013-03-03 13:55:24 +00:00
Barend Gehrels
ce3e4e858e
[geometry] reorganized buffer strategies
...
[SVN r83272]
2013-03-03 12:28:16 +00:00
Adam Wulkiewicz
4727f94f4d
rtree: IndexableGetter and EqualTo handled in members_holder interface.
...
Fix in glut_vis example - macro name fixed.
[SVN r83257]
2013-03-03 00:34:45 +00:00
Adam Wulkiewicz
33aef8ae3b
rtree: added indexable_getter and value_equal. Macro enabling debug interface renamed.
...
[SVN r83255]
2013-03-02 23:51:13 +00:00
Barend Gehrels
59ab90e79e
[geometry] Buffer update, added buffer support for multi_linestring, and the number of steps for round buffers can be specified (both requests of John Lilley)
...
[SVN r83243]
2013-03-02 14:30:50 +00:00
Adam Wulkiewicz
d04778f99e
rtree parameter Translator replaced by two IndexableGetter and EqualTo
...
[SVN r83238]
2013-03-02 02:20:40 +00:00
Adam Wulkiewicz
f536225918
added functors index::equal_to<V> and index::indexable<V>, not used yet
...
[SVN r83235]
2013-03-01 21:57:29 +00:00
Adam Wulkiewicz
0bc541d1e9
rtree query default spatial predicate removed. Explicit call of intersects() is expected.
...
Predicates and DistancePredicates are stored by value in visitors.
Each predicate is stored by value in expression tuple.
Examples and docs updated.
[SVN r83232]
2013-03-01 18:14:46 +00:00
Adam Wulkiewicz
0afdadc5c4
value() predicate renamed to satisfies()
...
[SVN r83224]
2013-03-01 02:59:39 +00:00
Barend Gehrels
9808bf8b45
[geometry] updated offset/buffer w.r.t. changes in library
...
[SVN r83189]
2013-02-27 17:25:07 +00:00
Adam Wulkiewicz
e621608667
index::runtime::XXX parameters moved and renamed to index::dynamic_XXX
...
[SVN r83188]
2013-02-27 13:30:14 +00:00
Adam Wulkiewicz
12bb15d27e
Added translator examples.
...
rtree: parameters passed in the constructor by const& instead of a copy.
[SVN r83135]
2013-02-24 16:42:39 +00:00
Adam Wulkiewicz
e1a4660d47
Added examples of indexing polygons.
...
Fixed c++11 compilation error caused by use of deleted Allocators copy ctor in rstar insert visitor.
[SVN r83110]
2013-02-23 23:47:19 +00:00
Adam Wulkiewicz
f7849be05d
doxygen_xml2qbk: fixed alt. class output for class specialization.
...
quickbook_output_indexterm() call removed from alt. class output.
docs updated
[SVN r83082]
2013-02-22 13:53:19 +00:00
Adam Wulkiewicz
d418dac57f
rtree predefined translator renamed to index::translator<>
...
index::translator::def<> renamed to index::translator<>
index::translator::index<> removed
translator helpers removed or moved to index::default::translator namespace
some unneeded includes removed
docs updated
[SVN r83077]
2013-02-22 03:23:41 +00:00
Adam Wulkiewicz
fd98aaab40
rtree: allocator_traits used in ctor and operator= (e.g. propagate_XXX or select_XXX),
...
index::swap() added,
query_range operator| generator moved to index::detail,
docs updated.
[SVN r83019]
2013-02-19 19:36:43 +00:00
Adam Wulkiewicz
27c53a3779
rtree: definition of _CRT_SECURE_NO_DEPRECATE removed
...
[SVN r83001]
2013-02-19 14:30:44 +00:00
Adam Wulkiewicz
b09c83883d
rtree: translator_wrapper removed,
...
detail::rtree::ptr_pair used in internal nodes instead of std::pair.
[SVN r83000]
2013-02-19 14:20:06 +00:00
Adam Wulkiewicz
a3778c9097
rtree: Geometries stored in predicates as const& instead of a copy, envelope_tag renamed to bounds_tag, MSVC warnings disabled/fixed.
...
[SVN r82999]
2013-02-19 13:17:52 +00:00
Adam Wulkiewicz
d16ffc0297
rtree: added include missing for standalone usage of detail::varray
...
[SVN r82979]
2013-02-18 19:40:39 +00:00
Adam Wulkiewicz
c47f314aaa
calls to allocator_traits::construct() and ::destroy() used, this time with valid parameters, C++11 requires raw pointers
...
[SVN r82966]
2013-02-18 03:37:52 +00:00
Adam Wulkiewicz
9198afb7f9
compile errors fixed: allocator_traits::construct() and destroyed() replaced by allocator calls because of errors in Boost.Container, nonasignable uses removed.
...
[SVN r82965]
2013-02-18 03:29:18 +00:00
Adam Wulkiewicz
a98548fe76
rtree: copy_from_back() replaced by move_from_back(), auto_deallocator used instead of try-catch block in create_node, nonassignable removed, container::allocator_traits used in create_node
...
[SVN r82964]
2013-02-18 03:02:28 +00:00
Adam Wulkiewicz
4270e53fe5
rtree detail varray error fixed
...
[SVN r82963]
2013-02-18 01:32:39 +00:00
Adam Wulkiewicz
9b2ebcde2e
rtree detail varray rvref support added.
...
ptr_pair added (not used for now).
[SVN r82962]
2013-02-18 01:19:22 +00:00
Adam Wulkiewicz
b122d309b7
rtree: some params definition corrected,
...
docs updated,
reference definition moved to the separate file.
[SVN r82949]
2013-02-17 14:57:29 +00:00
Adam Wulkiewicz
24626df0cf
rtree: unneeded allocators removed from members.
...
[SVN r82924]
2013-02-16 14:54:52 +00:00
Adam Wulkiewicz
cb38c7b034
rtree object size decreased by deriving allocators holder from allocators
...
[SVN r82918]
2013-02-16 01:21:32 +00:00
Adam Wulkiewicz
f43d5ca8f3
rtree object size decreased, bounds returned by copy, rtree members grouped in members_holder derived from potentially empty types
...
[SVN r82917]
2013-02-16 00:04:03 +00:00
Adam Wulkiewicz
214e9e8286
rtree errors fixes related to non-std allocator pointers usage
...
[SVN r82866]
2013-02-14 04:34:34 +00:00
Adam Wulkiewicz
b7f592f1f4
rtree non-std allocators support implemented.
...
interprocess test added.
[SVN r82864]
2013-02-14 01:11:17 +00:00
Adam Wulkiewicz
1b806fc797
compilation errors related to detail::rtree::get fixed
...
[SVN r82850]
2013-02-13 14:57:43 +00:00
Adam Wulkiewicz
6b270d31ec
raw pointers replaced by allocator pointer
...
[SVN r82849]
2013-02-13 14:33:11 +00:00
Adam Wulkiewicz
eb78310bc7
Added rtree_interprocess test (doesn't executed for now), error fixed in detail::varray
...
[SVN r82837]
2013-02-12 18:24:13 +00:00
Adam Wulkiewicz
8c6081100a
Removed
...
spatial_query(), nearest_query(),
related adaptors,
distance predicates generators bounded(), min_bounded() etc.,
detail static_vector renamed to varray.
Docs and tests updated.
[SVN r82824]
2013-02-11 19:11:41 +00:00
Adam Wulkiewicz
a90b56de26
boost::container::vector used in dynamic nodes. detail::static_vector renamed to detail::varray. Added Alloc parameter to varray. rtree::envelope() renamed to rtree::bounds(). Tests moddified. Docs tweaked.
...
[SVN r82766]
2013-02-06 20:56:29 +00:00
Barend Gehrels
7e949875aa
[geometry] applied patch of Vladimir Petrovic and changed std::string (which causes string-construction) to const char* for non-debug mode
...
[SVN r82690]
2013-02-02 18:47:00 +00:00
Adam Wulkiewicz
3f712b94f8
nearest() predicate and related classes moved from distance_predicates.hpp to predicates.hpp
...
query() methods and functions documented.
nearest() predicate documented.
Changes in various methods/functions description.
Deleted unneeded query_expr.
[SVN r82617]
2013-01-26 00:36:29 +00:00
Adam Wulkiewicz
fb25dff48e
Added rtree free function insert.
...
Added adaptors::queried().
nearest_query_range and spatial_query_range moved to adaptors::detail.
[SVN r82611]
2013-01-25 18:43:48 +00:00
Adam Wulkiewicz
cfb4ee0d43
MPL_ASSERT_MSG message modified.
...
[SVN r82606]
2013-01-25 13:23:10 +00:00
Adam Wulkiewicz
dfb33baede
Implemented all variants of rtree::query() method. spatial and nearest returning 1 and k values.
...
[SVN r82600]
2013-01-24 22:24:58 +00:00
Adam Wulkiewicz
455b2d9f45
Change in predicates.
...
empty() removed.
value() parameter renamed to Fun const& fun.
operator! moved to index::detail namespace.
Reference updated.
[SVN r82595]
2013-01-24 13:51:01 +00:00
Adam Wulkiewicz
344825c144
query_expr: implemented push_back_impl operator&& and find_nearest_impl
...
[SVN r82593]
2013-01-24 05:43:57 +00:00
Adam Wulkiewicz
1fdee7912a
added query_expr for test purposes
...
[SVN r82590]
2013-01-23 02:10:38 +00:00
Adam Wulkiewicz
26e9526564
boost/geometry/extensions/index/* moved to boost/geometry/index/*
...
rtree::box() renamed to rtree::envelope()
index::box() renamed to index::envelope()
some unneeded tests removed
docs updated
[SVN r82546]
2013-01-19 02:26:34 +00:00
Adam Wulkiewicz
4233d851c4
index/algorithms/* moved to index/detail/algorithms/*
...
[SVN r82545]
2013-01-19 01:15:55 +00:00
Adam Wulkiewicz
55774f5041
MSVC compilation error fixed.
...
is_valid moved to detail namespace.
[SVN r82544]
2013-01-19 00:23:48 +00:00
Adam Wulkiewicz
ca17094850
indexable traits and accessors moved to index::detail namespace
...
[SVN r82538]
2013-01-18 21:18:32 +00:00
Adam Wulkiewicz
b830ec1cdb
Files structure rearranged to better reflect namespace strcture. Some classes moved to different namespaces.
...
[SVN r82536]
2013-01-18 20:40:24 +00:00
Adam Wulkiewicz
392ac1a864
Options, functions: check_predicates(), are_boxes_ok(), are_levels_ok() moved to the index::detail namespace.
...
query_expr.hpp deleted.
[SVN r82523]
2013-01-17 15:19:40 +00:00
Adam Wulkiewicz
4836bbabce
root box calculation after remove moved from rtree::raw_remove() to visitor::remove.
...
[SVN r82522]
2013-01-17 14:37:40 +00:00
Adam Wulkiewicz
28a9448da5
Box stored in the rtree.
...
box() returns box_type const&.
rtree adapted to Box concept.
error in remove() fixed - size change if the Value wasn't removed.
Tests added.
[SVN r82515]
2013-01-17 03:54:52 +00:00
Adam Wulkiewicz
74db796acc
rtree: added bg::envelope() and bg::return_envelope().
...
doxygen_qbk2xml: added template parameters to detailed function output.
[SVN r82510]
2013-01-16 14:39:01 +00:00
Adam Wulkiewicz
9cd5626c90
rtree - added move ctor taking allocator
...
distance predicates - docs improved
doxygen_xml2qbk - group output finished (enums, defines and functions)
[SVN r82509]
2013-01-16 04:08:16 +00:00
Bruno Lalande
6090b106af
Made the length algorithm variant-aware.
...
[SVN r82484]
2013-01-13 23:09:27 +00:00
Adam Wulkiewicz
7994089084
Rtree docs improved.
...
[SVN r82483]
2013-01-13 20:02:19 +00:00
Barend Gehrels
f3735f6475
[geometry] Made concept-checks variant aware. For now the underlying types are skipped. So a specialization for variants is made, being empty. This also solves two omissions: checks for Ring and Segment. Besides that, it now derives from not-inherited. This was earlier not the case (i.e. concepts were not checked, if type was not found). The commit makes it also consistent with the new system (template parameters auto-derived if possible)
...
[SVN r82482]
2013-01-13 17:34:50 +00:00
Bruno Lalande
2da1ca09d1
Made wkt write variant-aware.
...
[SVN r82481]
2013-01-13 17:25:15 +00:00
Adam Wulkiewicz
36440429e0
rtree docs and doxygen_xml2qbk modified.
...
rtree docs:
fixed formatting, added rtree parameters info.
doxygen_xml2qbk:
added doxygen ref links support.
removed index_id_path - no longer needed.
[SVN r82479]
2013-01-13 15:35:10 +00:00
Barend Gehrels
d575690df3
[geometry] added include files for concept checking
...
[SVN r82476]
2013-01-13 15:05:24 +00:00
Bruno Lalande
8ae4743abb
Adapted multi/io/wkt to latest change.
...
[SVN r82474]
2013-01-13 12:04:01 +00:00
Bruno Lalande
acba0901a7
Made dispatch::wkt able to retrieve the tag by itself + used not_implemented.
...
[SVN r82473]
2013-01-13 11:57:45 +00:00
Bruno Lalande
dfb6a611db
Made the convert algorithm variant-aware.
...
[SVN r82472]
2013-01-12 23:06:18 +00:00
Bruno Lalande
4be6f96160
Reimplemented variants handling in num_points algorithm.
...
[SVN r82470]
2013-01-12 21:28:59 +00:00
Bruno Lalande
1be15177cb
Reimplemented variants handling in clear algorithm.
...
[SVN r82469]
2013-01-12 21:06:44 +00:00
Bruno Lalande
0394222c2b
Small fix - missing header.
...
[SVN r82468]
2013-01-12 20:59:42 +00:00
Bruno Lalande
ab7220987e
Removed a useless template parameter + used devariant_area in the no-strategy overload.
...
[SVN r82467]
2013-01-12 20:56:00 +00:00
Bruno Lalande
36c9694321
Reimplemented variant handling in area algorithm.
...
[SVN r82466]
2013-01-12 20:46:13 +00:00
Bruno Lalande
4d59f27f94
Better aligned the recent new code.
...
[SVN r82465]
2013-01-12 20:34:40 +00:00
Bruno Lalande
136d84356f
Used 'devarianted_' term in append algorithm, like for equals.
...
[SVN r82464]
2013-01-12 18:33:20 +00:00
Bruno Lalande
c3c0e57304
Made the equals algorithm variant-aware.
...
[SVN r82463]
2013-01-12 18:28:00 +00:00
Adam Wulkiewicz
17584a35d3
Moddified rtree description - required by doxygen to properly generate links.
...
[SVN r82454]
2013-01-12 03:49:19 +00:00
Bruno Lalande
ecf429362e
Adding back mistakenly removed polygon specialization
...
[SVN r82452]
2013-01-12 00:24:44 +00:00
Bruno Lalande
684945f1c5
Reimplemented variants handling in clear() to avoid function overloading.
...
[SVN r82450]
2013-01-11 21:54:41 +00:00
Bruno Lalande
13e2dc0984
Reimplemented variants handling in append to avoid function overloading.
...
[SVN r82449]
2013-01-11 21:16:55 +00:00
Adam Wulkiewicz
4e972f0389
Fixed errors in doxygen_xml2qbk - lists support, additional paragraphs display.
...
Added warnings and infos.
Rtree docs improved, added text formatting, warnings etc.
[SVN r82446]
2013-01-11 04:09:30 +00:00
Adam Wulkiewicz
53a5a25f55
Docs improved.
...
[SVN r82428]
2013-01-09 23:48:23 +00:00
Adam Wulkiewicz
5310131f4c
Rtree docs: added inserter, groups names changed.
...
[SVN r82420]
2013-01-09 16:43:16 +00:00
Adam Wulkiewicz
121ac6c683
rtree: missing parameters description added.
...
[SVN r82419]
2013-01-09 16:34:02 +00:00
Adam Wulkiewicz
7a707809a7
Default and index translator added to the reference.
...
doxygen_xml2qbk now displays members only if they have brief description.
[SVN r82418]
2013-01-09 16:31:16 +00:00
Adam Wulkiewicz
0b84c2b0a5
rtree constructors parameters moddified
...
[SVN r82416]
2013-01-09 13:36:19 +00:00
Adam Wulkiewicz
e72e9bcfad
Added move ctors and swap() to nodes allocators. Used those in rtree move ctor and swap(). Docs: added rtree methods exceptions detailed description.
...
[SVN r82415]
2013-01-09 13:07:45 +00:00
Adam Wulkiewicz
cf6a052ffd
Added adaptors to the reference.
...
[SVN r82414]
2013-01-08 23:56:10 +00:00
Adam Wulkiewicz
54a789ec78
Added spatial and distance predicates to the reference.
...
[SVN r82413]
2013-01-08 23:41:27 +00:00
Bruno Lalande
2cc83e50a1
Made the append algorithm variant-aware.
...
[SVN r82412]
2013-01-08 23:35:28 +00:00
Adam Wulkiewicz
a127e0eb70
Added rtree group to src description and free functions to reference.
...
Some changed in doxygen_xml2qbk - group handling, parameters changes etc.
[SVN r82411]
2013-01-08 23:03:43 +00:00
Bruno Lalande
79ce0f7bb5
Gave variant dispatcher a more algorithm-specific name.
...
[SVN r82409]
2013-01-08 21:58:04 +00:00
Adam Wulkiewicz
bd3dc677b5
\bgi_exception{} alias used.
...
[SVN r82407]
2013-01-08 17:45:27 +00:00
Adam Wulkiewicz
81e43183a5
Added cos_output_style to doxygen_xml2_qbk tool.
...
Detail member description output slightly changed.
[SVN r82405]
2013-01-08 15:54:30 +00:00
Adam Wulkiewicz
f63be38583
rtree methods description: \qbk{} alias changed to manual \xmlonly<qbk>...</qbk>\endxmlonly
...
[SVN r82404]
2013-01-08 15:32:33 +00:00
Adam Wulkiewicz
033fb806bf
added qbk params in rtree description
...
[SVN r82402]
2013-01-08 14:40:57 +00:00
Bruno Lalande
22fff3f43b
Made clear() variant-aware.
...
[SVN r82395]
2013-01-08 00:05:36 +00:00
Bruno Lalande
f78cee7c30
Integrated not_implemented into clear.
...
[SVN r82390]
2013-01-07 22:39:17 +00:00
Adam Wulkiewicz
c06e6efc98
R-tree docs improved.
...
[SVN r82387]
2013-01-07 21:08:48 +00:00
Adam Wulkiewicz
0870399a28
rtree methods info/definition improved
...
[SVN r82386]
2013-01-07 18:04:20 +00:00
Adam Wulkiewicz
1257977a04
R-tree docs improved
...
[SVN r82380]
2013-01-07 01:50:29 +00:00
Adam Wulkiewicz
1f3612c9e4
doxygen_xml2qbk used to build the rtree reference
...
[SVN r82379]
2013-01-07 01:00:02 +00:00
Bruno Lalande
2a5b55ffe9
Made num_points variant-aware.
...
[SVN r82378]
2013-01-06 22:27:38 +00:00
Bruno Lalande
da4868a421
Made clearer that variant's tag is irrelevant.
...
[SVN r82377]
2013-01-06 21:35:07 +00:00
Adam Wulkiewicz
fa55322ddc
Fixed error in nearest_query() - for Iterator which is not an inserter - operator++ call added.
...
[SVN r82371]
2013-01-06 00:58:54 +00:00
Adam Wulkiewicz
a8b63e7617
Added rtree autodoc reference.
...
[SVN r82359]
2013-01-04 20:40:36 +00:00
Adam Wulkiewicz
dcd4550b4d
Updated exception-safety description in sources.
...
[SVN r82355]
2013-01-04 18:13:08 +00:00
Adam Wulkiewicz
8364fd5adb
remove() description improved.
...
[SVN r82354]
2013-01-04 17:56:17 +00:00
Adam Wulkiewicz
31d95f9ac4
Added number of removed elements returned by rtree::remove().
...
[SVN r82353]
2013-01-04 17:38:18 +00:00
Adam Wulkiewicz
c8a643a9d7
Rtree static parameters methods changed to static.
...
[SVN r82079]
2012-12-18 13:52:22 +00:00
Adam Wulkiewicz
95f6cf8442
Some compilation errors corrected in local index::static_vector.
...
[SVN r82048]
2012-12-17 15:43:27 +00:00
Adam Wulkiewicz
b8e533f7be
static_vector size_t changed to std::size_t.
...
[SVN r82035]
2012-12-16 22:00:22 +00:00
Adam Wulkiewicz
c51fbe50b9
Iterators check changed in erase(f, l).
...
Tests upgraded.
[SVN r82032]
2012-12-16 19:34:51 +00:00
Adam Wulkiewicz
d96e31bb1b
Compilation error fixed.
...
[SVN r82031]
2012-12-16 19:11:26 +00:00
Adam Wulkiewicz
f43d94fa29
asserts/checks closed in separate functions:
...
check_capacity()
check_empty()
check_iterator_end_eq()
check_iterator_end_neq()
[SVN r82030]
2012-12-16 19:09:10 +00:00
Adam Wulkiewicz
24f349839f
Added templated versions of static_vector copy ctor and assignment.
...
GCC compile error fixed in test.
[SVN r82028]
2012-12-16 18:45:23 +00:00
Adam Wulkiewicz
32fbcf66ed
Added statid_vector::insert(pos, first, last) for non random access iterators.
...
Added uninitialized_copy_checked() helper method.
Added tests.
[SVN r82027]
2012-12-16 18:31:03 +00:00
Adam Wulkiewicz
7e6f3b197e
static_vector: assertion moved.
...
[SVN r82025]
2012-12-16 16:13:35 +00:00
Adam Wulkiewicz
0ae51b1dbc
Implemented static_vector::insert(pos, first, last) for random access iterators.
...
Tests added.
[SVN r82024]
2012-12-16 16:09:07 +00:00
Barend Gehrels
106876b29d
[geometry] merged revisions r78001:r78851 which were not yet merged earlier
...
[SVN r82023]
2012-12-16 16:08:33 +00:00
Barend Gehrels
5ce1a36676
[geometry] merged to release branch
...
[SVN r82022]
2012-12-16 15:14:35 +00:00
Barend Gehrels
202f8db2b2
[geometry] updated traverse to avoid output of nearly empty rings, like in convert_rings. This also affects unit tests
...
[SVN r82020]
2012-12-16 13:26:21 +00:00
Adam Wulkiewicz
5c9f96c750
Added static_vector::insert(pos, n, val) + test.
...
[SVN r82008]
2012-12-16 02:40:29 +00:00
Adam Wulkiewicz
8c6d651676
Fixed wrong assert in static_vector::insert(pos, val)
...
Test added.
[SVN r82003]
2012-12-16 01:02:38 +00:00
Adam Wulkiewicz
50bb3d9fdf
Error fixed in static_vector::insert(pos, val).
...
Test added.
[SVN r82002]
2012-12-16 00:58:07 +00:00
Adam Wulkiewicz
2b5cd1d7e8
implemented static_vector insert(pos, val)
...
[SVN r82000]
2012-12-16 00:40:39 +00:00
Adam Wulkiewicz
475837cfa6
static_vector: types comparison warnings fixed.
...
[SVN r81994]
2012-12-15 23:51:24 +00:00
Adam Wulkiewicz
20c8e649b7
static_vector: fixed wrong assert, removed ptr(i), calls of ptr(i) replaced by methods returning iterators wherever possible.
...
[SVN r81992]
2012-12-15 23:41:37 +00:00
Adam Wulkiewicz
addc5eebcf
Added static_vector::erase() and tests.
...
[SVN r81990]
2012-12-15 23:21:59 +00:00
Adam Wulkiewicz
b985f5a561
Added assertion in static_vector.
...
[SVN r81980]
2012-12-15 20:55:38 +00:00
Adam Wulkiewicz
ba031be21a
Added static_vector::assign(count, value) + test.
...
Added static_vector iterators test.
[SVN r81978]
2012-12-15 20:07:19 +00:00
Adam Wulkiewicz
bed0b92f6e
static_vector helper method uninitialized_copy(Val, It) changed to uninitialized_fill(It, Val).
...
[SVN r81977]
2012-12-15 19:31:45 +00:00
Adam Wulkiewicz
36f0abc509
Fixed gcc compiler errors.
...
[SVN r81974]
2012-12-15 16:42:56 +00:00
Adam Wulkiewicz
d55108b720
Added ctor and modified assign to static_vector.
...
static_vector(Iter, Iter), assign(Iter, Iter) + separated version for RandomIterators.
Private helper methods now are able to take arbitrary type (Iterator, Value).
[SVN r81971]
2012-12-15 16:30:57 +00:00
Adam Wulkiewicz
395777fb9d
fixed static_vector error related to construction of values with nontrivial default constructor.
...
tests added.
[SVN r81962]
2012-12-14 23:22:16 +00:00
Adam Wulkiewicz
da5a91bad4
static_vector error fixed, tests added.
...
[SVN r81960]
2012-12-14 22:59:19 +00:00
Adam Wulkiewicz
479c6a3bab
Error fixed in static_vector::at().
...
Added test for static_vector.
[SVN r81958]
2012-12-14 22:35:46 +00:00
Barend Gehrels
f7040ca437
[geometry] added combinations point/ring, point/polygon, point/multi_polygon for disjoint and intersects
...
[SVN r81955]
2012-12-14 22:12:12 +00:00
Adam Wulkiewicz
b22bd9525c
assertion added in static_vector::assign();
...
[SVN r81954]
2012-12-14 21:46:53 +00:00
Adam Wulkiewicz
bbba565874
Compilation error fixed.
...
[SVN r81953]
2012-12-14 21:28:04 +00:00
Adam Wulkiewicz
17ed2a700b
static_vector resize() and corresponding ctor divided into 2 methods/ctors (C++11).
...
First one uses default ctors (for noncopyable values).
Second one uses copy ctors (for values with no default ctor).
[SVN r81952]
2012-12-14 21:26:14 +00:00
Barend Gehrels
30cd790db3
[geometry] fix in variable names
...
[SVN r81951]
2012-12-14 21:19:49 +00:00
Adam Wulkiewicz
3005f91f84
Small improvement to the nearest_query added.
...
[SVN r81949]
2012-12-14 19:46:18 +00:00
Adam Wulkiewicz
627452da2a
Added rtree::count() method. Docs modified.
...
[SVN r81947]
2012-12-14 19:15:34 +00:00
Adam Wulkiewicz
d7cf32bcfa
Rtree value_type must no longer have default ctor defined.
...
Added static_vector::assign(), added assertion in static_vector::resize().
Added test for value without default ctor..
[SVN r81940]
2012-12-14 14:49:45 +00:00
Adam Wulkiewicz
8f67c58ea4
rtree::assign() commented out.
...
[SVN r81936]
2012-12-14 12:07:25 +00:00
Adam Wulkiewicz
79436250e5
Added assign() to the rtree interface. Fixed compilation error in static_vector.
...
[SVN r81935]
2012-12-14 11:58:40 +00:00
Adam Wulkiewicz
95000752cd
static_vector changes: added MPL_ASSERT, added difference_type.
...
[SVN r81934]
2012-12-14 11:33:48 +00:00
Adam Wulkiewicz
4022ec2ccc
added val_ref parameter to static_vector::resize() and constructor, added methods max_size(), data(), at(), added some comments
...
[SVN r81931]
2012-12-14 04:18:21 +00:00
Adam Wulkiewicz
ae07c29360
added optimized versions of static_vector operations, however preliminary tests on linux shows no speed difference
...
[SVN r81930]
2012-12-14 02:02:52 +00:00
Adam Wulkiewicz
a8f5d60f93
Added optimized uninitialized_copy() and destroy() to static_vector.
...
[SVN r81925]
2012-12-14 00:13:20 +00:00
Adam Wulkiewicz
34768c2fb2
Some VS warnings fixed.
...
[SVN r81923]
2012-12-13 23:08:37 +00:00
Adam Wulkiewicz
6f103fc04e
explicit keyword added in static_vector.
...
[SVN r81895]
2012-12-13 13:16:06 +00:00
Adam Wulkiewicz
aaf737a5ce
static_vector implemented and used in the rtree instead of pushable_array
...
[SVN r81885]
2012-12-13 03:34:54 +00:00
Adam Wulkiewicz
00481f40c2
BOOST_ASSERT used instead of std assert
...
[SVN r81812]
2012-12-10 01:21:00 +00:00
Adam Wulkiewicz
dd6430083d
Coding style improved (issues detected by Boost Inspect tool).
...
[SVN r81802]
2012-12-08 23:47:52 +00:00
Adam Wulkiewicz
f4f0094c3a
Merged from index_dev
...
Fixed rtree::clear() mem leak.
Added test for clear() and boost::shared_ptr as Values.
Each linear algo test file divided into 2 files.
Added reference in docs->rtree introduction.
[SVN r81778]
2012-12-07 22:52:53 +00:00
Adam Wulkiewicz
640ae6ced6
Inserter included in the rtree.hpp
...
Added docs regarding inserter and creation of the rtree from the query results.
Added info about comparison of tuples in default translator.
Merged from index_dev.
[SVN r81582]
2012-11-26 22:20:38 +00:00
Barend Gehrels
54a64a7e35
[geometry] fixed comparable_distance point-linestring (and -range, -polygon)
...
[SVN r81580]
2012-11-26 22:12:35 +00:00
Adam Wulkiewicz
6f5b384b93
Merged from index_dev.
...
not_xxx predicates generators removed.
Added rtree constructor, insert() and remove() taking Range.
Added default translator for boost::tuple<>.
Each R*tree test divided into 2 files.
Docs updated/modified/fixed.
[SVN r81571]
2012-11-26 18:54:09 +00:00
Adam Wulkiewicz
e1a14edce2
Merged from index_dev.
...
Docs improved (images added). Some samples and tests modified.
[SVN r81542]
2012-11-25 21:38:31 +00:00
Adam Wulkiewicz
f7d7e88bbb
Modified glut_vis additional test and added generated rtree images.
...
[SVN r81528]
2012-11-25 17:28:12 +00:00
Adam Wulkiewicz
5a6e87b146
Pointers and Iterators types removed from the default Translator.
...
[SVN r81523]
2012-11-24 22:17:08 +00:00
Adam Wulkiewicz
80be48d155
Added rtree::swap() method.
...
Added requirement 'Nonthrowing copy constructor of the Translator'.
[SVN r81512]
2012-11-24 19:54:36 +00:00
Adam Wulkiewicz
a901b88244
Fixed nullptr dereference errors. Merged from index_dev.
...
[SVN r81484]
2012-11-22 14:47:16 +00:00
Adam Wulkiewicz
e5766cf57e
Fixed nullptr dereference errors.
...
[SVN r81483]
2012-11-22 14:45:32 +00:00
Adam Wulkiewicz
52e8317c3b
warnings fixed, query and nearest visitors renamed
...
[SVN r81482]
2012-11-22 11:31:58 +00:00
Adam Wulkiewicz
0ccbb1fe0c
some of warnings fixed.
...
[SVN r81481]
2012-11-22 11:28:21 +00:00
Adam Wulkiewicz
b42b3e3c9f
nearest and query visitors renamed.
...
[SVN r81471]
2012-11-22 01:54:21 +00:00
Adam Wulkiewicz
46816e4c44
merged from index_dev.
...
Fixed memory leaks mostly related to exception-safety issues.
Modified docs, added tests.
[SVN r81458]
2012-11-21 15:47:51 +00:00
Adam Wulkiewicz
7bbf242891
Improved exception safety of the r-tree.
...
Requirement 'nonthrowing copy constructor of the BoundingObject/CoordinateType' changed to 'exception-safe copy constructor of the BoundingObject/CoordinateType'.
From now the r-tree do not use erase() method of the elements containers. It uses copy_from_back() and pop_back() instead.
erase() removed from pushable_array.
Added various memory leaks fixes taking throwing by Element's copy constructor into account.
Tests added.
Docs modified.
[SVN r81445]
2012-11-20 22:49:14 +00:00
Adam Wulkiewicz
7ed71e5324
Fixed memleak for CoordinateType/BoundingObject which have throwing copy constructor for R*tree.
...
Added comments regarding exception-safety.
[SVN r81438]
2012-11-20 17:00:41 +00:00
Adam Wulkiewicz
e2beb3cf2f
Safety issue fixed in pushable_array.
...
Filenames related to filters(old name) changed to adaptors.
[SVN r81436]
2012-11-20 13:45:48 +00:00
Barend Gehrels
3ec9d48e43
[geometry] fixed for_each using C++11 lambda's, including adding unit test for them
...
[SVN r81418]
2012-11-18 19:51:00 +00:00
Adam Wulkiewicz
ff1ccbdf29
Translator copy ctor exception handled.
...
Exception-safety docs moddified.
[SVN r81365]
2012-11-16 12:43:34 +00:00
Adam Wulkiewicz
04cf9fbc39
A cosmetic change in raw_destroy().
...
Some of the rtree member types and methods made private unless BOOST_GEOMETRY_INDEX_ENABLE_DEBUG_INTERFACE is defined.
[SVN r81355]
2012-11-15 11:23:36 +00:00
Adam Wulkiewicz
00c54279b4
std::vector MS implementation memory leak workaround added.
...
[SVN r81351]
2012-11-14 23:55:53 +00:00
Adam Wulkiewicz
6b456b1fc7
remove() don't return if there is no root, assertion check is done in raw_remove().
...
Docs updated.
[SVN r81350]
2012-11-14 23:35:14 +00:00
Adam Wulkiewicz
593ab6d9fb
Names changed query to spatial_query, nearest to nearest_query, query_filtered to adaptors::spatial_queried, nearest_filtered to adaptors::nearest_queried.
...
[SVN r81349]
2012-11-14 21:59:37 +00:00
Adam Wulkiewicz
118ec2fbf6
Error related to the state of the rval after moving fixed. The root being NULL is valid state. Root is created lazily, if needed. This means that default constructor won't throw as well as moving operations.
...
[SVN r81345]
2012-11-14 17:12:23 +00:00
Adam Wulkiewicz
0ce013bdba
mem leaks related exceptions in rtree copying fixed
...
[SVN r81340]
2012-11-14 14:37:09 +00:00
Adam Wulkiewicz
b00198e311
mem leaks related to exceptions in remove fixed
...
[SVN r81325]
2012-11-13 22:13:17 +00:00
Adam Wulkiewicz
6a1f024055
exceptions test improved.
...
[SVN r81302]
2012-11-12 01:07:59 +00:00
Adam Wulkiewicz
25e10f2539
potential mem leaks fixed in inserting algorithms, exceptions tests added.
...
[SVN r81301]
2012-11-12 00:47:07 +00:00
Adam Wulkiewicz
d008473125
mem leaks related to exceptions fixed in linear redistribute_elements.
...
[SVN r81284]
2012-11-10 13:29:07 +00:00
Adam Wulkiewicz
4dc16eb40d
Exception-safety of the default insert and split algorithms improved.
...
[SVN r81280]
2012-11-10 10:25:56 +00:00
Bruno Lalande
cd44f9090e
Made dispatch::reverse able to find the tag by itself.
...
[SVN r81077]
2012-10-28 19:25:13 +00:00
Bruno Lalande
7be65c1fbc
Made dispatch::num_points able to find the tag by itself + used not_implemented.
...
[SVN r81075]
2012-10-28 19:08:35 +00:00
Barend Gehrels
931d6b65bf
[geometry] Bugfix: difference problem reported by H2 at Boost.Geometry list at 2012-09-14 and 2012-10-11
...
[SVN r80993]
2012-10-15 21:12:25 +00:00
Adam Wulkiewicz
b164ec22c4
Added exact_match parameter to are_boxes_ok() check.
...
[SVN r80982]
2012-10-13 23:26:25 +00:00
Bruno Lalande
18e9c2d582
Defaulted Tag template parameter in dispatch::num_interior_rings.
...
[SVN r80972]
2012-10-12 21:47:24 +00:00
Bruno Lalande
212dec5619
Used not_implemented in dispatch::num_geometries.
...
[SVN r80970]
2012-10-12 21:38:41 +00:00
Bruno Lalande
852185860e
Defaulted Tag template parameter in dispatch::num_geometries.
...
[SVN r80969]
2012-10-12 21:36:00 +00:00
Bruno Lalande
5ec3230d0d
Defaulted various template parameters in dispatch::intersection_insert.
...
[SVN r80965]
2012-10-11 22:54:47 +00:00
Bruno Lalande
53508d6838
Moved more template params to function level in dispatch::intersection_insert.
...
[SVN r80948]
2012-10-10 22:46:46 +00:00
Bruno Lalande
ee51d3310e
Moved Strategy template parameter from class to function level in dispatch::intersection_insert.
...
[SVN r80944]
2012-10-10 21:35:39 +00:00
Bruno Lalande
4a741dd86c
Used not_implemented for dispatch::for_each.
...
[SVN r80941]
2012-10-10 20:18:17 +00:00
Bruno Lalande
db23bb2e83
Made dispatch::for_each able to retrieve the tag by itself.
...
[SVN r80922]
2012-10-09 23:19:54 +00:00
Bruno Lalande
2dce3e0c56
Moved Functor template param from class to function level in dispatch::for_each.
...
[SVN r80919]
2012-10-09 23:03:18 +00:00
Bruno Lalande
35b39be71a
Applied latest change to multi-for_each.
...
[SVN r80918]
2012-10-09 22:39:51 +00:00
Bruno Lalande
ce600855ba
Removed IsConst stuff from dispatch::for_each - this is useless because constness is part of the type already.
...
[SVN r80917]
2012-10-09 22:22:17 +00:00
Bruno Lalande
3e3fad1028
Made dispatch::for_each able to find out the geometry constness by itself, and used boost::is_const instead of dedicated overloads.
...
[SVN r80915]
2012-10-09 22:07:30 +00:00
Adam Wulkiewicz
0ab8fb772b
merged from index_dev.
...
clang warnings and error in nearest_k fixed.
added insert_traverse_data.
added additional tests.
[SVN r80841]
2012-10-04 09:37:39 +00:00
Adam Wulkiewicz
a8356c2625
fixed some warnings and error, added nearest query test which don't find all values.
...
[SVN r80838]
2012-10-03 23:59:01 +00:00
Adam Wulkiewicz
460aac42a7
Data changing in traversing process moved to separate structure.
...
[SVN r80827]
2012-10-03 18:10:29 +00:00
Adam Wulkiewicz
8f50f69560
index dev branch created
...
[SVN r80798]
2012-09-30 23:29:41 +00:00
Adam Wulkiewicz
321143ef6f
cosmetic changes
...
[SVN r80796]
2012-09-30 23:14:09 +00:00
Adam Wulkiewicz
6e5c17a53f
some names changed.
...
[SVN r80794]
2012-09-30 20:28:11 +00:00
Adam Wulkiewicz
4232b39920
removed not automatically deducable template parameters from methods templates (possible GCC compilation error).
...
[SVN r80788]
2012-09-30 17:29:00 +00:00
Adam Wulkiewicz
80bfe0ae01
code related to nodes visitation moved to XXX_visitor.hpp
...
[SVN r80782]
2012-09-30 12:54:25 +00:00
Adam Wulkiewicz
136e2fc742
dynamic_visitor added and nodes tags changed.
...
[SVN r80779]
2012-09-30 12:12:34 +00:00
Adam Wulkiewicz
eb7ba34800
NodeProxy create() template member replaced by template function.
...
[SVN r80774]
2012-09-30 11:40:09 +00:00
Adam Wulkiewicz
75959b7426
NodeProxy used in visitors instead of Parameters, Translator and Allocators.
...
[SVN r80771]
2012-09-30 11:11:50 +00:00
Adam Wulkiewicz
b17a68cc09
implemented basic functionality of node_proxy
...
[SVN r80753]
2012-09-29 12:56:38 +00:00
Adam Wulkiewicz
d38a6ad5e6
renamed node types files
...
[SVN r80752]
2012-09-29 11:44:21 +00:00
Adam Wulkiewicz
3541621b70
added node/concept.hpp and moved some of empty definitions there.
...
[SVN r80751]
2012-09-29 11:37:57 +00:00
Adam Wulkiewicz
df4497d35a
rtree node xxx_poly visitor and node types renamed to dynamic_xxx and moved to dynamic_visitor.hpp
...
[SVN r80750]
2012-09-28 23:27:12 +00:00
Bruno Lalande
4f5291ddc6
Added forgotten file geometries/variant.hpp
...
[SVN r80698]
2012-09-24 20:38:27 +00:00
Bruno Lalande
33efa07ed1
Moved Strategy template parameter from class level to function level in dispatch::convex_hull.
...
[SVN r80684]
2012-09-23 22:18:24 +00:00
Bruno Lalande
9c51c04471
Used not_implemented on dispatch::centroid.
...
[SVN r80682]
2012-09-23 21:34:38 +00:00
Bruno Lalande
2234750c4b
Made dispatch::centroid able to retrieve the tag by itself.
...
[SVN r80681]
2012-09-23 21:30:58 +00:00
Bruno Lalande
6dd794a09d
Removed now unused Point template parameter from dispatch::centroid.
...
[SVN r80680]
2012-09-23 21:20:25 +00:00
Bruno Lalande
fe2edf15f8
Moved Strategy template parameter from class level to function level in dispatch::centroid.
...
[SVN r80678]
2012-09-23 21:04:20 +00:00
Bruno Lalande
70ea8c83d1
Used not_implemented for dispatch::buffer.
...
[SVN r80675]
2012-09-23 18:18:28 +00:00
Bruno Lalande
76b499a8d5
Made dispatch::buffer able to retrieve the tags by itself.
...
[SVN r80673]
2012-09-23 18:14:44 +00:00
Bruno Lalande
48ba1751d5
Moved the T template param to function level in dispatch::buffer and renamed it.
...
[SVN r80671]
2012-09-23 17:14:31 +00:00
Bruno Lalande
9a84ecdf0e
Made dispatch::perimeter able to retrieve the tag by itself.
...
[SVN r80665]
2012-09-23 12:30:51 +00:00
Bruno Lalande
189d847b90
Moved Strategy template parameter from class level to function level in dispatch::perimeter.
...
[SVN r80663]
2012-09-23 11:28:14 +00:00
Bruno Lalande
15cce77f1b
Made dispatch::length able to retrieve the tag by itself.
...
[SVN r80652]
2012-09-22 23:15:06 +00:00
Bruno Lalande
2fca916308
Replicated last change in dispatch::length to multi-length and perimeter.
...
[SVN r80651]
2012-09-22 23:07:57 +00:00
Bruno Lalande
9a6a9f3aa6
Moved Strategy from class level to function level in length.
...
[SVN r80650]
2012-09-22 22:55:12 +00:00
Adam Wulkiewicz
d0ce652bb7
implemented additional query_expr helpers.
...
[SVN r80612]
2012-09-21 01:57:29 +00:00
Adam Wulkiewicz
85730539be
Added query_expr.hpp
...
[SVN r80611]
2012-09-20 23:42:09 +00:00
Bruno Lalande
b3dcf83fa3
Added support for variant geometries in area algorithms.
...
[SVN r80610]
2012-09-20 21:48:47 +00:00
Bruno Lalande
49a7d9cfc1
Added missing header.
...
[SVN r80548]
2012-09-16 22:52:40 +00:00
Bruno Lalande
c750e3b1eb
Updated nsphere code to reflect latest core changes.
...
[SVN r80547]
2012-09-16 22:52:03 +00:00
Bruno Lalande
ab0bd43b80
Fixed typo in static error messages.
...
[SVN r80545]
2012-09-16 22:06:39 +00:00
Bruno Lalande
c8880d6edc
Added missing header.
...
[SVN r80500]
2012-09-11 22:42:10 +00:00
Bruno Lalande
6866f31237
Removed use of auto keyword.
...
[SVN r80499]
2012-09-11 22:39:51 +00:00
Adam Wulkiewicz
11e96c6247
fixed near/far macros issue by renaming near(to to_nearest), far(to to_furthest) and centroid to to_centroid for consistency.
...
[SVN r80398]
2012-09-04 18:09:39 +00:00
Bruno Lalande
0209699020
Moved Strategy from class to function level in dispatch::area. Preliminary change for integration of variant geometry.
...
[SVN r80366]
2012-09-02 21:14:49 +00:00
Bruno Lalande
7f5b0233e6
Made dispatch::unique able to retrieve the tag by itself.
...
[SVN r80245]
2012-08-26 23:33:14 +00:00
Bruno Lalande
2151e81851
Moved some template params from class to function level in dispatch::unique.
...
[SVN r80244]
2012-08-26 23:08:36 +00:00
Bruno Lalande
347e4727b9
Integrated not_implemented into union.
...
[SVN r80243]
2012-08-26 22:49:53 +00:00
Bruno Lalande
3ecfdfe1c7
Moved OutputIterator template param from class to function level in dispatch::union.
...
[SVN r80242]
2012-08-26 22:39:16 +00:00
Bruno Lalande
514132a751
Moved Strategy template param from class to function level in dispatch::union.
...
[SVN r80240]
2012-08-26 21:36:04 +00:00
Adam Wulkiewicz
d0890859f0
numeric_limits<>::max() handled correctly.
...
[SVN r80239]
2012-08-26 19:54:39 +00:00
Adam Wulkiewicz
1f72fc54cb
Implemented r-tree run-time parameters. Tests modified. Added remove() test.
...
[SVN r80230]
2012-08-26 00:41:11 +00:00
Bruno Lalande
d4142f48dc
Made dispatch::union able to reverse itself.
...
[SVN r80229]
2012-08-25 22:42:38 +00:00
Bruno Lalande
7dd075c1bd
Defaulted more template params in dispatch::union.
...
[SVN r80218]
2012-08-25 21:50:02 +00:00
Bruno Lalande
435eb815cf
Made dispatch::union enable to detect areals by itself.
...
[SVN r80199]
2012-08-25 12:50:30 +00:00
Bruno Lalande
316e4dd121
Made dispatch::union able to retrieve the tags by itself.
...
[SVN r80194]
2012-08-25 09:07:09 +00:00
Adam Wulkiewicz
4c41822454
Modified docs, files descriptions, added quick_start example.
...
[SVN r80164]
2012-08-23 21:55:34 +00:00
Bruno Lalande
726a608b0a
Removed now useless strategy template params from dispatch::transform.
...
[SVN r80162]
2012-08-23 20:40:08 +00:00
Bruno Lalande
15ae4f6357
Made dispatch::transform able to retrieve the tags by itself.
...
[SVN r80161]
2012-08-23 20:19:11 +00:00
Bruno Lalande
198e2c73b7
Moved some template params from class to function level in transform helper metafunctions.
...
[SVN r80160]
2012-08-23 19:57:34 +00:00
Adam Wulkiewicz
e625a0913b
Predefined r-tree creation algorithms parameters described.
...
[SVN r80151]
2012-08-23 01:04:00 +00:00
Adam Wulkiewicz
be4cb4d9a8
r-tree methods description expanded, default translator description added
...
[SVN r80150]
2012-08-23 00:51:24 +00:00
Adam Wulkiewicz
761a80e1a9
Description of predicates and distance_predicates added.
...
[SVN r80149]
2012-08-22 23:32:01 +00:00
Adam Wulkiewicz
0231d54d6d
r-tree reference return in moving assignment operator added, r-tree copying and moving tests implemented.
...
[SVN r80144]
2012-08-22 18:52:05 +00:00
Adam Wulkiewicz
58e9b22f9b
Implemented moving semantics in the r-tree.
...
[SVN r80142]
2012-08-22 14:59:29 +00:00
Bruno Lalande
2d0bcf4725
Aligned multi/simplify to latest change.
...
[SVN r80130]
2012-08-21 22:09:37 +00:00
Bruno Lalande
8a5ed60cc4
Made dispatch::simplify more self-contained.
...
[SVN r80128]
2012-08-21 21:39:19 +00:00
Barend Gehrels
c719e7477e
[geometry] Applied (slightly adapted) patch by Karsten Ahnert sent to me Jul 25, fixing disjoint for degenerate segments
...
[SVN r79757]
2012-07-26 16:16:43 +00:00
Barend Gehrels
bbb95e04b3
[geometry] rephrased solution to avoid signed/unsigned warning
...
[SVN r79671]
2012-07-22 13:31:26 +00:00
Barend Gehrels
7e6ea5baef
[geometry] Small tweak, avoid inner rings with e.g. two points only. Plus comment update / tab removal
...
[SVN r79669]
2012-07-22 13:05:29 +00:00
Barend Gehrels
f6f6dc7b73
[geometry] updates some flaws (w.r.t. headerfiles, comments) for buffer/offset
...
[SVN r79642]
2012-07-21 18:20:36 +00:00
Barend Gehrels
aa8b26c69f
[geometry] Get rid of auto which was (temporary) inserted during creating buffer operations
...
[SVN r79641]
2012-07-21 18:18:50 +00:00
Barend Gehrels
d316c1bf68
[geometry] merged into release (two fixes, doc change) since r79395
...
[SVN r79534]
2012-07-15 15:02:16 +00:00
Barend Gehrels
67d9f79bd3
[geometry] Bugfix for integer coordinates, causing intersection points at wrong locations (severe)
...
[SVN r79505]
2012-07-14 16:58:23 +00:00
Barend Gehrels
5ae467dbc7
[geometry] removed tabs in cart_intersect.hpp
...
[SVN r79504]
2012-07-14 16:53:22 +00:00
Barend Gehrels
a0572c75e7
[geometry] merged into release for 1.51 (breaking change w.r.t. custom point traits)
...
[SVN r79395]
2012-07-09 21:06:05 +00:00
Barend Gehrels
04a8bb8018
[geometry] Breaking change (for some situations). Changed custom-pointer-types w.r.t. typetraits. This is based on ideas on the mailing list, Bruno, Mats and me
...
[SVN r79368]
2012-07-08 20:15:06 +00:00
Barend Gehrels
ea99120ca1
[geometry] applied patch of Karsten Ahnert to fix cross-track error
...
[SVN r79207]
2012-07-01 15:44:11 +00:00
Adam Wulkiewicz
34be8fbad5
removed doubled algorithm index::overlap().
...
[SVN r79137]
2012-06-27 13:45:10 +00:00
Adam Wulkiewicz
f9b2279725
Added rtree predicate index::touches(). The code is commented out since the geometry::touches() algorithm is probably not finished yet. Fixed GCC compile errors in tests.
...
[SVN r79135]
2012-06-27 12:25:38 +00:00
Adam Wulkiewicz
a1d3066d9a
Fixed error in linear::find_greatest_normalized_separation.
...
Implemented rtree inserts and intersection queries tests for Points and pair<Box, int>.
[SVN r79122]
2012-06-26 19:42:30 +00:00
Adam Wulkiewicz
4d79f3dade
tabs changed to spaces in rstar/redistribute_elements.hpp
...
[SVN r79109]
2012-06-26 13:42:37 +00:00
Adam Wulkiewicz
c00ddbd2a8
some tests and optimizations.
...
[SVN r79107]
2012-06-26 11:49:56 +00:00
Adam Wulkiewicz
31c5e016e7
added tests of some index's algorithms + index::margin() optimization.
...
[SVN r79090]
2012-06-25 19:00:24 +00:00
Barend Gehrels
acf672695f
[geometry] merged revision 78724 thru 7880 w.r.t. bugfixes
...
[SVN r78852]
2012-06-07 18:43:44 +00:00
Bruno Lalande
60673ef3e5
Used not_implemented on 'overlaps' algorithm.
...
[SVN r78841]
2012-06-06 22:54:39 +00:00
Bruno Lalande
68d75892d1
Made dispatch::overlaps able to retrieve the tags by itself.
...
[SVN r78840]
2012-06-06 22:43:21 +00:00
Bruno Lalande
f3a50d889b
Applied not_implemented to expand algorithm.
...
[SVN r78824]
2012-06-05 21:21:41 +00:00
Bruno Lalande
55bd635431
Made dispatch::expand more self-contained.
...
[SVN r78822]
2012-06-05 21:08:53 +00:00
Bruno Lalande
26538787b2
Applied not_implemented to equals algorithm.
...
[SVN r78821]
2012-06-05 21:08:09 +00:00
Bruno Lalande
fe69c4fa3f
Adapted multi specializations of dispatch::equals to last changes.
...
[SVN r78819]
2012-06-05 19:42:07 +00:00
Bruno Lalande
be4a03b7c1
Made dispatch::equals self-reversible.
...
[SVN r78818]
2012-06-05 18:49:56 +00:00
Bruno Lalande
7978fc6c95
Made dispatch::equals more self-contained.
...
[SVN r78817]
2012-06-05 18:41:43 +00:00
Bruno Lalande
a45af28485
Integrated not_implemented into envelope.
...
[SVN r78814]
2012-06-05 16:57:22 +00:00
Bruno Lalande
9cd61fb3cd
Moved template params from class to function level in dispatch::envelope for those we don't actually dispatch on.
...
[SVN r78813]
2012-06-05 16:47:37 +00:00
Bruno Lalande
4da6143920
Made dispatch::disjoint more self-contained.
...
[SVN r78809]
2012-06-04 19:13:34 +00:00
Bruno Lalande
15e85e390d
Moved more template params from class to function level in intersection.
...
[SVN r78808]
2012-06-04 17:57:21 +00:00
Bruno Lalande
ff423e5a0b
Moved Strategy template param from class to function in intersection.
...
[SVN r78804]
2012-06-03 22:48:02 +00:00
Barend Gehrels
de83c413e8
[geometry] take output point type (overlay) / enable different point types (point on border)
...
[SVN r78797]
2012-06-01 21:49:28 +00:00
Barend Gehrels
b194a3000f
[geometry] fix of failing disjoint for polygon/box
...
[SVN r78795]
2012-06-01 21:43:56 +00:00
Barend Gehrels
547e49d388
[geometry] merge since today's r78712
...
[SVN r78717]
2012-05-28 13:04:24 +00:00
Barend Gehrels
3a88ece6d1
[geometry] added touches to general header
...
[SVN r78715]
2012-05-28 12:40:26 +00:00
Barend Gehrels
e6a41704f4
[geometry] now casted size the other side as well to account for possible non-merge of Boost.Range
...
[SVN r78713]
2012-05-28 11:40:46 +00:00
Barend Gehrels
e3c8eed009
[geometry] merged since r77001
...
[SVN r78712]
2012-05-28 11:29:18 +00:00
Barend Gehrels
92a0469037
[geometry] doc update for touches
...
[SVN r78706]
2012-05-28 10:02:17 +00:00
Barend Gehrels
a93168b1cf
[geometry] Avoid warning about missing case enums
...
[SVN r78695]
2012-05-27 20:12:54 +00:00
Barend Gehrels
fe1a477a2e
[geometry] Added gcc-needed include
...
[SVN r78694]
2012-05-27 20:07:33 +00:00
Barend Gehrels
32d2fc1351
[geometry] added touch
...
[SVN r78690]
2012-05-27 17:42:37 +00:00
Barend Gehrels
6d5938ec37
[geometry] fixed disjoint for multi-polygon/multi-polygon where (not-first) rings were inside each other
...
[SVN r78685]
2012-05-27 15:12:40 +00:00
Barend Gehrels
aabd778f6e
[geometry] pending commits for buffer
...
[SVN r78680]
2012-05-27 13:17:22 +00:00
Barend Gehrels
a6caeb51bf
[geometry] Fixes for point_on_border multi-version
...
[SVN r78673]
2012-05-27 11:22:15 +00:00
Barend Gehrels
04d370d86e
[geometry] recent work on buffers (march/april) - pending commit
...
[SVN r78656]
2012-05-26 20:58:56 +00:00
Barend Gehrels
c135b40632
[geometry] bugfix - qualify math - pending commit
...
[SVN r78655]
2012-05-26 20:55:05 +00:00
Barend Gehrels
527480d804
[geometry] bugfix for union (pending commit)
...
[SVN r78650]
2012-05-26 19:28:53 +00:00
Barend Gehrels
a2d238b717
Update w.r.t. Boost.Range size now unsigned - remove warnings
...
[SVN r78616]
2012-05-25 14:38:55 +00:00
Barend Gehrels
38f02d292d
Update w.r.t. Boost.Range size now unsigned
...
[SVN r78614]
2012-05-25 14:27:09 +00:00
Barend Gehrels
2aed65855f
[geometry] fix of several robustness issues in cart_intersect and get_turn_info found by testing buffer algorithm. Also restructured cart_intersect such that all robustness issues are handled in separate methods (could be policy later). Finally fixed ever circling iterator with range (for assignment)
...
[SVN r77988]
2012-04-15 11:44:15 +00:00
Adam Wulkiewicz
3de87192fa
size_t changed to Container::size_type in translator::index<Container>
...
[SVN r77982]
2012-04-15 01:46:20 +00:00
Barend Gehrels
d03d2e17a4
[geometry] robustness fixes (all found by buffer robustness tests)
...
[SVN r77351]
2012-03-16 16:58:26 +00:00
Barend Gehrels
481b42d976
[geometry] fix for robustness issue on touch with r > 1
...
[SVN r77337]
2012-03-14 18:57:46 +00:00
Barend Gehrels
bad5e628ac
[geometry] Finetuned robustness fixes of this weekend and fixed (again) for case #ggl_list_20110820_christophe
...
[SVN r77308]
2012-03-11 20:37:51 +00:00
Barend Gehrels
ed4e8fb438
[geometry] surpress gcc warning
...
[SVN r77306]
2012-03-11 18:14:24 +00:00
Barend Gehrels
601abf8798
[geometry] fixed robustness issue with non-consistent side-info in collinear case
...
[SVN r77304]
2012-03-11 17:46:23 +00:00
Barend Gehrels
0d699b7098
[geometry] buffer update (a.o. implemented multi), updated tests, and added robustness test
...
[SVN r77299]
2012-03-10 21:13:37 +00:00
Barend Gehrels
1c59a19106
[geometry] updates for clang/gcc
...
[SVN r77298]
2012-03-10 19:41:38 +00:00
Barend Gehrels
575098e9b6
[geometry] Fixed several robustness issues: non-valid polygons/rings are not added anymore;
...
collinear is now symmetric (it could happen that A was collinear w.r.t. B but not vice versa, that is now resolved);
vertical/horizontal (nearly collinear) segments are now checked later (this and previous bug were found by buffer-high-volume tests).
Added testcases (buffer_rt_f did cause problems with previous implementation, fixed now). Updated testcases (some cases are quite sensitive to implementation while output is still valid)
[SVN r77296]
2012-03-10 19:11:17 +00:00
Barend Gehrels
0c66579409
[geometry] fix in comparing doubles (comparing e.g. 0 with 4e-19)
...
[SVN r77284]
2012-03-09 13:31:44 +00:00
Adam Wulkiewicz
7352afd5d9
R-tree methods and functions documented.
...
rtree::nearest() template parameter name changed.
[SVN r77277]
2012-03-08 22:15:06 +00:00
Barend Gehrels
7f26c674df
[geometry] projections added (processed version of) new_projection submitted by Krzysztof Czainski, including example
...
[SVN r77232]
2012-03-05 14:45:09 +00:00
Barend Gehrels
ee169cb7d7
[geometry] projections, added Natural Earth projection
...
[SVN r77231]
2012-03-05 14:41:02 +00:00
Barend Gehrels
ef4d45ac9a
[geometry] buffer, extracted occupation info to separate file
...
[SVN r77227]
2012-03-05 14:07:53 +00:00
Barend Gehrels
74ba4d71c7
[geometry] fixed extensions project_transformer
...
[SVN r77213]
2012-03-04 12:35:50 +00:00
Barend Gehrels
31e27aa035
[geometry] update buffer for gcc compilation (does not accept sort/remove_if on struct defs in member functions)
...
[SVN r77211]
2012-03-04 12:09:34 +00:00
Barend Gehrels
39df5a1c4a
[geometry] updated buffer for clang compilation
...
[SVN r77210]
2012-03-04 12:02:03 +00:00
Barend Gehrels
e0ccd3bbc0
[geometry] breaking change, namespace projection is renamed projections to avoid clash with class projection. Suggested by Krzysztof Czainski
...
[SVN r77207]
2012-03-04 11:12:17 +00:00
Barend Gehrels
e5a483550f
[geometry] projections, updated copyright
...
[SVN r77204]
2012-03-04 10:42:09 +00:00
Barend Gehrels
6355ca279e
[geometry] Applied patch of Krzysztof Czainski to conditionally avoid using boost numeric cast.
...
Note: we will look for a more general approach later.
[SVN r77203]
2012-03-04 10:14:50 +00:00
Barend Gehrels
4156da7bbf
Boost.Geometry Projections now use Boost.Math constants
...
[SVN r77184]
2012-03-03 19:53:05 +00:00
Barend Gehrels
b9b6be97f9
Boost.Geometry Projection: applied patch (submitted by Krzysztof Czainski) to avoid static const constants
...
[SVN r77183]
2012-03-03 19:42:35 +00:00
Barend Gehrels
15d2c12330
Boost.Geometry - projections, generated again from proj4 (trunk)
...
[SVN r77179]
2012-03-03 18:26:01 +00:00
Barend Gehrels
a7361e2780
Boost.Geometry Projection: applied patch (submitted by Krzysztof Czainski) to avoid cosl, causing problems for some compilers
...
[SVN r77178]
2012-03-03 16:22:43 +00:00
Barend Gehrels
9ba627fa1b
Boost.Geometry Projections removed unused variable s
...
[SVN r77177]
2012-03-03 16:13:49 +00:00
Barend Gehrels
14699d2254
Boost.Geometry Buffer - removed duplicate approach for finding blocked turns
...
[SVN r77172]
2012-03-03 12:02:36 +00:00
Barend Gehrels
4b59798db3
Boost.Geometry buffer update
...
[SVN r77171]
2012-03-03 11:24:46 +00:00
Barend Gehrels
577f86d246
Boost.Geometry update in last fix (removes double assignment, handles follow-for warning gcc, comment-typos)
...
[SVN r77122]
2012-02-26 21:26:06 +00:00
Barend Gehrels
349864cec9
Boost.Geometry bugfix for disjoint of opposite-equal or or opposite-collinear segments
...
plus prepares extra parameters for buffer
[SVN r77121]
2012-02-26 20:00:05 +00:00
Barend Gehrels
13495b06fc
Boost.Geometry processed patch https://svn.boost.org/trac/boost/ticket/6166 for missing transformation
...
[SVN r77108]
2012-02-24 15:36:23 +00:00
Barend Gehrels
7372dfa3a4
Boost.Geometry applied patch from ticket https://svn.boost.org/trac/boost/ticket/6584 and fixed a related bug about the return type of strategies/projected_point which was integer for integer points (and should have been promoted to FP, fixed)
...
[SVN r77107]
2012-02-24 12:32:38 +00:00
Barend Gehrels
6322c9c33e
Boost.Geometry applied patch from ticket https://svn.boost.org/trac/boost/ticket/6585
...
[SVN r77103]
2012-02-24 10:25:24 +00:00
Barend Gehrels
0bda936005
Boost.Geometry buffer update (repairs linestring (partly))
...
[SVN r77075]
2012-02-19 21:16:07 +00:00
Barend Gehrels
a4e26f8d21
Boost.Geometry fixes for offset-extension w.r.t. new buffer approach (does not run yet but compiles)
...
[SVN r77063]
2012-02-18 11:04:19 +00:00
Barend Gehrels
dffa159cd5
Boost.Geometry Substantial progress on buffer
...
[SVN r77061]
2012-02-18 10:07:18 +00:00
Barend Gehrels
c8bc3cc1e1
Boost.Geometry merge doc updates
...
[SVN r77001]
2012-02-12 18:01:22 +00:00
Barend Gehrels
388feb89ae
Boost.Geometry doc updates and fixes
...
[SVN r76997]
2012-02-12 17:07:37 +00:00
Barend Gehrels
af40216f1d
Boost.Geometry merged fixes/doc updates to release branch
...
[SVN r76991]
2012-02-12 13:04:01 +00:00
Barend Gehrels
b3d5729e4d
Boost.Geometry line/poly overlay (new for 1.49), bugfix (avoid degenerate lines with only one point, and sub-sort on operation in case of duplicate intersection points). Including unit test update.
...
Note, this also fixes two earlier unit tests with degenerate outputs.
[SVN r76978]
2012-02-11 17:10:17 +00:00
Barend Gehrels
b86fa4fe8a
Boost.Geometry fix, point_in_ring should get strategy, and included covered_by for multi (belongs to last fix)
...
[SVN r76977]
2012-02-11 14:52:43 +00:00
Barend Gehrels
e35a3b1610
Boost.Geometry line/poly overlay (new for 1.49), bugfix (take point-in-between instead of first point)
...
[SVN r76975]
2012-02-11 14:24:42 +00:00
Barend Gehrels
43d6bfc722
Boost.Geometry fix - multi_centroid should have same throwing behaviour as centroid
...
[SVN r76964]
2012-02-10 20:44:25 +00:00
Barend Gehrels
604bb60f17
Boost.Geometry doc updates
...
[SVN r76963]
2012-02-10 19:52:53 +00:00
Barend Gehrels
6ee3d1bf15
Added non-included algorithm header files (Boost.Geometry ML 2012-02-08)
...
[SVN r76949]
2012-02-08 19:20:45 +00:00
Barend Gehrels
178b23f538
Belongs to last commit, second call to throw (not warned by by MSVC...)
...
[SVN r76917]
2012-02-06 20:53:34 +00:00
Barend Gehrels
56a8ecb01b
Commented throw_on_empty_input for area, length, perimeter (but not for distance), see comments in throw_on_empty_input.hpp
...
[SVN r76916]
2012-02-06 20:50:12 +00:00
Barend Gehrels
c018c393f4
Manually reversed move of cross_product.hpp from extensions and renamal of stream_wkt to iomanip (because it is in /wkt/ we now call it stream.hpp)
...
[SVN r76912]
2012-02-06 18:41:46 +00:00
Barend Gehrels
b9d85b89d5
Merged geometry fixes since 2011-01-15
...
[SVN r76904]
2012-02-05 18:47:13 +00:00
Barend Gehrels
e5f2fd419b
Fixed ticket #6019 , when multiple points were on the left, the points below the point taken were popped out by the algorithm, because they were sorted from top to bottom. We therefore take the lower-left point such that there are no points below. This problem was not present at the right side but we now take there the upper right point.
...
[SVN r76899]
2012-02-05 16:19:23 +00:00
Barend Gehrels
42895fbf4c
Removed redundant test (also before #6019 , fix will be committed later today)
...
[SVN r76898]
2012-02-05 14:29:34 +00:00
Barend Gehrels
ab570e43d9
Removing old if-defined stuff before the fix of ticket #6019
...
[SVN r76897]
2012-02-05 14:27:36 +00:00
Barend Gehrels
e240595fc0
Fixed missing include for multi/append
...
[SVN r76896]
2012-02-05 11:32:56 +00:00
Barend Gehrels
cd84ffd149
cross_product.hpp which is now splitted into cross_product (the real) and determinant
...
[SVN r76895]
2012-02-05 11:18:51 +00:00
Barend Gehrels
59cc514794
Compile fix, geometry namespace should be there for side (in some scenarios).
...
Numeric fix, centroid should use !equals and not !=
[SVN r76886]
2012-02-04 17:40:32 +00:00
Barend Gehrels
861ae36157
We stick to the way more common term determinant for 2d side/area/centroid calculations.
...
It is in detail - we might use LA or another library in the future
[SVN r76884]
2012-02-04 17:16:49 +00:00
Barend Gehrels
7e34299ced
Fixed distance of large integers
...
[SVN r76881]
2012-02-04 15:14:33 +00:00
Bruno Lalande
e707b7660f
Made the multi version of dispatch::convert inherit from its underlying implementation.
...
[SVN r76872]
2012-02-04 10:35:35 +00:00
Barend Gehrels
26100514b9
Fixed disjoint case directed to "error" (which as later on directed to disjoint again, why it was never noticed, but that is changed now)
...
[SVN r76863]
2012-02-03 23:33:28 +00:00
Barend Gehrels
89de77ff7e
Added virtual d'tor with throw spec which was not checked by MSVC
...
[SVN r76861]
2012-02-03 22:11:58 +00:00
Barend Gehrels
1cd17cbe45
Fixed wrong behaviour for intersects/disjoint algorithms for pair of linestrings which were degenerate, or collinear, or one starting in the middle from the other.
...
Also removed the never-used parallel option.
Throws an error at unexpected input (robustness errors)
[SVN r76859]
2012-02-03 21:14:13 +00:00
Barend Gehrels
f20bfd7b83
Bugfix, fixes including wkt/iomanip.hpp which should not be done. It might cause an assertion to fail on any non-streamable type
...
[SVN r76856]
2012-02-03 18:21:05 +00:00
Barend Gehrels
18ef2e7e03
Fixed greater<...> w.r.t. type (same as less<...> last week, this one was forgotten)
...
[SVN r76854]
2012-02-03 15:21:48 +00:00
Barend Gehrels
cd86a8a31b
Now correctly select starting/end point and middle-point-of-round
...
[SVN r76780]
2012-01-29 21:26:20 +00:00
Barend Gehrels
1f5e4c45e4
Buffer, added intersection check on already splitted of rings. This is necessary for cases like #indentation7 where the new helper-line crosses an already moved other helperline.
...
[SVN r76776]
2012-01-29 14:31:23 +00:00
Barend Gehrels
a4e0d5c384
Belongs to last commit, two tidy ups more
...
[SVN r76772]
2012-01-29 11:02:13 +00:00
Barend Gehrels
ddfed476c1
Check on positive area of split off rings, further moved/renamed things and prepared for next phase
...
[SVN r76771]
2012-01-29 10:58:35 +00:00
Barend Gehrels
01a2346472
Small fix for svg-debugging
...
[SVN r76769]
2012-01-28 23:13:53 +00:00
Barend Gehrels
a4bb2f9de1
Harmonized offset with buffer, using range_buffer, and making hooklets vary on parameter.
...
This repairs offset (broken few days)
[SVN r76767]
2012-01-28 21:13:39 +00:00
Barend Gehrels
4594a65da4
Introduced cross-product for area,centroid,side,intersection(determinant,direction,relation)
...
[SVN r76755]
2012-01-28 18:29:47 +00:00
Barend Gehrels
10b649c234
Moved cross product from extensions
...
[SVN r76751]
2012-01-28 15:43:19 +00:00
Barend Gehrels
3a655b7080
Fixed subtle bug causing polygons with large integers to be reversed because of the wrongly typed predicate
...
[SVN r76741]
2012-01-28 14:39:47 +00:00
Barend Gehrels
2360d2443b
Temporarily fixed offset
...
[SVN r76737]
2012-01-28 12:21:45 +00:00
Barend Gehrels
f7604ade9a
Removed two obsolete headerfiles
...
[SVN r76734]
2012-01-28 12:01:57 +00:00
Barend Gehrels
0dad0809af
Moved check on input size such that they are together
...
[SVN r76733]
2012-01-28 12:01:11 +00:00
Barend Gehrels
3ab79561b5
Update for non MSVC
...
[SVN r76731]
2012-01-28 11:11:45 +00:00
Barend Gehrels
70db31de02
Buffer update - this solves indentation-case up to 0.6 and tests it
...
[SVN r76730]
2012-01-28 10:58:33 +00:00
Barend Gehrels
c4427fd248
Fixed covered_by for multi
...
[SVN r76728]
2012-01-27 22:55:27 +00:00
Barend Gehrels
7b18dd20f4
Update in extensions: buffer. Reworked appender, now correctly buffers all saw/bowls (but not yet indentations and many others)
...
[SVN r76717]
2012-01-27 17:02:59 +00:00
Barend Gehrels
9af7694911
Milestone, buffer is basically working now. That's to say, convex polygons, or some concavities are buffered correctly. Still to do:
...
- concavities in starting point
- intersections beyond hooklets
- concavities-only (as in triangular holes)
- internal overlaps (with dissolve)
[SVN r76710]
2012-01-26 20:54:17 +00:00
Bruno Lalande
b18b27dea4
Integrated 'within' algorithm into support_status.
...
[SVN r76695]
2012-01-25 23:11:12 +00:00
Bruno Lalande
d7f1136044
Moved Strategy template param from class level to function level in dispatch::within.
...
[SVN r76694]
2012-01-25 23:01:50 +00:00
Bruno Lalande
2700a5a1ba
Made dispatch::within able to retrieve the tags by itself.
...
[SVN r76693]
2012-01-25 22:54:01 +00:00
Barend Gehrels
20eca8b2fa
Buffer update, merged impl's of polygon/linestring into range_buffer, and some more tidy up
...
[SVN r76676]
2012-01-24 23:04:30 +00:00
Bruno Lalande
6c256b142e
Integrated covered_by into support_status.
...
[SVN r76674]
2012-01-24 21:36:40 +00:00
Bruno Lalande
fc59cdf857
Moved Strategy template parameter from class level to function level in dispatch::covered_by.
...
[SVN r76672]
2012-01-24 21:15:48 +00:00
Bruno Lalande
bb01b619e1
Made dispatch::covered_by able to retrieve the tags by itself.
...
[SVN r76671]
2012-01-24 21:05:31 +00:00
Bruno Lalande
ba013bdef2
Integrated 'correct' algorithm into support_status.
...
[SVN r76670]
2012-01-24 21:02:01 +00:00
Bruno Lalande
e97af061f5
Made dispatch::correct able to retrieve the tag by itself.
...
[SVN r76669]
2012-01-24 20:15:05 +00:00
Barend Gehrels
e6678840c4
Updated buffer, harmonized impl's for polygon/linestring for easier merge in next step
...
[SVN r76638]
2012-01-22 18:58:08 +00:00
Barend Gehrels
80191e68ac
[Geometry] Fixed unused parameters warnings in 15 files
...
[SVN r76586]
2012-01-19 16:17:50 +00:00
Barend Gehrels
a41aea7187
Applied (modified) patch of Christophe to avoid gcc warnings on unused parameters
...
[SVN r76585]
2012-01-19 09:56:47 +00:00
Barend Gehrels
df8bf1fd78
Small update for buffer (essentially removed the define which caused an incorrect bufferline)
...
[SVN r76548]
2012-01-16 22:13:22 +00:00
Barend Gehrels
4ef66d61e8
[Geometry - merged up to r76521]
...
[SVN r76525]
2012-01-15 16:38:26 +00:00
Barend Gehrels
19b5092f3c
[Geometry - removed util]
...
[SVN r76524]
2012-01-15 16:33:30 +00:00
Barend Gehrels
2c176018e3
[Geometry] Merge / dsv only
...
[SVN r76523]
2012-01-15 16:26:56 +00:00
Barend Gehrels
7ceb964879
Added necessary num_points header to functions which might throw
...
[SVN r76518]
2012-01-15 14:04:38 +00:00
Barend Gehrels
05ab4d557a
Added empty_input_exception and applied for distance, length, area, perimeter
...
Removed exception for convex_hull because that can be handled (for now) by leaving output empty. To be decided what is the definitive (additional, optional) behaviour.
[SVN r76514]
2012-01-15 13:23:08 +00:00
Barend Gehrels
5a8e6dcf8a
Fix for non-msvc
...
[SVN r76501]
2012-01-14 22:59:53 +00:00
Barend Gehrels
d022e45558
Added implementation for boxes
...
[SVN r76499]
2012-01-14 22:25:53 +00:00
Barend Gehrels
440a1c2cf3
Fixed missing header file, and added append for multi_point
...
[SVN r76493]
2012-01-14 17:19:51 +00:00
Barend Gehrels
72518c78f7
Fixed convex_hull for empty geometries by throwing exception
...
[SVN r76488]
2012-01-14 14:44:21 +00:00
Barend Gehrels
a80a3b4512
Moved dsv/multi, and fixed used settings and missing separator between single occurances
...
[SVN r76484]
2012-01-14 12:09:03 +00:00
Barend Gehrels
0cc8628084
Added two include files for multi in the general multi header. Added dsv to prepare for move
...
[SVN r76483]
2012-01-14 10:48:01 +00:00
Barend Gehrels
a3d25b5361
Ignore variables as suggested on the list by Vishnu, to avoid clang warnings (part two)
...
[SVN r76478]
2012-01-14 00:04:19 +00:00
Barend Gehrels
3de7d51235
Ignore variables as suggested on the list by Vishnu, to avoid clang warnings
...
[SVN r76477]
2012-01-13 23:59:50 +00:00
Barend Gehrels
cb192192cc
Bugfix, in get_turns segments in the same source should only be skipped if iterated linearly. If coming from a partition, it might be different. By default don't skipped them.
...
[SVN r76469]
2012-01-13 20:50:43 +00:00
Barend Gehrels
5597f59a84
Cosmetic changes (<= 80 char's / line) only
...
[SVN r76467]
2012-01-13 20:46:37 +00:00
Barend Gehrels
2c816039b9
Fixes in extension buffer
...
[SVN r76460]
2012-01-13 17:19:55 +00:00
Barend Gehrels
aea119f33c
Fixes w.r.t. self_intersection_points
...
[SVN r76436]
2012-01-12 18:59:08 +00:00
Bruno Lalande
bc888acf58
Moved OutputGeometry in dispatch::convex_hull from class level to function level. Renamed some template parameters to better reflect their roles.
...
[SVN r76417]
2012-01-11 22:35:02 +00:00
Bruno Lalande
2542febb0c
Made dispatch::convex_hull more self-contained.
...
[SVN r76400]
2012-01-10 23:15:59 +00:00
Bruno Lalande
0f1163e4a8
Removed unused tags from convex_hull dispatchers.
...
[SVN r76393]
2012-01-09 22:53:17 +00:00
Bruno Lalande
be61bc66e7
Made dispatch::clear able to retrieve the tag by itself.
...
[SVN r76391]
2012-01-09 22:31:33 +00:00
Barend Gehrels
7cb0ae96fd
Boost.Geometry update copyright -> 2012
...
[SVN r76390]
2012-01-09 21:56:08 +00:00
Barend Gehrels
47f78e4e05
Merge for Boost.Geometry
...
[SVN r76363]
2012-01-08 10:49:28 +00:00
Barend Gehrels
385719bc3c
Updated copyright year in 2 files
...
[SVN r76360]
2012-01-08 10:33:39 +00:00
Barend Gehrels
745744df37
Merge - after merge edits for Geometry
...
[SVN r76354]
2012-01-08 00:33:36 +00:00
Bruno Lalande
a487537a04
Made inheritence from multi_to_multi to single_to_multi private.
...
[SVN r76348]
2012-01-07 22:58:00 +00:00
Bruno Lalande
124d7041e6
Made distance dispatch classes for multi actually inherit from their underlying implementation to ensure not_implemented works.
...
[SVN r76347]
2012-01-07 22:50:40 +00:00
Barend Gehrels
66affa3646
Merged - added missing io/io.hpp
...
[SVN r76344]
2012-01-07 18:05:53 +00:00
Barend Gehrels
145efff553
Merged - added missing io/dsv/write.hpp file
...
[SVN r76343]
2012-01-07 18:02:59 +00:00
Barend Gehrels
121d5c11c3
Merged Geometry headerfiles
...
[SVN r76342]
2012-01-07 17:58:37 +00:00
Barend Gehrels
2baaa1df1f
Added new io folder to release branch
...
[SVN r76340]
2012-01-07 17:32:00 +00:00
Bruno Lalande
2a0816ae25
Fixed a regression in dispatch::distance on the strategy reversal.
...
[SVN r76217]
2011-12-28 23:55:33 +00:00
Bruno Lalande
7668a8745b
Made dispatch::area able to retrieve the default strategy by itself.
...
[SVN r76210]
2011-12-28 13:29:15 +00:00
Bruno Lalande
5a760c7355
Made dispatch::area able to retrieve the geometry tag by itself.
...
[SVN r76206]
2011-12-28 10:30:03 +00:00
Mateusz Loskot
88b87f23a5
[geometry] Fix typos. Refs #6003 .
...
[SVN r76151]
2011-12-25 17:33:34 +00:00
Barend Gehrels
690de46880
Fixed M$ compiler bug (well, that's what I think of it now)
...
[SVN r76085]
2011-12-20 22:19:39 +00:00
Bruno Lalande
1bdac6a166
Simplified not_implemented.
...
[SVN r76072]
2011-12-19 23:00:32 +00:00
Bruno Lalande
478f6bd60d
Made dispatch::append able to find the range tag by itself.
...
[SVN r76053]
2011-12-18 23:22:35 +00:00
Barend Gehrels
30b6ba4395
Curly brace convention update only
...
[SVN r76012]
2011-12-17 11:19:12 +00:00
Bruno Lalande
e29d99311f
Moved slightly misplaced specialization...
...
[SVN r76004]
2011-12-16 23:20:35 +00:00
Bruno Lalande
9ff892b616
Had dispatch::distance take care of the default strategy retrieval/inversion.
...
[SVN r76003]
2011-12-16 23:16:22 +00:00
Bruno Lalande
25e7109a2f
Made dispatch::distance able to get the strategy tag by itself.
...
[SVN r76001]
2011-12-16 22:04:56 +00:00
Bruno Lalande
16ef03980f
Changed the multi versions of dispatch::distance according to changes made in r75975.
...
[SVN r75996]
2011-12-16 17:06:44 +00:00
Mateusz Loskot
afcef6e56f
Boost.Geometry:
...
* Introducing new layout of IO formats in geometry/io/<FORMAT>/ with unified set of public headers: <FORMAT>.hpp, read.hpp, write.hpp and iomanip.hpp
* Moved OGC Well-Known-Text (WKT) format from geometry/extensions/gis/io/wkt to geometry/io
* Renamed stream_wkt.hpp to iomanip.hpp to reflect what it defines: manipulators for streams.
* Removed deprecated headers and updated other headers to use the new locations.
[SVN r75977]
2011-12-16 01:28:37 +00:00
Bruno Lalande
418bdc52d2
Made dispatch::distance able to reverse itself. This is no longer driven by the caller.
...
[SVN r75975]
2011-12-15 23:26:22 +00:00
Bruno Lalande
f6eb4968eb
dispatch::distance now gets the geometry tags by itself.
...
[SVN r75972]
2011-12-15 22:13:26 +00:00
Bruno Lalande
d7e613f8b7
Reduced dispatch::convert required parameters to their bare minimum.
...
[SVN r75948]
2011-12-14 23:29:35 +00:00
Bruno Lalande
cdaba1bebb
Improved not_implemented.
...
[SVN r75935]
2011-12-13 23:24:52 +00:00
Bruno Lalande
1fa8099345
Defaulted another template parameter of dispatch::convert.
...
[SVN r75833]
2011-12-07 00:04:53 +00:00
Bruno Lalande
4b0afc334f
Reflected last change on dispatch::convert in multi/convert.hpp.
...
[SVN r75823]
2011-12-06 13:46:42 +00:00
Bruno Lalande
881a1020b1
Made dispatch::convert more self-contained by having its primary definition find the dimension by itself.
...
[SVN r75817]
2011-12-05 23:12:07 +00:00
Bruno Lalande
73642eb0f1
Applied not_implemented to 'convert' algorithm. Added it to support_status.
...
[SVN r75816]
2011-12-05 23:00:42 +00:00
Bruno Lalande
812aa1e7b2
Moved the static assertion to not_implemented.
...
[SVN r75797]
2011-12-04 02:28:07 +00:00
Bruno Lalande
8e4e6a2fc2
New mechanism for easy checking of implementation status.
...
[SVN r75796]
2011-12-04 02:00:25 +00:00
Barend Gehrels
cd7371b664
Added segment-to-segment conversion, therefore box_to_box is now indexed_to_indexed.
...
This also fixes last weeks accidental (but still working...) reversal of index/dimension
[SVN r75782]
2011-12-03 10:25:48 +00:00
Adam Wulkiewicz
dc4a922a0f
Reference to temporary - error fixed.
...
[SVN r75771]
2011-12-02 14:16:43 +00:00
Barend Gehrels
5801bd31af
Linestring/polygon overlay, phase 9 (difference for multi)
...
[SVN r75688]
2011-11-27 12:05:49 +00:00
Barend Gehrels
2eadb6247a
Added box-to-box conversion
...
[SVN r75686]
2011-11-27 11:06:47 +00:00
Barend Gehrels
838d092eb7
Fix for gcc - assert does not work here or like this
...
[SVN r75685]
2011-11-27 10:46:11 +00:00
Barend Gehrels
a7b42a758b
Linestring/polygon overlay, fix for gcc (and probably more): extracted subclass
...
[SVN r75684]
2011-11-27 10:44:22 +00:00
Barend Gehrels
c9418d4fe4
Linestring/polygon overlay, phase 8 (difference)
...
[SVN r75682]
2011-11-27 10:23:05 +00:00
Barend Gehrels
81c7e515ba
Linestring/polygon overlay, phase 7 (collinear/equal)
...
[SVN r75670]
2011-11-26 17:30:16 +00:00
Barend Gehrels
2702c80ff4
Typo in comment
...
[SVN r75650]
2011-11-24 22:48:13 +00:00
Barend Gehrels
3f6a81d61b
Linestring/polygon overlay, phase 6 (ring, counter clockwise)
...
[SVN r75574]
2011-11-20 14:53:36 +00:00
Barend Gehrels
7a4ee056bf
Linestring/polygon overlay, phase 4 (multi_linestring/multi_polygon, and multi_linestring/polygon)
...
[SVN r75570]
2011-11-20 13:03:07 +00:00
Barend Gehrels
8a5ffa7a66
Linestring/polygon overlay, phase 4 (linestring/multi_polygon, which effectively uses the same implementation)
...
[SVN r75568]
2011-11-20 12:33:55 +00:00
Barend Gehrels
95c5d6f945
Linestring/polygon overlay, third phase (including segments along polygon's border)
...
[SVN r75564]
2011-11-20 11:50:06 +00:00
Barend Gehrels
ae52ce120a
Linestring/polygon overlay, second phase (including touching intersection points)
...
[SVN r75555]
2011-11-19 16:37:55 +00:00
Barend Gehrels
a000d93d8f
Linestring/polygon overlay, first phase
...
[SVN r75551]
2011-11-19 13:40:44 +00:00
Adam Wulkiewicz
6b85fedf0e
some comments added.
...
[SVN r75325]
2011-11-05 20:39:59 +00:00
Adam Wulkiewicz
65b31372a4
split result OutIter replaced by reference to the container.
...
[SVN r75316]
2011-11-04 14:57:11 +00:00
Adam Wulkiewicz
d349714143
split modify only one node and assigns newly created to output iterator. pushable_array works with back_inserter.
...
[SVN r75314]
2011-11-04 13:54:27 +00:00
Barend Gehrels
a3648f0e1c
Fixed dissolve issue by using own policy
...
[SVN r75296]
2011-11-04 10:22:38 +00:00
Adam Wulkiewicz
f9a7e41017
cR-tree kmeans options and files added (not yet implemented)
...
[SVN r75238]
2011-11-01 20:30:06 +00:00
Adam Wulkiewicz
8dbee3a8f6
rtree is no longer noncopyable
...
[SVN r75193]
2011-10-31 15:06:21 +00:00
Barend Gehrels
76fa593076
Fixed order-problem by avoiding argument reversion. See correspondence on GGL mailing list 2011/10/25
...
[SVN r75115]
2011-10-25 19:33:22 +00:00
Mateusz Loskot
b46bc26858
[geometry] Restructured WKT io files to follow structure of: geometry/domains/<DOMAIN>/io/<FORMAT>/<read|write>.hpp
...
[SVN r75076]
2011-10-20 23:20:05 +00:00
Mateusz Loskot
aa55176325
[geometry] Updated include guards to reflect current file path
...
[SVN r75075]
2011-10-20 22:34:10 +00:00
Mateusz Loskot
90ce0fa3d1
[geometry] Moved util/write_dsv.hpp to io/dsv/write.hpp. This introduces refinement of new io structure: geometry/io/<FORMAT>/<read|write>.hpp
...
[SVN r75073]
2011-10-20 21:12:52 +00:00
Barend Gehrels
a7d945dad2
Merged up to and including change 74761
...
[SVN r74858]
2011-10-09 18:30:04 +00:00
Barend Gehrels
104f5de462
Fix ticket 5954, use strategy directly, not the comparable strategy (unless fixed otherwise)
...
[SVN r74761]
2011-10-06 17:06:30 +00:00
Adam Wulkiewicz
ac8acebab6
Allocator default constructor as default rtree parameter fixed.
...
[SVN r74678]
2011-10-03 20:59:44 +00:00
Adam Wulkiewicz
456b9fd283
Allocators used in nodes children containers creation.
...
[SVN r74675]
2011-10-03 20:30:53 +00:00
Adam Wulkiewicz
9d61bed3e2
exceptions handled
...
[SVN r74664]
2011-10-03 09:24:17 +00:00
Adam Wulkiewicz
3f3f991f10
basic use of allocators implemented.
...
[SVN r74662]
2011-10-03 00:07:32 +00:00
Adam Wulkiewicz
a1e7923de2
prepared to use allocators, memory leak in remove visitor fixed, tests added
...
[SVN r74661]
2011-10-02 23:32:22 +00:00
Adam Wulkiewicz
a292370c67
boost::variant based nodes with static-size elements containers added
...
[SVN r74647]
2011-10-02 12:42:59 +00:00
Adam Wulkiewicz
a495ec75fd
destroy visitor moddified, some asserts added.
...
[SVN r74646]
2011-10-02 10:49:54 +00:00
Adam Wulkiewicz
f16cfaf4a3
some comments added
...
[SVN r74621]
2011-10-01 10:03:38 +00:00
Adam Wulkiewicz
164f39cf18
added bgi::insert_iterator<> and bgi::inserter() + tests.
...
[SVN r74620]
2011-09-30 22:48:01 +00:00
Adam Wulkiewicz
84b1230d6d
added rtree's constructor, insert, remove methods and free functions working for ranges specified by a pair of iterators.
...
[SVN r74619]
2011-09-30 21:39:13 +00:00
Adam Wulkiewicz
4bc1bc3eb7
copy constructor implemented + tests updated, rtree::get_translator() changed to rtree::translator() + other files updated to respect this
...
[SVN r74618]
2011-09-30 13:12:44 +00:00
Adam Wulkiewicz
f163bd877a
rtree's clear(), box() + tests added.
...
[SVN r74616]
2011-09-30 10:03:46 +00:00
Adam Wulkiewicz
66c2cf2605
nearest query optimized by rejecting distant nodes before adding them to the active branches list.
...
[SVN r74610]
2011-09-29 13:38:03 +00:00
Adam Wulkiewicz
48176c64e6
k-nearest query optimized by use of heap instead of sorting.
...
[SVN r74608]
2011-09-29 11:48:13 +00:00
Adam Wulkiewicz
e6633533d6
operator!() predicates generators implemented.
...
[SVN r74606]
2011-09-29 00:03:45 +00:00
Adam Wulkiewicz
c6c1fee74b
additional predicates implemented.
...
[SVN r74604]
2011-09-28 23:29:50 +00:00
Mateusz Loskot
69b1a2f8f8
[geometry] Added FIXME comment related to ticket #5954
...
[SVN r74600]
2011-09-28 17:05:35 +00:00
Adam Wulkiewicz
68fc281a60
Value predicates added. Error in boost::tuple predicates check fixed.
...
[SVN r74596]
2011-09-28 11:04:17 +00:00
Adam Wulkiewicz
cfc5335ccc
templates and functions parameters changed in filters and rtree's functions to suit new distances predicates.
...
[SVN r74594]
2011-09-27 19:43:13 +00:00
Adam Wulkiewicz
e42f8b61c5
Distances predicates version 2 implemented. Now the user may use different predicates for knn point, min and max distances.
...
[SVN r74593]
2011-09-27 19:31:01 +00:00
Adam Wulkiewicz
2ee9adef72
knn query distance predicates (first version) implemented
...
[SVN r74558]
2011-09-25 09:54:42 +00:00
Adam Wulkiewicz
3d7ac58ba5
some names changed, distance predicates implemented, specialization for nodes implemented partially - not finished
...
[SVN r74536]
2011-09-23 16:02:13 +00:00
Adam Wulkiewicz
5989892e82
comparable distance calculating algorithms names changed
...
[SVN r74528]
2011-09-22 23:16:20 +00:00
Adam Wulkiewicz
d2ec53ab4e
some names changed, namespace error fixed
...
[SVN r74524]
2011-09-22 21:51:21 +00:00
Adam Wulkiewicz
528d112c9c
fixed: memory leak in rtree destructor
...
[SVN r74520]
2011-09-22 18:30:17 +00:00
Adam Wulkiewicz
9de013a3a1
knn distance calculators added + naming errors fixed
...
[SVN r74519]
2011-09-22 18:21:22 +00:00
Adam Wulkiewicz
99b3f7b60a
some todo comments added, names changed
...
[SVN r74510]
2011-09-22 11:34:02 +00:00
Adam Wulkiewicz
dca40d8822
distance calculators that will be used in knn implemented, some names changed to more general in knn results wrappers.
...
[SVN r74497]
2011-09-21 18:50:15 +00:00
Adam Wulkiewicz
d0604349d5
random rtree insert/query/nearest tests implemented
...
[SVN r74460]
2011-09-18 21:19:20 +00:00
Adam Wulkiewicz
6c0cfd7d10
error fixed in rtree's overlaps predicate check specialization for node
...
[SVN r74447]
2011-09-18 10:42:46 +00:00
Adam Wulkiewicz
4ea2a9d915
namespace names error fixed
...
[SVN r74439]
2011-09-17 19:47:01 +00:00
Adam Wulkiewicz
f40db8b264
maxdist algorithm added
...
[SVN r74438]
2011-09-17 18:41:36 +00:00
Adam Wulkiewicz
f84c5bff81
nearest_filter implemented, spatial_filter changed to query_filter.
...
[SVN r74435]
2011-09-17 10:45:08 +00:00
Adam Wulkiewicz
8c7aec4b3e
k nearest neighbors search implemented, empty predicate added, pop_back() added to pushable_array, glFlush() and glClear() calls removed from gl_draw(), number of found objects added to spatial query, find visitor and corresponding rtree's method removed.
...
[SVN r74422]
2011-09-16 19:44:04 +00:00
Barend Gehrels
38321e2bb9
coordinate_cast of rational, bugfix and implemented parsing strings like 3/2 (how it is streamed)
...
[SVN r74375]
2011-09-14 20:28:04 +00:00
Barend Gehrels
ff0031dca7
Ticket #5747 Removed (commented) unused variables
...
[SVN r74202]
2011-09-03 12:52:18 +00:00
Barend Gehrels
25a26d48c1
Bugfix (robustness issue) based on ticket ggl-list by Christophe, dated Aug 20, 2011
...
Phase 1, it still has to be reworked
[SVN r74170]
2011-08-30 21:16:50 +00:00
Barend Gehrels
9dc22e4a06
Added support for point-output
...
[SVN r74163]
2011-08-30 15:56:05 +00:00
Barend Gehrels
5a9fcef9c6
Applied patch Mario Lang, using rational_cast instead
...
[SVN r74150]
2011-08-30 11:30:01 +00:00
Barend Gehrels
71a45e1544
Added basic support for Boost.Rational
...
[SVN r74147]
2011-08-30 10:46:34 +00:00
Barend Gehrels
ba6f3e64b0
Removed using double for highest/lowest as it is not appropriate for e.g. rational
...
[SVN r74146]
2011-08-30 10:00:22 +00:00
Adam Wulkiewicz
ea822b7aea
predicates implemented, query() method added to the rtree + some cleanup.
...
[SVN r74082]
2011-08-27 00:05:54 +00:00
Barend Gehrels
635bfd7773
Fixed error in fusion support
...
[SVN r73784]
2011-08-15 17:33:36 +00:00
Barend Gehrels
ad1a3072ff
Small changes to enable Boost.Rational (part 1)
...
[SVN r73602]
2011-08-07 18:30:52 +00:00
Barend Gehrels
fa5087e44a
Fixed performance issue on self intersections
...
[SVN r73599]
2011-08-07 16:46:33 +00:00
Barend Gehrels
6fda236075
Reorganized backtracking in a separate strategy, different for normal overlay and dissolve. Checking on self-intersections is now done in that strategy (for overlay). It is not part of the normal path anymore. This can increase the speed drastically, in some cases.
...
[SVN r73546]
2011-08-05 13:14:22 +00:00
Barend Gehrels
a23fd5e7b1
Added a utility to skip the check on self intersections in overlays, if you know the input is valid.
...
(BOOST_GEOMETRY_OVERLAY_SKIP_CHECK_SELF_INTERSECTIONS)
[SVN r73429]
2011-07-29 10:32:56 +00:00
Barend Gehrels
38188d36b4
Fixed bug reported by Akira T on [Boost-users] at 27-7-2011 3:17
...
[SVN r73414]
2011-07-28 20:57:46 +00:00
Adam Wulkiewicz
f9aafbf5aa
previous change reverted - intersects used instead of overlaps
...
[SVN r73392]
2011-07-26 20:58:13 +00:00
Adam Wulkiewicz
d5029f92d2
intersects replaced by overlaps in find visitor
...
[SVN r73391]
2011-07-26 20:53:40 +00:00
Adam Wulkiewicz
b65c697cad
within and distance_sqr removed from index/algorithms. geometry::covered_by used in remove visitor.
...
[SVN r73370]
2011-07-26 02:21:17 +00:00
Barend Gehrels
778c3b878e
Fixed convert for two array-types (which cannot be copied in non-MSVC)
...
[SVN r73327]
2011-07-24 10:25:53 +00:00
Barend Gehrels
6d5456b0d6
Fix in assert for gcc (probably gcc-bug, gcc 4.4.5 on Linux, it considers a const expr. in a macro as non-const)
...
[SVN r73326]
2011-07-24 09:56:05 +00:00
Barend Gehrels
72731b5750
Added assign_indexed_point.hpp forgotten in previous commit
...
[SVN r73325]
2011-07-24 09:45:10 +00:00
Barend Gehrels
086fee9c73
Added assign_box_corners.hpp in previous commit
...
[SVN r73324]
2011-07-24 09:43:57 +00:00
Barend Gehrels
382b4a0f1c
Supported convert (and therefore also assign) for many (the most useful) other combinations now (e.g. polygon/polygon with different point-types)
...
[SVN r73321]
2011-07-24 09:39:47 +00:00
Barend Gehrels
1bbd1aa73d
Enhancement: intersection/union/difference create a unique output set now, by checking just before appending each point
...
[SVN r73318]
2011-07-24 08:49:13 +00:00
Barend Gehrels
f956f587ae
Fixed type (for conversion/warning), minor change in sectionalize (equals instead of diff/0)
...
[SVN r73316]
2011-07-24 08:13:59 +00:00
Barend Gehrels
6ba4da656f
Fixed first/second in cart_intersect.hpp
...
[SVN r73285]
2011-07-21 19:55:56 +00:00
Barend Gehrels
bff7b95e84
Added a "covered_by" algorithm (= within or on border)
...
Revised point-in-box, box-in-box, now with strategies
Therefore, revised within strategy.
Also adapted concept for within, and refactored getting parameters into parameter_type_of (also used by distance concept)
To avoid specifying default strategies again and again for all spherical coordinate systems, used the spherical_tag as the parent for spherical_polar_tag, spherical_equatorial_tag, geographic_tag
[SVN r73177]
2011-07-17 12:26:01 +00:00
Adam Wulkiewicz
40a9cd095f
some options-related template parameters names changed
...
[SVN r73158]
2011-07-16 22:09:04 +00:00
Adam Wulkiewicz
d70a1756f9
node split algorithm separated from insert visitor, it's now tag-dispatchable.
...
[SVN r73157]
2011-07-16 22:00:42 +00:00
Adam Wulkiewicz
a55d592702
insert tags renamed
...
[SVN r73154]
2011-07-16 20:56:56 +00:00
Adam Wulkiewicz
32181b8734
node tag names changed
...
[SVN r73140]
2011-07-16 09:59:35 +00:00
Barend Gehrels
7e5f19edbd
Removed (obsolete) usage of within_code in assign_parents
...
[SVN r73120]
2011-07-15 16:45:01 +00:00
Barend Gehrels
b3b168e438
Removed unnecessary using clause
...
[SVN r73061]
2011-07-13 18:59:43 +00:00
Barend Gehrels
9373b40ef3
Fixed error in Box1/Box2
...
[SVN r73060]
2011-07-13 18:59:02 +00:00
Adam Wulkiewicz
5586fc85bf
visitors are now explicitly nonassignable. rtree is set as noncopyable since copying isn't implemented.
...
[SVN r73029]
2011-07-13 01:57:30 +00:00
Adam Wulkiewicz
3081e37140
area-related names changed to content-related names. index::within parameters sequence corrected to match the geometry::within parameters sequence.
...
[SVN r73027]
2011-07-13 01:27:30 +00:00
Barend Gehrels
b896888ec3
Added strategy to convert spherical equatorial
...
[SVN r72981]
2011-07-09 13:20:55 +00:00
Barend Gehrels
85ac00be0c
Fixed wrong comment
...
[SVN r72980]
2011-07-09 13:19:21 +00:00
Barend Gehrels
6cf7d2cd24
Moved within_code from within_util.hpp to within.hpp, and implemented for point/box and box/box
...
[SVN r72874]
2011-07-03 14:20:20 +00:00
Barend Gehrels
7b792b1a73
Bugfix of case sent to list on 2011-06-27 by Phillip. To detect if geometry is within another, we use "point_on_border". We used a mid-point there (necessary for intersections), but, from now on, if there are no intersections, we should not use the mid-point because of robustness issues.
...
In other words, we should use the same point for both intersection-->side and within-->side.
[SVN r72852]
2011-07-02 14:30:53 +00:00
Adam Wulkiewicz
5e0d091ab6
Implemented R* choose_next_node algorithm version choosing by nearly min overlap cost
...
[SVN r72714]
2011-06-21 19:29:44 +00:00
Barend Gehrels
772c367507
Merged commit 72603 to Release Branch
...
Fixes problem with commented ifdef's (2x)
See Boost ML 15-06-2011 19:36 (CET)
Authorized by Daniel James
[SVN r72656]
2011-06-17 18:47:16 +00:00
Adam Wulkiewicz
6c593d13a9
c++98 errors fixed
...
[SVN r72620]
2011-06-17 09:46:03 +00:00
Adam Wulkiewicz
1e46876a0d
Static parameters are now used everywhere in the code. Further optimizations implemented in quadratic redistribute_elements. Some errors corrected in pushable_array.
...
[SVN r72619]
2011-06-16 23:10:10 +00:00
Adam Wulkiewicz
523107a4fa
min and max elements numbers are now template parameters. New node type added - with arrays of static size. Various parameters are the first template parameter of options::rtree.
...
[SVN r72618]
2011-06-16 21:15:06 +00:00
Adam Wulkiewicz
c89a7d988f
broken #include fixed in gl_draw and print visitors
...
[SVN r72605]
2011-06-15 19:37:13 +00:00
Adam Wulkiewicz
e6256090e9
node_poly is now default node, node_variant is enabled by tag dispatching instead of #define. default_variant_tag added. Asserts implemented as macro BOOST_GEOMETRY_INDEX_ASSERT(CONDITION, TEXT_MSG).
...
[SVN r72604]
2011-06-15 18:11:59 +00:00
Barend Gehrels
f6b0488d5f
Fixed commented ifdefs
...
[SVN r72603]
2011-06-15 16:14:50 +00:00
Adam Wulkiewicz
c93fad9c6e
r* insert corrected to handle boost::variant nodes
...
[SVN r72600]
2011-06-14 22:53:56 +00:00
Adam Wulkiewicz
550823d1fe
translator::getter::equals() changed. Value::operator== used instead of geometry::equals(...).
...
[SVN r72575]
2011-06-13 22:25:35 +00:00
Adam Wulkiewicz
269c0b5eb3
options moved from index::detail::rtree::options<...> to index::options::rtree<...>
...
[SVN r72574]
2011-06-13 21:16:15 +00:00
Adam Wulkiewicz
7a36d65bab
translator::getter added + some cleanup e.g. in /rstar/insert.hpp visitors::insert replaced by detail::rstar::insert.
...
[SVN r72573]
2011-06-13 21:04:55 +00:00
Adam Wulkiewicz
7ae26e7c0f
Algo-related names changed to Options-related names. All options gathered in one file /rtree/options.hpp instead of defining them separately for all rtree variants in /rtree/[variant]/options.hpp.
...
[SVN r72569]
2011-06-13 16:34:49 +00:00
Adam Wulkiewicz
dd731e101a
simple Tag template parameter replaced by Algo traits containing tags of some number of algorithms. User now may use a combination of implemented algorithms or just use one of the predefined.
...
[SVN r72562]
2011-06-13 00:26:38 +00:00
Adam Wulkiewicz
8e23f2aa6b
split functionality (creation of the new node, parent setting, creating of the new root) moved to the default insert visitor
...
[SVN r72557]
2011-06-12 19:29:56 +00:00
Adam Wulkiewicz
58105add5f
rtree template parameters sequence changed
...
[SVN r72556]
2011-06-12 18:51:12 +00:00
Adam Wulkiewicz
a3166316a8
dirty check of children nodes (is_leaf) removed from rstar* choose_next_node, replaced by passing additional parameter
...
[SVN r72550]
2011-06-12 11:23:31 +00:00
Adam Wulkiewicz
eb1cd72e93
r* split fully implemented
...
[SVN r72549]
2011-06-12 11:10:12 +00:00
Adam Wulkiewicz
2f477241e3
reinserting insert visitor corrected, insert visitors now relies on relative level, levels check added, boxes check corrected.
...
[SVN r72531]
2011-06-09 23:55:58 +00:00
Barend Gehrels
8cbd04307a
Boost.Geometry: Merged r72410 through r72424
...
[SVN r72425]
2011-06-05 21:14:57 +00:00
Barend Gehrels
b9ae2f8835
Updated doc w.r.t. side strategies
...
[SVN r72418]
2011-06-05 17:40:41 +00:00
Barend Gehrels
c76cee8932
Boost.Geometry: Merged r72086 through r72406
...
[SVN r72409]
2011-06-05 14:43:07 +00:00
Barend Gehrels
60b4d5d4b1
Small adaptions to side
...
[SVN r72293]
2011-05-30 20:55:10 +00:00
Barend Gehrels
699f63a637
Huiller: changed to calculation types (now supporting ttmath)
...
distance_projected_point.hpp: minor changes
[SVN r72286]
2011-05-30 15:07:12 +00:00
Barend Gehrels
e20206ab23
Made side strategy consistent with distance etc (with services::default_strategy)
...
Updated test spherical_side.cpp now testing ssf, cross_track, cartesian
[SVN r72269]
2011-05-29 20:46:22 +00:00
Barend Gehrels
b78f097e02
Fixed side-by-cross-track (now non-default)
...
[SVN r72240]
2011-05-28 09:19:28 +00:00
Barend Gehrels
48d5f65669
Fixed ssf for spherical equatorial coordinate system (old version was for polar)
...
[SVN r72238]
2011-05-27 23:02:58 +00:00
Barend Gehrels
5eb0739f08
Spherical coordinate systems: splitted into "polar" and "equatorial" with opposite (co)latitude
...
[SVN r72233]
2011-05-27 22:01:05 +00:00
Barend Gehrels
80458f256d
Added spherical side formula
...
[SVN r72208]
2011-05-27 08:46:32 +00:00
Barend Gehrels
53cd02a7ee
Merged r72075 .. 72082
...
[SVN r72083]
2011-05-22 15:58:43 +00:00
Barend Gehrels
a6088a5532
Fixed typo
...
[SVN r72075]
2011-05-22 14:39:51 +00:00
Barend Gehrels
ed6731169a
Merging r71820 through r72073
...
[SVN r72074]
2011-05-22 14:23:38 +00:00
Barend Gehrels
92a2d629ea
(Re)implemented equals_with_epsilon for ttmath
...
Therefore partly reverted earlier change with TypeForEpsilon
[SVN r72060]
2011-05-21 13:51:15 +00:00
Barend Gehrels
bcad57a4a3
Fix for gcc (abs vs std::abs)
...
[SVN r72059]
2011-05-21 12:06:14 +00:00
Barend Gehrels
f79ce43c81
Fixed geometry::equals for high precision
...
[SVN r72029]
2011-05-18 18:06:34 +00:00
Barend Gehrels
1f818c7527
Fixed (embarrassing but non-harmful) bug for performance shortcut
...
[SVN r72027]
2011-05-18 08:02:10 +00:00
Adam Wulkiewicz
9dbb67ed82
intersects changed to within in remove visitor + some comments added
...
[SVN r71927]
2011-05-13 20:23:16 +00:00
Adam Wulkiewicz
0465fa31b9
example program improved
...
[SVN r71926]
2011-05-13 19:16:46 +00:00
Adam Wulkiewicz
9ca1848322
polymorphic node type added and used as default
...
[SVN r71915]
2011-05-13 10:59:49 +00:00
Adam Wulkiewicz
e30a6f4515
rstar partially implemented
...
[SVN r71880]
2011-05-11 21:15:00 +00:00
Barend Gehrels
21fc3b147d
Fixed box_view copy, added order traits function and corresponding unit test
...
[SVN r71861]
2011-05-10 17:26:00 +00:00
Barend Gehrels
925dd5e868
Doc update
...
[SVN r71836]
2011-05-08 20:58:46 +00:00
Barend Gehrels
c821efcc2b
Removed std_as_linestring/ring/multi_point and c_array* and boost_array* because there are now macros for that
...
Mention box/point/segment as helper-geometry explicitly
Removed all std geometries from geometries.hpp, geometry.hpp, multi.hpp - they have to be included explicitly
[SVN r71825]
2011-05-08 15:55:43 +00:00
Barend Gehrels
b7eff024e9
Merged small change (71816,71817), updated ring.hpp/linestring.hpp manually
...
Merged geometry.hpp from 71710 to 71817 (was not done in previous steps)
Removed ranges manually as it was not in source anymore and could not be merged
[SVN r71818]
2011-05-08 12:45:21 +00:00
Barend Gehrels
d772abb370
Removed now empty folders
...
[SVN r71816]
2011-05-08 12:26:25 +00:00
Barend Gehrels
f287a5e22a
Merged updates for (small) changes for views/ranges/iterators (r71711 through r71812)
...
[SVN r71813]
2011-05-08 12:15:38 +00:00
Barend Gehrels
f2d097365a
Moved circular_iterator to extensions (was not used internally)
...
Moved range_type/as_range to details (of views/algorithms)
[SVN r71807]
2011-05-08 10:57:21 +00:00
Barend Gehrels
0a08d1f42c
Moved box_range/segment_range to views, renamed to box_view/segment_view, removed corresponding iterators (now nested class), created detail::points_view of which other two are derived
...
[SVN r71794]
2011-05-07 22:11:19 +00:00
Adam Wulkiewicz
c06e620e28
cleanup
...
[SVN r71775]
2011-05-06 23:59:05 +00:00
Adam Wulkiewicz
9dcca981e2
corrected: gcc compile errors, wrong assert in remove; + minor changes
...
[SVN r71764]
2011-05-06 15:04:03 +00:00
Adam Wulkiewicz
4d82c421ac
quadratic split error corrected
...
[SVN r71763]
2011-05-06 13:36:37 +00:00
Adam Wulkiewicz
e09f022a2d
quadratic split algorithm added, error in linear split corrected
...
[SVN r71755]
2011-05-06 00:51:49 +00:00
Adam Wulkiewicz
919c6286b8
remove algorithm added + some other changes
...
[SVN r71726]
2011-05-04 21:33:15 +00:00
Barend Gehrels
543e65e840
Fixed box-in-box (default_strategy was not defined)
...
[SVN r71721]
2011-05-04 20:40:34 +00:00
Barend Gehrels
98819656e8
Added (previously deleted) macro's for register linestring, ring. Added macro's for register multi geometries
...
[SVN r71714]
2011-05-04 16:11:44 +00:00
Barend Gehrels
3eb466b8de
Merged Boost.Geometry from revision 71351 through 71709
...
Mainly registration macro (instead of calling header files) for Boost.Tuple, C-Array, Boost.Array, Boost.Fusion
Second the intersections check if geometries are valid
Further doc updates
[SVN r71710]
2011-05-04 12:15:07 +00:00
Adam Wulkiewicz
d121f4e9e9
searching time tests related code added
...
[SVN r71664]
2011-05-02 12:14:44 +00:00
Adam Wulkiewicz
bff387c631
insert algorithm divided to tag dispatched parts
...
[SVN r71658]
2011-05-01 23:51:45 +00:00
Adam Wulkiewicz
803ac7fbf9
operator| moved to namespace index
...
[SVN r71642]
2011-05-01 01:11:45 +00:00
Adam Wulkiewicz
7a761b359e
rtree::find parameters changed
...
[SVN r71640]
2011-05-01 00:42:54 +00:00
Adam Wulkiewicz
433c250891
new creation algorithm added
...
[SVN r71634]
2011-04-30 20:53:59 +00:00
Barend Gehrels
6cb19c253c
Fixed box_iterator behaviour to support Boost.Range concept checking
...
[SVN r71628]
2011-04-30 16:29:21 +00:00
Bruno Lalande
d92dbecb6a
Aligned adapted C array and Boost Array to the recent changes.
...
[SVN r71575]
2011-04-28 21:26:54 +00:00
Adam Wulkiewicz
7d10680771
reinsertions disabled + minor changes
...
[SVN r71544]
2011-04-27 18:14:45 +00:00
Barend Gehrels
49804f1291
Documented box, renamed TEMPLATIZED TEMPLATED
...
Removed registration of linestring/ring as it will be replaced by view or view_as
[SVN r71490]
2011-04-25 21:19:26 +00:00
Bruno Lalande
5c8365befb
Removed adapted/fusion_<cs>.hpp files and added a macro to use instead.
...
[SVN r71475]
2011-04-25 08:32:51 +00:00
Bruno Lalande
fc68031c90
Removed adapted/tuple_<cs>.hpp files and added a macro to use instead.
...
[SVN r71448]
2011-04-23 22:26:50 +00:00
Barend Gehrels
7949efd6d4
Doc update;
...
Added boost_polygon.hpp header including the other adaption headers
[SVN r71423]
2011-04-22 22:27:34 +00:00
Barend Gehrels
c0c548769f
Fix in interior_type
...
[SVN r71416]
2011-04-22 11:01:31 +00:00
Barend Gehrels
8a449c8bdb
Added check for valid input for all intersections. If not valid, it throws.
...
[SVN r71357]
2011-04-17 20:55:57 +00:00
Bruno Lalande
0b9230931c
Generalized Boost.Tuple adaptation to nD.
...
[SVN r71349]
2011-04-17 09:55:12 +00:00
Barend Gehrels
5a25db7b35
Added boost/geometry.hpp to release branch
...
[SVN r71338]
2011-04-16 23:21:23 +00:00
Barend Gehrels
a1f2e966de
Merged Boost.Geometry from revision 71123 to 71336
...
[SVN r71337]
2011-04-16 23:19:36 +00:00
Barend Gehrels
8cca47c971
Doc update (metafunctions tag, tag_cast, point_type)
...
[SVN r71329]
2011-04-16 20:42:57 +00:00
Barend Gehrels
5be2736b4b
Added headerfiles now missing for clang
...
[SVN r71326]
2011-04-16 18:05:13 +00:00
Barend Gehrels
68fd8869c5
Added boost/geometry.hpp
...
Doc update (metafunctions coordinate type, system, dimensions, point_order, closure, tags degree/radian, constans min_corner, max_corner)
[SVN r71325]
2011-04-16 18:00:03 +00:00
Barend Gehrels
5580e6b622
Added/updated doc/examples for assign/convert/convex_hull
...
[SVN r71321]
2011-04-16 13:16:26 +00:00
Barend Gehrels
6cd0509ac0
Small doc fix
...
[SVN r71319]
2011-04-16 12:24:09 +00:00
Barend Gehrels
726e26b971
Moved assign-variants to detail, reverted (manually) move of convert to detail
...
[SVN r71309]
2011-04-16 11:31:53 +00:00
Barend Gehrels
9ac4cc29f3
Moved make with range to detail, otherwise inconsistent with renaming of assign.hpp
...
[SVN r71298]
2011-04-15 20:55:00 +00:00
Barend Gehrels
be53ecf97b
Splitted files assign/assign_values to avoid circularities
...
[SVN r71212]
2011-04-12 20:13:06 +00:00
Barend Gehrels
3cf4b0e1fe
Temporary solved mutual inclusion assign/convert
...
[SVN r71210]
2011-04-12 18:41:53 +00:00
Barend Gehrels
603f435d47
Changed assign to assign_values / assign_points and copied in assign from convert
...
[SVN r71208]
2011-04-12 18:24:24 +00:00
Bruno Lalande
4b4d957802
Small fix - forgotten const
...
[SVN r71170]
2011-04-10 20:44:26 +00:00
Barend Gehrels
731999217a
Added doc for equals
...
[SVN r71156]
2011-04-09 21:24:54 +00:00
Barend Gehrels
9f6bf428bb
Added and updated documentation of correct, transform, distance, comparable_distance
...
[SVN r71152]
2011-04-09 20:29:34 +00:00
Bruno Lalande
edc40b6580
Added assign_value and assign_point to arithmetic functions.
...
[SVN r71126]
2011-04-08 21:13:10 +00:00
Barend Gehrels
595bae61d9
Doc update, added behaviour/samples of clear, expand, reverse, unique
...
[SVN r71124]
2011-04-08 20:19:01 +00:00
Barend Gehrels
b38c8a16dd
Merged 71027,71093,71117 (centroid nD plus convert to detail)
...
[SVN r71119]
2011-04-08 15:41:37 +00:00
Barend Gehrels
2e024cff21
Moved convert to detail::convert
...
Removed deprecated file copy.hpp
[SVN r71117]
2011-04-08 14:49:49 +00:00
Bruno Lalande
85f1994a42
Actually enabled centroid linestring calculation for nD.
...
[SVN r71093]
2011-04-07 21:11:17 +00:00
Bruno Lalande
9a615d79d3
Generalized linestring centroid to nD.
...
[SVN r71027]
2011-04-06 06:56:16 +00:00
Adam Wulkiewicz
98e4b47b32
reinsert implemented
...
[SVN r70964]
2011-04-03 23:07:34 +00:00
Barend Gehrels
496425a7e8
Added geometry.hpp to release branche
...
[SVN r70916]
2011-04-02 22:22:02 +00:00
Barend Gehrels
819e63d90d
Added views to release branche
...
[SVN r70915]
2011-04-02 22:21:47 +00:00
Barend Gehrels
a818f281f0
Added util to release branche
...
[SVN r70914]
2011-04-02 22:21:31 +00:00
Barend Gehrels
176c5ab134
Added strategies to release branche
...
[SVN r70913]
2011-04-02 22:21:18 +00:00
Barend Gehrels
9141e16986
Added ranges to release branche
...
[SVN r70912]
2011-04-02 22:21:05 +00:00
Barend Gehrels
8499d60f83
Added policies to release branche
...
[SVN r70911]
2011-04-02 22:20:52 +00:00
Barend Gehrels
8a1fd4b6cb
Added multi to release branche
...
[SVN r70910]
2011-04-02 22:20:39 +00:00
Barend Gehrels
65a39eede8
Added iterators to release branche
...
[SVN r70909]
2011-04-02 22:20:26 +00:00
Barend Gehrels
eeebd00ed2
Added geometries to release branche
...
[SVN r70908]
2011-04-02 22:20:13 +00:00
Barend Gehrels
03b9859716
Added domains to release branche
...
[SVN r70907]
2011-04-02 22:20:00 +00:00
Barend Gehrels
071a6d7864
Added arithmetic to release branche
...
[SVN r70906]
2011-04-02 22:19:46 +00:00
Barend Gehrels
571311f82e
Added algorithms to release branche
...
[SVN r70905]
2011-04-02 22:19:34 +00:00
Barend Gehrels
abcff8f711
Added core to release branche
...
[SVN r70904]
2011-04-02 22:19:20 +00:00
Barend Gehrels
eefb1b6056
Moved units to extension
...
[SVN r70898]
2011-04-02 21:55:40 +00:00
Barend Gehrels
2f39b02bc8
Moved cross_product to extensions/arithmetic
...
[SVN r70858]
2011-04-02 16:26:25 +00:00
Barend Gehrels
17a6801d57
Small fixes for examples/extensions
...
[SVN r70855]
2011-04-02 14:27:38 +00:00
Barend Gehrels
fbaa12058e
Renamed distance_result to default_distance_result, same for area/length
...
For within, using tag_cast now like done in centroid
Obsoleted is_linear
Small comment changes
[SVN r70853]
2011-04-02 13:29:21 +00:00
Barend Gehrels
42326ebd41
Have to include provided geometries because of move of replace_point_type
...
[SVN r70837]
2011-04-01 21:12:47 +00:00
Barend Gehrels
86fb6b5f9b
Moved replace_point_type
...
[SVN r70836]
2011-04-01 21:06:59 +00:00
Barend Gehrels
1422185504
Comment change, moved replace_point_type to extension
...
[SVN r70830]
2011-04-01 19:56:06 +00:00
Barend Gehrels
6db68c62b5
Renamed make_ functions return_ (centroid, buffer, envelope)
...
Renamed _inserter functions _insert and moved them to namespace detail (intersection, union, difference, sym_difference, simplify, convex_hull)
[SVN r70824]
2011-04-01 16:38:43 +00:00
Mateusz Loskot
5e85f0e019
[geometry] Commented max_segments_per_section
...
[SVN r70753]
2011-03-30 13:13:12 +00:00
Mateusz Loskot
957028326a
[geometry] Applied patch from Philipp Reh removing use of named constant max_segments_per_section due to problems with GCC 4.6. TODO: to be reviewed.
...
[SVN r70752]
2011-03-30 13:11:14 +00:00
Adam Wulkiewicz
5b96b96c34
choose_next_node algorithm changed
...
[SVN r70746]
2011-03-30 10:16:03 +00:00
Barend Gehrels
bd27fef768
Moved some non-finished code to extensions
...
Documented centroid,clear,within
[SVN r70710]
2011-03-29 21:17:41 +00:00
Adam Wulkiewicz
034bf7ce0a
tagstags are now in the index namespace
...
[SVN r70702]
2011-03-29 18:22:56 +00:00
Adam Wulkiewicz
9c2ff58818
namespaces hierarchy changed
...
[SVN r70701]
2011-03-29 18:03:10 +00:00
Adam Wulkiewicz
c8b2db4306
rtree Box template parameter removed
...
[SVN r70689]
2011-03-29 00:34:09 +00:00
Barend Gehrels
66b00dae7e
Removed obsolete file
...
[SVN r70644]
2011-03-27 18:54:13 +00:00
Barend Gehrels
1908dccb1f
Fixed error for MSVC in some circumstances, "begin" without namespace was a problem
...
[SVN r70642]
2011-03-27 18:37:27 +00:00
Adam Wulkiewicz
c88052c506
overlap error patch + minor changes
...
[SVN r70627]
2011-03-27 13:44:55 +00:00
Adam Wulkiewicz
e05afa847e
other version of split algorithm + a lot of minor changes
...
[SVN r70607]
2011-03-27 02:21:45 +00:00
Barend Gehrels
985db5a6b8
Updated copyright messages
...
[SVN r70600]
2011-03-26 22:33:15 +00:00
Barend Gehrels
be95eb40d8
Splitted strategy "centroid_weighted_length.hpp from centroid.hpp
...
Added tags pointlike_tag, linear_tag, areal_tag to share strategies
Implemented multi_linestring making use of weighted_length
[SVN r70571]
2011-03-26 17:01:28 +00:00
Adam Wulkiewicz
c5e823bbb5
R*tree implementation based on boost::variant
...
[SVN r70531]
2011-03-24 23:52:27 +00:00
Barend Gehrels
67f5b36e32
Bugfix partition for clang
...
Added undocked par for sectionalize
[SVN r70183]
2011-03-19 14:01:11 +00:00
Barend Gehrels
a1e9dbe493
Moved "within" in "select_rings" to a later phase to avoid too many calls to within in some cases
...
[SVN r70136]
2011-03-18 19:35:19 +00:00
Bruno Lalande
0c9e4b52bb
Fixed wrong comment
...
[SVN r70089]
2011-03-17 23:13:21 +00:00
Barend Gehrels
05186e267d
Changed BOOST_AUTO to BOOST_AUTO_TPL for pgi 11.2
...
[SVN r70060]
2011-03-17 14:02:01 +00:00
Barend Gehrels
2b03e95bc1
Silence clang warnings by adding initialization
...
[SVN r70059]
2011-03-17 13:15:10 +00:00
Barend Gehrels
c800f15ff0
Removed obsolete files
...
Moved two not-used experimental views to extensions/util
Moved for_each_range from util to algorithm/detail and to namespace detail
[SVN r70056]
2011-03-17 13:00:19 +00:00
Barend Gehrels
82b3fe985b
Performance fix for get_turns/partition
...
[SVN r69958]
2011-03-13 16:09:47 +00:00
Barend Gehrels
6c430f7d1f
Added check in partition to check if partitioning is necessary, saves building up index vector(s)
...
[SVN r69948]
2011-03-13 15:22:31 +00:00
Barend Gehrels
4d147a71d3
Revised get_turns using partition instead of own implementation
...
Changed section to make use of ring_identifier instead of own indexes
Cleanup in using boost::geometry:: inside sources
[SVN r69943]
2011-03-13 14:46:07 +00:00
Barend Gehrels
397ddc7b18
Implemented partition for two ranges
...
[SVN r69942]
2011-03-13 14:43:17 +00:00
Barend Gehrels
9bdd88f741
Renamed combine to expand
...
[SVN r69916]
2011-03-13 11:02:13 +00:00
Barend Gehrels
39614450b9
Moved wkt, phase 4, cleanup
...
[SVN r69915]
2011-03-13 10:09:54 +00:00
Barend Gehrels
571790def4
Moved wkt, phase 3, in debug-defines
...
Moved parse to extensions
[SVN r69908]
2011-03-13 00:18:21 +00:00
Barend Gehrels
d7bc400caf
Moved wkt, phase 2, added warning and renamed include guards
...
[SVN r69907]
2011-03-13 00:03:25 +00:00
Barend Gehrels
0fc4cf96fb
Moved wkt (used in nearly all tests) from extension to domains tree for release
...
[SVN r69905]
2011-03-12 23:49:21 +00:00
Barend Gehrels
b12af33576
Small change to avoid warnings
...
[SVN r69841]
2011-03-11 12:54:07 +00:00
Barend Gehrels
9a02da8f4f
Worked on divide_and_conquer, now called partition, extra internal vectors with exceeding were not necessary, and therefore the mapping with processed-info neither
...
[SVN r69839]
2011-03-11 11:36:43 +00:00
Barend Gehrels
205091b3d4
Refactored/removed quadratic loop (dramatic performance increase)
...
Added separate and generic divide_and_conquer.hpp
[SVN r69828]
2011-03-10 21:50:35 +00:00
Barend Gehrels
394b7ec79d
Fixed robustness problem for case called "ggl_list_20110306_javier"
...
[SVN r69611]
2011-03-06 21:15:21 +00:00
Barend Gehrels
76f68b1bb7
Fixed error in new assemble approach, now both recursive_boxes as intersection_pies are completely running (again) for all combinations of open,cw,ccw,multi,box,triangle
...
[SVN r69587]
2011-03-05 23:27:06 +00:00
Barend Gehrels
7b17f677b7
Fixed call to do_reverse for std::vector output
...
[SVN r69586]
2011-03-05 22:43:48 +00:00
Barend Gehrels
93eb8e0994
Fixed TODO item from list for better reversal of ccw polygons
...
[SVN r69584]
2011-03-05 22:23:29 +00:00
Barend Gehrels
0161ed1f43
Implemented/fixed behaviour for empty polygons in intersections
...
Simplified reversal
Implemented transform for segment,multi_point,multi_linestring
Implemented wkt for segment
[SVN r69569]
2011-03-04 21:39:30 +00:00
Barend Gehrels
8c9c643f93
Fixed behaviour of new approach for dissolve
...
[SVN r69519]
2011-03-03 16:17:47 +00:00
Barend Gehrels
1c4e9cc8d8
Fixed behaviour of new approach for dissolve
...
[SVN r69517]
2011-03-03 16:13:52 +00:00
Barend Gehrels
7cccbf4bb0
Added include file for gcc
...
[SVN r69514]
2011-03-03 11:30:27 +00:00
Barend Gehrels
2fcbf1c7c9
Refactored assemble.hpp, now three parts: select_rings, assign_parents, add_rings
...
Rewritten ring_properties
Obsoleted add_to_containment.hpp, assemble.hpp
[SVN r69510]
2011-03-03 11:21:59 +00:00
Barend Gehrels
d43dc2b88c
Fix on forgotten typename
...
[SVN r69338]
2011-02-27 17:14:39 +00:00
Barend Gehrels
264b278308
Some adaptions for ttmath type
...
Doc update in (sym)difference
[SVN r69335]
2011-02-27 16:20:00 +00:00
Barend Gehrels
a736372915
Src update, move of ref/* to reference/*
...
[SVN r69329]
2011-02-27 14:16:11 +00:00
Barend Gehrels
3456835605
Added _inserter versions for (symmetric)difference
...
Replaced double by coordinate type in correct
Added multi in generic geometry include file
[SVN r69314]
2011-02-26 22:33:13 +00:00
Barend Gehrels
d9e68a120e
added multi/algorithms/difference.hpp
...
[SVN r69258]
2011-02-24 22:47:06 +00:00
Barend Gehrels
03c1d5ec31
Doc update
...
Fixed/added difference with box (box/Reversed)
Fixed/added append for some combinations (segment), splitted dispatch into two cases
[SVN r69252]
2011-02-24 22:29:01 +00:00
Barend Gehrels
239f794eb8
Added geometry:: to set to avoid clash with std::set
...
[SVN r69134]
2011-02-21 23:15:33 +00:00
Barend Gehrels
bd482c32ba
Deprecated copy_coordinates (=>convert)
...
Doc update (assign/make)
[SVN r69127]
2011-02-21 22:23:16 +00:00
Barend Gehrels
4badcdc600
Moved dissolve to extension
...
Fixed extensions connect/offset tests for gcc
[SVN r69086]
2011-02-20 18:18:10 +00:00
Barend Gehrels
034bc775df
Renamed container_access to mutable_range
...
[SVN r69075]
2011-02-20 13:10:46 +00:00
Barend Gehrels
c679b2312d
Selected other solution for mutable container, now having metafunction rvalue_type
...
[SVN r69058]
2011-02-19 14:39:49 +00:00
Barend Gehrels
029ce7c2c4
Enhanced mutable polygon concept with respect to proxies. Now Boost.Polygon is supported for both reading/writing.
...
Upgraded ttmath
Added coordinate_cast to support "lexical_cast" of ttmath numbers
[SVN r69054]
2011-02-19 13:33:14 +00:00
Mateusz Loskot
90e46544b5
[geometry] Replaced TODO comment with BOOST_ASSERT to guard unexpected execution point.
...
[SVN r68950]
2011-02-16 16:41:53 +00:00
Barend Gehrels
95e61f338e
Use traits::resize now instead of assuming a container resize method
...
[SVN r68935]
2011-02-15 22:33:18 +00:00
Barend Gehrels
7fa765ded2
for_each_segment doc update
...
[SVN r68930]
2011-02-15 21:14:41 +00:00
Barend Gehrels
e7d222e929
Fixed typo
...
[SVN r68807]
2011-02-12 15:37:38 +00:00
Barend Gehrels
4faf0f235d
Replaced is_multi by tag_cast as planned (see also http://barendgehrels.blogspot.com/2010/10/tag-dispatching-and-inheritance.html )
...
Moved num_geometries to algorithms/ folder
Created new file num_interior_rings.hpp (extracted from interior_rings.hpp)
[SVN r68803]
2011-02-12 15:26:36 +00:00
Barend Gehrels
6a886721e7
Update for c++0x where I don't get BOOST_AUTO to work.
...
[SVN r68749]
2011-02-09 19:30:52 +00:00
Barend Gehrels
f1d0a98b0c
Small fixes in extensions
...
[SVN r68712]
2011-02-08 12:01:23 +00:00
Barend Gehrels
73197970ee
Fixed accidental usage of bg::
...
[SVN r68709]
2011-02-08 07:45:54 +00:00
Barend Gehrels
167c4ebd36
Removed an accidental typedef (which MSVC 2005 surprisingly accepts)
...
[SVN r68704]
2011-02-07 21:48:02 +00:00
Barend Gehrels
3d0230f8b4
Propagate constness in metafunction ring_return_type
...
[SVN r68703]
2011-02-07 20:51:35 +00:00
Barend Gehrels
9fbd4da716
Added now necessary reference after change in read wkt
...
[SVN r68702]
2011-02-07 20:09:46 +00:00
Barend Gehrels
da3998874d
Changed polygon concept to implement const/mutable usage
...
Therefore changed container_access
Added namespace "write" to enable writable containers or ranges
Reimplemented much of Boost.Polygon's polygon_with_hole_data adaption
[SVN r68694]
2011-02-07 18:44:49 +00:00
Barend Gehrels
0871cb8295
get/set update for doc
...
[SVN r68682]
2011-02-06 21:09:58 +00:00
Barend Gehrels
a7e547a7e3
Doc update
...
Renamed macro to throw/don't throw BOOST_GEOMETRY_CENTROID_NO_THROW
[SVN r68574]
2011-01-30 21:48:22 +00:00
Barend Gehrels
2b6ee203f1
Missing comma
...
[SVN r68390]
2011-01-23 16:34:36 +00:00
Barend Gehrels
1e823499b6
Renamed linear_ring to ring (linear_ring is still available)
...
Doc update
Renamed some template parameters (for doc)
[SVN r68385]
2011-01-23 16:04:35 +00:00
Barend Gehrels
32d95d3d8e
Doc update
...
Renamed area_by_triangles.hpp to area_surveyor.hpp because most files are named to their inventor or formula
[SVN r68370]
2011-01-22 18:51:45 +00:00
Barend Gehrels
cf7b735a1e
Small doc-gen update, move from qbk{include,...} to qbk{[include ...]} to have greater flexibility (any qbk code can now be inlined)
...
[SVN r68304]
2011-01-19 18:17:51 +00:00
Barend Gehrels
e116f5ddda
Removed assertion (currently goes of for GeometryOut, is a vector, not a geometry-type)
...
[SVN r68254]
2011-01-18 21:28:38 +00:00
Barend Gehrels
e051050b44
Added Boost.Fusion points adapted to Boost.Geometry (effectively by Akira Takahashi)
...
Added MPL-assertions to traits classes not yet having them
Added constructors for linear_ring/linestring to support Boost.Assign better
[SVN r68239]
2011-01-18 18:51:57 +00:00
Barend Gehrels
b7bc3c4c77
Reimplemented remove_spikes by first marking and after that removing, the algorithm is also changed.
...
This can not only remove "spikes" but also larger indentations, exdentations (intrusions/extrusions).
We need the marking to check before if there are spikes.
(Note: this is payed-project-related work)
Plus small trailing needs for model:: namespace here
[SVN r68226]
2011-01-18 12:57:25 +00:00
Barend Gehrels
a58b79d0b6
Added MPL assertions
...
[SVN r68218]
2011-01-17 20:54:38 +00:00
Barend Gehrels
cbcf275ea7
Doc update, move from qbk/* to qbk/include and separate qbk files in folder ref
...
[SVN r68215]
2011-01-17 20:41:54 +00:00
Steven Watanabe
d234480b24
Revert [67111] (addition of boost/detail/iomanip.hpp) and all the commits that depend on it. ([68137], [68140], [68141], [68154], and [68165]).
...
[SVN r68168]
2011-01-15 08:11:51 +00:00
Bryce Adelstein-Lelbach
dff17a97aa
Replacing the use of <iomanip> with <boost/detail/iomanip.hpp> across Boost.
...
On Linux, GNU's libstdc++, which is the default stdlib for icc and clang,
cannot parse the <iomanip> header in version 4.5+ (which thankfully neither
compiler advises the use of yet), as it's original C++98-friendly
implementation has been replaced with a gnu++0x implementation.
<boost/detail/iomanip.hpp> is a portable implementation of <iomanip>, providing
boost::detail::setfill, boost::detail::setbase, boost::detail::setw,
boost::detail::setprecision, boost::detail::setiosflags and
boost::detail::resetiosflags.
[SVN r68140]
2011-01-14 02:35:58 +00:00
Barend Gehrels
216f8a1d15
Used reversible_view in convex_hull to fix stlport
...
[SVN r67918]
2011-01-10 18:38:04 +00:00
Barend Gehrels
3cec88ae05
Moved all other snippets to separate examples
...
[SVN r67778]
2011-01-08 14:01:04 +00:00
Barend Gehrels
30304863c7
Moved snippets point and point_register to separate examples
...
[SVN r67775]
2011-01-08 12:06:29 +00:00
Barend Gehrels
0146ad416e
Changed m_clustered into pointer for clang (forbidding mutable ref's)
...
[SVN r67769]
2011-01-08 09:59:22 +00:00
Barend Gehrels
9b8db4f822
Inspect tool report update (library)
...
[SVN r67630]
2011-01-03 18:26:02 +00:00
Barend Gehrels
7e2866274a
Doc update
...
[SVN r67587]
2011-01-02 20:23:45 +00:00
Barend Gehrels
52a088851e
Doc update (usually change from Doxygen group)
...
Changed some strategies from struct to class
[SVN r67555]
2011-01-01 22:35:47 +00:00
Barend Gehrels
b554a94560
Doc update (doxygen)
...
[SVN r67509]
2010-12-30 22:03:00 +00:00
Barend Gehrels
b504ad8107
Update for difference
...
Changed value (1,-1) to overlay_type now
Removed dissolve flag, now an overlay type
[SVN r67487]
2010-12-29 13:57:06 +00:00
Barend Gehrels
ee21185f40
Removed range_detail
...
[SVN r67485]
2010-12-29 10:21:12 +00:00
Barend Gehrels
7bb8eaf573
Included boost/version.hpp as this is not always automatically done
...
[SVN r67482]
2010-12-28 20:33:01 +00:00
Barend Gehrels
07189d825d
Adapted reversible_view to new names for Boost 1.46 (trunk)
...
[SVN r67480]
2010-12-28 18:41:23 +00:00
Barend Gehrels
80b9f998b1
Adapted boost range adaptors to new names for Boost 1.46 (trunk)
...
[SVN r67479]
2010-12-28 18:39:58 +00:00
Barend Gehrels
7e96ac247f
Splitted intersection and intersection_inserter
...
Doing back_inserter now in later phase of dispatch
Added MPL assertions to coordinate system and type
Modified read_wkt with output iterator option
[SVN r67473]
2010-12-28 16:37:11 +00:00
Barend Gehrels
f0be3d6d8b
Update for quickbook/doxygen
...
[SVN r67444]
2010-12-24 14:19:00 +00:00
Barend Gehrels
0b1aff4624
Fixed minimum_ring_size for open rings
...
[SVN r67413]
2010-12-22 17:43:14 +00:00
Barend Gehrels
f0989204fb
Added multi/closure.hpp (adaptions for MPL_ASSERT) - all should be closed otherwise linestring is closed explicitly
...
[SVN r67402]
2010-12-21 22:45:43 +00:00
Barend Gehrels
97245d28ba
Added multi/closure.hpp (adaptions for MPL_ASSERT)
...
[SVN r67396]
2010-12-21 21:41:49 +00:00
Barend Gehrels
3d7dc39f28
Added multi/closure.hpp
...
[SVN r67395]
2010-12-21 21:24:17 +00:00
Barend Gehrels
5b4b030fcb
Added Reverse to copy_segment_point.hpp,
...
and therefore, to enrich_intersection_points.hpp, handle_tangencies.hpp
Protected point_order with MPL_ASSERT
[SVN r67374]
2010-12-20 21:25:21 +00:00
Barend Gehrels
9c6417c331
Implemented counterclockwise-geometry / box
...
Removed obsolete order in traverse/copy segments
Added option ReverseOut in overlay to support ccw or difference better, this should be enhanced
Obsoleted cartesian2d and cartesian3d
[SVN r67321]
2010-12-19 12:17:10 +00:00
Barend Gehrels
c75f01c42c
Bugfix in remove headerfile
...
[SVN r67312]
2010-12-18 21:43:58 +00:00
Barend Gehrels
a352ce1a8a
Moved closeable_view,reversible_view to views
...
Added identity_view to avoid copies
Renamed get_full_section.hpp to range_by_section.hpp
Added (temporary?) reference to ring/linestring types in ring_return_type...
[SVN r67309]
2010-12-18 21:39:33 +00:00
Barend Gehrels
e36fd1ebc6
Incorporated reversible_view in sectionalize, get_turns, copy_segments
...
Included Reverse boolean parameter in get_turns, traverse, overlay
Removed closeable_view from get_full_section (was confusing and not necessary)
Algorithms difference and sym_difference now use reverse iteration instead of reversing the whole geometry beforehand
Asserted some other metafunctions with BOOST_MPL_ASSERT_MSG
[SVN r67303]
2010-12-18 16:52:59 +00:00
Barend Gehrels
e7e2ab6b47
Removed obsolete get_sections
...
Small debug-tweak in assemble
[SVN r67295]
2010-12-18 10:29:46 +00:00
Barend Gehrels
2d69e93a5d
Changed BOOST_AUTO by typename interior_rings in loops through interior rings
...
[SVN r67244]
2010-12-15 19:52:49 +00:00
Barend Gehrels
370d887001
Added Boost.Range range adaptors adaptions for Boost.Geometry
...
[SVN r67224]
2010-12-13 21:34:48 +00:00
Barend Gehrels
21866296fe
(Re)added explicit to constructor
...
[SVN r67196]
2010-12-12 22:35:20 +00:00
Barend Gehrels
e9bf98f8a8
Removed explicit constructor, no need to, for test reversible_closeable_view.cpp
...
[SVN r67192]
2010-12-12 19:37:57 +00:00
Barend Gehrels
625b25a5ec
Made closeable_view and reversible_view metafunctions, defining itself or a Boost.Range reversed_range or a closing_view
...
[SVN r67186]
2010-12-12 15:46:52 +00:00
Barend Gehrels
748d8059d1
Clean up / renaming / adding namespace / etc in bp adaption
...
[SVN r67181]
2010-12-12 10:45:36 +00:00
Barend Gehrels
1f90af482d
Updated polygon.hpp, ring_type is now reference because it returns a reference to its rings
...
Updated many test files to avoid point_2d
Updated boost.polygon adaption
[SVN r67178]
2010-12-11 15:51:38 +00:00
Barend Gehrels
fa5027dc66
Changed const impl.
...
[SVN r67175]
2010-12-11 14:53:01 +00:00
Barend Gehrels
1038035c43
Removed (the need for) range_iterator_const_if_c using BOOST_AUTO
...
[SVN r67168]
2010-12-11 14:24:31 +00:00
Barend Gehrels
573610796d
Changed loops to BOOST_AUTO in preparation of change in concept of interior_rings/return_type
...
[SVN r67167]
2010-12-11 14:03:54 +00:00
Barend Gehrels
e9ed507574
Committed added files for concept-change to include reference to ring_type and interior_type.
...
For interior_type.hpp, this is split off from interior_rings.hpp
Changed comment in add_const_if_c
[SVN r67166]
2010-12-11 12:04:48 +00:00
Barend Gehrels
bd7f7879c1
Committed added files for concept-change to include reference to ring_type and interior_type.
...
For interior_type.hpp, this is split off from interior_rings.hpp
Changed comment in add_const_if_c
[SVN r67165]
2010-12-11 11:57:02 +00:00
Barend Gehrels
11a5805da2
Small updates in comment and in new Boost.Polygon ring adaptor
...
[SVN r67070]
2010-12-06 18:33:53 +00:00
Barend Gehrels
92cecaa0f5
Added Boost.Polygon support (point, box, ring)
...
[SVN r67042]
2010-12-05 21:47:08 +00:00
Barend Gehrels
1c8fce3059
model namespaces, moved point_xy to d2::point_xy, revised point_ll_deg to ll::point<degree>
...
[SVN r66975]
2010-12-02 16:10:47 +00:00
Barend Gehrels
e299295f8e
Fixed point-segment default_strategy construct
...
Fixed cross track for latlong (partly)
[SVN r66828]
2010-11-28 21:49:46 +00:00
Barend Gehrels
853c097413
Fixed path-omission for svg_mapper
...
[SVN r66818]
2010-11-28 14:37:36 +00:00
Barend Gehrels
773131faa5
Major update:
...
1) all provided geometries are now in namespace model
2) segment is renamed to model::referring_segment, there is also a model::segment which owns the points
[SVN r66810]
2010-11-28 13:23:44 +00:00
Barend Gehrels
6de74295af
Removed two warnings
...
[SVN r66807]
2010-11-28 09:34:14 +00:00
Barend Gehrels
b16e1b3247
Fixed last pie case (as multi-polygon)
...
[SVN r66587]
2010-11-15 09:38:32 +00:00
Barend Gehrels
8282f1e9e8
Fixed two new cases coming from multi-polygon pie-test
...
[SVN r66579]
2010-11-14 21:05:22 +00:00
Barend Gehrels
23abb2d19f
small cleanup within
...
[SVN r66569]
2010-11-14 14:33:12 +00:00
Barend Gehrels
c3c238623d
Assemble/traverse/enrich: complete update for handling self tangencies
...
Strategies area, within, centroid, transform adapted to new conventions using services
Centroid: removed underscore
Correct: support for open polygons
Get turns: support for open polygons
Sectionalize/segments: support for open polygons
Closing iterator: complete new implementation to support open polygons better
Numpoints: added boolean parameter to add one for open polygons
Within: bugfix for point-on-border-of-interior ring, this needed returning three values -1,0,1 instead of boolean
polygon/ring: added a copy in namespace model:: as agreed long ago, with other default template parameters
[SVN r66449]
2010-11-08 10:18:33 +00:00
Barend Gehrels
2a1244ddfb
Changed warning for adaption of Boost.Array
...
[SVN r66212]
2010-10-27 10:52:31 +00:00
Barend Gehrels
5b10aad7b4
Added Boost Array point adapter created by Alfredo Correa
...
[SVN r66211]
2010-10-27 10:43:31 +00:00
Mateusz Loskot
b0ee536873
[geometry] Updated detailed description of area algorithm. Paragraphs copied from previous version of quickbook doc.
...
[SVN r66113]
2010-10-20 00:09:40 +00:00
Barend Gehrels
d262e99aea
Fixed dissolve and added to jamfile
...
[SVN r65941]
2010-10-13 14:38:56 +00:00
Barend Gehrels
d36962b53d
Refreshed get_turns: removed is_multi, moved pieces to implementation, shared things, implemented for multi
...
Made orientation for linear intersections flexible (because doesn't care)
There is now clipping (intersection box/geometry) for multi_polygon and multi_linestring
[SVN r65938]
2010-10-13 13:45:54 +00:00
Barend Gehrels
71d48da6e0
Implemented box with reverse polygon overlay
...
[SVN r65932]
2010-10-12 20:27:49 +00:00
Barend Gehrels
8f86439655
Implemented ccw, plus check on areal feature, to union, conform intersection
...
Splitted assemble.hpp into get_ring.hpp, convert_ring.hpp, add_to_containment.hpp, overlay.hpp, assemble.hpp
Added some other mpl asserts
[SVN r65923]
2010-10-12 13:04:45 +00:00
Barend Gehrels
0f3c09e022
Added default to avoid gcc warning about missing enumeration
...
[SVN r65921]
2010-10-12 10:48:28 +00:00
Barend Gehrels
6564152e98
Finished ccw implementation of intersection
...
Added mpl assert for correct, if not implemented
Restructured intersection.cpp unit test to support cw
[SVN r65920]
2010-10-12 10:39:09 +00:00
Barend Gehrels
51610518b1
Replaced ignore field by ignore method for swapping operations (for counter clockwise)
...
Added test/algorithms/overlay/ccw_traverse.cpp to test counterclockwise polygon overlays
Added test/algorithms/overlay to standards Jamfile.v2
Moved some testcases to overlay_cases.hpp
Some warning removals in test cases
[SVN r65913]
2010-10-11 16:18:51 +00:00
Barend Gehrels
73fd9c49de
Added multi_linestring of intersections
...
Changed intersection dispatching using is_areal
[SVN r65892]
2010-10-10 19:47:31 +00:00
Barend Gehrels
e87a82051b
Added MPL asserts for geometry combinations which are not implemented in intersection.
...
[SVN r65881]
2010-10-10 16:47:18 +00:00
Barend Gehrels
4589062969
Doc update
...
Converter update (now convenience headers)
[SVN r65334]
2010-09-07 16:28:21 +00:00
Barend Gehrels
d92605e4f0
Doc update
...
Renamed snippet to example
Added additional distinguishing qbk option
Some doc fixes
[SVN r65322]
2010-09-06 16:26:04 +00:00
Barend Gehrels
7a082bb4f4
Modified IntersectionStrategy and AssignPolicy into a TurnPolicy (having the two)
...
[SVN r65255]
2010-09-04 15:16:56 +00:00
Barend Gehrels
a6dec17e20
Added model::segment (preparing model namespace)
...
[SVN r65214]
2010-09-03 10:25:59 +00:00
Barend Gehrels
63199bfe5d
Added model::segment (preparing model namespace)
...
[SVN r65213]
2010-09-03 10:24:41 +00:00
Barend Gehrels
3a5e4ebdf1
Update of Doxygen/qbk documentation
...
[SVN r65212]
2010-09-03 10:23:21 +00:00
Barend Gehrels
9b0bf9f07c
Update of Doxygen/qbk documentation
...
[SVN r65211]
2010-09-03 10:22:14 +00:00
Barend Gehrels
141b5a9018
Added disjoint option for segment/segment and linestring/linestring
...
[SVN r65082]
2010-08-28 14:26:45 +00:00
Barend Gehrels
446a79f168
Doc update
...
[SVN r64844]
2010-08-16 12:56:31 +00:00
Barend Gehrels
6ce5644821
Made difference_type public
...
[SVN r64843]
2010-08-16 12:38:05 +00:00
Barend Gehrels
eb04aeb7ad
Added difference_type, reported as missing on the GGL mailing list
...
[SVN r64840]
2010-08-16 07:36:10 +00:00
Barend Gehrels
8753236b6d
Major doc upgrade (step one of many)
...
A.o. moved Doxygen groups to separate headerfiles
Silenced Doxygen warnings
[SVN r64819]
2010-08-15 14:29:57 +00:00
Barend Gehrels
5d9b9e3edc
Correct now works for any geometry
...
[SVN r64738]
2010-08-11 13:02:41 +00:00
Barend Gehrels
801f2e0eed
Recent changes in qbk-generation
...
[SVN r64692]
2010-08-09 10:33:57 +00:00
Barend Gehrels
4800ea7918
Small tweaks in shapelib extension
...
[SVN r64596]
2010-08-04 15:45:23 +00:00
Barend Gehrels
349cab7b0d
Added shapelib extension to create shapefiles using shapelib
...
(shameless plug: writing shapefiles has never been easier)
[SVN r64594]
2010-08-04 12:35:16 +00:00
Barend Gehrels
e3406eada4
Made box/segment iterators random access
...
[SVN r64590]
2010-08-04 09:17:31 +00:00
Barend Gehrels
694c501f2e
Updated comments for (experimental) qbk
...
[SVN r64530]
2010-08-01 20:22:44 +00:00
Barend Gehrels
dec2d42c3f
Fixed renamal view/ranges
...
[SVN r64511]
2010-07-31 19:25:59 +00:00
Barend Gehrels
98e9ca82c6
added box_iterator
...
[SVN r64507]
2010-07-31 18:51:13 +00:00
Barend Gehrels
9cd71226df
clip_linestring: renamed linestring to range (for support segments)
...
added distance checks
added mpl assertions
added intersection segment/box
renamed "segment_iterator" to "segment_returning_iterator" to be able to reuse that name later on
[SVN r64505]
2010-07-31 18:41:31 +00:00
Barend Gehrels
80531061b6
Added support for distance point/open ring
...
[SVN r64416]
2010-07-28 20:29:19 +00:00
Barend Gehrels
718f431b2a
Added point-ring distance plus testcase
...
[SVN r64414]
2010-07-28 18:07:06 +00:00
Barend Gehrels
8cf4b739b4
Fixed make_distance_result for within extension
...
Typos
[SVN r64263]
2010-07-22 16:04:05 +00:00
Barend Gehrels
b6444b5475
Fixed old issue that only geometry::segment could be used in distance
...
Splitted custom segment, moved to separate header
[SVN r64115]
2010-07-17 20:59:30 +00:00
Barend Gehrels
db53e722db
Removed traits::append_point.
...
The library now used std::back_insert_iterator everywhere
[SVN r64113]
2010-07-17 20:26:29 +00:00
Barend Gehrels
516e7cafb4
Added clear for multi-geometries
...
[SVN r64098]
2010-07-17 14:25:33 +00:00
Barend Gehrels
33b785b225
Removed "use_std" for linestring / linear_ring because it is not necessary. Default now does "push_back", specialization possible
...
Plus necessary changes for this.
Also moved stuff from test distance to test_distance.hpp
[SVN r64095]
2010-07-17 14:02:12 +00:00
Barend Gehrels
8cf84e37b6
Added Point-Point strategy to default_strategy for Point-segment
...
Added some MPL assertions
Updated distance tests
[SVN r64087]
2010-07-17 10:46:25 +00:00
Barend Gehrels
2f4ae2c6b6
Added remove_const (here it is necessary to avoid vector<const point_type>)
...
[SVN r63997]
2010-07-13 20:13:52 +00:00
Barend Gehrels
659b1e8366
Removed redundant remove_const calls
...
Added function_types approach for simplify
[SVN r63994]
2010-07-13 19:59:29 +00:00
Barend Gehrels
12392703d5
Removed redundant typenames
...
[SVN r63991]
2010-07-13 18:55:27 +00:00
Barend Gehrels
6665ed83c3
Applied new approach using function_types instead of member types to point-segment-distance strategies
...
[SVN r63988]
2010-07-13 18:48:43 +00:00
Barend Gehrels
9cca814e47
Removed remove_member_function_pointer, we use function_types now
...
[SVN r63973]
2010-07-13 17:59:11 +00:00
Barend Gehrels
fc813439b0
Using function_types now instead of defining first_point_type and second_point_type
...
[SVN r63971]
2010-07-13 17:40:11 +00:00
Barend Gehrels
c2b901f8eb
Added template parameter to ellipsoid
...
[SVN r63842]
2010-07-11 10:57:45 +00:00
Barend Gehrels
42e22b922e
Updated definition of PI to support templated UDT
...
Updated Andoyer for high precision
[SVN r63839]
2010-07-11 09:40:32 +00:00
Barend Gehrels
0c7383dc5b
ttmath exp/mnt reversal
...
removed first/second point type (as it is only necessary for concept checking)
[SVN r63707]
2010-07-06 20:46:37 +00:00
Barend Gehrels
49618c7e0d
Replaced member-type return_type by meta-function return_type
...
[SVN r63706]
2010-07-06 20:15:59 +00:00
Barend Gehrels
7b1b14a5a0
Added (possibly temporary) ttmath as extension / contribution, for testing high precision
...
[SVN r63668]
2010-07-05 17:06:03 +00:00
Barend Gehrels
bf45a7c988
strategy_distance is now better named to services::default_strategy (with version for point and segment)
...
strategy_tag is now services::tag everywhere
[SVN r63634]
2010-07-04 21:29:06 +00:00
Barend Gehrels
71ac1282e3
Removed more std:: occurances
...
Added high precision for Vincenty
[SVN r63601]
2010-07-04 16:03:33 +00:00
Barend Gehrels
7bb11ad3f0
Added comparable_distance
...
Removed geometry::math::pi, now using boost::constants::pi
Solved abs/std::abs issues (2)
[SVN r63593]
2010-07-04 13:26:08 +00:00
Barend Gehrels
c125309514
Fix in new abs approach for transform (unit sphere forwards/backwards was not exactly 1.000 by rounding errors)
...
[SVN r63591]
2010-07-04 12:44:42 +00:00
Barend Gehrels
89acf8d4e6
Solved abs/std::abs issues
...
[SVN r63590]
2010-07-04 12:19:55 +00:00
Barend Gehrels
c06164f32c
Fixed for gcc
...
[SVN r63586]
2010-07-04 11:36:38 +00:00
Barend Gehrels
7e2ebcf144
Fixed warning and bug in new distance approach
...
[SVN r63582]
2010-07-04 10:14:59 +00:00
Barend Gehrels
0d48c4fe3c
Fixed default parameter of default_distance_strategy_segment
...
[SVN r63581]
2010-07-04 10:09:25 +00:00
Barend Gehrels
ddb8894b81
Added non-const version of get_section
...
Major changes in distance strategies
Changed double from simplify to template parameter
Added a promote_floating_point
Added a fp_coordinate_type
Added namespaced point in custom example
Added mpl assertion in overlaps (should be done in most algorithms by default)
Added high precision test for various distance algorithms
[SVN r63580]
2010-07-04 10:07:22 +00:00
Barend Gehrels
9c23118c37
Added non-const version of get_section
...
Major changes in distance strategies
Changed double from simplify to template parameter
Added a promote_floating_point
Added a fp_coordinate_type
Added namespaced point in custom example
Added mpl assertion in overlaps (should be done in most algorithms by default)
Added high precision test for various distance algorithms
[SVN r63579]
2010-07-04 10:01:10 +00:00
Barend Gehrels
dba12f1660
Minor cosmetic changes
...
[SVN r63558]
2010-07-03 19:56:28 +00:00
Barend Gehrels
4dcea0ced6
Follow-up, fixed renamed field
...
[SVN r63132]
2010-06-20 12:22:27 +00:00
Barend Gehrels
1605264c57
Greatly simplified the registration of point classes, thereby enabling points with namespaces and/or points class templates
...
[SVN r63131]
2010-06-20 12:15:11 +00:00
Barend Gehrels
8b260caec8
Added ever_circling_range_iterator (range version)
...
Small adaptions to get_turns
[SVN r62180]
2010-05-24 20:52:33 +00:00
Barend Gehrels
8e9dfdf3e6
Moved order/closure outside dispatches, not necessary there / more overhead
...
Implemented order/closure in within
[SVN r62175]
2010-05-24 17:03:41 +00:00
Barend Gehrels
520dd593b6
Jamfile update
...
Fixed perimeter for non-closed rings
[SVN r62173]
2010-05-24 14:01:10 +00:00
Barend Gehrels
5fb11344e4
Corrected closure for area
...
Added closure for centroid
Modified/fixed closing iterator (didn't compile for MSVC 2010)
[SVN r62172]
2010-05-24 13:54:32 +00:00
Barend Gehrels
04d8c000be
Fixed syntax in equal / closing_iterator (will be iterator_facade)
...
[SVN r62171]
2010-05-24 11:31:08 +00:00
Barend Gehrels
068c2fa90a
Added closed / closure
...
Updated jamfiles
[SVN r62170]
2010-05-24 09:07:05 +00:00
Barend Gehrels
b35d1d74f0
Updates for clang
...
[SVN r62070]
2010-05-17 19:51:46 +00:00
Barend Gehrels
d6d33fbd38
Added optional flag to base iterator
...
Added closing iterator
Added closeable_view
[SVN r61760]
2010-05-04 15:49:16 +00:00
Barend Gehrels
7380fda632
Implemented circular_iterator to reverse also backwards
...
Reversed const std::string -> std::string const for consistency
Default mirror tempate argument for map transformer
Set embed manifest to false because of after-link errors, sometimes but not always, on VC2005 / Win7 / 64 bits
[SVN r61739]
2010-05-02 21:38:12 +00:00
Barend Gehrels
6078e42285
Update for gcc (4) - first solutions were not accepted - might be solved using this-> but now solved differently
...
[SVN r61712]
2010-04-30 16:42:07 +00:00
Barend Gehrels
915f5c66f1
Update for gcc (3)
...
[SVN r61711]
2010-04-30 16:34:43 +00:00
Barend Gehrels
a251750de3
Update for gcc (2)
...
[SVN r61710]
2010-04-30 16:32:48 +00:00
Barend Gehrels
bceab2b0f2
Update for gcc
...
[SVN r61709]
2010-04-30 16:22:23 +00:00
Barend Gehrels
da5e753d62
Updated paths
...
Added ccw test for area
[SVN r61707]
2010-04-30 14:58:07 +00:00
Barend Gehrels
64f3bdb447
Changed area behaviour (now using reversible view to support ccw poylgons)
...
Added some buffer alternatives (all not perfect)
[SVN r61701]
2010-04-30 09:11:07 +00:00
Barend Gehrels
1108f3cab3
Move overlay -> detail/overlay phase 2, moving files and adapting includes
...
[SVN r61544]
2010-04-24 16:57:53 +00:00
Barend Gehrels
ee78fe9333
Moved section iterators to extensions
...
Solved wxwidges vcproj
Removed /W4 flag in Jamroot
[SVN r61536]
2010-04-24 14:22:22 +00:00
Barend Gehrels
94cca2747c
Moved buffer to extensions (includes)
...
[SVN r61535]
2010-04-24 14:20:48 +00:00
Barend Gehrels
9472704c05
Moved buffer to extensions
...
[SVN r61533]
2010-04-24 14:14:20 +00:00
Barend Gehrels
099c4ee88a
Stylistic changes, harmonizing const T& -> T const&
...
[SVN r61527]
2010-04-24 12:09:54 +00:00
Barend Gehrels
1609ce14ee
Stylistic changes, harmonizing range_const_iterator<T> -> range_iterator<T const>
...
Removing remove_const or adding remove_const.hpp where possible / necessary
[SVN r61526]
2010-04-24 09:35:17 +00:00
Barend Gehrels
2f0817f7a8
Stylistic changes
...
[SVN r61512]
2010-04-23 20:53:06 +00:00
Barend Gehrels
754c51e3e5
Added boost/range.hpp where necessary (often replaces /functions and /metafunctions)
...
Some stylistic changes
[SVN r61511]
2010-04-23 17:47:33 +00:00
Barend Gehrels
d86ad883a4
Added forgotten typename
...
[SVN r61509]
2010-04-23 16:03:22 +00:00
Barend Gehrels
547e244209
Last changes in buffer before moving it to extensions
...
Changes in dissolver/split rings
Added extensions/offset
Added const behaviour for for_each_coordinate
Aded reverse test for intersection
[SVN r61507]
2010-04-23 15:45:17 +00:00
Barend Gehrels
fccdc12ee6
Added missing std:: include files cstddef,vector,deque,map,string
...
[SVN r61493]
2010-04-22 21:59:06 +00:00
Barend Gehrels
7bd58d04a6
Moved "dissolve multi_linestring" to separate algorithm "connect" (in Extension) because it is actually not dissolve, and will need separate strategies
...
[SVN r61463]
2010-04-21 14:42:35 +00:00
Barend Gehrels
5cfdb62a4d
Added "reversible_view" to allow iterating forward/backward through a range based on a template parameter
...
[SVN r61366]
2010-04-18 17:41:33 +00:00
Barend Gehrels
8b337ef55d
Centroid - update for different coordinate types
...
Added buffer join round strategy, new implementation
[SVN r61228]
2010-04-12 16:24:13 +00:00
Barend Gehrels
d800cfd056
Updated buffer / double->coordinate_type
...
Added buffering new approach (per segment), do not use this yet.
[SVN r61227]
2010-04-12 16:19:51 +00:00
Mateusz Loskot
305df85138
Geometry: missing <vector> header in algorithms/equals.hpp
...
[SVN r61170]
2010-04-09 21:24:57 +00:00
Mateusz Loskot
62e5034d51
Geometry: missing typename keyword to allow name lookup for vector::const_iterator in dissolve_multi::apply().
...
[SVN r61169]
2010-04-09 20:58:16 +00:00
Barend Gehrels
e1bf818b97
Removed quadratic behavior in split_rings, now one call to get_turns, sort turns, and split
...
[SVN r61121]
2010-04-07 12:00:15 +00:00
Barend Gehrels
9ddef70ee5
Replaced BOOST_FOREACH by normal loop
...
[SVN r61099]
2010-04-06 12:18:02 +00:00
Barend Gehrels
94aed71cbc
fixed dissolve linestring->ring
...
[SVN r61039]
2010-04-04 12:29:35 +00:00
Barend Gehrels
765060bf5a
Fixed multi_dissolve using new dissolver
...
Dissolve now outputs, normally, to a vector of the original geometry, or, in case of a multi, to its single type. Like union and intersection
Implemented multi_dissolve for not-connected linestrings
Fixed some accidental tabs from testcases
[SVN r61036]
2010-04-04 11:10:26 +00:00
Barend Gehrels
ebe3ff9f1c
Buffer - update for gcc, abs->std::abs
...
[SVN r61027]
2010-04-03 20:33:14 +00:00
Barend Gehrels
c1f1e7b816
Many changes for / related to buffer
...
[SVN r61019]
2010-04-03 13:37:34 +00:00
Mateusz Loskot
79b7468411
Geometry: trivial updates to a few Doxygen comments - testing Doxygen output.
...
[SVN r60712]
2010-03-19 21:01:09 +00:00
Barend Gehrels
3483e972fc
Added gcc-missing include file for multi/dissolve
...
[SVN r60648]
2010-03-16 12:44:08 +00:00
Barend Gehrels
403971c45b
Updated multi/equals to new approach
...
[SVN r60647]
2010-03-16 12:41:17 +00:00
Barend Gehrels
7db23dc6f8
Moved sectionalize/get_section to detail/sections/
...
[SVN r60642]
2010-03-16 11:35:47 +00:00
Barend Gehrels
288c14fee0
Removed accidental tabs
...
[SVN r60641]
2010-03-16 11:01:49 +00:00
Barend Gehrels
31ce90bbc5
Updated monotonic sections, splitted sectionalize_range to sectionalize_part to be able to create sections on-the-fly
...
[SVN r60640]
2010-03-16 10:59:25 +00:00
Barend Gehrels
f85e60d04f
Some stylistic changes, added optional SameScale paramter to mapper, added policy for remove_spikes
...
[SVN r60609]
2010-03-15 09:34:08 +00:00
Barend Gehrels
df92b1b557
Removed accidental tabs
...
[SVN r60596]
2010-03-14 23:01:47 +00:00
Barend Gehrels
0f58541268
Bugfix in equals (and removed tabs)
...
[SVN r60595]
2010-03-14 23:00:27 +00:00
Barend Gehrels
291f098d4b
Small changes in layout
...
[SVN r60592]
2010-03-14 22:22:39 +00:00
Barend Gehrels
f3726574d4
Reworked equals
...
[SVN r60591]
2010-03-14 22:21:49 +00:00
Barend Gehrels
6f6864faef
Updated dissolve ("dissolve" renamed to "dissolve_inserter", added free function "dissolve")
...
Added dissolve for multipolygons
[SVN r60578]
2010-03-14 14:30:06 +00:00
Barend Gehrels
8823fd19ce
Multi uses same structure as reverse now, detail/modify
...
[SVN r60553]
2010-03-13 12:57:16 +00:00
Barend Gehrels
11a4c3d7d8
Added reverse for multi_linestring
...
Used generic "modify" for reverse
[SVN r60551]
2010-03-13 12:27:37 +00:00
Mateusz Loskot
40e623b954
Geometry: added Doxygen @file command and doxygenized comments in register/point.hpp, so Doxygen generates docs for it. Part of testing dox2boostbook for public macros.
...
[SVN r60519]
2010-03-12 14:22:04 +00:00
Barend Gehrels
a5e5785d40
Fix in circle
...
Added reverse for multi
[SVN r60342]
2010-03-08 09:56:24 +00:00
Barend Gehrels
e562723ea8
Fixed namespace ending parenthesis
...
[SVN r60341]
2010-03-08 09:52:23 +00:00
Mateusz Loskot
48937ecb80
Geometry: moved Index template parameter comments next to the right versions of get/set accessors. Use tripple /// for testing with new reference.{doxygen|.xsl} generator.
...
[SVN r60332]
2010-03-07 22:58:07 +00:00
Barend Gehrels
7abd0bb0aa
Added difference and sym_difference
...
Added reverse conform std::reverse
[SVN r60001]
2010-02-28 21:20:07 +00:00
Barend Gehrels
1b8ad7edec
Bugfix in visit_info
...
Added multi-line behaviour for svg_mapper
Added remove_spikes algorithm in extensions
[SVN r59960]
2010-02-27 14:02:20 +00:00
Mateusz Loskot
3748d38e35
Geometry: testing doxygen and quickbook integration with /// style comments and formatting of varios elements of synopsis.
...
[SVN r59851]
2010-02-23 00:31:24 +00:00
Barend Gehrels
7a85b4c1f9
Moved rejected to the operation level, now state of visited
...
This solves cases 56/57. 55 still to be solved
[SVN r59806]
2010-02-21 12:38:45 +00:00
Mateusz Loskot
85ad11676a
Geometry: fixed comment in util/math.hpp
...
[SVN r59793]
2010-02-20 20:33:33 +00:00
Barend Gehrels
3b3d80ff0d
Projection - header updates
...
[SVN r59789]
2010-02-20 19:17:00 +00:00
Barend Gehrels
c8e66e9f0b
Fix pconic projection (by using proj trunk)
...
Removed most types from projections for compilation time
Style change in projection factory
[SVN r59788]
2010-02-20 19:09:17 +00:00
Barend Gehrels
c16c094b9e
Updated svg_mapper
...
Updated 07_graph_route_example.cpp using svg_mapper now
[SVN r59787]
2010-02-20 17:28:53 +00:00
Barend Gehrels
ef4ab98d72
Added algorithms (a.o. buffer) and geometries/registration macros
...
[SVN r59783]
2010-02-20 16:40:13 +00:00
Barend Gehrels
ec65a47e2f
Added extensions
...
[SVN r59779]
2010-02-20 16:24:09 +00:00
Barend Gehrels
5f6e73bc33
Silenced warnings
...
[SVN r59776]
2010-02-20 15:47:52 +00:00
Barend Gehrels
cead073c84
Added libs/geometry/test folder with many tests
...
[SVN r59773]
2010-02-20 15:03:37 +00:00
Barend Gehrels
d78f0db938
Fixed num_geometries include
...
[SVN r59764]
2010-02-20 11:03:02 +00:00
Barend Gehrels
9b2f85075f
Added num_geometries, dissolve
...
Fixed self turn points, new template parameter
[SVN r59763]
2010-02-20 11:00:51 +00:00
Barend Gehrels
394bb3dea4
Replaced "return_if_found" by InterruptPolicy
...
[SVN r59684]
2010-02-14 21:51:08 +00:00
Barend Gehrels
6f78325fec
Additions and some fixes
...
[SVN r59678]
2010-02-14 14:50:03 +00:00
Barend Gehrels
132fdd87ee
Bugfix in assemble for multi
...
Bugfix in get_turns in one constellation
Other preparations for dissolve/buffer
[SVN r59593]
2010-02-09 09:24:02 +00:00
Barend Gehrels
8f7e3593e9
Boost.Geometry, small update
...
[SVN r59384]
2010-01-31 21:27:11 +00:00
Barend Gehrels
16df4ca38c
Update copyright + include files
...
[SVN r59382]
2010-01-31 21:13:43 +00:00
Barend Gehrels
eef963ea3e
First update after acceptance, renamed to Boost.Geometry, revised intersections, plus more changes
...
[SVN r59381]
2010-01-31 21:11:12 +00:00