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