1[/ 2 Copyright Hans Dembinski 2018 - 2019. 3 Distributed under the Boost Software License, Version 1.0. 4 (See accompanying file LICENSE_1_0.txt or copy at 5 https://www.boost.org/LICENSE_1_0.txt) 6] 7 8[section:DiscreteAxis DiscreteAxis] 9 10A [*DiscreteAxis] is one of two optional refinements of the [link histogram.concepts.Axis [*Axis]] concept, the other one is the [link histogram.concepts.IntervalAxis IntervalAxis]. This concept is for axes in which each bin represents a single value instead of an interval. 11 12Discrete axes can be further divided into ordered and unordered. An axis is ordered, when bin indices i < j < k imply that value[i] < value[j] < value[k] or value[i] > value[j] > value[k] for all i, j, k. The [classref boost::histogram::axis::integer integer axis] is ordered and the [classref boost::histogram::axis::category category axis] is unordered. 13 14An unordered discrete axis cannot have an underflow bin. Since there is no order, one can have at most one extra bin that counts values not handled by the axis. By convention the overflow bin is used for that. 15 16[heading Associated Types] 17 18* [link histogram.concepts.Axis [*Axis]] 19* [link histogram.concepts.IntervalAxis [*IntervalAxis]] 20 21[heading Optional features] 22 23* `A` is a type meeting the requirements of [*DiscreteAxis] 24* `a` is a value of type `A` 25* `V` is the type accepted for conversion into an index 26* `v` is a value of type `V` 27* `i` is a value of type [headerref boost/histogram/fwd.hpp `boost::histogram::axis::index_type`] 28* `AxisIter` is an /RandomAccessIterator/ over the bins of `A` 29* `ReAxisIter` is a reverse /RandomAccessIterator/ over the bins of `A` 30 31[table Valid expressions 32[[Expression] [Returns] [Semantics, Pre/Post-conditions]] 33[ 34 [`a.ordered()`] 35 [`bool`] 36 [ 37 Static constexpr member function which returns true if the axis is ordered and false otherwise. If this is absent, the library checks whether the value type is arithmetic instead, see [funcref boost::histogram::axis::traits::ordered]. 38 ] 39] 40[ 41 [`a.value(i)`] 42 [`V`] 43 [ 44 Const member function which maps an index to a value. The mapping must be injective: each index must be uniquely mapped to one value. The effect must be exactly the inverse of `a.index(v)`. The return value may be a const reference, if the lifetime of the referred object is equal to the lifetime of the axis. 45 ] 46] 47[ 48 [`a.bin(i)`] 49 [`V`] 50 [ 51 Must have the same effect as `a.value(i)`. 52 ] 53] 54[ 55 [`s.begin()`] 56 [`AxisIter`] 57 [ 58 Const member function which return an iterator to the bin with index `0`. 59 ] 60] 61[ 62 [`s.end()`] 63 [`AxisIter`] 64 [ 65 Const member function which returns an iterator to the bin with index `s.size()`. 66 ] 67] 68[ 69 [`s.rbegin()`] 70 [`ReAxisIter`] 71 [ 72 Const member function which return a reverse iterator to the bin with index `s.size()-1`. 73 ] 74] 75[ 76 [`s.rend()`] 77 [`ReAxisIter`] 78 [ 79 Const member function which returns an iterator to the bin with index `-1`. 80 ] 81] 82] 83 84[tip The complete iterator interface can be added to a user-defined axis which implements `a.bin(i)` by inheriting from the [classref boost::histogram::axis::iterator_mixin iterator_mixin].] 85 86[heading Models] 87 88* [classref boost::histogram::axis::category] 89* [classref boost::histogram::axis::integer], if first template parameter is `int` 90 91[endsect] 92