18 #ifndef INCLUDED_UHD_UTILS_ALGORITHM_HPP    19 #define INCLUDED_UHD_UTILS_ALGORITHM_HPP    22 #include <boost/range/begin.hpp>    23 #include <boost/range/end.hpp>    41     template<
typename Range> 
inline Range 
sorted(
const Range &range){
    42         Range r(range); std::sort(boost::begin(r), boost::end(r)); 
return r;
    55     template<
typename Range> 
inline Range 
reversed(
const Range &range){
    56         Range r(range); std::reverse(boost::begin(r), boost::end(r)); 
return r;
    68     template<
typename Range, 
typename T> 
inline    69     bool has(
const Range &range, 
const T &value){
    70         return boost::end(range) != std::find(boost::begin(range), boost::end(range), value);
    80     template<
typename T> 
inline T 
clip(
const T &val, 
const T &bound1, 
const T &bound2){
    81         const T minimum = std::min(bound1, bound2);
    82         if (val < minimum) 
return minimum;
    83         const T maximum = std::max(bound1, bound2);
    84         if (val > maximum) 
return maximum;
 bool has(const Range &range, const T &value)
Definition: algorithm.hpp:69
 
Range reversed(const Range &range)
Definition: algorithm.hpp:55
 
Range sorted(const Range &range)
Definition: algorithm.hpp:41
 
Definition: convert.hpp:28
 
T clip(const T &val, const T &bound1, const T &bound2)
Definition: algorithm.hpp:80