13 #ifndef BOOST_GIL_METAFUNCTIONS_HPP
14 #define BOOST_GIL_METAFUNCTIONS_HPP
30 #include <boost/mpl/accumulate.hpp>
31 #include <boost/mpl/back.hpp>
32 #include <boost/mpl/bool.hpp>
33 #include <boost/mpl/if.hpp>
34 #include <boost/mpl/pop_back.hpp>
35 #include <boost/mpl/push_back.hpp>
36 #include <boost/mpl/transform.hpp>
37 #include <boost/mpl/vector_c.hpp>
38 #include <boost/mpl/vector.hpp>
39 #include <boost/type_traits.hpp>
43 namespace boost {
namespace gil {
46 template <
typename T,
typename L>
struct pixel;
47 template <
typename BitField,
typename ChannelRefVec,
typename Layout>
struct packed_pixel;
53 template <
typename Pixel,
bool IsPlanar,
typename Alloc>
class image;
54 template <
typename T>
struct channel_type;
55 template <
typename T>
struct color_space_type;
56 template <
typename T>
struct channel_mapping_type;
81 template <
typename T,
typename L>
struct pixel_reference_is_basic<const pixel<T,L>&> :
public mpl::true_ {};
82 template <
typename TR,
typename Cs>
struct pixel_reference_is_basic<planar_pixel_reference<TR,Cs> > :
public mpl::true_ {};
83 template <
typename TR,
typename Cs>
struct pixel_reference_is_basic<const planar_pixel_reference<TR,Cs> > :
public mpl::true_ {};
89 template <
typename Iterator>
91 template <
typename T,
typename L>
93 template <
typename T,
typename L>
94 struct iterator_is_basic<const pixel<T,L>* > :
public mpl::true_ {};
95 template <
typename T,
typename Cs>
96 struct iterator_is_basic<planar_pixel_iterator< T*,Cs> > :
public mpl::true_ {};
97 template <
typename T,
typename Cs>
98 struct iterator_is_basic<planar_pixel_iterator<const T*,Cs> > :
public mpl::true_ {};
99 template <
typename T,
typename L>
100 struct iterator_is_basic<memory_based_step_iterator< pixel<T,L>*> > :
public mpl::true_ {};
101 template <
typename T,
typename L>
102 struct iterator_is_basic<memory_based_step_iterator<const pixel<T,L>*> > :
public mpl::true_ {};
103 template <
typename T,
typename Cs>
104 struct iterator_is_basic<memory_based_step_iterator<planar_pixel_iterator< T*,Cs> > > :
public mpl::true_ {};
105 template <
typename T,
typename Cs>
106 struct iterator_is_basic<memory_based_step_iterator<planar_pixel_iterator<const T*,Cs> > > :
public mpl::true_ {};
122 template <
typename Pixel,
bool IsPlanar,
typename Alloc>
struct image_is_basic<
image<Pixel,IsPlanar,Alloc> > :
public mpl::true_ {};
131 template <
typename It,
bool IsBase,
bool EqualsStepType>
struct iterator_is_step_impl;
133 template <
typename It,
bool IsBase>
struct iterator_is_step_impl<It,IsBase,true> :
public mpl::true_{};
136 template <
typename It>
struct iterator_is_step_impl<It,true,false> :
public mpl::false_{};
139 template <
typename It>
struct iterator_is_step_impl<It,false,false>
140 :
public iterator_is_step<typename iterator_adaptor_get_base<It>::type>{};
145 template <
typename I>
struct iterator_is_step
146 :
public detail::iterator_is_step_impl<I,
147 !is_iterator_adaptor<I>::type::value,
148 is_same<I,typename dynamic_x_step_type<I>::type>::value >{};
168 template <
typename PixelReference>
170 :
public mpl::not_<is_same<typename remove_const_and_reference<PixelReference>::type,
171 typename remove_const_and_reference<PixelReference>::type::value_type> > {};
175 template <
typename Pixel>
176 struct pixel_is_reference :
public mpl::or_<is_reference<Pixel>, pixel_reference_is_proxy<Pixel> > {};
221 template <
typename T,
typename L>
struct pixel_reference_type<T,L,false,false> {
typedef const pixel<T,L>& type; };
222 template <
typename T,
typename L>
struct pixel_reference_type<T,L,true,true> {
typedef const planar_pixel_reference<typename channel_traits<T>::reference,
typename color_space_type<L>::type> type; };
223 template <
typename T,
typename L>
struct pixel_reference_type<T,L,true,false> {
typedef const planar_pixel_reference<typename channel_traits<T>::const_reference,
typename color_space_type<L>::type> type; };
229 template <
typename Pixel>
struct iterator_type_from_pixel<Pixel,false,false,false> {
typedef const Pixel* type; };
230 template <
typename Pixel>
struct iterator_type_from_pixel<Pixel,true,false,true> {
231 typedef planar_pixel_iterator<typename channel_traits<typename channel_type<Pixel>::type>::pointer,
typename color_space_type<Pixel>::type> type;
233 template <
typename Pixel>
struct iterator_type_from_pixel<Pixel,true,false,false> {
234 typedef planar_pixel_iterator<typename channel_traits<typename channel_type<Pixel>::type>::const_pointer,
typename color_space_type<Pixel>::type> type;
236 template <
typename Pixel,
bool IsPlanar,
bool IsMutable>
struct iterator_type_from_pixel<Pixel,IsPlanar,true,IsMutable> {
237 typedef memory_based_step_iterator<typename iterator_type_from_pixel<Pixel,IsPlanar,false,IsMutable>::type> type;
242 template <
typename T,
typename L,
bool IsPlanar=false,
bool IsStep=false,
bool IsMutable=true>
struct iterator_type{};
244 template <
typename T,
typename L>
struct iterator_type<T,L,false,false,false> {
typedef const pixel<T,L>* type; };
245 template <
typename T,
typename L>
struct iterator_type<T,L,true,false,true> {
typedef planar_pixel_iterator<T*,typename L::color_space_t> type; };
246 template <
typename T,
typename L>
struct iterator_type<T,L,true,false,false> {
typedef planar_pixel_iterator<const T*,typename L::color_space_t> type; };
247 template <
typename T,
typename L,
bool IsPlanar,
bool IsMutable>
struct iterator_type<T,L,IsPlanar,true,IsMutable> {
248 typedef memory_based_step_iterator<typename iterator_type<T,L,IsPlanar,false,IsMutable>::type> type;
253 template <
typename XIterator>
261 template <
typename BitField,
typename FirstBit,
typename NumBits>
262 struct packed_channel_reference_type {
263 typedef const packed_channel_reference<BitField,FirstBit::value,NumBits::value,true> type;
266 template <
typename BitField,
typename ChannelBitSizesVector>
267 class packed_channel_references_vector_type {
270 typedef typename mpl::accumulate<ChannelBitSizesVector, mpl::vector1<mpl::int_<0> >,
271 mpl::push_back<mpl::_1, mpl::plus<mpl::back<mpl::_1>, mpl::_2> > >::type first_bits_vector;
273 typedef typename mpl::transform<typename mpl::pop_back<first_bits_vector>::type, ChannelBitSizesVector,
274 packed_channel_reference_type<BitField, mpl::_1,mpl::_2> >::type type;
287 template <
typename BitField,
typename ChannelBitSizeVector,
typename Layout>
303 template <
typename BitField,
typename ChannelBitSizeVector,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
310 template <
typename BitField,
unsigned Size1,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
315 template <
typename BitField,
unsigned Size1,
unsigned Size2,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
320 template <
typename BitField,
unsigned Size1,
unsigned Size2,
unsigned Size3,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
325 template <
typename BitField,
unsigned Size1,
unsigned Size2,
unsigned Size3,
unsigned Size4,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
330 template <
typename BitField,
unsigned Size1,
unsigned Size2,
unsigned Size3,
unsigned Size4,
unsigned Size5,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
340 template <
typename ChannelBitSizeVector,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
343 BOOST_STATIC_CONSTANT(
int, bit_size = (mpl::accumulate<ChannelBitSizeVector, mpl::int_<0>, mpl::plus<mpl::_1, mpl::_2> >::type::value));
344 typedef typename detail::min_fast_uint<bit_size+7>::type bitfield_t;
352 template <
unsigned Size1,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
357 template <
unsigned Size1,
unsigned Size2,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
362 template <
unsigned Size1,
unsigned Size2,
unsigned Size3,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
367 template <
unsigned Size1,
unsigned Size2,
unsigned Size3,
unsigned Size4,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
372 template <
unsigned Size1,
unsigned Size2,
unsigned Size3,
unsigned Size4,
unsigned Size5,
typename Layout,
typename Alloc=std::allocator<
unsigned char> >
379 template <
typename Channel,
typename Layout>
385 template <
typename BitField,
int NumBits,
bool IsMutable,
typename Layout>
386 struct pixel_value_type< packed_dynamic_channel_reference<BitField,NumBits,IsMutable>,Layout> :
388 template <
typename BitField,
int NumBits,
bool IsMutable,
typename Layout>
389 struct pixel_value_type<const packed_dynamic_channel_reference<BitField,NumBits,IsMutable>,Layout> :
390 public packed_pixel_type<BitField, mpl::vector1_c<unsigned,NumBits>, Layout> {};
392 template <
typename BitField,
int FirstBit,
int NumBits,
bool IsMutable,
typename Layout>
393 struct pixel_value_type< packed_channel_reference<BitField,FirstBit,NumBits,IsMutable>,Layout> :
394 public packed_pixel_type<BitField, mpl::vector1_c<unsigned,NumBits>, Layout> {};
395 template <
typename BitField,
int FirstBit,
int NumBits,
bool IsMutable,
typename Layout>
396 struct pixel_value_type<const packed_channel_reference<BitField,FirstBit,NumBits,IsMutable>,Layout> :
397 public packed_pixel_type<BitField, mpl::vector1_c<unsigned,NumBits>, Layout> {};
399 template <
int NumBits,
typename Layout>
400 struct pixel_value_type<packed_channel_value<NumBits>,Layout> :
401 public packed_pixel_type<typename detail::min_fast_uint<NumBits>::type, mpl::vector1_c<unsigned,NumBits>, Layout> {};
406 template <
typename T,
typename L,
bool IsPlanar=false,
bool IsStepX=false,
bool IsMutable=true>
413 template <
typename T,
typename L,
bool IsPlanar=false,
bool IsStepX=false,
bool IsMutable=true>
420 template <
typename T,
typename L,
bool IsPlanar=false,
typename Alloc=std::allocator<
unsigned char> >
427 template <
typename Pixel,
bool IsPlanar=false,
bool IsStepX=false,
bool IsMutable=true>
436 template <
typename Ref,
typename T=use_default,
typename L=use_default,
typename IsPlanar=use_default,
typename IsMutable=use_default>
438 typedef typename remove_reference<Ref>::type pixel_t;
439 typedef typename mpl::if_<is_same<T, use_default>,
typename channel_type<pixel_t>::type, T >::type channel_t;
440 typedef typename mpl::if_<is_same<L, use_default>,
443 static const bool planar=mpl::if_<is_same<IsPlanar,use_default>, is_planar<pixel_t>, IsPlanar>::type::value;
451 template <
typename Iterator,
typename T=use_default,
typename L=use_default,
typename IsPlanar=use_default,
typename IsStep=use_default,
typename IsMutable=use_default>
453 typedef typename mpl::if_<is_same<T ,use_default>,
typename channel_type<Iterator>::type, T >::type channel_t;
454 typedef typename mpl::if_<is_same<L,use_default>,
458 static const bool planar=mpl::if_<is_same<IsPlanar,use_default>, is_planar<Iterator>, IsPlanar>::type::value;
467 template <
typename View,
typename T=use_default,
typename L=use_default,
typename IsPlanar=use_default,
typename StepX=use_default,
typename IsMutable=use_default>
469 typedef typename mpl::if_<is_same<T ,use_default>,
typename channel_type<View>::type, T>
::type channel_t;
470 typedef typename mpl::if_<is_same<L,use_default>,
472 static const bool mut =mpl::if_<is_same<IsMutable,use_default>,
view_is_mutable<View>, IsMutable>::type::value;
473 static const bool planar=mpl::if_<is_same<IsPlanar,use_default>, is_planar<View>, IsPlanar>::type::value;
482 template <
typename Image,
typename T=use_default,
typename L=use_default,
typename IsPlanar=use_default>
484 typedef typename mpl::if_<is_same<T ,use_default>,
typename channel_type<Image>::type, T >
::type channel_t;
485 typedef typename mpl::if_<is_same<L,use_default>,
487 static const bool planar=mpl::if_<is_same<IsPlanar,use_default>, is_planar<Image>, IsPlanar>::type::value;
metafunction predicate determining whether the given iterator is a plain one or an adaptor over anoth...
Definition: concept.hpp:72
Returns the type of an interleaved packed image: an image whose channels may not be byte-aligned...
Definition: metafunctions.hpp:304
Determines whether the given pixel reference is a proxy class or a native C++ reference.
Definition: metafunctions.hpp:169
Concept check classes for GIL concepts.
A reference proxy to a planar pixel. Models: HomogeneousColorBaseConcept, HomogeneousPixelConcept.
Definition: metafunctions.hpp:48
Returns the type of a homogeneous image given the channel type, layout, and whether it operates on pl...
Definition: metafunctions.hpp:421
Determines if the given locator has a horizontal step that could be set dynamically.
Definition: metafunctions.hpp:152
Returns the type of a homogeneous view given the channel type, layout, whether it operates on planar ...
Definition: metafunctions.hpp:414
A lightweight object that interprets memory as a 2D array of pixels. Models ImageViewConcept,PixelBasedConcept,HasDynamicXStepTypeConcept,HasDynamicYStepTypeConcept,HasTransposedTypeConcept.
Definition: image_view.hpp:69
returns the base iterator for a given iterator adaptor. Provide an specialization when introducing ne...
Definition: concept.hpp:74
Returns the type of a single-channel image given its bitfield type, the bit size of its channel and i...
Definition: metafunctions.hpp:311
Represents a pixel value (a container of channels). Models: HomogeneousColorBaseValueConcept, PixelValueConcept, HomogeneousPixelBasedConcept.
Definition: metafunctions.hpp:46
Returns the type of a homogeneous iterator given the channel type, layout, whether it operates on pla...
Definition: metafunctions.hpp:242
Returns the type of a four channel image given its bitfield type, the bit size of its channels and it...
Definition: metafunctions.hpp:326
Returns the type of a two channel image given its bitfield type, the bit size of its channels and its...
Definition: metafunctions.hpp:316
Returns the type of a five channel bit-aligned image given the bit size of its channels and its layou...
Definition: metafunctions.hpp:373
Heterogeneous pixel reference corresponding to non-byte-aligned bit range. Models ColorBaseConcept...
Definition: bit_aligned_pixel_reference.hpp:124
Constructs a pixel iterator type from a source pixel iterator type by changing some of the properties...
Definition: metafunctions.hpp:452
An iterator over planar pixels. Models HomogeneousColorBaseConcept, PixelIteratorConcept, HomogeneousPixelBasedConcept, MemoryBasedIteratorConcept, HasDynamicXStepTypeConcept.
Definition: algorithm.hpp:52
Determines if a given pixel iterator is basic Basic iterators must use gil::pixel (if interleaved)...
Definition: metafunctions.hpp:90
Constructs a pixel reference type from a source pixel reference type by changing some of the properti...
Definition: metafunctions.hpp:437
Returns the type of a four channel bit-aligned image given the bit size of its channels and its layou...
Definition: metafunctions.hpp:368
Memory-based pixel locator. Models: PixelLocatorConcept,HasDynamicXStepTypeConcept,HasDynamicYStepTypeConcept,HasTransposedTypeConceptThe class takes a step iterator as a parameter. The step iterator provides navigation along the vertical axis while its base iterator provides horizontal navigation.
Definition: algorithm.hpp:56
Given a pixel iterator defining access to pixels along a row, returns the types of the corresponding ...
Definition: metafunctions.hpp:254
Basic images must use basic views and std::allocator of char.
Definition: metafunctions.hpp:121
Determines if the given pixel reference is mutable (i.e. its channels can be changed) ...
Definition: metafunctions.hpp:186
Determines if the given locator is mutable (i.e. its pixels can be changed)
Definition: metafunctions.hpp:192
Constructs a homogeneous image type from a source image type by changing some of the properties...
Definition: metafunctions.hpp:483
Represents a color space and ordering of channels in memory.
Definition: utility.hpp:321
container interface over image view. Models ImageConcept, PixelBasedConcept
Definition: image.hpp:58
Determines if a given locator is basic. A basic locator is memory-based and has basic x_iterator and ...
Definition: metafunctions.hpp:111
Returns the type of a homogeneous pixel reference given the channel type, layout, whether it operates...
Definition: metafunctions.hpp:219
Returns the type of a packed image whose pixels may not be byte aligned. For example, an "rgb222" image is bit-aligned because its pixel spans six bits.
Definition: metafunctions.hpp:341
Determines if the given view has a vertical step that could be set dynamically.
Definition: metafunctions.hpp:164
Determines if the given view is mutable (i.e. its pixels can be changed)
Definition: metafunctions.hpp:195
Returns the type of a homogeneous pixel given the channel type and layout.
Definition: metafunctions.hpp:380
Returns the type of a homogeneous locator given the channel type, layout, whether it operates on plan...
Definition: metafunctions.hpp:407
Metafunction predicate returning whether the given iterator allows for changing its values...
Definition: concept.hpp:71
Constructs an image view type from a source view type by changing some of the properties.Use use_default for the properties of the source view that you want to keep.
Definition: metafunctions.hpp:468
Returns the type of a packed pixel given its bitfield type, the bit size of its channels and its layo...
Definition: metafunctions.hpp:288
Heterogeneous pixel value whose channel references can be constructed from the pixel bitfield and the...
Definition: concept.hpp:85
Given a model of a pixel, determines whether the model represents a pixel reference (as opposed to pi...
Definition: metafunctions.hpp:176
Returns the type of a single-channel bit-aligned image given the bit size of its channel and its layo...
Definition: metafunctions.hpp:353
Determines if a given pixel reference is basic Basic references must use gil::pixel& (if interleaved)...
Definition: metafunctions.hpp:79
Returns the type of a three channel image given its bitfield type, the bit size of its channels and i...
Definition: metafunctions.hpp:321
Determines if the given locator has a vertical step that could be set dynamically.
Definition: metafunctions.hpp:156
Basic views must be over basic locators.
Definition: metafunctions.hpp:116
Determines if the given iterator has a step that could be set dynamically.
Definition: metafunctions.hpp:129
Returns the type of a two channel bit-aligned image given the bit size of its channels and its layout...
Definition: metafunctions.hpp:358
Returns the type of a pixel iterator given the pixel type, whether it operates on planar data...
Definition: metafunctions.hpp:227
Returns the type of a view the pixel type, whether it operates on planar data and whether it has a st...
Definition: metafunctions.hpp:428
MEMORY-BASED STEP ITERATOR.
Definition: algorithm.hpp:54
Returns the type of a three channel bit-aligned image given the bit size of its channels and its layo...
Definition: metafunctions.hpp:363
Determines if the given view has a horizontal step that could be set dynamically. ...
Definition: metafunctions.hpp:160
Returns the type of a five channel image given its bitfield type, the bit size of its channels and it...
Definition: metafunctions.hpp:331