annotate DEPENDENCIES/generic/include/boost/icl/open_interval.hpp @ 125:34e428693f5d vext

Vext -> Repoint
author Chris Cannam
date Thu, 14 Jun 2018 11:15:39 +0100
parents c530137014c0
children
rev   line source
Chris@16 1 /*-----------------------------------------------------------------------------+
Chris@16 2 Copyright (c) 2010-2010: Joachim Faulhaber
Chris@16 3 +------------------------------------------------------------------------------+
Chris@16 4 Distributed under the Boost Software License, Version 1.0.
Chris@16 5 (See accompanying file LICENCE.txt or copy at
Chris@16 6 http://www.boost.org/LICENSE_1_0.txt)
Chris@16 7 +-----------------------------------------------------------------------------*/
Chris@16 8 #ifndef BOOST_ICL_OPEN_INTERVAL_HPP_JOFA_100930
Chris@16 9 #define BOOST_ICL_OPEN_INTERVAL_HPP_JOFA_100930
Chris@16 10
Chris@16 11 #include <functional>
Chris@16 12 #include <boost/concept/assert.hpp>
Chris@101 13 #include <boost/icl/detail/concept_check.hpp>
Chris@16 14 #include <boost/icl/concept/interval.hpp>
Chris@16 15 #include <boost/icl/type_traits/value_size.hpp>
Chris@16 16 #include <boost/icl/type_traits/type_to_string.hpp>
Chris@16 17
Chris@16 18 namespace boost{namespace icl
Chris@16 19 {
Chris@16 20
Chris@16 21 template <class DomainT,
Chris@16 22 ICL_COMPARE Compare = ICL_COMPARE_INSTANCE(ICL_COMPARE_DEFAULT, DomainT)>
Chris@16 23 class open_interval
Chris@16 24 {
Chris@16 25 public:
Chris@16 26 typedef open_interval<DomainT,Compare> type;
Chris@16 27 typedef DomainT domain_type;
Chris@16 28 typedef ICL_COMPARE_DOMAIN(Compare,DomainT) domain_compare;
Chris@16 29
Chris@16 30 public:
Chris@16 31 //==========================================================================
Chris@16 32 //= Construct, copy, destruct
Chris@16 33 //==========================================================================
Chris@16 34 /** Default constructor; yields an empty interval <tt>(0,0)</tt>. */
Chris@16 35 open_interval()
Chris@16 36 : _lwb(identity_element<DomainT>::value()), _upb(identity_element<DomainT>::value())
Chris@16 37 {
Chris@16 38 BOOST_CONCEPT_ASSERT((DefaultConstructibleConcept<DomainT>));
Chris@16 39 BOOST_CONCEPT_ASSERT((LessThanComparableConcept<DomainT>));
Chris@16 40 }
Chris@16 41
Chris@16 42 //NOTE: Compiler generated copy constructor is used
Chris@16 43
Chris@16 44 /** Constructor for an open singleton interval <tt>(val-1,val+1)</tt> */
Chris@16 45 explicit open_interval(const DomainT& val)
Chris@16 46 : _lwb(pred(val)), _upb(succ(val))
Chris@16 47 {
Chris@16 48 BOOST_CONCEPT_ASSERT((DefaultConstructibleConcept<DomainT>));
Chris@16 49 BOOST_CONCEPT_ASSERT((LessThanComparableConcept<DomainT>));
Chris@16 50 // Only for discrete types this ctor creates an interval containing
Chris@16 51 // a single element only.
Chris@16 52 BOOST_STATIC_ASSERT((icl::is_discrete<DomainT>::value));
Chris@16 53 BOOST_ASSERT((numeric_minimum<DomainT, domain_compare, is_numeric<DomainT>::value >
Chris@16 54 ::is_less_than(val) ));
Chris@16 55 }
Chris@16 56
Chris@16 57 /** Interval from <tt>low</tt> to <tt>up</tt> with bounds <tt>bounds</tt> */
Chris@16 58 open_interval(const DomainT& low, const DomainT& up) :
Chris@16 59 _lwb(low), _upb(up)
Chris@16 60 {
Chris@16 61 BOOST_CONCEPT_ASSERT((DefaultConstructibleConcept<DomainT>));
Chris@16 62 BOOST_CONCEPT_ASSERT((LessThanComparableConcept<DomainT>));
Chris@16 63 }
Chris@16 64
Chris@16 65 DomainT lower()const{ return _lwb; }
Chris@16 66 DomainT upper()const{ return _upb; }
Chris@16 67
Chris@16 68 private:
Chris@16 69 DomainT _lwb;
Chris@16 70 DomainT _upb;
Chris@16 71 };
Chris@16 72
Chris@16 73 //==============================================================================
Chris@16 74 //=T open_interval -> concept intervals
Chris@16 75 //==============================================================================
Chris@16 76 template<class DomainT, ICL_COMPARE Compare>
Chris@16 77 struct interval_traits< icl::open_interval<DomainT, Compare> >
Chris@16 78 {
Chris@16 79 typedef DomainT domain_type;
Chris@16 80 typedef ICL_COMPARE_DOMAIN(Compare,DomainT) domain_compare;
Chris@16 81 typedef icl::open_interval<DomainT, Compare> interval_type;
Chris@16 82
Chris@16 83 static interval_type construct(const domain_type& lo, const domain_type& up)
Chris@16 84 {
Chris@16 85 return interval_type(lo, up);
Chris@16 86 }
Chris@16 87
Chris@16 88 static domain_type lower(const interval_type& inter_val){ return inter_val.lower(); };
Chris@16 89 static domain_type upper(const interval_type& inter_val){ return inter_val.upper(); };
Chris@16 90 };
Chris@16 91
Chris@16 92
Chris@16 93 //==============================================================================
Chris@16 94 //= Type traits
Chris@16 95 //==============================================================================
Chris@16 96 template <class DomainT, ICL_COMPARE Compare>
Chris@16 97 struct interval_bound_type< open_interval<DomainT,Compare> >
Chris@16 98 {
Chris@16 99 typedef interval_bound_type type;
Chris@16 100 BOOST_STATIC_CONSTANT(bound_type, value = interval_bounds::static_open);
Chris@16 101 };
Chris@16 102
Chris@16 103 template <class DomainT, ICL_COMPARE Compare>
Chris@16 104 struct type_to_string<icl::open_interval<DomainT,Compare> >
Chris@16 105 {
Chris@16 106 static std::string apply()
Chris@16 107 { return "(I)<"+ type_to_string<DomainT>::apply() +">"; }
Chris@16 108 };
Chris@16 109
Chris@16 110 template<class DomainT, ICL_COMPARE Compare>
Chris@16 111 struct value_size<icl::open_interval<DomainT,Compare> >
Chris@16 112 {
Chris@16 113 static std::size_t apply(const icl::open_interval<DomainT>&)
Chris@16 114 { return 2; }
Chris@16 115 };
Chris@16 116
Chris@16 117 }} // namespace icl boost
Chris@16 118
Chris@16 119 #endif
Chris@16 120