psimpl 7
psimpl Namespace Reference

Root namespace of the polyline simplification library. More...

Namespaces

namespace  math
 

Contains functions for calculating statistics and distances between various geometric entities.


namespace  util
 

Contains utility functions and classes.


Classes

class  PolylineSimplification
 Provides various simplification algorithms for n-dimensional simple polylines. More...

Functions

template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator simplify_nth_point (ForwardIterator first, ForwardIterator last, unsigned n, OutputIterator result)
 Performs the nth point routine (NP).
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator simplify_radial_distance (ForwardIterator first, ForwardIterator last, typename std::iterator_traits< ForwardIterator >::value_type tol, OutputIterator result)
 Performs the (radial) distance between points routine (RD).
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator simplify_perpendicular_distance (ForwardIterator first, ForwardIterator last, typename std::iterator_traits< ForwardIterator >::value_type tol, unsigned repeat, OutputIterator result)
 Repeatedly performs the perpendicular distance routine (PD).
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator simplify_perpendicular_distance (ForwardIterator first, ForwardIterator last, typename std::iterator_traits< ForwardIterator >::value_type tol, OutputIterator result)
 Performs the perpendicular distance routine (PD).
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator simplify_reumann_witkam (ForwardIterator first, ForwardIterator last, typename std::iterator_traits< ForwardIterator >::value_type tol, OutputIterator result)
 Performs Reumann-Witkam polyline simplification (RW).
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator simplify_opheim (ForwardIterator first, ForwardIterator last, typename std::iterator_traits< ForwardIterator >::value_type min_tol, typename std::iterator_traits< ForwardIterator >::value_type max_tol, OutputIterator result)
 Performs Opheim polyline simplification (OP).
template<unsigned DIM, class BidirectionalIterator , class OutputIterator >
OutputIterator simplify_lang (BidirectionalIterator first, BidirectionalIterator last, typename std::iterator_traits< BidirectionalIterator >::value_type tol, unsigned look_ahead, OutputIterator result)
 Performs Lang polyline simplification (LA).
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator simplify_douglas_peucker (ForwardIterator first, ForwardIterator last, typename std::iterator_traits< ForwardIterator >::value_type tol, OutputIterator result)
 Performs Douglas-Peucker polyline simplification (DP).
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator simplify_douglas_peucker_n (ForwardIterator first, ForwardIterator last, unsigned count, OutputIterator result)
 Performs a variant of Douglas-Peucker polyline simplification (DPn).
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator compute_positional_errors2 (ForwardIterator original_first, ForwardIterator original_last, ForwardIterator simplified_first, ForwardIterator simplified_last, OutputIterator result, bool *valid=0)
 Computes the squared positional error between a polyline and its simplification.
template<unsigned DIM, class ForwardIterator >
math::Statistics compute_positional_error_statistics (ForwardIterator original_first, ForwardIterator original_last, ForwardIterator simplified_first, ForwardIterator simplified_last, bool *valid=0)
 Computes statistics for the positional errors between a polyline and its simplification.

Detailed Description

Root namespace of the polyline simplification library.


Function Documentation

template<unsigned DIM, class ForwardIterator >
math::Statistics psimpl::compute_positional_error_statistics ( ForwardIterator  original_first,
ForwardIterator  original_last,
ForwardIterator  simplified_first,
ForwardIterator  simplified_last,
bool *  valid = 0 
)

Computes statistics for the positional errors between a polyline and its simplification.

This is a convenience function that provides template type deduction for PolylineSimplification::ComputePositionalErrorStatistics.

Parameters:
[in]original_firstthe first coordinate of the first polyline point
[in]original_lastone beyond the last coordinate of the last polyline point
[in]simplified_firstthe first coordinate of the first simplified polyline point
[in]simplified_lastone beyond the last coordinate of the last simplified polyline point
[out]valid[optional] indicates if the computed statistics are valid
Returns:
the computed statistics
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator psimpl::compute_positional_errors2 ( ForwardIterator  original_first,
ForwardIterator  original_last,
ForwardIterator  simplified_first,
ForwardIterator  simplified_last,
OutputIterator  result,
bool *  valid = 0 
)

Computes the squared positional error between a polyline and its simplification.

This is a convenience function that provides template type deduction for PolylineSimplification::ComputePositionalErrors2.

Parameters:
[in]original_firstthe first coordinate of the first polyline point
[in]original_lastone beyond the last coordinate of the last polyline point
[in]simplified_firstthe first coordinate of the first simplified polyline point
[in]simplified_lastone beyond the last coordinate of the last simplified polyline point
[in]resultdestination of the squared positional errors
[out]valid[optional] indicates if the computed positional errors are valid
Returns:
one beyond the last computed positional error
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator psimpl::simplify_douglas_peucker ( ForwardIterator  first,
ForwardIterator  last,
typename std::iterator_traits< ForwardIterator >::value_type  tol,
OutputIterator  result 
)

Performs Douglas-Peucker polyline simplification (DP).

This is a convenience function that provides template type deduction for PolylineSimplification::DouglasPeucker.

Parameters:
[in]firstthe first coordinate of the first polyline point
[in]lastone beyond the last coordinate of the last polyline point
[in]tolperpendicular (point-to-segment) distance tolerance
[in]resultdestination of the simplified polyline
Returns:
one beyond the last coordinate of the simplified polyline
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator psimpl::simplify_douglas_peucker_n ( ForwardIterator  first,
ForwardIterator  last,
unsigned  count,
OutputIterator  result 
)

Performs a variant of Douglas-Peucker polyline simplification (DPn).

This is a convenience function that provides template type deduction for PolylineSimplification::DouglasPeuckerAlt.

Parameters:
[in]firstthe first coordinate of the first polyline point
[in]lastone beyond the last coordinate of the last polyline point
[in]countthe maximum number of points of the simplified polyline
[in]resultdestination of the simplified polyline
Returns:
one beyond the last coordinate of the simplified polyline
template<unsigned DIM, class BidirectionalIterator , class OutputIterator >
OutputIterator psimpl::simplify_lang ( BidirectionalIterator  first,
BidirectionalIterator  last,
typename std::iterator_traits< BidirectionalIterator >::value_type  tol,
unsigned  look_ahead,
OutputIterator  result 
)

Performs Lang polyline simplification (LA).

This is a convenience function that provides template type deduction for PolylineSimplification::Lang.

Parameters:
[in]firstthe first coordinate of the first polyline point
[in]lastone beyond the last coordinate of the last polyline point
[in]tolperpendicular (point-to-segment) distance tolerance
[in]look_aheaddefines the size of the search region
[in]resultdestination of the simplified polyline
Returns:
one beyond the last coordinate of the simplified polyline
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator psimpl::simplify_nth_point ( ForwardIterator  first,
ForwardIterator  last,
unsigned  n,
OutputIterator  result 
)

Performs the nth point routine (NP).

This is a convenience function that provides template type deduction for PolylineSimplification::NthPoint.

Parameters:
[in]firstthe first coordinate of the first polyline point
[in]lastone beyond the last coordinate of the last polyline point
[in]nspecifies 'each nth point'
[in]resultdestination of the simplified polyline
Returns:
one beyond the last coordinate of the simplified polyline
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator psimpl::simplify_opheim ( ForwardIterator  first,
ForwardIterator  last,
typename std::iterator_traits< ForwardIterator >::value_type  min_tol,
typename std::iterator_traits< ForwardIterator >::value_type  max_tol,
OutputIterator  result 
)

Performs Opheim polyline simplification (OP).

This is a convenience function that provides template type deduction for PolylineSimplification::Opheim.

Parameters:
[in]firstthe first coordinate of the first polyline point
[in]lastone beyond the last coordinate of the last polyline point
[in]min_tolminimum distance tolerance
[in]max_tolmaximum distance tolerance
[in]resultdestination of the simplified polyline
Returns:
one beyond the last coordinate of the simplified polyline
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator psimpl::simplify_perpendicular_distance ( ForwardIterator  first,
ForwardIterator  last,
typename std::iterator_traits< ForwardIterator >::value_type  tol,
OutputIterator  result 
)

Performs the perpendicular distance routine (PD).

This is a convenience function that provides template type deduction for PolylineSimplification::PerpendicularDistance.

Parameters:
[in]firstthe first coordinate of the first polyline point
[in]lastone beyond the last coordinate of the last polyline point
[in]tolperpendicular (segment-to-point) distance tolerance
[in]resultdestination of the simplified polyline
Returns:
one beyond the last coordinate of the simplified polyline
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator psimpl::simplify_perpendicular_distance ( ForwardIterator  first,
ForwardIterator  last,
typename std::iterator_traits< ForwardIterator >::value_type  tol,
unsigned  repeat,
OutputIterator  result 
)

Repeatedly performs the perpendicular distance routine (PD).

This is a convenience function that provides template type deduction for PolylineSimplification::PerpendicularDistance.

Parameters:
[in]firstthe first coordinate of the first polyline point
[in]lastone beyond the last coordinate of the last polyline point
[in]tolperpendicular (segment-to-point) distance tolerance
[in]repeatthe number of times to successively apply the PD routine.
[in]resultdestination of the simplified polyline
Returns:
one beyond the last coordinate of the simplified polyline
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator psimpl::simplify_radial_distance ( ForwardIterator  first,
ForwardIterator  last,
typename std::iterator_traits< ForwardIterator >::value_type  tol,
OutputIterator  result 
)

Performs the (radial) distance between points routine (RD).

This is a convenience function that provides template type deduction for PolylineSimplification::RadialDistance.

Parameters:
[in]firstthe first coordinate of the first polyline point
[in]lastone beyond the last coordinate of the last polyline point
[in]tolradial (point-to-point) distance tolerance
[in]resultdestination of the simplified polyline
Returns:
one beyond the last coordinate of the simplified polyline
template<unsigned DIM, class ForwardIterator , class OutputIterator >
OutputIterator psimpl::simplify_reumann_witkam ( ForwardIterator  first,
ForwardIterator  last,
typename std::iterator_traits< ForwardIterator >::value_type  tol,
OutputIterator  result 
)

Performs Reumann-Witkam polyline simplification (RW).

This is a convenience function that provides template type deduction for PolylineSimplification::ReumannWitkam.

Parameters:
[in]firstthe first coordinate of the first polyline point
[in]lastone beyond the last coordinate of the last polyline point
[in]tolperpendicular (point-to-line) distance tolerance
[in]resultdestination of the simplified polyline
Returns:
one beyond the last coordinate of the simplified polyline