annotate DEPENDENCIES/generic/include/boost/icl/closed_interval.hpp @ 16:2665513ce2d3

Add boost headers
author Chris Cannam
date Tue, 05 Aug 2014 11:11:38 +0100
parents
children c530137014c0
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_CLOSED_INTERVAL_HPP_JOFA_100324
Chris@16 9 #define BOOST_ICL_CLOSED_INTERVAL_HPP_JOFA_100324
Chris@16 10
Chris@16 11 #include <boost/icl/concept/interval.hpp>
Chris@16 12 #include <boost/icl/type_traits/value_size.hpp>
Chris@16 13 #include <boost/icl/type_traits/type_to_string.hpp>
Chris@16 14
Chris@16 15 namespace boost{namespace icl
Chris@16 16 {
Chris@16 17
Chris@16 18 template <class DomainT,
Chris@16 19 ICL_COMPARE Compare = ICL_COMPARE_INSTANCE(ICL_COMPARE_DEFAULT, DomainT)>
Chris@16 20 class closed_interval
Chris@16 21 {
Chris@16 22 public:
Chris@16 23 typedef closed_interval<DomainT,Compare> type;
Chris@16 24 typedef DomainT domain_type;
Chris@16 25 typedef ICL_COMPARE_DOMAIN(Compare,DomainT) domain_compare;
Chris@16 26
Chris@16 27 public:
Chris@16 28 //==========================================================================
Chris@16 29 //= Construct, copy, destruct
Chris@16 30 //==========================================================================
Chris@16 31 /** Default constructor; yields an empty interval <tt>[0,0)</tt>. */
Chris@16 32 closed_interval()
Chris@16 33 : _lwb(unit_element<DomainT>::value()), _upb(identity_element<DomainT>::value())
Chris@16 34 {
Chris@16 35 BOOST_CONCEPT_ASSERT((DefaultConstructibleConcept<DomainT>));
Chris@16 36 BOOST_CONCEPT_ASSERT((LessThanComparableConcept<DomainT>));
Chris@16 37 BOOST_STATIC_ASSERT((icl::is_discrete<DomainT>::value));
Chris@16 38 }
Chris@16 39
Chris@16 40 //NOTE: Compiler generated copy constructor is used
Chris@16 41
Chris@16 42 /** Constructor for a closed singleton interval <tt>[val,val]</tt> */
Chris@16 43 explicit closed_interval(const DomainT& val)
Chris@16 44 : _lwb(val), _upb(val)
Chris@16 45 {
Chris@16 46 BOOST_CONCEPT_ASSERT((DefaultConstructibleConcept<DomainT>));
Chris@16 47 BOOST_CONCEPT_ASSERT((LessThanComparableConcept<DomainT>));
Chris@16 48 BOOST_STATIC_ASSERT((!icl::is_continuous<DomainT>::value));
Chris@16 49 }
Chris@16 50
Chris@16 51 /** Interval from <tt>low</tt> to <tt>up</tt> with bounds <tt>bounds</tt> */
Chris@16 52 closed_interval(const DomainT& low, const DomainT& up) :
Chris@16 53 _lwb(low), _upb(up)
Chris@16 54 {
Chris@16 55 BOOST_CONCEPT_ASSERT((DefaultConstructibleConcept<DomainT>));
Chris@16 56 BOOST_CONCEPT_ASSERT((LessThanComparableConcept<DomainT>));
Chris@16 57 }
Chris@16 58
Chris@16 59 DomainT lower()const{ return _lwb; }
Chris@16 60 DomainT upper()const{ return _upb; }
Chris@16 61
Chris@16 62 DomainT first()const{ return _lwb; }
Chris@16 63 DomainT last() const{ return _upb; }
Chris@16 64
Chris@16 65 private:
Chris@16 66 DomainT _lwb;
Chris@16 67 DomainT _upb;
Chris@16 68 };
Chris@16 69
Chris@16 70
Chris@16 71 //==============================================================================
Chris@16 72 //=T closed_interval -> concept intervals
Chris@16 73 //==============================================================================
Chris@16 74 template<class DomainT, ICL_COMPARE Compare>
Chris@16 75 struct interval_traits< icl::closed_interval<DomainT, Compare> >
Chris@16 76 {
Chris@16 77 typedef DomainT domain_type;
Chris@16 78 typedef ICL_COMPARE_DOMAIN(Compare,DomainT) domain_compare;
Chris@16 79 typedef icl::closed_interval<DomainT, Compare> interval_type;
Chris@16 80
Chris@16 81 static interval_type construct(const domain_type& lo, const domain_type& up)
Chris@16 82 {
Chris@16 83 return interval_type(lo, up);
Chris@16 84 }
Chris@16 85
Chris@16 86 static domain_type lower(const interval_type& inter_val){ return inter_val.lower(); };
Chris@16 87 static domain_type upper(const interval_type& inter_val){ return inter_val.upper(); };
Chris@16 88 };
Chris@16 89
Chris@16 90 //==============================================================================
Chris@16 91 //= Type traits
Chris@16 92 //==============================================================================
Chris@16 93 template <class DomainT, ICL_COMPARE Compare>
Chris@16 94 struct interval_bound_type< closed_interval<DomainT,Compare> >
Chris@16 95 {
Chris@16 96 typedef interval_bound_type type;
Chris@16 97 BOOST_STATIC_CONSTANT(bound_type, value = interval_bounds::static_closed);
Chris@16 98 };
Chris@16 99
Chris@16 100 template <class DomainT, ICL_COMPARE Compare>
Chris@16 101 struct type_to_string<icl::closed_interval<DomainT,Compare> >
Chris@16 102 {
Chris@16 103 static std::string apply()
Chris@16 104 { return "[I]<"+ type_to_string<DomainT>::apply() +">"; }
Chris@16 105 };
Chris@16 106
Chris@16 107 template<class DomainT>
Chris@16 108 struct value_size<icl::closed_interval<DomainT> >
Chris@16 109 {
Chris@16 110 static std::size_t apply(const icl::closed_interval<DomainT>&)
Chris@16 111 { return 2; }
Chris@16 112 };
Chris@16 113
Chris@16 114 }} // namespace icl boost
Chris@16 115
Chris@16 116 #endif
Chris@16 117