| 
Class representing an image (up to 4 dimensions wide), each pixel being of type T.  
 More... 
| 
Public Types |  | typedef T * | iterator |  |  | Simple iterator type, to loop through each pixel value of an image instance. 
 |  | typedef const T * | const_iterator |  |  | Simple const iterator type, to loop through each pixel value of a constimage instance.
 |  | typedef T | value_type |  |  | Pixel value type. 
 |  
| 
Constructors / Destructor / Instance Management |  |  | ~CImg () |  |  | Destroy image. 
 |  |  | CImg () |  |  | Construct empty image. 
 |  |  | CImg (const unsigned int size_x, const unsigned int size_y=1, const unsigned int size_z=1, const unsigned int size_c=1) |  |  | Construct image with specified size. 
 |  |  | CImg (const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c, const T value) |  |  | Construct image with specified size and initialize pixel values. 
 |  |  | CImg (const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c, const int value0, const int value1,...) |  |  | Construct image with specified size and initialize pixel values from a sequence of integers. 
 |  |  | CImg (const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c, const double value0, const double value1,...) |  |  | Construct image with specified size and initialize pixel values from a sequence of doubles. 
 |  |  | CImg (const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c, const char *const values, const bool repeat_values) |  |  | Construct image with specified size and initialize pixel values from a value string. 
 |  | template<typename t > |  |  | CImg (const t *const values, const unsigned int size_x, const unsigned int size_y=1, const unsigned int size_z=1, const unsigned int size_c=1, const bool is_shared=false) |  |  | Construct image with specified size and initialize pixel values from a memory buffer. 
 |  |  | CImg (const T *const values, const unsigned int size_x, const unsigned int size_y=1, const unsigned int size_z=1, const unsigned int size_c=1, const bool is_shared=false) |  |  | Construct image with specified size and initialize pixel values from a memory buffer [specialization]. 
 |  |  | CImg (const char *const filename) |  |  | Construct image from reading an image file. 
 |  | template<typename t > |  |  | CImg (const CImg< t > &img) |  |  | Construct image copy. 
 |  |  | CImg (const CImg< T > &img) |  |  | Construct image copy [specialization]. 
 |  | template<typename t > |  |  | CImg (const CImg< t > &img, const bool is_shared) |  |  | Advanced copy constructor. 
 |  |  | CImg (const CImg< T > &img, const bool is_shared) |  |  | Advanced copy constructor [specialization]. 
 |  | template<typename t > |  |  | CImg (const CImg< t > &img, const char *const dimensions) |  |  | Construct image with dimensions borrowed from another image. 
 |  | template<typename t > |  |  | CImg (const CImg< t > &img, const char *const dimensions, const T value) |  |  | Construct image with dimensions borrowed from another image and initialize pixel values. 
 |  |  | CImg (const CImgDisplay &disp) |  |  | Construct image from a display window. 
 |  | CImg< T > & | assign () |  |  | Construct empty image [in-place version]. 
 |  | CImg< T > & | assign (const unsigned int size_x, const unsigned int size_y=1, const unsigned int size_z=1, const unsigned int size_c=1) |  |  | Construct image with specified size [in-place version]. 
 |  | CImg< T > & | assign (const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c, const T value) |  |  | Construct image with specified size and initialize pixel values [in-place version]. 
 |  | CImg< T > & | assign (const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c, const int value0, const int value1,...) |  |  | Construct image with specified size and initialize pixel values from a sequence of integers [in-place version]. 
 |  | CImg< T > & | assign (const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c, const double value0, const double value1,...) |  |  | Construct image with specified size and initialize pixel values from a sequence of doubles [in-place version]. 
 |  | CImg< T > & | assign (const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c, const char *const values, const bool repeat_values) |  |  | Construct image with specified size and initialize pixel values from a value string [in-place version]. 
 |  | template<typename t > |  | CImg< T > & | assign (const t *const values, const unsigned int size_x, const unsigned int size_y=1, const unsigned int size_z=1, const unsigned int size_c=1) |  |  | Construct image with specified size and initialize pixel values from a memory buffer [in-place version]. 
 |  | CImg< T > & | assign (const T *const values, const unsigned int size_x, const unsigned int size_y=1, const unsigned int size_z=1, const unsigned int size_c=1) |  |  | Construct image with specified size and initialize pixel values from a memory buffer [specialization]. 
 |  | template<typename t > |  | CImg< T > & | assign (const t *const values, const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c, const bool is_shared) |  |  | Construct image with specified size and initialize pixel values from a memory buffer [overloading]. 
 |  | CImg< T > & | assign (const T *const values, const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c, const bool is_shared) |  |  | Construct image with specified size and initialize pixel values from a memory buffer [overloading]. 
 |  | CImg< T > & | assign (const char *const filename) |  |  | Construct image from reading an image file [in-place version]. 
 |  | template<typename t > |  | CImg< T > & | assign (const CImg< t > &img) |  |  | Construct image copy [in-place version]. 
 |  | template<typename t > |  | CImg< T > & | assign (const CImg< t > &img, const bool is_shared) |  |  | In-place version of the advanced copy constructor. 
 |  | template<typename t > |  | CImg< T > & | assign (const CImg< t > &img, const char *const dimensions) |  |  | Construct image with dimensions borrowed from another image [in-place version]. 
 |  | template<typename t > |  | CImg< T > & | assign (const CImg< t > &img, const char *const dimensions, const T value) |  |  | Construct image with dimensions borrowed from another image and initialize pixel values [in-place version]. 
 |  | CImg< T > & | assign (const CImgDisplay &disp) |  |  | Construct image from a display window [in-place version]. 
 |  | CImg< T > & | clear () |  |  | Construct empty image [in-place version]. 
 |  | template<typename t > |  | CImg< t > & | move_to (CImg< t > &img) |  |  | Transfer content of an image instance into another one. 
 |  | CImg< T > & | move_to (CImg< T > &img) |  |  | Transfer content of an image instance into another one [specialization]. 
 |  | template<typename t > |  | CImgList< t > & | move_to (CImgList< t > &list, const unsigned int pos=~0U) |  |  | Transfer content of an image instance into a new image in an image list. 
 |  | CImg< T > & | swap (CImg< T > &img) |  |  | Swap fields of two image instances. 
 |  | static CImg< T > & | empty () |  |  | Return a reference to an empty image. 
 |  
| 
Overloaded Operators |  | T & | operator() (const unsigned int x, const unsigned int y=0, const unsigned int z=0, const unsigned int c=0) |  |  | Access to a pixel value. 
 |  | const T & | operator() (const unsigned int x, const unsigned int y=0, const unsigned int z=0, const unsigned int c=0) const |  |  | Access to a pixel value [const version]. 
 |  | T & | operator() (const unsigned int x, const unsigned int y, const unsigned int z, const unsigned int c, const unsigned long wh, const unsigned long whd=0) |  |  | Access to a pixel value. 
 |  | const T & | operator() (const unsigned int x, const unsigned int y, const unsigned int z, const unsigned int c, const unsigned long wh, const unsigned long whd=0) const |  |  | Access to a pixel value [const version]. 
 |  |  | operator T * () |  |  | Implicitely cast an image into a T*.
 |  |  | operator const T * () const |  |  | Implicitely cast an image into a T*[const version].
 |  | CImg< T > & | operator= (const T value) |  |  | Assign a value to all image pixels. 
 |  | CImg< T > & | operator= (const char *const expression) |  |  | Assign pixels values from a specified expression. 
 |  | template<typename t > |  | CImg< T > & | operator= (const CImg< t > &img) |  |  | Copy an image into the current image instance. 
 |  | CImg< T > & | operator= (const CImg< T > &img) |  |  | Copy an image into the current image instance [specialization]. 
 |  | CImg< T > & | operator= (const CImgDisplay &disp) |  |  | Copy the content of a display window to the current image instance. 
 |  | template<typename t > |  | CImg< T > & | operator+= (const t value) |  |  | In-place addition operator. 
 |  | CImg< T > & | operator+= (const char *const expression) |  |  | In-place addition operator. 
 |  | template<typename t > |  | CImg< T > & | operator+= (const CImg< t > &img) |  |  | In-place addition operator. 
 |  | CImg< T > & | operator++ () |  |  | In-place increment operator (prefix). 
 |  | CImg< T > | operator++ (int) |  |  | In-place increment operator (postfix). 
 |  | CImg< T > | operator+ () const |  |  | Return a non-shared copy of the image instance. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | operator+ (const t value) const |  |  | Addition operator. 
 |  | CImg< Tfloat > | operator+ (const char *const expression) const |  |  | Addition operator. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | operator+ (const CImg< t > &img) const |  |  | Addition operator. 
 |  | template<typename t > |  | CImg< T > & | operator-= (const t value) |  |  | In-place substraction operator. 
 |  | CImg< T > & | operator-= (const char *const expression) |  |  | In-place substraction operator. 
 |  | template<typename t > |  | CImg< T > & | operator-= (const CImg< t > &img) |  |  | In-place substraction operator. 
 |  | CImg< T > & | operator-- () |  |  | In-place decrement operator (prefix). 
 |  | CImg< T > | operator-- (int) |  |  | In-place decrement operator (postfix). 
 |  | CImg< T > | operator- () const |  |  | Replace each pixel by its opposite value. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | operator- (const t value) const |  |  | Substraction operator. 
 |  | CImg< Tfloat > | operator- (const char *const expression) const |  |  | Substraction operator. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | operator- (const CImg< t > &img) const |  |  | Substraction operator. 
 |  | template<typename t > |  | CImg< T > & | operator*= (const t value) |  |  | In-place multiplication operator. 
 |  | CImg< T > & | operator*= (const char *const expression) |  |  | In-place multiplication operator. 
 |  | template<typename t > |  | CImg< T > & | operator*= (const CImg< t > &img) |  |  | In-place multiplication operator. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | operator* (const t value) const |  |  | Multiplication operator. 
 |  | CImg< Tfloat > | operator* (const char *const expression) const |  |  | Multiplication operator. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | operator* (const CImg< t > &img) const |  |  | Multiplication operator. 
 |  | template<typename t > |  | CImg< T > & | operator/= (const t value) |  |  | In-place division operator. 
 |  | CImg< T > & | operator/= (const char *const expression) |  |  | In-place division operator. 
 |  | template<typename t > |  | CImg< T > & | operator/= (const CImg< t > &img) |  |  | In-place division operator. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | operator/ (const t value) const |  |  | Division operator. 
 |  | CImg< Tfloat > | operator/ (const char *const expression) const |  |  | Division operator. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | operator/ (const CImg< t > &img) const |  |  | Division operator. 
 |  | template<typename t > |  | CImg< T > & | operator%= (const t value) |  |  | In-place modulo operator. 
 |  | CImg< T > & | operator%= (const char *const expression) |  |  | In-place modulo operator. 
 |  | template<typename t > |  | CImg< T > & | operator%= (const CImg< t > &img) |  |  | In-place modulo operator. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | operator% (const t value) const |  |  | Modulo operator. 
 |  | CImg< Tfloat > | operator% (const char *const expression) const |  |  | Modulo operator. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | operator% (const CImg< t > &img) const |  |  | Modulo operator. 
 |  | template<typename t > |  | CImg< T > & | operator&= (const t value) |  |  | In-place bitwise AND operator. 
 |  | CImg< T > & | operator&= (const char *const expression) |  |  | In-place bitwise AND operator. 
 |  | template<typename t > |  | CImg< T > & | operator&= (const CImg< t > &img) |  |  | In-place bitwise AND operator. 
 |  | template<typename t > |  | CImg< T > | operator& (const t value) const |  |  | Bitwise AND operator. 
 |  | CImg< T > | operator& (const char *const expression) const |  |  | Bitwise AND operator. 
 |  | template<typename t > |  | CImg< T > | operator& (const CImg< t > &img) const |  |  | Bitwise AND operator. 
 |  | template<typename t > |  | CImg< T > & | operator|= (const t value) |  |  | In-place bitwise OR operator. 
 |  | CImg< T > & | operator|= (const char *const expression) |  |  | In-place bitwise OR operator. 
 |  | template<typename t > |  | CImg< T > & | operator|= (const CImg< t > &img) |  |  | In-place bitwise OR operator. 
 |  | template<typename t > |  | CImg< T > | operator| (const t value) const |  |  | Bitwise OR operator. 
 |  | CImg< T > | operator| (const char *const expression) const |  |  | Bitwise OR operator. 
 |  | template<typename t > |  | CImg< T > | operator| (const CImg< t > &img) const |  |  | Bitwise OR operator. 
 |  | template<typename t > |  | CImg< T > & | operator^= (const t value) |  |  | In-place bitwise XOR operator. 
 |  | CImg< T > & | operator^= (const char *const expression) |  |  | In-place bitwise XOR operator. 
 |  | template<typename t > |  | CImg< T > & | operator^= (const CImg< t > &img) |  |  | In-place bitwise XOR operator. 
 |  | template<typename t > |  | CImg< T > | operator^ (const t value) const |  |  | Bitwise XOR operator. 
 |  | CImg< T > | operator^ (const char *const expression) const |  |  | Bitwise XOR operator. 
 |  | template<typename t > |  | CImg< T > | operator^ (const CImg< t > &img) const |  |  | Bitwise XOR operator. 
 |  | template<typename t > |  | CImg< T > & | operator<<= (const t value) |  |  | In-place bitwise left shift operator. 
 |  | CImg< T > & | operator<<= (const char *const expression) |  |  | In-place bitwise left shift operator. 
 |  | template<typename t > |  | CImg< T > & | operator<<= (const CImg< t > &img) |  |  | In-place bitwise left shift operator. 
 |  | template<typename t > |  | CImg< T > | operator<< (const t value) const |  |  | Bitwise left shift operator. 
 |  | CImg< T > | operator<< (const char *const expression) const |  |  | Bitwise left shift operator. 
 |  | template<typename t > |  | CImg< T > | operator<< (const CImg< t > &img) const |  |  | Bitwise left shift operator. 
 |  | template<typename t > |  | CImg< T > & | operator>>= (const t value) |  |  | In-place bitwise right shift operator. 
 |  | CImg< T > & | operator>>= (const char *const expression) |  |  | In-place bitwise right shift operator. 
 |  | template<typename t > |  | CImg< T > & | operator>>= (const CImg< t > &img) |  |  | In-place bitwise right shift operator. 
 |  | template<typename t > |  | CImg< T > | operator>> (const t value) const |  |  | Bitwise right shift operator. 
 |  | CImg< T > | operator>> (const char *const expression) const |  |  | Bitwise right shift operator. 
 |  | template<typename t > |  | CImg< T > | operator>> (const CImg< t > &img) const |  |  | Bitwise right shift operator. 
 |  | CImg< T > | operator~ () const |  |  | Bitwise inversion operator. 
 |  | template<typename t > |  | bool | operator== (const t value) const |  |  | Test if all pixels of an image have the same value. 
 |  | bool | operator== (const char *const expression) const |  |  | Test if all pixel values of an image follow a specified expression. 
 |  | template<typename t > |  | bool | operator== (const CImg< t > &img) const |  |  | Test if two images have the same size and values. 
 |  | template<typename t > |  | bool | operator!= (const t value) const |  |  | Test if pixels of an image are all different from a value. 
 |  | bool | operator!= (const char *const expression) const |  |  | Test if all pixel values of an image are different from a specified expression. 
 |  | template<typename t > |  | bool | operator!= (const CImg< t > &img) const |  |  | Test if two images have different sizes or values. 
 |  | template<typename t > |  | CImgList< typename cimg::superset< T, t >::type >
 | operator, (const CImg< t > &img) const |  |  | Construct an image list from two images. 
 |  | template<typename t > |  | CImgList< typename cimg::superset< T, t >::type >
 | operator, (const CImgList< t > &list) const |  |  | Construct an image list from image instance and an input image list. 
 |  | CImgList< T > | operator< (const char axis) const |  |  | Split image along specified axis. 
 |  
| 
Instance Characteristics |  | int | width () const |  |  | Return the number of image columns. 
 |  | int | height () const |  |  | Return the number of image rows. 
 |  | int | depth () const |  |  | Return the number of image slices. 
 |  | int | spectrum () const |  |  | Return the number of image channels. 
 |  | unsigned long | size () const |  |  | Return the total number of pixel values. 
 |  | T * | data () |  |  | Return a pointer to the first pixel value. 
 |  | const T * | data () const |  |  | Return a pointer to the first pixel value [const version]. 
 |  | T * | data (const unsigned int x, const unsigned int y=0, const unsigned int z=0, const unsigned int c=0) |  |  | Return a pointer to a located pixel value. 
 |  | const T * | data (const unsigned int x, const unsigned int y=0, const unsigned int z=0, const unsigned int c=0) const |  |  | Return a pointer to a located pixel value [const version]. 
 |  | long | offset (const int x, const int y=0, const int z=0, const int c=0) const |  |  | Return the offset to a located pixel value, with respect to the beginning of the pixel buffer. 
 |  | iterator | begin () |  |  | Return a CImg<T>::iterator pointing to the first pixel value. 
 |  | const_iterator | begin () const |  |  | Return a CImg<T>::iterator pointing to the first value of the pixel buffer [const version]. 
 |  | iterator | end () |  |  | Return a CImg<T>::iterator pointing next to the last pixel value. 
 |  | const_iterator | end () const |  |  | Return a CImg<T>::iterator pointing next to the last pixel value [const version]. 
 |  | T & | front () |  |  | Return a reference to the first pixel value. 
 |  | const T & | front () const |  |  | Return a reference to the first pixel value [const version]. 
 |  | T & | back () |  |  | Return a reference to the last pixel value. 
 |  | const T & | back () const |  |  | Return a reference to the last pixel value [const version]. 
 |  | T & | at (const int offset, const T out_value) |  |  | Access to a pixel value at a specified offset, using Dirichlet boundary conditions. 
 |  | T | at (const int offset, const T out_value) const |  |  | Access to a pixel value at a specified offset, using Dirichlet boundary conditions [const version]. 
 |  | T & | at (const int offset) |  |  | Access to a pixel value at a specified offset, using Neumann boundary conditions. 
 |  | T | at (const int offset) const |  |  | Access to a pixel value at a specified offset, using Neumann boundary conditions [const version]. 
 |  | T & | atX (const int x, const int y, const int z, const int c, const T out_value) |  |  | Access to a pixel value, using Dirichlet boundary conditions for the X-coordinate. 
 |  | T | atX (const int x, const int y, const int z, const int c, const T out_value) const |  |  | Access to a pixel value, using Dirichlet boundary conditions for the X-coordinate [const version]. 
 |  | T & | atX (const int x, const int y=0, const int z=0, const int c=0) |  |  | Access to a pixel value, using Neumann boundary conditions for the X-coordinate. 
 |  | T | atX (const int x, const int y=0, const int z=0, const int c=0) const |  |  | Access to a pixel value, using Neumann boundary conditions for the X-coordinate [const version]. 
 |  | T & | atXY (const int x, const int y, const int z, const int c, const T out_value) |  |  | Access to a pixel value, using Dirichlet boundary conditions for the X and Y-coordinates. 
 |  | T | atXY (const int x, const int y, const int z, const int c, const T out_value) const |  |  | Access to a pixel value, using Dirichlet boundary conditions for the X and Y coordinates [const version]. 
 |  | T & | atXY (const int x, const int y, const int z=0, const int c=0) |  |  | Access to a pixel value, using Neumann boundary conditions for the X and Y-coordinates. 
 |  | T | atXY (const int x, const int y, const int z=0, const int c=0) const |  |  | Access to a pixel value, using Neumann boundary conditions for the X and Y-coordinates [const version]. 
 |  | T & | atXYZ (const int x, const int y, const int z, const int c, const T out_value) |  |  | Access to a pixel value, using Dirichlet boundary conditions for the X,Y and Z-coordinates. 
 |  | T | atXYZ (const int x, const int y, const int z, const int c, const T out_value) const |  |  | Access to a pixel value, using Dirichlet boundary conditions for the X,Y and Z-coordinates [const version]. 
 |  | T & | atXYZ (const int x, const int y, const int z, const int c=0) |  |  | Access to a pixel value, using Neumann boundary conditions for the X,Y and Z-coordinates. 
 |  | T | atXYZ (const int x, const int y, const int z, const int c=0) const |  |  | Access to a pixel value, using Neumann boundary conditions for the X,Y and Z-coordinates [const version]. 
 |  | T & | atXYZC (const int x, const int y, const int z, const int c, const T out_value) |  |  | Access to a pixel value, using Dirichlet boundary conditions. 
 |  | T | atXYZC (const int x, const int y, const int z, const int c, const T out_value) const |  |  | Access to a pixel value, using Dirichlet boundary conditions [const version]. 
 |  | T & | atXYZC (const int x, const int y, const int z, const int c) |  |  | Access to a pixel value, using Neumann boundary conditions. 
 |  | T | atXYZC (const int x, const int y, const int z, const int c) const |  |  | Access to a pixel value, using Neumann boundary conditions [const version]. 
 |  | Tfloat | linear_atX (const float fx, const int y, const int z, const int c, const T out_value) const |  |  | Return pixel value, using linear interpolation and Dirichlet boundary conditions for the X-coordinate. 
 |  | Tfloat | linear_atX (const float fx, const int y=0, const int z=0, const int c=0) const |  |  | Return pixel value, using linear interpolation and Neumann boundary conditions for the X-coordinate. 
 |  | Tfloat | linear_atXY (const float fx, const float fy, const int z, const int c, const T out_value) const |  |  | Return pixel value, using linear interpolation and Dirichlet boundary conditions for the X and Y-coordinates. 
 |  | Tfloat | linear_atXY (const float fx, const float fy, const int z=0, const int c=0) const |  |  | Return pixel value, using linear interpolation and Neumann boundary conditions for the X and Y-coordinates. 
 |  | Tfloat | linear_atXYZ (const float fx, const float fy, const float fz, const int c, const T out_value) const |  |  | Return pixel value, using linear interpolation and Dirichlet boundary conditions for the X,Y and Z-coordinates. 
 |  | Tfloat | linear_atXYZ (const float fx, const float fy=0, const float fz=0, const int c=0) const |  |  | Return pixel value, using linear interpolation and Neumann boundary conditions for the X,Y and Z-coordinates. 
 |  | Tfloat | linear_atXYZC (const float fx, const float fy, const float fz, const float fc, const T out_value) const |  |  | Return pixel value, using linear interpolation and Dirichlet boundary conditions for all X,Y,Z and C-coordinates. 
 |  | Tfloat | linear_atXYZC (const float fx, const float fy=0, const float fz=0, const float fc=0) const |  |  | Return pixel value, using linear interpolation and Neumann boundary conditions for all X,Y,Z and C-coordinates. 
 |  | Tfloat | cubic_atX (const float fx, const int y, const int z, const int c, const T out_value) const |  |  | Return pixel value, using cubic interpolation and Dirichlet boundary conditions for the X-coordinate. 
 |  | Tfloat | cubic_atX (const float fx, const int y, const int z, const int c, const T out_value, const Tfloat min_value, const Tfloat max_value) const |  |  | Return damped pixel value, using cubic interpolation and Dirichlet boundary conditions for the X-coordinate. 
 |  | Tfloat | cubic_atX (const float fx, const int y=0, const int z=0, const int c=0) const |  |  | Return pixel value, using cubic interpolation and Neumann boundary conditions for the X-coordinate. 
 |  | Tfloat | cubic_atX (const float fx, const int y, const int z, const int c, const Tfloat min_value, const Tfloat max_value) const |  |  | Return damped pixel value, using cubic interpolation and Neumann boundary conditions for the X-coordinate. 
 |  | Tfloat | cubic_atXY (const float fx, const float fy, const int z, const int c, const T out_value) const |  |  | Return pixel value, using cubic interpolation and Dirichlet boundary conditions for the X and Y-coordinates. 
 |  | Tfloat | cubic_atXY (const float fx, const float fy, const int z, const int c, const T out_value, const Tfloat min_value, const Tfloat max_value) const |  |  | Return damped pixel value, using cubic interpolation and Dirichlet boundary conditions for the X and Y-coordinates. 
 |  | Tfloat | cubic_atXY (const float fx, const float fy, const int z=0, const int c=0) const |  |  | Return pixel value, using cubic interpolation and Neumann boundary conditions for the X and Y-coordinates. 
 |  | Tfloat | cubic_atXY (const float fx, const float fy, const int z, const int c, const Tfloat min_value, const Tfloat max_value) const |  |  | Return damped pixel value, using cubic interpolation and Neumann boundary conditions for the X and Y-coordinates. 
 |  | Tfloat | cubic_atXYZ (const float fx, const float fy, const float fz, const int c, const T out_value) const |  |  | Return pixel value, using cubic interpolation and Dirichlet boundary conditions for the X,Y and Z-coordinates. 
 |  | Tfloat | cubic_atXYZ (const float fx, const float fy, const float fz, const int c, const T out_value, const Tfloat min_value, const Tfloat max_value) const |  |  | Return damped pixel value, using cubic interpolation and Dirichlet boundary conditions for the X,Y and Z-coordinates. 
 |  | Tfloat | cubic_atXYZ (const float fx, const float fy, const float fz, const int c=0) const |  |  | Return pixel value, using cubic interpolation and Neumann boundary conditions for the X,Y and Z-coordinates. 
 |  | Tfloat | cubic_atXYZ (const float fx, const float fy, const float fz, const int c, const Tfloat min_value, const Tfloat max_value) const |  |  | Return damped pixel value, using cubic interpolation and Neumann boundary conditions for the X,Y and Z-coordinates. 
 |  | CImg< T > & | set_linear_atXY (const T &value, const float fx, const float fy=0, const int z=0, const int c=0, const bool is_added=false) |  |  | Set pixel value, using linear interpolation for the X and Y-coordinates. 
 |  | CImg< T > & | set_linear_atXYZ (const T &value, const float fx, const float fy=0, const float fz=0, const int c=0, const bool is_added=false) |  |  | Set pixel value, using linear interpolation for the X,Y and Z-coordinates. 
 |  | CImg< charT > | value_string (const char separator=',', const unsigned int max_size=0) const |  |  | Return a C-string containing a list of all values of the image instance. 
 |  | static const char * | pixel_type () |  |  | Return the type of image pixel values as a C string. 
 |  
| 
Instance Checking |  | bool | is_shared () const |  |  | Test shared state of the pixel buffer. 
 |  | bool | is_empty () const |  |  | Test if image instance is empty. 
 |  | bool | is_inf () const |  |  | Test if image instance contains a 'inf' value. 
 |  | bool | is_nan () const |  |  | Test if image instance contains a 'nan' value. 
 |  | bool | is_sameX (const unsigned int size_x) const |  |  | Test if image width is equal to specified value. 
 |  | template<typename t > |  | bool | is_sameX (const CImg< t > &img) const |  |  | Test if image width is equal to specified value. 
 |  | bool | is_sameX (const CImgDisplay &disp) const |  |  | Test if image width is equal to specified value. 
 |  | bool | is_sameY (const unsigned int size_y) const |  |  | Test if image height is equal to specified value. 
 |  | template<typename t > |  | bool | is_sameY (const CImg< t > &img) const |  |  | Test if image height is equal to specified value. 
 |  | bool | is_sameY (const CImgDisplay &disp) const |  |  | Test if image height is equal to specified value. 
 |  | bool | is_sameZ (const unsigned int size_z) const |  |  | Test if image depth is equal to specified value. 
 |  | template<typename t > |  | bool | is_sameZ (const CImg< t > &img) const |  |  | Test if image depth is equal to specified value. 
 |  | bool | is_sameC (const unsigned int size_c) const |  |  | Test if image spectrum is equal to specified value. 
 |  | template<typename t > |  | bool | is_sameC (const CImg< t > &img) const |  |  | Test if image spectrum is equal to specified value. 
 |  | bool | is_sameXY (const unsigned int size_x, const unsigned int size_y) const |  |  | Test if image width and height are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameXY (const CImg< t > &img) const |  |  | Test if image width and height are the same as that of another image. 
 |  | bool | is_sameXY (const CImgDisplay &disp) const |  |  | Test if image width and height are the same as that of an existing display window. 
 |  | bool | is_sameXZ (const unsigned int size_x, const unsigned int size_z) const |  |  | Test if image width and depth are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameXZ (const CImg< t > &img) const |  |  | Test if image width and depth are the same as that of another image. 
 |  | bool | is_sameXC (const unsigned int size_x, const unsigned int size_c) const |  |  | Test if image width and spectrum are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameXC (const CImg< t > &img) const |  |  | Test if image width and spectrum are the same as that of another image. 
 |  | bool | is_sameYZ (const unsigned int size_y, const unsigned int size_z) const |  |  | Test if image height and depth are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameYZ (const CImg< t > &img) const |  |  | Test if image height and depth are the same as that of another image. 
 |  | bool | is_sameYC (const unsigned int size_y, const unsigned int size_c) const |  |  | Test if image height and spectrum are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameYC (const CImg< t > &img) const |  |  | Test if image height and spectrum are the same as that of another image. 
 |  | bool | is_sameZC (const unsigned int size_z, const unsigned int size_c) const |  |  | Test if image depth and spectrum are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameZC (const CImg< t > &img) const |  |  | Test if image depth and spectrum are the same as that of another image. 
 |  | bool | is_sameXYZ (const unsigned int size_x, const unsigned int size_y, const unsigned int size_z) const |  |  | Test if image width, height and depth are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameXYZ (const CImg< t > &img) const |  |  | Test if image width, height and depth are the same as that of another image. 
 |  | bool | is_sameXYC (const unsigned int size_x, const unsigned int size_y, const unsigned int size_c) const |  |  | Test if image width, height and spectrum are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameXYC (const CImg< t > &img) const |  |  | Test if image width, height and spectrum are the same as that of another image. 
 |  | bool | is_sameXZC (const unsigned int size_x, const unsigned int size_z, const unsigned int size_c) const |  |  | Test if image width, depth and spectrum are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameXZC (const CImg< t > &img) const |  |  | Test if image width, depth and spectrum are the same as that of another image. 
 |  | bool | is_sameYZC (const unsigned int size_y, const unsigned int size_z, const unsigned int size_c) const |  |  | Test if image height, depth and spectrum are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameYZC (const CImg< t > &img) const |  |  | Test if image height, depth and spectrum are the same as that of another image. 
 |  | bool | is_sameXYZC (const unsigned int size_x, const unsigned int size_y, const unsigned int size_z, const unsigned int size_c) const |  |  | Test if image width, height, depth and spectrum are equal to specified values. 
 |  | template<typename t > |  | bool | is_sameXYZC (const CImg< t > &img) const |  |  | Test if image width, height, depth and spectrum are the same as that of another image. 
 |  | bool | containsXYZC (const int x, const int y=0, const int z=0, const int c=0) const |  |  | Test if specified coordinates are inside image bounds. 
 |  | template<typename t > |  | bool | contains (const T &pixel, t &x, t &y, t &z, t &c) const |  |  | Test if pixel value is inside image bounds and get its X,Y,Z and C-coordinates. 
 |  | template<typename t > |  | bool | contains (const T &pixel, t &x, t &y, t &z) const |  |  | Test if pixel value is inside image bounds and get its X,Y and Z-coordinates. 
 |  | template<typename t > |  | bool | contains (const T &pixel, t &x, t &y) const |  |  | Test if pixel value is inside image bounds and get its X and Y-coordinates. 
 |  | template<typename t > |  | bool | contains (const T &pixel, t &x) const |  |  | Test if pixel value is inside image bounds and get its X-coordinate. 
 |  | bool | contains (const T &pixel) const |  |  | Test if pixel value is inside image bounds. 
 |  | template<typename t > |  | bool | is_overlapped (const CImg< t > &img) const |  |  | Test if pixel buffers of instance and input images overlap. 
 |  | template<typename tp , typename tc , typename to > |  | bool | is_object3d (const CImgList< tp > &primitives, const CImgList< tc > &colors, const to &opacities, const bool is_full_check=true, char *const error_message=0) const |  |  | Test if the set { *this,primitives,colors,opacities}defines a valid 3d object.
 |  | bool | is_CImg3d (const bool is_full_check=true, char *const error_message=0) const |  |  | Test if image instance represents a valid serialization of a 3d object. 
 |  
| 
Mathematical Functions |  | CImg< T > & | sqr () |  |  | Compute the square value of each pixel value. 
 |  | CImg< Tfloat > | get_sqr () const |  |  | Compute the square value of each pixel value [new-instance version]. 
 |  | CImg< T > & | sqrt () |  |  | Compute the square root of each pixel value. 
 |  | CImg< Tfloat > | get_sqrt () const |  |  | Compute the square root of each pixel value [new-instance version]. 
 |  | CImg< T > & | exp () |  |  | Compute the exponential of each pixel value. 
 |  | CImg< Tfloat > | get_exp () const |  |  | Compute the exponential of each pixel value [new-instance version]. 
 |  | CImg< T > & | log () |  |  | Compute the logarithm of each pixel value. 
 |  | CImg< Tfloat > | get_log () const |  |  | Compute the logarithm of each pixel value [new-instance version]. 
 |  | CImg< T > & | log2 () |  |  | Compute the base-2 logarithm of each pixel value. 
 |  | CImg< Tfloat > | get_log2 () const |  |  | Compute the base-10 logarithm of each pixel value [new-instance version]. 
 |  | CImg< T > & | log10 () |  |  | Compute the base-10 logarithm of each pixel value. 
 |  | CImg< Tfloat > | get_log10 () const |  |  | Compute the base-10 logarithm of each pixel value [new-instance version]. 
 |  | CImg< T > & | abs () |  |  | Compute the absolute value of each pixel value. 
 |  | CImg< Tfloat > | get_abs () const |  |  | Compute the absolute value of each pixel value [new-instance version]. 
 |  | CImg< T > & | sign () |  |  | Compute the sign of each pixel value. 
 |  | CImg< Tfloat > | get_sign () const |  |  | Compute the sign of each pixel value [new-instance version]. 
 |  | CImg< T > & | cos () |  |  | Compute the cosine of each pixel value. 
 |  | CImg< Tfloat > | get_cos () const |  |  | Compute the cosine of each pixel value [new-instance version]. 
 |  | CImg< T > & | sin () |  |  | Compute the sine of each pixel value. 
 |  | CImg< Tfloat > | get_sin () const |  |  | Compute the sine of each pixel value [new-instance version]. 
 |  | CImg< T > & | sinc () |  |  | Compute the sinc of each pixel value. 
 |  | CImg< Tfloat > | get_sinc () const |  |  | Compute the sinc of each pixel value [new-instance version]. 
 |  | CImg< T > & | tan () |  |  | Compute the tangent of each pixel value. 
 |  | CImg< Tfloat > | get_tan () const |  |  | Compute the tangent of each pixel value [new-instance version]. 
 |  | CImg< T > & | cosh () |  |  | Compute the hyperbolic cosine of each pixel value. 
 |  | CImg< Tfloat > | get_cosh () const |  |  | Compute the hyperbolic cosine of each pixel value [new-instance version]. 
 |  | CImg< T > & | sinh () |  |  | Compute the hyperbolic sine of each pixel value. 
 |  | CImg< Tfloat > | get_sinh () const |  |  | Compute the hyperbolic sine of each pixel value [new-instance version]. 
 |  | CImg< T > & | tanh () |  |  | Compute the hyperbolic tangent of each pixel value. 
 |  | CImg< Tfloat > | get_tanh () const |  |  | Compute the hyperbolic tangent of each pixel value [new-instance version]. 
 |  | CImg< T > & | acos () |  |  | Compute the arccosine of each pixel value. 
 |  | CImg< Tfloat > | get_acos () const |  |  | Compute the arccosine of each pixel value [new-instance version]. 
 |  | CImg< T > & | asin () |  |  | Compute the arcsine of each pixel value. 
 |  | CImg< Tfloat > | get_asin () const |  |  | Compute the arcsine of each pixel value [new-instance version]. 
 |  | CImg< T > & | atan () |  |  | Compute the arctangent of each pixel value. 
 |  | CImg< Tfloat > | get_atan () const |  |  | Compute the arctangent of each pixel value [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | atan2 (const CImg< t > &img) |  |  | Compute the arctangent2 of each pixel value. 
 |  | template<typename t > |  | CImg< Tfloat > | get_atan2 (const CImg< t > &img) const |  |  | Compute the arctangent2 of each pixel value [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | mul (const CImg< t > &img) |  |  | In-place pointwise multiplication. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | get_mul (const CImg< t > &img) const |  |  | In-place pointwise multiplication [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | div (const CImg< t > &img) |  |  | In-place pointwise division. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | get_div (const CImg< t > &img) const |  |  | In-place pointwise division [new-instance version]. 
 |  | CImg< T > & | pow (const double p) |  |  | Raise each pixel value to a specified power. 
 |  | CImg< Tfloat > | get_pow (const double p) const |  |  | Raise each pixel value to a specified power [new-instance version]. 
 |  | CImg< T > & | pow (const char *const expression) |  |  | Raise each pixel value to a power, specified from an expression. 
 |  | CImg< Tfloat > | get_pow (const char *const expression) const |  |  | Raise each pixel value to a power, specified from an expression [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | pow (const CImg< t > &img) |  |  | Raise each pixel value to a power, pointwisely specified from another image. 
 |  | template<typename t > |  | CImg< Tfloat > | get_pow (const CImg< t > &img) const |  |  | Raise each pixel value to a power, pointwisely specified from another image [new-instance version]. 
 |  | CImg< T > & | rol (const unsigned int n=1) |  |  | Compute the bitwise left rotation of each pixel value. 
 |  | CImg< T > | get_rol (const unsigned int n=1) const |  |  | Compute the bitwise left rotation of each pixel value [new-instance version]. 
 |  | CImg< T > & | rol (const char *const expression) |  |  | Compute the bitwise left rotation of each pixel value. 
 |  | CImg< T > | get_rol (const char *const expression) const |  |  | Compute the bitwise left rotation of each pixel value [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | rol (const CImg< t > &img) |  |  | Compute the bitwise left rotation of each pixel value. 
 |  | template<typename t > |  | CImg< T > | get_rol (const CImg< t > &img) const |  |  | Compute the bitwise left rotation of each pixel value [new-instance version]. 
 |  | CImg< T > & | ror (const unsigned int n=1) |  |  | Compute the bitwise right rotation of each pixel value. 
 |  | CImg< T > | get_ror (const unsigned int n=1) const |  |  | Compute the bitwise right rotation of each pixel value [new-instance version]. 
 |  | CImg< T > & | ror (const char *const expression) |  |  | Compute the bitwise right rotation of each pixel value. 
 |  | CImg< T > | get_ror (const char *const expression) const |  |  | Compute the bitwise right rotation of each pixel value [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | ror (const CImg< t > &img) |  |  | Compute the bitwise right rotation of each pixel value. 
 |  | template<typename t > |  | CImg< T > | get_ror (const CImg< t > &img) const |  |  | Compute the bitwise right rotation of each pixel value [new-instance version]. 
 |  | CImg< T > & | min (const T val) |  |  | Pointwise min operator between instance image and a value. 
 |  | CImg< T > | get_min (const T val) const |  |  | Pointwise min operator between instance image and a value [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | min (const CImg< t > &img) |  |  | Pointwise min operator between two images. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | get_min (const CImg< t > &img) const |  |  | Pointwise min operator between two images [new-instance version]. 
 |  | CImg< T > & | min (const char *const expression) |  |  | Pointwise min operator between an image and an expression. 
 |  | CImg< Tfloat > | get_min (const char *const expression) const |  |  | Pointwise min operator between an image and an expression [new-instance version]. 
 |  | CImg< T > & | max (const T val) |  |  | Pointwise max operator between instance image and a value. 
 |  | CImg< T > | get_max (const T val) const |  |  | Pointwise max operator between instance image and a value [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | max (const CImg< t > &img) |  |  | Pointwise max operator between two images. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | get_max (const CImg< t > &img) const |  |  | Pointwise max operator between two images [new-instance version]. 
 |  | CImg< T > & | max (const char *const expression) |  |  | Pointwise max operator between an image and an expression. 
 |  | CImg< Tfloat > | get_max (const char *const expression) const |  |  | Pointwise max operator between an image and an expression [new-instance version]. 
 |  | T & | min () |  |  | Return a reference to the minimum pixel value. 
 |  | const T & | min () const |  |  | Return a reference to the minimum pixel value [const version]. 
 |  | T & | max () |  |  | Return a reference to the maximum pixel value. 
 |  | const T & | max () const |  |  | Return a reference to the maximum pixel value [const version]. 
 |  | template<typename t > |  | T & | min_max (t &max_val) |  |  | Return a reference to the minimum pixel value as well as the maximum pixel value. 
 |  | template<typename t > |  | const T & | min_max (t &max_val) const |  |  | Return a reference to the minimum pixel value as well as the maximum pixel value [const version]. 
 |  | template<typename t > |  | T & | max_min (t &min_val) |  |  | Return a reference to the maximum pixel value as well as the minimum pixel value. 
 |  | template<typename t > |  | const T & | max_min (t &min_val) const |  |  | Return a reference to the maximum pixel value as well as the minimum pixel value [const version]. 
 |  | T | kth_smallest (const unsigned int k) const |  |  | Return the kth smallest pixel value. 
 |  | T | median () const |  |  | Return the median pixel value. 
 |  | Tdouble | sum () const |  |  | Return the sum of all the pixel values. 
 |  | Tdouble | mean () const |  |  | Return the average pixel value. 
 |  | Tdouble | variance (const unsigned int variance_method=1) const |  |  | Return the variance of the pixel values. 
 |  | template<typename t > |  | Tdouble | variance_mean (const unsigned int variance_method, t &mean) const |  |  | Return the variance as well as the average of the pixel values. 
 |  | Tdouble | variance_noise (const unsigned int variance_method=2) const |  |  | Return estimated variance of the noise. 
 |  | template<typename t > |  | Tdouble | MSE (const CImg< t > &img) const |  |  | Compute the MSE (Mean-Squared Error) between two images. 
 |  | template<typename t > |  | Tdouble | PSNR (const CImg< t > &img, const Tdouble max_value=255) const |  |  | Compute the PSNR (Peak Signal-to-Noise Ratio) between two images. 
 |  | double | eval (const char *const expression, const double x=0, const double y=0, const double z=0, const double c=0) const |  |  | Evaluate math formula. 
 |  | template<typename t > |  | CImg< doubleT > | eval (const char *const expression, const CImg< t > &xyzc) const |  |  | Evaluate math formula on a set of variables. 
 |  | CImg< Tdouble > | get_stats (const unsigned int variance_method=1) const |  |  | Compute statistics vector from the pixel values. 
 |  | CImg< T > & | stats (const unsigned int variance_method=1) |  |  | Compute statistics vector from the pixel values [in-place version]. 
 |  
| 
Vector / Matrix Operations |  | Tdouble | magnitude (const int magnitude_type=2) const |  |  | Compute norm of the image, viewed as a matrix. 
 |  | Tdouble | trace () const |  |  | Compute the trace of the image, viewed as a matrix. 
 |  | Tdouble | det () const |  |  | Compute the determinant of the image, viewed as a matrix. 
 |  | template<typename t > |  | Tdouble | dot (const CImg< t > &img) const |  |  | Compute the dot product between instance and argument, viewed as matrices. 
 |  | CImg< T > | get_vector_at (const unsigned int x, const unsigned int y=0, const unsigned int z=0) const |  |  | Get vector-valued pixel located at specified position. 
 |  | CImg< T > | get_matrix_at (const unsigned int x=0, const unsigned int y=0, const unsigned int z=0) const |  |  | Get (square) matrix-valued pixel located at specified position. 
 |  | CImg< T > | get_tensor_at (const unsigned int x, const unsigned int y=0, const unsigned int z=0) const |  |  | Get tensor-valued pixel located at specified position. 
 |  | template<typename t > |  | CImg< T > & | set_vector_at (const CImg< t > &vec, const unsigned int x, const unsigned int y=0, const unsigned int z=0) |  |  | Set vector-valued pixel at specified position. 
 |  | template<typename t > |  | CImg< T > & | set_matrix_at (const CImg< t > &mat, const unsigned int x=0, const unsigned int y=0, const unsigned int z=0) |  |  | Set (square) matrix-valued pixel at specified position. 
 |  | template<typename t > |  | CImg< T > & | set_tensor_at (const CImg< t > &ten, const unsigned int x=0, const unsigned int y=0, const unsigned int z=0) |  |  | Set tensor-valued pixel at specified position. 
 |  | CImg< T > & | vector () |  |  | Unroll pixel values along axis y.
 |  | CImg< T > | get_vector () const |  |  | Unroll pixel values along axis y[new-instance version].
 |  | CImg< T > & | matrix () |  |  | Resize image to become a scalar square matrix. 
 |  | CImg< T > | get_matrix () const |  |  | Resize image to become a scalar square matrix [new-instance version]. 
 |  | CImg< T > & | tensor () |  |  | Resize image to become a symmetric tensor. 
 |  | CImg< T > | get_tensor () const |  |  | Resize image to become a symmetric tensor [new-instance version]. 
 |  | CImg< T > & | diagonal () |  |  | Resize image to become a diagonal matrix. 
 |  | CImg< T > | get_diagonal () const |  |  | Resize image to become a diagonal matrix [new-instance version]. 
 |  | CImg< T > & | identity_matrix () |  |  | Replace the image by an identity matrix. 
 |  | CImg< T > | get_identity_matrix () const |  |  | Replace the image by an identity matrix [new-instance version]. 
 |  | CImg< T > & | sequence (const T a0, const T a1) |  |  | Fill image with a linear sequence of values. 
 |  | CImg< T > | get_sequence (const T a0, const T a1) const |  |  | Fill image with a linear sequence of values [new-instance version]. 
 |  | CImg< T > & | transpose () |  |  | Transpose the image, viewed as a matrix. 
 |  | CImg< T > | get_transpose () const |  |  | Transpose the image, viewed as a matrix [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | cross (const CImg< t > &img) |  |  | Compute the cross product between two 1x3images, viewed as 3d vectors.
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | get_cross (const CImg< t > &img) const |  |  | Compute the cross product between two 1x3images, viewed as 3d vectors [new-instance version].
 |  | CImg< T > & | invert (const bool use_LU=true) |  |  | Invert the instance image, viewed as a matrix. 
 |  | CImg< Tfloat > | get_invert (const bool use_LU=true) const |  |  | Invert the instance image, viewed as a matrix [new-instance version]. 
 |  | CImg< T > & | pseudoinvert () |  |  | Compute the Moore-Penrose pseudo-inverse of the instance image, viewed as a matrix. 
 |  | CImg< Tfloat > | get_pseudoinvert () const |  |  | Compute the Moore-Penrose pseudo-inverse of the instance image, viewed as a matrix [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | solve (const CImg< t > &A) |  |  | Solve a system of linear equations. 
 |  | template<typename t > |  | CImg< typename cimg::superset2 < T, t, float >::type >
 | get_solve (const CImg< t > &A) const |  |  | Solve a system of linear equations [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | solve_tridiagonal (const CImg< t > &A) |  |  | Solve a tridiagonal system of linear equations. 
 |  | template<typename t > |  | CImg< typename cimg::superset2 < T, t, float >::type >
 | get_solve_tridiagonal (const CImg< t > &A) const |  |  | Solve a tridiagonal system of linear equations [new-instance version]. 
 |  | template<typename t > |  | const CImg< T > & | eigen (CImg< t > &val, CImg< t > &vec) const |  |  | Compute eigenvalues and eigenvectors of the instance image, viewed as a matrix. 
 |  | CImgList< Tfloat > | get_eigen () const |  |  | Compute eigenvalues and eigenvectors of the instance image, viewed as a matrix. 
 |  | template<typename t > |  | const CImg< T > & | symmetric_eigen (CImg< t > &val, CImg< t > &vec) const |  |  | Compute eigenvalues and eigenvectors of the instance image, viewed as a symmetric matrix. 
 |  | CImgList< Tfloat > | get_symmetric_eigen () const |  |  | Compute eigenvalues and eigenvectors of the instance image, viewed as a symmetric matrix. 
 |  | template<typename t > |  | CImg< T > & | sort (CImg< t > &permutations, const bool is_increasing=true) |  |  | Sort pixel values and get sorting permutations. 
 |  | template<typename t > |  | CImg< T > | get_sort (CImg< t > &permutations, const bool is_increasing=true) const |  |  | Sort pixel values and get sorting permutations [new-instance version]. 
 |  | CImg< T > & | sort (const bool is_increasing=true, const char axis=0) |  |  | Sort pixel values. 
 |  | CImg< T > | get_sort (const bool is_increasing=true, const char axis=0) const |  |  | Sort pixel values [new-instance version]. 
 |  | template<typename t > |  | const CImg< T > & | SVD (CImg< t > &U, CImg< t > &S, CImg< t > &V, const bool sorting=true, const unsigned int max_iteration=40, const float lambda=0) const |  |  | Compute the SVD of the instance image, viewed as a general matrix. 
 |  | CImgList< Tfloat > | get_SVD (const bool sorting=true, const unsigned int max_iteration=40, const float lambda=0) const |  |  | Compute the SVD of the instance image, viewed as a general matrix. 
 |  | template<typename t > |  | CImg< T > & | dijkstra (const unsigned int starting_node, const unsigned int ending_node, CImg< t > &previous_node) |  |  | Return minimal path in a graph, using the Dijkstra algorithm. 
 |  | template<typename t > |  | CImg< T > | get_dijkstra (const unsigned int starting_node, const unsigned int ending_node, CImg< t > &previous_node) const |  |  | Return minimal path in a graph, using the Dijkstra algorithm [new-instance version]. 
 |  | CImg< T > & | dijkstra (const unsigned int starting_node, const unsigned int ending_node=~0U) |  |  | Return minimal path in a graph, using the Dijkstra algorithm. 
 |  | CImg< Tfloat > | get_dijkstra (const unsigned int starting_node, const unsigned int ending_node=~0U) const |  |  | Return minimal path in a graph, using the Dijkstra algorithm [new-instance version]. 
 |  | template<typename tf , typename t > |  | static CImg< T > | dijkstra (const tf &distance, const unsigned int nb_nodes, const unsigned int starting_node, const unsigned int ending_node, CImg< t > &previous_node) |  |  | Compute minimal path in a graph, using the Dijkstra algorithm. 
 |  | template<typename tf , typename t > |  | static CImg< T > | dijkstra (const tf &distance, const unsigned int nb_nodes, const unsigned int starting_node, const unsigned int ending_node=~0U) |  |  | Return minimal path in a graph, using the Dijkstra algorithm. 
 |  | static CImg< T > | string (const char *const str, const bool is_last_zero=true) |  |  | Return an image containing the ascii codes of the specified string. 
 |  | static CImg< T > | vector (const T &a0) |  |  | Return a 1x1image containing specified value.
 |  | static CImg< T > | vector (const T &a0, const T &a1) |  |  | Return a 1x2image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2) |  |  | Return a 1x3image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3) |  |  | Return a 1x4image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4) |  |  | Return a 1x5image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5) |  |  | Return a 1x6image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6) |  |  | Return a 1x7image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7) |  |  | Return a 1x8image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8) |  |  | Return a 1x9image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8, const T &a9) |  |  | Return a 1x10image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8, const T &a9, const T &a10) |  |  | Return a 1x11image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8, const T &a9, const T &a10, const T &a11) |  |  | Return a 1x12image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8, const T &a9, const T &a10, const T &a11, const T &a12) |  |  | Return a 1x13image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8, const T &a9, const T &a10, const T &a11, const T &a12, const T &a13) |  |  | Return a 1x14image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8, const T &a9, const T &a10, const T &a11, const T &a12, const T &a13, const T &a14) |  |  | Return a 1x15image containing specified values.
 |  | static CImg< T > | vector (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8, const T &a9, const T &a10, const T &a11, const T &a12, const T &a13, const T &a14, const T &a15) |  |  | Return a 1x16image containing specified values.
 |  | static CImg< T > | matrix (const T &a0) |  |  | Return a 1x1 matrix containing specified coefficients. 
 |  | static CImg< T > | matrix (const T &a0, const T &a1, const T &a2, const T &a3) |  |  | Return a 2x2 matrix containing specified coefficients. 
 |  | static CImg< T > | matrix (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8) |  |  | Return a 3x3 matrix containing specified coefficients. 
 |  | static CImg< T > | matrix (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8, const T &a9, const T &a10, const T &a11, const T &a12, const T &a13, const T &a14, const T &a15) |  |  | Return a 4x4 matrix containing specified coefficients. 
 |  | static CImg< T > | matrix (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5, const T &a6, const T &a7, const T &a8, const T &a9, const T &a10, const T &a11, const T &a12, const T &a13, const T &a14, const T &a15, const T &a16, const T &a17, const T &a18, const T &a19, const T &a20, const T &a21, const T &a22, const T &a23, const T &a24) |  |  | Return a 5x5 matrix containing specified coefficients. 
 |  | static CImg< T > | tensor (const T &a0) |  |  | Return a 1x1 symmetric matrix containing specified coefficients. 
 |  | static CImg< T > | tensor (const T &a0, const T &a1, const T &a2) |  |  | Return a 2x2 symmetric matrix tensor containing specified coefficients. 
 |  | static CImg< T > | tensor (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4, const T &a5) |  |  | Return a 3x3 symmetric matrix containing specified coefficients. 
 |  | static CImg< T > | diagonal (const T &a0) |  |  | Return a 1x1 diagonal matrix containing specified coefficients. 
 |  | static CImg< T > | diagonal (const T &a0, const T &a1) |  |  | Return a 2x2 diagonal matrix containing specified coefficients. 
 |  | static CImg< T > | diagonal (const T &a0, const T &a1, const T &a2) |  |  | Return a 3x3 diagonal matrix containing specified coefficients. 
 |  | static CImg< T > | diagonal (const T &a0, const T &a1, const T &a2, const T &a3) |  |  | Return a 4x4 diagonal matrix containing specified coefficients. 
 |  | static CImg< T > | diagonal (const T &a0, const T &a1, const T &a2, const T &a3, const T &a4) |  |  | Return a 5x5 diagonal matrix containing specified coefficients. 
 |  | static CImg< T > | identity_matrix (const unsigned int N) |  |  | Return a NxN identity matrix. 
 |  | static CImg< T > | sequence (const unsigned int N, const T a0, const T a1) |  |  | Return a N-numbered sequence vector from a0toa1.
 |  | static CImg< T > | rotation_matrix (const float x, const float y, const float z, const float w, const bool is_quaternion=false) |  |  | Return a 3x3 rotation matrix along the (x,y,z)-axis with an angle w. 
 |  
| 
Value Manipulation |  | CImg< T > & | fill (const T val) |  |  | Fill all pixel values with specified value. 
 |  | CImg< T > | get_fill (const T val) const |  |  | Fill all pixel values with specified value [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1) |  |  | Fill sequentially all pixel values with specified values. 
 |  | CImg< T > | get_fill (const T val0, const T val1) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10, const T val11) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10, const T val11) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10, const T val11, const T val12) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10, const T val11, const T val12) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10, const T val11, const T val12, const T val13) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10, const T val11, const T val12, const T val13) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10, const T val11, const T val12, const T val13, const T val14) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10, const T val11, const T val12, const T val13, const T val14) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10, const T val11, const T val12, const T val13, const T val14, const T val15) |  |  | Fill sequentially all pixel values with specified values [overloading]. 
 |  | CImg< T > | get_fill (const T val0, const T val1, const T val2, const T val3, const T val4, const T val5, const T val6, const T val7, const T val8, const T val9, const T val10, const T val11, const T val12, const T val13, const T val14, const T val15) const |  |  | Fill sequentially all pixel values with specified values [new-instance version]. 
 |  | CImg< T > & | fill (const char *const expression, const bool repeat_flag) |  |  | Fill sequentially pixel values according to a given expression. 
 |  | CImg< T > | get_fill (const char *const values, const bool repeat_values) const |  |  | Fill sequentially pixel values according to a given expression [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | fill (const CImg< t > &values, const bool repeat_values=true) |  |  | Fill sequentially pixel values according to the values found in another image. 
 |  | template<typename t > |  | CImg< T > | get_fill (const CImg< t > &values, const bool repeat_values=true) const |  |  | Fill sequentially pixel values according to the values found in another image [new-instance version]. 
 |  | CImg< T > & | fillX (const unsigned int y, const unsigned int z, const unsigned int c, const int a0,...) |  |  | Fill pixel values along the X-axis at a specified pixel position. 
 |  | CImg< T > & | fillX (const unsigned int y, const unsigned int z, const unsigned int c, const double a0,...) |  |  | Fill pixel values along the X-axis at a specified pixel position [overloading]. 
 |  | CImg< T > & | fillY (const unsigned int x, const unsigned int z, const unsigned int c, const int a0,...) |  |  | Fill pixel values along the Y-axis at a specified pixel position. 
 |  | CImg< T > & | fillY (const unsigned int x, const unsigned int z, const unsigned int c, const double a0,...) |  |  | Fill pixel values along the Y-axis at a specified pixel position [overloading]. 
 |  | CImg< T > & | fillZ (const unsigned int x, const unsigned int y, const unsigned int c, const int a0,...) |  |  | Fill pixel values along the Z-axis at a specified pixel position. 
 |  | CImg< T > & | fillZ (const unsigned int x, const unsigned int y, const unsigned int c, const double a0,...) |  |  | Fill pixel values along the Z-axis at a specified pixel position [overloading]. 
 |  | CImg< T > & | fillC (const unsigned int x, const unsigned int y, const unsigned int z, const int a0,...) |  |  | Fill pixel values along the C-axis at a specified pixel position. 
 |  | CImg< T > & | fillC (const unsigned int x, const unsigned int y, const unsigned int z, const double a0,...) |  |  | Fill pixel values along the C-axis at a specified pixel position [overloading]. 
 |  | CImg< T > & | discard (const T value) |  |  | Discard specified value in the image buffer. 
 |  | CImg< T > | get_discard (const T value) const |  |  | Discard specified value in the image buffer [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | discard (const CImg< t > &values) |  |  | Discard specified sequence of values in the image buffer. 
 |  | template<typename t > |  | CImg< T > | get_discard (const CImg< t > &values) const |  |  | Discard specified sequence of values in the image buffer [new-instance version]. 
 |  | CImg< T > & | invert_endianness () |  |  | Invert endianness of all pixel values. 
 |  | CImg< T > | get_invert_endianness () const |  |  | Invert endianness of all pixel values [new-instance version]. 
 |  | CImg< T > & | rand (const T val_min, const T val_max) |  |  | Fill image with random values in specified range. 
 |  | CImg< T > | get_rand (const T val_min, const T val_max) const |  |  | Fill image with random values in specified range [new-instance version]. 
 |  | CImg< T > & | round (const double y=1, const int rounding_type=0) |  |  | Round pixel values. 
 |  | CImg< T > | get_round (const double y=1, const unsigned int rounding_type=0) const |  |  | Round pixel values [new-instance version]. 
 |  | CImg< T > & | noise (const double sigma, const unsigned int noise_type=0) |  |  | Add random noise to pixel values. 
 |  | CImg< T > | get_noise (const double sigma, const unsigned int noise_type=0) const |  |  | Add random noise to pixel values [new-instance version]. 
 |  | CImg< T > & | normalize (const T min_value, const T max_value) |  |  | Linearly normalize pixel values. 
 |  | CImg< Tfloat > | get_normalize (const T min_value, const T max_value) const |  |  | Linearly normalize pixel values [new-instance version]. 
 |  | CImg< T > & | normalize () |  |  | Normalize multi-valued pixels of the image instance, with respect to their L2-norm. 
 |  | CImg< Tfloat > | get_normalize () const |  |  | Normalize multi-valued pixels of the image instance, with respect to their L2-norm [new-instance version]. 
 |  | CImg< T > & | norm (const int norm_type=2) |  |  | Compute L2-norm of each multi-valued pixel of the image instance. 
 |  | CImg< Tfloat > | get_norm (const int norm_type=2) const |  |  | Compute L2-norm of each multi-valued pixel of the image instance [new-instance version]. 
 |  | CImg< T > & | cut (const T min_value, const T max_value) |  |  | Cut pixel values in specified range. 
 |  | CImg< T > | get_cut (const T min_value, const T max_value) const |  |  | Cut pixel values in specified range [new-instance version]. 
 |  | CImg< T > & | quantize (const unsigned int nb_levels, const bool keep_range=true) |  |  | Uniformly quantize pixel values. 
 |  | CImg< T > | get_quantize (const unsigned int n, const bool keep_range=true) const |  |  | Uniformly quantize pixel values [new-instance version]. 
 |  | CImg< T > & | threshold (const T value, const bool soft_threshold=false, const bool strict_threshold=false) |  |  | Threshold pixel values. 
 |  | CImg< T > | get_threshold (const T value, const bool soft_threshold=false, const bool strict_threshold=false) const |  |  | Threshold pixel values [new-instance version]. 
 |  | CImg< T > & | histogram (const unsigned int nb_levels, const T min_value=(T) 0, const T max_value=(T) 0) |  |  | Compute the histogram of pixel values. 
 |  | CImg< ulongT > | get_histogram (const unsigned int nb_levels, const T min_value=(T) 0, const T max_value=(T) 0) const |  |  | Compute the histogram of pixel values [new-instance version]. 
 |  | CImg< T > & | equalize (const unsigned int nb_levels, const T min_value=(T) 0, const T max_value=(T) 0) |  |  | Equalize histogram of pixel values. 
 |  | CImg< T > | get_equalize (const unsigned int nblevels, const T val_min=(T) 0, const T val_max=(T) 0) const |  |  | Equalize histogram of pixel values [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | index (const CImg< t > &colormap, const float dithering=1, const bool map_indexes=false) |  |  | Index multi-valued pixels regarding to a specified colormap. 
 |  | template<typename t > |  | CImg< typename CImg< t >::Tuint > | get_index (const CImg< t > &colormap, const float dithering=1, const bool map_indexes=true) const |  |  | Index multi-valued pixels regarding to a specified colormap [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | map (const CImg< t > &colormap) |  |  | Map predefined colormap on the scalar (indexed) image instance. 
 |  | template<typename t > |  | CImg< t > | get_map (const CImg< t > &colormap) const |  |  | Map predefined colormap on the scalar (indexed) image instance [new-instance version]. 
 |  | CImg< T > & | label (const bool is_high_connectivity=false, const Tfloat tolerance=0) |  |  | Label connected components. 
 |  | CImg< unsigned long > | get_label (const bool is_high_connectivity=false, const Tfloat tolerance=0) const |  |  | Label connected components [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | label (const CImg< t > &connectivity_mask, const Tfloat tolerance=0) |  |  | Label connected components [overloading]. 
 |  | template<typename t > |  | CImg< unsigned long > | get_label (const CImg< t > &connectivity_mask, const Tfloat tolerance=0) const |  |  | Label connected components [new-instance version]. 
 |  
| 
Color Base Management |  | CImg< T > & | sRGBtoRGB () |  |  | Convert pixel values from sRGB to RGB color spaces. 
 |  | CImg< Tfloat > | get_sRGBtoRGB () const |  |  | Convert pixel values from sRGB to RGB color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtosRGB () |  |  | Convert pixel values from RGB to sRGB color spaces. 
 |  | CImg< Tfloat > | get_RGBtosRGB () const |  |  | Convert pixel values from RGB to sRGB color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoHSV () |  |  | Convert pixel values from RGB to HSV color spaces. 
 |  | CImg< Tfloat > | get_RGBtoHSV () const |  |  | Convert pixel values from RGB to HSV color spaces [new-instance version]. 
 |  | CImg< T > & | HSVtoRGB () |  |  | Convert pixel values from HSV to RGB color spaces. 
 |  | CImg< Tuchar > | get_HSVtoRGB () const |  |  | Convert pixel values from HSV to RGB color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoHSL () |  |  | Convert pixel values from RGB to HSL color spaces. 
 |  | CImg< Tfloat > | get_RGBtoHSL () const |  |  | Convert pixel values from RGB to HSL color spaces [new-instance version]. 
 |  | CImg< T > & | HSLtoRGB () |  |  | Convert pixel values from HSL to RGB color spaces. 
 |  | CImg< Tuchar > | get_HSLtoRGB () const |  |  | Convert pixel values from HSL to RGB color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoHSI () |  |  | Convert pixel values from RGB to HSI color spaces. 
 |  | CImg< Tfloat > | get_RGBtoHSI () const |  |  | Convert pixel values from RGB to HSI color spaces [new-instance version]. 
 |  | CImg< T > & | HSItoRGB () |  |  | Convert pixel values from HSI to RGB color spaces. 
 |  | CImg< Tfloat > | get_HSItoRGB () const |  |  | Convert pixel values from HSI to RGB color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoYCbCr () |  |  | Convert pixel values from RGB to YCbCr color spaces. 
 |  | CImg< Tuchar > | get_RGBtoYCbCr () const |  |  | Convert pixel values from RGB to YCbCr color spaces [new-instance version]. 
 |  | CImg< T > & | YCbCrtoRGB () |  |  | Convert pixel values from RGB to YCbCr color spaces. 
 |  | CImg< Tuchar > | get_YCbCrtoRGB () const |  |  | Convert pixel values from RGB to YCbCr color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoYUV () |  |  | Convert pixel values from RGB to YUV color spaces. 
 |  | CImg< Tfloat > | get_RGBtoYUV () const |  |  | Convert pixel values from RGB to YUV color spaces [new-instance version]. 
 |  | CImg< T > & | YUVtoRGB () |  |  | Convert pixel values from YUV to RGB color spaces. 
 |  | CImg< Tuchar > | get_YUVtoRGB () const |  |  | Convert pixel values from YUV to RGB color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoCMY () |  |  | Convert pixel values from RGB to CMY color spaces. 
 |  | CImg< Tuchar > | get_RGBtoCMY () const |  |  | Convert pixel values from RGB to CMY color spaces [new-instance version]. 
 |  | CImg< T > & | CMYtoRGB () |  |  | Convert pixel values from CMY to RGB color spaces. 
 |  | CImg< Tuchar > | get_CMYtoRGB () const |  |  | Convert pixel values from CMY to RGB color spaces [new-instance version]. 
 |  | CImg< T > & | CMYtoCMYK () |  |  | Convert pixel values from CMY to CMYK color spaces. 
 |  | CImg< Tuchar > | get_CMYtoCMYK () const |  |  | Convert pixel values from CMY to CMYK color spaces [new-instance version]. 
 |  | CImg< T > & | CMYKtoCMY () |  |  | Convert pixel values from CMYK to CMY color spaces. 
 |  | CImg< Tfloat > | get_CMYKtoCMY () const |  |  | Convert pixel values from CMYK to CMY color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoXYZ () |  |  | Convert pixel values from RGB to XYZ_709 color spaces. 
 |  | CImg< Tfloat > | get_RGBtoXYZ () const |  |  | Convert pixel values from RGB to XYZ_709 color spaces [new-instance version]. 
 |  | CImg< T > & | XYZtoRGB () |  |  | Convert pixel values from XYZ_709 to RGB color spaces. 
 |  | CImg< Tuchar > | get_XYZtoRGB () const |  |  | Convert pixel values from XYZ_709 to RGB color spaces [new-instance version]. 
 |  | CImg< T > & | XYZtoLab () |  |  | Convert pixel values from XYZ_709 to Lab color spaces. 
 |  | CImg< Tfloat > | get_XYZtoLab () const |  |  | Convert pixel values from XYZ_709 to Lab color spaces [new-instance version]. 
 |  | CImg< T > & | LabtoXYZ () |  |  | Convert pixel values from Lab to XYZ_709 color spaces. 
 |  | CImg< Tfloat > | get_LabtoXYZ () const |  |  | Convert pixel values from Lab to XYZ_709 color spaces [new-instance version]. 
 |  | CImg< T > & | XYZtoxyY () |  |  | Convert pixel values from XYZ_709 to xyY color spaces. 
 |  | CImg< Tfloat > | get_XYZtoxyY () const |  |  | Convert pixel values from XYZ_709 to xyY color spaces [new-instance version]. 
 |  | CImg< T > & | xyYtoXYZ () |  |  | Convert pixel values from xyY pixels to XYZ_709 color spaces. 
 |  | CImg< Tfloat > | get_xyYtoXYZ () const |  |  | Convert pixel values from xyY pixels to XYZ_709 color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoLab () |  |  | Convert pixel values from RGB to Lab color spaces. 
 |  | CImg< Tfloat > | get_RGBtoLab () const |  |  | Convert pixel values from RGB to Lab color spaces [new-instance version]. 
 |  | CImg< T > & | LabtoRGB () |  |  | Convert pixel values from Lab to RGB color spaces. 
 |  | CImg< Tuchar > | get_LabtoRGB () const |  |  | Convert pixel values from Lab to RGB color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoxyY () |  |  | Convert pixel values from RGB to xyY color spaces. 
 |  | CImg< Tfloat > | get_RGBtoxyY () const |  |  | Convert pixel values from RGB to xyY color spaces [new-instance version]. 
 |  | CImg< T > & | xyYtoRGB () |  |  | Convert pixel values from xyY to RGB color spaces. 
 |  | CImg< Tuchar > | get_xyYtoRGB () const |  |  | Convert pixel values from xyY to RGB color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoCMYK () |  |  | Convert pixel values from RGB to CMYK color spaces. 
 |  | CImg< Tfloat > | get_RGBtoCMYK () const |  |  | Convert pixel values from RGB to CMYK color spaces [new-instance version]. 
 |  | CImg< T > & | CMYKtoRGB () |  |  | Convert pixel values from CMYK to RGB color spaces. 
 |  | CImg< Tuchar > | get_CMYKtoRGB () const |  |  | Convert pixel values from CMYK to RGB color spaces [new-instance version]. 
 |  | CImg< T > & | RGBtoBayer () |  |  | Convert RGB color image to a Bayer-coded scalar image. 
 |  | CImg< T > | get_RGBtoBayer () const |  |  | Convert RGB color image to a Bayer-coded scalar image [new-instance version]. 
 |  | CImg< T > & | BayertoRGB (const unsigned int interpolation_type=3) |  |  | Convert Bayer-coded scalar image to a RGB color image. 
 |  | CImg< Tuchar > | get_BayertoRGB (const unsigned int interpolation_type=3) const |  |  | Convert Bayer-coded scalar image to a RGB color image [new-instance version]. 
 |  | static const CImg< Tuchar > & | default_LUT256 () |  |  | Return colormap "default", containing 256 colors entries in RGB. 
 |  | static const CImg< Tuchar > & | HSV_LUT256 () |  |  | Return colormap "HSV", containing 256 colors entries in RGB. 
 |  | static const CImg< Tuchar > & | lines_LUT256 () |  |  | Return colormap "lines", containing 256 colors entries in RGB. 
 |  | static const CImg< Tuchar > & | hot_LUT256 () |  |  | Return colormap "hot", containing 256 colors entries in RGB. 
 |  | static const CImg< Tuchar > & | cool_LUT256 () |  |  | Return colormap "cool", containing 256 colors entries in RGB. 
 |  | static const CImg< Tuchar > & | jet_LUT256 () |  |  | Return colormap "jet", containing 256 colors entries in RGB. 
 |  | static const CImg< Tuchar > & | flag_LUT256 () |  |  | Return colormap "flag", containing 256 colors entries in RGB. 
 |  | static const CImg< Tuchar > & | cube_LUT256 () |  |  | Return colormap "cube", containing 256 colors entries in RGB. 
 |  
| 
Geometric / Spatial Manipulation |  | CImg< T > & | resize (const int size_x, const int size_y=-100, const int size_z=-100, const int size_c=-100, const int interpolation_type=1, const unsigned int boundary_conditions=0, const float centering_x=0, const float centering_y=0, const float centering_z=0, const float centering_c=0) |  |  | Resize image to new dimensions. 
 |  | CImg< T > | get_resize (const int size_x, const int size_y=-100, const int size_z=-100, const int size_c=-100, const int interpolation_type=1, const unsigned int boundary_conditions=0, const float centering_x=0, const float centering_y=0, const float centering_z=0, const float centering_c=0) const |  |  | Resize image to new dimensions [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | resize (const CImg< t > &src, const int interpolation_type=1, const unsigned int boundary_conditions=0, const float centering_x=0, const float centering_y=0, const float centering_z=0, const float centering_c=0) |  |  | Resize image to dimensions of another image. 
 |  | template<typename t > |  | CImg< T > | get_resize (const CImg< t > &src, const int interpolation_type=1, const unsigned int boundary_conditions=0, const float centering_x=0, const float centering_y=0, const float centering_z=0, const float centering_c=0) const |  |  | Resize image to dimensions of another image [new-instance version]. 
 |  | CImg< T > & | resize (const CImgDisplay &disp, const int interpolation_type=1, const unsigned int boundary_conditions=0, const float centering_x=0, const float centering_y=0, const float centering_z=0, const float centering_c=0) |  |  | Resize image to dimensions of a display window. 
 |  | CImg< T > | get_resize (const CImgDisplay &disp, const int interpolation_type=1, const unsigned int boundary_conditions=0, const float centering_x=0, const float centering_y=0, const float centering_z=0, const float centering_c=0) const |  |  | Resize image to dimensions of a display window [new-instance version]. 
 |  | CImg< T > & | resize_halfXY () |  |  | Resize image to half-size along XY axes, using an optimized filter. 
 |  | CImg< T > | get_resize_halfXY () const |  |  | Resize image to half-size along XY axes, using an optimized filter [new-instance version]. 
 |  | CImg< T > & | resize_doubleXY () |  |  | Resize image to double-size, using the Scale2X algorithm. 
 |  | CImg< T > | get_resize_doubleXY () const |  |  | Resize image to double-size, using the Scale2X algorithm [new-instance version]. 
 |  | CImg< T > & | resize_tripleXY () |  |  | Resize image to triple-size, using the Scale3X algorithm. 
 |  | CImg< T > | get_resize_tripleXY () const |  |  | Resize image to triple-size, using the Scale3X algorithm [new-instance version]. 
 |  | CImg< T > & | mirror (const char axis) |  |  | Mirror image content along specified axis. 
 |  | CImg< T > | get_mirror (const char axis) const |  |  | Mirror image content along specified axis [new-instance version]. 
 |  | CImg< T > & | mirror (const char *const axes) |  |  | Mirror image content along specified axes. 
 |  | CImg< T > | get_mirror (const char *const axes) const |  |  | Mirror image content along specified axes [new-instance version]. 
 |  | CImg< T > & | shift (const int delta_x, const int delta_y=0, const int delta_z=0, const int delta_c=0, const int boundary_conditions=0) |  |  | Shift image content. 
 |  | CImg< T > | get_shift (const int delta_x, const int delta_y=0, const int delta_z=0, const int delta_c=0, const int boundary_conditions=0) const |  |  | Shift image content [new-instance version]. 
 |  | CImg< T > & | permute_axes (const char *const order) |  |  | Permute axes order. 
 |  | CImg< T > | get_permute_axes (const char *const order) const |  |  | Permute axes order [new-instance version]. 
 |  | CImg< T > & | unroll (const char axis) |  |  | Unroll pixel values along specified axis. 
 |  | CImg< T > | get_unroll (const char axis) const |  |  | Unroll pixel values along specified axis [new-instance version]. 
 |  | CImg< T > & | rotate (const float angle, const unsigned int interpolation=1, const unsigned int boundary=0) |  |  | Rotate image with arbitrary angle. 
 |  | CImg< T > | get_rotate (const float angle, const unsigned int interpolation=1, const unsigned int boundary=0) const |  |  | Rotate image with arbitrary angle [new-instance version]. 
 |  | CImg< T > & | rotate (const float angle, const float cx, const float cy, const float zoom, const unsigned int interpolation=1, const unsigned int boundary=3) |  |  | Rotate image with arbitrary angle, around a center point. 
 |  | CImg< T > | get_rotate (const float angle, const float cx, const float cy, const float zoom, const unsigned int interpolation=1, const unsigned int boundary=3) const |  |  | Rotate image with arbitrary angle, around a center point [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | warp (const CImg< t > &warp, const bool is_relative=false, const unsigned int interpolation=1, const unsigned int boundary_conditions=0) |  |  | Warp image content by a warping field. 
 |  | template<typename t > |  | CImg< T > | get_warp (const CImg< t > &warp, const bool is_relative=false, const unsigned int interpolation=1, const unsigned int boundary_conditions=0) const |  |  | Warp image content by a warping field [new-instance version] 
 |  | CImg< T > | get_projections2d (const unsigned int x0, const unsigned int y0, const unsigned int z0) const |  |  | Generate a 2d representation of a 3d image, with XY,XZ and YZ views. 
 |  | CImg< T > & | projections2d (const unsigned int x0, const unsigned int y0, const unsigned int z0) |  |  | Construct a 2d representation of a 3d image, with XY,XZ and YZ views [in-place version]. 
 |  | CImg< T > & | crop (const int x0, const int y0, const int z0, const int c0, const int x1, const int y1, const int z1, const int c1, const bool boundary_conditions=false) |  |  | Crop image region. 
 |  | CImg< T > | get_crop (const int x0, const int y0, const int z0, const int c0, const int x1, const int y1, const int z1, const int c1, const bool boundary_conditions=false) const |  |  | Crop image region [new-instance version]. 
 |  | CImg< T > & | crop (const int x0, const int y0, const int z0, const int x1, const int y1, const int z1, const bool boundary_conditions=false) |  |  | Crop image region [overloading]. 
 |  | CImg< T > | get_crop (const int x0, const int y0, const int z0, const int x1, const int y1, const int z1, const bool boundary_conditions=false) const |  |  | Crop image region [new-instance version]. 
 |  | CImg< T > & | crop (const int x0, const int y0, const int x1, const int y1, const bool boundary_conditions=false) |  |  | Crop image region [overloading]. 
 |  | CImg< T > | get_crop (const int x0, const int y0, const int x1, const int y1, const bool boundary_conditions=false) const |  |  | Crop image region [new-instance version]. 
 |  | CImg< T > & | crop (const int x0, const int x1, const bool boundary_conditions=false) |  |  | Crop image region [overloading]. 
 |  | CImg< T > | get_crop (const int x0, const int x1, const bool boundary_conditions=false) const |  |  | Crop image region [new-instance version]. 
 |  | CImg< T > & | autocrop (const T value, const char *const axes="czyx") |  |  | Autocrop image region, regarding the specified background value. 
 |  | CImg< T > | get_autocrop (const T value, const char *const axes="czyx") const |  |  | Autocrop image region, regarding the specified background value [new-instance version]. 
 |  | CImg< T > & | autocrop (const T *const color=0, const char *const axes="zyx") |  |  | Autocrop image region, regarding the specified background color. 
 |  | CImg< T > | get_autocrop (const T *const color=0, const char *const axes="zyx") const |  |  | Autocrop image region, regarding the specified background color [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | autocrop (const CImg< t > &color, const char *const axes="zyx") |  |  | Autocrop image region, regarding the specified background color [overloading]. 
 |  | template<typename t > |  | CImg< T > | get_autocrop (const CImg< t > &color, const char *const axes="zyx") const |  |  | Autocrop image region, regarding the specified background color [new-instance version]. 
 |  | CImg< T > | get_column (const int x0) const |  |  | Return specified image column. 
 |  | CImg< T > & | column (const int x0) |  |  | Return specified image column [in-place version]. 
 |  | CImg< T > & | columns (const int x0, const int x1) |  |  | Return specified range of image columns. 
 |  | CImg< T > | get_columns (const int x0, const int x1) const |  |  | Return specified range of image columns [in-place version]. 
 |  | CImg< T > | get_row (const int y0) const |  |  | Return specified image row. 
 |  | CImg< T > & | row (const int y0) |  |  | Return specified image row [in-place version]. 
 |  | CImg< T > | get_rows (const int y0, const int y1) const |  |  | Return specified range of image rows. 
 |  | CImg< T > & | rows (const int y0, const int y1) |  |  | Return specified range of image rows [in-place version]. 
 |  | CImg< T > | get_slice (const int z0) const |  |  | Return specified image slice. 
 |  | CImg< T > & | slice (const int z0) |  |  | Return specified image slice [in-place version]. 
 |  | CImg< T > | get_slices (const int z0, const int z1) const |  |  | Return specified range of image slices. 
 |  | CImg< T > & | slices (const int z0, const int z1) |  |  | Return specified range of image slices [in-place version]. 
 |  | CImg< T > | get_channel (const int c0) const |  |  | Return specified image channel. 
 |  | CImg< T > & | channel (const int c0) |  |  | Return specified image channel [in-place version]. 
 |  | CImg< T > | get_channels (const int c0, const int c1) const |  |  | Return specified range of image channels. 
 |  | CImg< T > & | channels (const int c0, const int c1) |  |  | Return specified range of image channels [in-place version]. 
 |  | CImg< floatT > | get_streamline (const float x, const float y, const float z, const float L=256, const float dl=0.1f, const unsigned int interpolation_type=2, const bool is_backward_tracking=false, const bool is_oriented_only=false) const |  |  | Return stream line of a 2d or 3d vector field. 
 |  | CImg< T > | get_shared_points (const unsigned int x0, const unsigned int x1, const unsigned int y0=0, const unsigned int z0=0, const unsigned int c0=0) |  |  | Return a shared-memory image referencing a range of pixels of the image instance. 
 |  | const CImg< T > | get_shared_points (const unsigned int x0, const unsigned int x1, const unsigned int y0=0, const unsigned int z0=0, const unsigned int c0=0) const |  |  | Return a shared-memory image referencing a range of pixels of the image instance [const version]. 
 |  | CImg< T > | get_shared_rows (const unsigned int y0, const unsigned int y1, const unsigned int z0=0, const unsigned int c0=0) |  |  | Return a shared-memory image referencing a range of rows of the image instance. 
 |  | const CImg< T > | get_shared_rows (const unsigned int y0, const unsigned int y1, const unsigned int z0=0, const unsigned int c0=0) const |  |  | Return a shared-memory image referencing a range of rows of the image instance [const version]. 
 |  | CImg< T > | get_shared_row (const unsigned int y0, const unsigned int z0=0, const unsigned int c0=0) |  |  | Return a shared-memory image referencing one row of the image instance. 
 |  | const CImg< T > | get_shared_row (const unsigned int y0, const unsigned int z0=0, const unsigned int c0=0) const |  |  | Return a shared-memory image referencing one row of the image instance [const version]. 
 |  | CImg< T > | get_shared_slices (const unsigned int z0, const unsigned int z1, const unsigned int c0=0) |  |  | Return a shared memory image referencing a range of slices of the image instance. 
 |  | const CImg< T > | get_shared_slices (const unsigned int z0, const unsigned int z1, const unsigned int c0=0) const |  |  | Return a shared memory image referencing a range of slices of the image instance [const version]. 
 |  | CImg< T > | get_shared_slice (const unsigned int z0, const unsigned int c0=0) |  |  | Return a shared-memory image referencing one slice of the image instance. 
 |  | const CImg< T > | get_shared_slice (const unsigned int z0, const unsigned int c0=0) const |  |  | Return a shared-memory image referencing one slice of the image instance [const version]. 
 |  | CImg< T > | get_shared_channels (const unsigned int c0, const unsigned int c1) |  |  | Return a shared-memory image referencing a range of channels of the image instance. 
 |  | const CImg< T > | get_shared_channels (const unsigned int c0, const unsigned int c1) const |  |  | Return a shared-memory image referencing a range of channels of the image instance [const version]. 
 |  | CImg< T > | get_shared_channel (const unsigned int c0) |  |  | Return a shared-memory image referencing one channel of the image instance. 
 |  | const CImg< T > | get_shared_channel (const unsigned int c0) const |  |  | Return a shared-memory image referencing one channel of the image instance [const version]. 
 |  | CImg< T > | get_shared () |  |  | Return a shared-memory version of the image instance. 
 |  | const CImg< T > | get_shared () const |  |  | Return a shared-memory version of the image instance [const version]. 
 |  | CImgList< T > | get_split (const char axis, const int nb=0) const |  |  | Split image into a list along specified axis. 
 |  | CImgList< T > | get_split (const T value, const bool keep_values, const bool is_shared) const |  |  | Split image into a list of one-column vectors, according to a specified splitting value. 
 |  | template<typename t > |  | CImgList< T > | get_split (const CImg< t > &values, const bool keep_values, const bool is_shared) const |  |  | Split image into a list of one-column vectors, according to a specified splitting value sequence. 
 |  | template<typename t > |  | CImg< T > & | append (const CImg< t > &img, const char axis='x', const float align=0) |  |  | Append two images along specified axis. 
 |  | CImg< T > & | append (const CImg< T > &img, const char axis='x', const float align=0) |  |  | Append two images along specified axis [specialization]. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | get_append (const CImg< T > &img, const char axis='x', const float align=0) const |  |  | Append two images along specified axis [const version]. 
 |  | CImg< T > | get_append (const CImg< T > &img, const char axis='x', const float align=0) const |  |  | Append two images along specified axis [specialization]. 
 |  | template<typename tfunc > |  | static CImg< floatT > | streamline (const tfunc &func, const float x, const float y, const float z, const float L=256, const float dl=0.1f, const unsigned int interpolation_type=2, const bool is_backward_tracking=false, const bool is_oriented_only=false, const float x0=0, const float y0=0, const float z0=0, const float x1=0, const float y1=0, const float z1=0) |  |  | Return stream line of a 3d vector field. 
 |  | static CImg< floatT > | streamline (const char *const expression, const float x, const float y, const float z, const float L=256, const float dl=0.1f, const unsigned int interpolation_type=2, const bool is_backward_tracking=true, const bool is_oriented_only=false, const float x0=0, const float y0=0, const float z0=0, const float x1=0, const float y1=0, const float z1=0) |  |  | Return stream line of a 3d vector field [overloading]. 
 |  
| 
Filtering / Transforms |  | template<typename t > |  | CImg< T > & | correlate (const CImg< t > &mask, const unsigned int boundary_conditions=1, const bool is_normalized=false) |  |  | Correlate image by a mask. 
 |  | template<typename t > |  | CImg< typename cimg::superset2 < T, t, float >::type >
 | get_correlate (const CImg< t > &mask, const unsigned int boundary_conditions=1, const bool is_normalized=false) const |  |  | Correlate image by a mask [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | convolve (const CImg< t > &mask, const unsigned int boundary_conditions=1, const bool is_normalized=false) |  |  | Convolve image by a mask. 
 |  | template<typename t > |  | CImg< typename cimg::superset2 < T, t, float >::type >
 | get_convolve (const CImg< t > &mask, const unsigned int boundary_conditions=1, const bool is_normalized=false) const |  |  | Convolve image by a mask [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | erode (const CImg< t > &mask, const unsigned int boundary_conditions=1, const bool is_normalized=false) |  |  | Erode image by a structuring element. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | get_erode (const CImg< t > &mask, const unsigned int boundary_conditions=1, const bool is_normalized=false) const |  |  | Erode image by a structuring element [new-instance version]. 
 |  | CImg< T > & | erode (const unsigned int sx, const unsigned int sy, const unsigned int sz=1) |  |  | Erode image by a rectangular structuring element of specified size. 
 |  | CImg< T > | get_erode (const unsigned int sx, const unsigned int sy, const unsigned int sz=1) const |  |  | Erode image by a rectangular structuring element of specified size [new-instance version]. 
 |  | CImg< T > & | erode (const unsigned int s) |  |  | Erode the image by a square structuring element of specified size. 
 |  | CImg< T > | get_erode (const unsigned int s) const |  |  | Erode the image by a square structuring element of specified size [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | dilate (const CImg< t > &mask, const unsigned int boundary_conditions=1, const bool is_normalized=false) |  |  | Dilate image by a structuring element. 
 |  | template<typename t > |  | CImg< typename cimg::superset < T, t >::type >
 | get_dilate (const CImg< t > &mask, const unsigned int boundary_conditions=1, const bool is_normalized=false) const |  |  | Dilate image by a structuring element [new-instance version]. 
 |  | CImg< T > & | dilate (const unsigned int sx, const unsigned int sy, const unsigned int sz=1) |  |  | Dilate image by a rectangular structuring element of specified size. 
 |  | CImg< T > | get_dilate (const unsigned int sx, const unsigned int sy, const unsigned int sz=1) const |  |  | Dilate image by a rectangular structuring element of specified size [new-instance version]. 
 |  | CImg< T > & | dilate (const unsigned int s) |  |  | Dilate image by a square structuring element of specified size. 
 |  | CImg< T > | get_dilate (const unsigned int s) const |  |  | Dilate image by a square structuring element of specified size [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | watershed (const CImg< t > &priority, const bool fill_lines=true) |  |  | Compute watershed transform. 
 |  | template<typename t > |  | CImg< T > | get_watershed (const CImg< t > &priority, const bool fill_lines=true) const |  |  | Compute watershed transform [new-instance version]. 
 |  | CImg< T > & | deriche (const float sigma, const int order=0, const char axis='x', const bool boundary_conditions=true) |  |  | Apply recursive Deriche filter. 
 |  | CImg< Tfloat > | get_deriche (const float sigma, const int order=0, const char axis='x', const bool boundary_conditions=true) const |  |  | Apply recursive Deriche filter [new-instance version]. 
 |  | CImg< T > & | vanvliet (const float sigma, const int order, const char axis='x', const bool boundary_conditions=true) |  |  | Van Vliet recursive Gaussian filter. 
 |  | CImg< Tfloat > | get_vanvliet (const float sigma, const int order, const char axis='x', const bool boundary_conditions=true) const |  |  | Blur image using Van Vliet recursive Gaussian filter. [new-instance version]. 
 |  | CImg< T > & | blur (const float sigma_x, const float sigma_y, const float sigma_z, const bool boundary_conditions=true, const bool is_gaussian=false) |  |  | Blur image. 
 |  | CImg< Tfloat > | get_blur (const float sigma_x, const float sigma_y, const float sigma_z, const bool boundary_conditions=true, const bool is_gaussian=false) const |  |  | Blur image [new-instance version]. 
 |  | CImg< T > & | blur (const float sigma, const bool boundary_conditions=true, const bool is_gaussian=false) |  |  | Blur image isotropically. 
 |  | CImg< Tfloat > | get_blur (const float sigma, const bool boundary_conditions=true, const bool is_gaussian=false) const |  |  | Blur image isotropically [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | blur_anisotropic (const CImg< t > &G, const float amplitude=60, const float dl=0.8f, const float da=30, const float gauss_prec=2, const unsigned int interpolation_type=0, const bool is_fast_approx=1) |  |  | Blur image anisotropically, directed by a field of diffusion tensors. 
 |  | template<typename t > |  | CImg< T > | get_blur_anisotropic (const CImg< t > &G, const float amplitude=60, const float dl=0.8f, const float da=30, const float gauss_prec=2, const unsigned int interpolation_type=0, const bool is_fast_approx=true) const |  |  | Blur image anisotropically, directed by a field of diffusion tensors [new-instance version]. 
 |  | CImg< T > & | blur_anisotropic (const float amplitude, const float sharpness=0.7f, const float anisotropy=0.6f, const float alpha=0.6f, const float sigma=1.1f, const float dl=0.8f, const float da=30, const float gauss_prec=2, const unsigned int interpolation_type=0, const bool is_fast_approx=true) |  |  | Blur image anisotropically, in an edge-preserving way. 
 |  | CImg< T > | get_blur_anisotropic (const float amplitude, const float sharpness=0.7f, const float anisotropy=0.6f, const float alpha=0.6f, const float sigma=1.1f, const float dl=0.8f, const float da=30, const float gauss_prec=2, const unsigned int interpolation_type=0, const bool is_fast_approx=true) const |  |  | Blur image anisotropically, in an edge-preserving way [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | blur_bilateral (const CImg< t > &guide, const float sigma_x, const float sigma_y, const float sigma_z, const float sigma_r, const int bgrid_x, const int bgrid_y, const int bgrid_z, const int bgrid_r, const bool interpolation_type=true) |  |  | Blur image, with the joint bilateral filter. 
 |  | template<typename t > |  | CImg< T > | get_blur_bilateral (const CImg< t > &guide, const float sigma_x, const float sigma_y, const float sigma_z, const float sigma_r, const int bgrid_x, const int bgrid_y, const int bgrid_z, const int bgrid_r, const bool interpolation_type=true) const |  |  | Blur image, with the joint bilateral filter [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | blur_bilateral (const CImg< t > &guide, const float sigma_s, const float sigma_r, const int bgrid_s=-33, const int bgrid_r=32, const bool interpolation_type=true) |  |  | Blur image using the joint bilateral filter. 
 |  | template<typename t > |  | CImg< T > | get_blur_bilateral (const CImg< t > &guide, const float sigma_s, const float sigma_r, const int bgrid_s=-33, const int bgrid_r=32, const bool interpolation_type=true) const |  |  | Blur image using the bilateral filter [new-instance version]. 
 |  | CImg< T > & | blur_patch (const float sigma_s, const float sigma_p, const unsigned int patch_size=3, const unsigned int lookup_size=4, const float smoothness=0, const bool is_fast_approx=true) |  |  | Blur image using patch-based space. 
 |  | CImg< T > | get_blur_patch (const float sigma_s, const float sigma_p, const unsigned int patch_size=3, const unsigned int lookup_size=4, const float smoothness=0, const bool is_fast_approx=true) const |  |  | Blur image using patch-based space [new-instance version]. 
 |  | CImg< T > & | blur_median (const unsigned int n) |  |  | Blur image with the median filter. 
 |  | CImg< T > | get_blur_median (const unsigned int n) const |  |  | Blur image with the median filter [new-instance version]. 
 |  | CImg< T > & | sharpen (const float amplitude, const bool sharpen_type=false, const float edge=1, const float alpha=0, const float sigma=0) |  |  | Sharpen image. 
 |  | CImg< T > | get_sharpen (const float amplitude, const bool sharpen_type=false, const float edge=1, const float alpha=0, const float sigma=0) const |  |  | Sharpen image [new-instance version]. 
 |  | CImgList< Tfloat > | get_gradient (const char *const axes=0, const int scheme=3) const |  |  | Return image gradient. 
 |  | CImgList< Tfloat > | get_hessian (const char *const axes=0) const |  |  | Return image hessian. 
 |  | CImg< T > & | laplacian () |  |  | Compute image laplacian. 
 |  | CImg< Tfloat > | get_laplacian () const |  |  | Compute image laplacian [new-instance version]. 
 |  | CImg< T > & | structure_tensors (const unsigned int scheme=2) |  |  | Compute the structure tensor field of an image. 
 |  | CImg< Tfloat > | get_structure_tensors (const unsigned int scheme=2) const |  |  | Compute the structure tensor field of an image [new-instance version]. 
 |  | CImg< T > & | diffusion_tensors (const float sharpness=0.7f, const float anisotropy=0.6f, const float alpha=0.6f, const float sigma=1.1f, const bool is_sqrt=false) |  |  | Compute field of diffusion tensors for edge-preserving smoothing. 
 |  | CImg< Tfloat > | get_diffusion_tensors (const float sharpness=0.7f, const float anisotropy=0.6f, const float alpha=0.6f, const float sigma=1.1f, const bool is_sqrt=false) const |  |  | Compute field of diffusion tensors for edge-preserving smoothing [new-instance version]. 
 |  | CImg< T > & | displacement (const CImg< T > &source, const float smoothness=0.1f, const float precision=5.0f, const unsigned int nb_scales=0, const unsigned int iteration_max=10000, const bool is_backward=false) |  |  | Estimate displacement field between two images. 
 |  | CImg< Tfloat > | get_displacement (const CImg< T > &source, const float smoothness=0.1f, const float precision=5.0f, const unsigned int nb_scales=0, const unsigned int iteration_max=10000, const bool is_backward=false) const |  |  | Estimate displacement field between two images [new-instance version]. 
 |  | CImg< T > & | distance (const T value, const unsigned int metric=2) |  |  | Compute Euclidean distance function to a specified value. 
 |  | CImg< Tfloat > | get_distance (const T value, const unsigned int metric=2) const |  |  | Compute distance to a specified value [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | distance (const T value, const CImg< t > &metric_mask) |  |  | Compute chamfer distance to a specified value, with a custom metric. 
 |  | template<typename t > |  | CImg< Tfloat > | get_distance (const T value, const CImg< t > &metric_mask) const |  |  | Compute chamfer distance to a specified value, with a custom metric [new-instance version]. 
 |  | template<typename t , typename to > |  | CImg< T > & | distance_dijkstra (const T value, const CImg< t > &metric, const bool is_high_connectivity, CImg< to > &return_path) |  |  | Compute distance to a specified value, according to a custom metric (use dijkstra algorithm). 
 |  | template<typename t , typename to > |  | CImg< Tfloat > | get_distance_dijkstra (const T value, const CImg< t > &metric, const bool is_high_connectivity, CImg< to > &return_path) const |  |  | Compute distance map to a specified value, according to a custom metric (use dijkstra algorithm). [new-instance version]. 
 |  | template<typename t > |  | CImg< T > & | distance_dijkstra (const T value, const CImg< t > &metric, const bool is_high_connectivity=false) |  |  | Compute distance map to a specified value, according to a custom metric (use dijkstra algorithm). [overloading]. 
 |  | template<typename t > |  | CImg< Tfloat > | get_distance_dijkstra (const T value, const CImg< t > &metric, const bool is_high_connectivity=false) const |  |  | Compute distance map to a specified value, according to a custom metric (use dijkstra algorithm). [new-instance version]. 
 |  | template<typename t > |  | CImg & | distance_eikonal (const T value, const CImg< t > &metric) |  |  | Compute distance map to one source point, according to a custom metric (use fast marching algorithm). 
 |  | template<typename t > |  | CImg< Tfloat > | get_distance_eikonal (const T value, const CImg< t > &metric) const |  |  | Compute distance map to one source point, according to a custom metric (use fast marching algorithm). 
 |  | CImg< T > & | distance_eikonal (const unsigned int nb_iterations, const float band_size=0, const float time_step=0.5f) |  |  | Compute distance function to 0-valued isophotes, using the Eikonal PDE. 
 |  | CImg< Tfloat > | get_distance_eikonal (const unsigned int nb_iterations, const float band_size=0, const float time_step=0.5f) const |  |  | Compute distance function to 0-valued isophotes, using the Eikonal PDE [new-instance version]. 
 |  | CImg< T > & | haar (const char axis, const bool invert=false, const unsigned int nb_scales=1) |  |  | Compute Haar multiscale wavelet transform. 
 |  | CImg< Tfloat > | get_haar (const char axis, const bool invert=false, const unsigned int nb_scales=1) const |  |  | Compute Haar multiscale wavelet transform [new-instance version]. 
 |  | CImg< T > & | haar (const bool invert=false, const unsigned int nb_scales=1) |  |  | Compute Haar multiscale wavelet transform [overloading]. 
 |  | CImg< Tfloat > | get_haar (const bool invert=false, const unsigned int nb_scales=1) const |  |  | Compute Haar multiscale wavelet transform [new-instance version]. 
 |  | CImgList< Tfloat > | get_FFT (const char axis, const bool is_invert=false) const |  |  | Compute 1d Fast Fourier Transform, along a specified axis. 
 |  | CImgList< Tfloat > | get_FFT (const bool is_invert=false) const |  |  | Compute n-d Fast Fourier Transform. 
 |  | static void | FFT (CImg< T > &real, CImg< T > &imag, const char axis, const bool is_invert=false) |  |  | Compute 1d Fast Fourier Transform, along a specified axis. 
 |  | static void | FFT (CImg< T > &real, CImg< T > &imag, const bool is_invert=false, const unsigned int nb_threads=0) |  |  | Compute n-d Fast Fourier Transform. 
 |  
| 
3d Objects Management |  | CImg< T > & | shift_object3d (const float tx, const float ty=0, const float tz=0) |  |  | Shift 3d object's vertices. 
 |  | CImg< Tfloat > | get_shift_object3d (const float tx, const float ty=0, const float tz=0) const |  |  | Shift 3d object's vertices [new-instance version]. 
 |  | CImg< T > & | shift_object3d () |  |  | Shift 3d object's vertices, so that it becomes centered. 
 |  | CImg< Tfloat > | get_shift_object3d () const |  |  | Shift 3d object's vertices, so that it becomes centered [new-instance version]. 
 |  | CImg< T > & | resize_object3d (const float sx, const float sy=-100, const float sz=-100) |  |  | Resize 3d object. 
 |  | CImg< Tfloat > | get_resize_object3d (const float sx, const float sy=-100, const float sz=-100) const |  |  | Resize 3d object [new-instance version]. 
 |  | CImg< T > | resize_object3d () |  |  | Resize 3d object to unit size. 
 |  | CImg< Tfloat > | get_resize_object3d () const |  |  | Resize 3d object to unit size [new-instance version]. 
 |  | template<typename tf , typename tp , typename tff > |  | CImg< T > & | append_object3d (CImgList< tf > &primitives, const CImg< tp > &obj_vertices, const CImgList< tff > &obj_primitives) |  |  | Merge two 3d objects together. 
 |  | template<typename tp , typename tc , typename tt , typename tx > |  | const CImg< T > & | texturize_object3d (CImgList< tp > &primitives, CImgList< tc > &colors, const CImg< tt > &texture, const CImg< tx > &coords=CImg< tx >::empty()) const |  |  | Texturize primitives of a 3d object. 
 |  | template<typename tf , typename tc , typename te > |  | CImg< floatT > | get_elevation3d (CImgList< tf > &primitives, CImgList< tc > &colors, const CImg< te > &elevation) const |  |  | Generate a 3d elevation of the image instance. 
 |  | template<typename tf , typename tc > |  | CImg< floatT > | get_projections3d (CImgList< tf > &primitives, CImgList< tc > &colors, const unsigned int x0, const unsigned int y0, const unsigned int z0, const bool normalize_colors=false) const |  |  | Generate the 3d projection planes of the image instance. 
 |  | template<typename tf > |  | CImg< floatT > | get_isoline3d (CImgList< tf > &primitives, const float isovalue, const int size_x=-100, const int size_y=-100) const |  |  | Generate a isoline of the image instance as a 3d object. 
 |  | template<typename tf > |  | CImg< floatT > | get_isosurface3d (CImgList< tf > &primitives, const float isovalue, const int size_x=-100, const int size_y=-100, const int size_z=-100) const |  |  | Generate an isosurface of the image instance as a 3d object. 
 |  | template<typename tp , typename tc , typename to > |  | CImg< T > & | object3dtoCImg3d (const CImgList< tp > &primitives, const CImgList< tc > &colors, const to &opacities) |  |  | Convert 3d object into a CImg3d representation. 
 |  | template<typename tp , typename tc > |  | CImg< T > & | object3dtoCImg3d (const CImgList< tp > &primitives, const CImgList< tc > &colors) |  |  | Convert 3d object into a CImg3d representation [overloading]. 
 |  | template<typename tp > |  | CImg< T > & | object3dtoCImg3d (const CImgList< tp > &primitives) |  |  | Convert 3d object into a CImg3d representation [overloading]. 
 |  | CImg< T > & | object3dtoCImg3d () |  |  | Convert 3d object into a CImg3d representation [overloading]. 
 |  | template<typename tp , typename tc , typename to > |  | CImg< floatT > | get_object3dtoCImg3d (const CImgList< tp > &primitives, const CImgList< tc > &colors, const to &opacities) const |  |  | Convert 3d object into a CImg3d representation [new-instance version]. 
 |  | template<typename tp , typename tc > |  | CImg< floatT > | get_object3dtoCImg3d (const CImgList< tp > &primitives, const CImgList< tc > &colors) const |  |  | Convert 3d object into a CImg3d representation [overloading]. 
 |  | template<typename tp > |  | CImg< floatT > | get_object3dtoCImg3d (const CImgList< tp > &primitives) const |  |  | Convert 3d object into a CImg3d representation [overloading]. 
 |  | CImg< floatT > | get_object3dtoCImg3d () const |  |  | Convert 3d object into a CImg3d representation [overloading]. 
 |  | template<typename tp , typename tc , typename to > |  | CImg< T > & | CImg3dtoobject3d (CImgList< tp > &primitives, CImgList< tc > &colors, CImgList< to > &opacities) |  |  | Convert CImg3d representation into a 3d object. 
 |  | template<typename tp , typename tc , typename to > |  | CImg< T > | get_CImg3dtoobject3d (CImgList< tp > &primitives, CImgList< tc > &colors, CImgList< to > &opacities) const |  |  | Convert CImg3d representation into a 3d object [new-instance version]. 
 |  | template<typename tf , typename tfunc > |  | static CImg< floatT > | elevation3d (CImgList< tf > &primitives, const tfunc &func, const float x0, const float y0, const float x1, const float y1, const int size_x=256, const int size_y=256) |  |  | Compute 3d elevation of a function as a 3d object. 
 |  | template<typename tf > |  | static CImg< floatT > | elevation3d (CImgList< tf > &primitives, const char *const expression, const float x0, const float y0, const float x1, const float y1, const int size_x=256, const int size_y=256) |  |  | Compute 3d elevation of a function, as a 3d object [overloading]. 
 |  | template<typename tf , typename tfunc > |  | static CImg< floatT > | isoline3d (CImgList< tf > &primitives, const tfunc &func, const float isovalue, const float x0, const float y0, const float x1, const float y1, const int size_x=256, const int size_y=256) |  |  | Compute 0-isolines of a function, as a 3d object. 
 |  | template<typename tf > |  | static CImg< floatT > | isoline3d (CImgList< tf > &primitives, const char *const expression, const float isovalue, const float x0, const float y0, const float x1, const float y1, const int size_x=256, const int size_y=256) |  |  | Compute isolines of a function, as a 3d object [overloading]. 
 |  | template<typename tf , typename tfunc > |  | static CImg< floatT > | isosurface3d (CImgList< tf > &primitives, const tfunc &func, const float isovalue, const float x0, const float y0, const float z0, const float x1, const float y1, const float z1, const int size_x=32, const int size_y=32, const int size_z=32) |  |  | Compute isosurface of a function, as a 3d object. 
 |  | template<typename tf > |  | static CImg< floatT > | isosurface3d (CImgList< tf > &primitives, const char *const expression, const float isovalue, const float x0, const float y0, const float z0, const float x1, const float y1, const float z1, const int dx=32, const int dy=32, const int dz=32) |  |  | Compute isosurface of a function, as a 3d object [overloading]. 
 |  | template<typename tf > |  | static CImg< floatT > | box3d (CImgList< tf > &primitives, const float size_x=200, const float size_y=100, const float size_z=100) |  |  | Generate a 3d box object. 
 |  | template<typename tf > |  | static CImg< floatT > | cone3d (CImgList< tf > &primitives, const float radius=50, const float size_z=100, const unsigned int subdivisions=24) |  |  | Generate a 3d cone. 
 |  | template<typename tf > |  | static CImg< floatT > | cylinder3d (CImgList< tf > &primitives, const float radius=50, const float size_z=100, const unsigned int subdivisions=24) |  |  | Generate a 3d cylinder. 
 |  | template<typename tf > |  | static CImg< floatT > | torus3d (CImgList< tf > &primitives, const float radius1=100, const float radius2=30, const unsigned int subdivisions1=24, const unsigned int subdivisions2=12) |  |  | Generate a 3d torus. 
 |  | template<typename tf > |  | static CImg< floatT > | plane3d (CImgList< tf > &primitives, const float size_x=100, const float size_y=100, const unsigned int subdivisions_x=10, const unsigned int subdivisions_y=10) |  |  | Generate a 3d XY-plane. 
 |  | template<typename tf > |  | static CImg< floatT > | sphere3d (CImgList< tf > &primitives, const float radius=50, const unsigned int subdivisions=3) |  |  | Generate a 3d sphere. 
 |  | template<typename tf , typename t > |  | static CImg< floatT > | ellipsoid3d (CImgList< tf > &primitives, const CImg< t > &tensor, const unsigned int subdivisions=3) |  |  | Generate a 3d ellipsoid. 
 |  
| 
Drawing Functions |  | template<typename tc > |  | CImg< T > & | draw_point (const int x0, const int y0, const int z0, const tc *const color, const float opacity=1) |  |  | Draw a 3d point. 
 |  | template<typename tc > |  | CImg< T > & | draw_point (const int x0, const int y0, const tc *const color, const float opacity=1) |  |  | Draw a 2d point [simplification]. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_point (const CImg< t > &points, const tc *const color, const float opacity=1) |  | template<typename tc > |  | CImg< T > & | draw_line (const int x0, const int y0, const int x1, const int y1, const tc *const color, const float opacity=1, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a 2d line. 
 |  | template<typename tz , typename tc > |  | CImg< T > & | draw_line (CImg< tz > &zbuffer, const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const tc *const color, const float opacity=1, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a 2d line, with z-buffering. 
 |  | template<typename tc > |  | CImg< T > & | draw_line (const int x0, const int y0, const int z0, const int x1, const int y1, const int z1, const tc *const color, const float opacity=1, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a 3d line. 
 |  | template<typename tc > |  | CImg< T > & | draw_line (const int x0, const int y0, const int x1, const int y1, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const float opacity=1, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a textured 2d line. 
 |  | template<typename tc > |  | CImg< T > & | draw_line (const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const float opacity=1, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a textured 2d line, with perspective correction. 
 |  | template<typename tz , typename tc > |  | CImg< T > & | draw_line (CImg< tz > &zbuffer, const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const float opacity=1, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a textured 2d line, with perspective correction and z-buffering. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_line (const CImg< t > &points, const tc *const color, const float opacity=1, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a set of consecutive lines. 
 |  | template<typename tc > |  | CImg< T > & | draw_arrow (const int x0, const int y0, const int x1, const int y1, const tc *const color, const float opacity=1, const float angle=30, const float length=-10, const unsigned int pattern=~0U) |  |  | Draw a 2d arrow. 
 |  | template<typename tc > |  | CImg< T > & | draw_spline (const int x0, const int y0, const float u0, const float v0, const int x1, const int y1, const float u1, const float v1, const tc *const color, const float opacity=1, const float precision=0.25, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a 2d spline. 
 |  | template<typename tc > |  | CImg< T > & | draw_spline (const int x0, const int y0, const int z0, const float u0, const float v0, const float w0, const int x1, const int y1, const int z1, const float u1, const float v1, const float w1, const tc *const color, const float opacity=1, const float precision=4, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a 3d spline [overloading]. 
 |  | template<typename t > |  | CImg< T > & | draw_spline (const int x0, const int y0, const float u0, const float v0, const int x1, const int y1, const float u1, const float v1, const CImg< t > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const float opacity=1, const float precision=4, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a textured 2d spline. 
 |  | template<typename tp , typename tt , typename tc > |  | CImg< T > & | draw_spline (const CImg< tp > &points, const CImg< tt > &tangents, const tc *const color, const float opacity=1, const bool is_closed_set=false, const float precision=4, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a set of consecutive splines. 
 |  | template<typename tp , typename tc > |  | CImg< T > & | draw_spline (const CImg< tp > &points, const tc *const color, const float opacity=1, const bool is_closed_set=false, const float precision=4, const unsigned int pattern=~0U, const bool init_hatch=true) |  |  | Draw a set of consecutive splines [overloading]. 
 |  | template<typename tc > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const int x1, const int y1, const int x2, const int y2, const tc *const color, const float opacity=1) |  |  | Draw a filled 2d triangle. 
 |  | template<typename tc > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const int x1, const int y1, const int x2, const int y2, const tc *const color, const float opacity, const unsigned int pattern) |  |  | Draw a outlined 2d triangle. 
 |  | template<typename tz , typename tc > |  | CImg< T > & | draw_triangle (CImg< tz > &zbuffer, const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const int x2, const int y2, const float z2, const tc *const color, const float opacity=1, const float brightness=1) |  |  | Draw a filled 2d triangle, with z-buffering. 
 |  | template<typename tc > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const int x1, const int y1, const int x2, const int y2, const tc *const color, const float brightness0, const float brightness1, const float brightness2, const float opacity=1) |  |  | Draw a Gouraud-shaded 2d triangle. 
 |  | template<typename tz , typename tc > |  | CImg< T > & | draw_triangle (CImg< tz > &zbuffer, const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const int x2, const int y2, const float z2, const tc *const color, const float brightness0, const float brightness1, const float brightness2, const float opacity=1) |  |  | Draw a Gouraud-shaded 2d triangle, with z-buffering [overloading]. 
 |  | template<typename tc1 , typename tc2 , typename tc3 > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const int x1, const int y1, const int x2, const int y2, const tc1 *const color1, const tc2 *const color2, const tc3 *const color3, const float opacity=1) |  |  | Draw a color-interpolated 2d triangle. 
 |  | template<typename tc > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const int x1, const int y1, const int x2, const int y2, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const int tx2, const int ty2, const float opacity=1, const float brightness=1) |  |  | Draw a textured 2d triangle. 
 |  | template<typename tc > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const int x2, const int y2, const float z2, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const int tx2, const int ty2, const float opacity=1, const float brightness=1) |  |  | Draw a 2d textured triangle, with perspective correction. 
 |  | template<typename tz , typename tc > |  | CImg< T > & | draw_triangle (CImg< tz > &zbuffer, const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const int x2, const int y2, const float z2, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const int tx2, const int ty2, const float opacity=1, const float brightness=1) |  |  | Draw a textured 2d triangle, with perspective correction and z-buffering. 
 |  | template<typename tc , typename tl > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const int x1, const int y1, const int x2, const int y2, const tc *const color, const CImg< tl > &light, const int lx0, const int ly0, const int lx1, const int ly1, const int lx2, const int ly2, const float opacity=1) |  |  | Draw a Phong-shaded 2d triangle. 
 |  | template<typename tz , typename tc , typename tl > |  | CImg< T > & | draw_triangle (CImg< tz > &zbuffer, const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const int x2, const int y2, const float z2, const tc *const color, const CImg< tl > &light, const int lx0, const int ly0, const int lx1, const int ly1, const int lx2, const int ly2, const float opacity=1) |  |  | Draw a Phong-shaded 2d triangle, with z-buffering. 
 |  | template<typename tc > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const int x1, const int y1, const int x2, const int y2, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const int tx2, const int ty2, const float brightness0, const float brightness1, const float brightness2, const float opacity=1) |  |  | Draw a textured Gouraud-shaded 2d triangle. 
 |  | template<typename tc > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const int x2, const int y2, const float z2, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const int tx2, const int ty2, const float brightness0, const float brightness1, const float brightness2, const float opacity=1) |  |  | Draw a textured Gouraud-shaded 2d triangle, with perspective correction [overloading]. 
 |  | template<typename tz , typename tc > |  | CImg< T > & | draw_triangle (CImg< tz > &zbuffer, const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const int x2, const int y2, const float z2, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const int tx2, const int ty2, const float brightness0, const float brightness1, const float brightness2, const float opacity=1) |  |  | Draw a textured Gouraud-shaded 2d triangle, with perspective correction and z-buffering [overloading]. 
 |  | template<typename tc , typename tl > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const int x1, const int y1, const int x2, const int y2, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const int tx2, const int ty2, const CImg< tl > &light, const int lx0, const int ly0, const int lx1, const int ly1, const int lx2, const int ly2, const float opacity=1) |  |  | Draw a textured Phong-shaded 2d triangle. 
 |  | template<typename tc , typename tl > |  | CImg< T > & | draw_triangle (const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const int x2, const int y2, const float z2, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const int tx2, const int ty2, const CImg< tl > &light, const int lx0, const int ly0, const int lx1, const int ly1, const int lx2, const int ly2, const float opacity=1) |  |  | Draw a textured Phong-shaded 2d triangle, with perspective correction. 
 |  | template<typename tz , typename tc , typename tl > |  | CImg< T > & | draw_triangle (CImg< tz > &zbuffer, const int x0, const int y0, const float z0, const int x1, const int y1, const float z1, const int x2, const int y2, const float z2, const CImg< tc > &texture, const int tx0, const int ty0, const int tx1, const int ty1, const int tx2, const int ty2, const CImg< tl > &light, const int lx0, const int ly0, const int lx1, const int ly1, const int lx2, const int ly2, const float opacity=1) |  |  | Draw a textured Phong-shaded 2d triangle, with perspective correction and z-buffering. 
 |  | CImg< T > & | draw_rectangle (const int x0, const int y0, const int z0, const int c0, const int x1, const int y1, const int z1, const int c1, const T val, const float opacity=1) |  |  | Draw a filled 4d rectangle. 
 |  | template<typename tc > |  | CImg< T > & | draw_rectangle (const int x0, const int y0, const int z0, const int x1, const int y1, const int z1, const tc *const color, const float opacity=1) |  |  | Draw a filled 3d rectangle. 
 |  | template<typename tc > |  | CImg< T > & | draw_rectangle (const int x0, const int y0, const int z0, const int x1, const int y1, const int z1, const tc *const color, const float opacity, const unsigned int pattern) |  |  | Draw an outlined 3d rectangle [overloading]. 
 |  | template<typename tc > |  | CImg< T > & | draw_rectangle (const int x0, const int y0, const int x1, const int y1, const tc *const color, const float opacity=1) |  |  | Draw a filled 2d rectangle. 
 |  | template<typename tc > |  | CImg< T > & | draw_rectangle (const int x0, const int y0, const int x1, const int y1, const tc *const color, const float opacity, const unsigned int pattern) |  |  | Draw a outlined 2d rectangle [overloading]. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_polygon (const CImg< t > &points, const tc *const color, const float opacity=1) |  |  | Draw a filled 2d polygon. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_polygon (const CImg< t > &points, const tc *const color, const float opacity, const unsigned int pattern) |  |  | Draw a outlined 2d polygon [overloading]. 
 |  | template<typename tc > |  | CImg< T > & | draw_ellipse (const int x0, const int y0, const float r1, const float r2, const float angle, const tc *const color, const float opacity=1) |  |  | Draw a filled 2d ellipse. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_ellipse (const int x0, const int y0, const CImg< t > &tensor, const tc *const color, const float opacity=1) |  |  | Draw a filled 2d ellipse [overloading]. 
 |  | template<typename tc > |  | CImg< T > & | draw_ellipse (const int x0, const int y0, const float r1, const float r2, const float angle, const tc *const color, const float opacity, const unsigned int pattern) |  |  | Draw an outlined 2d ellipse. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_ellipse (const int x0, const int y0, const CImg< t > &tensor, const tc *const color, const float opacity, const unsigned int pattern) |  |  | Draw an outlined 2d ellipse [overloading]. 
 |  | template<typename tc > |  | CImg< T > & | draw_circle (const int x0, const int y0, int radius, const tc *const color, const float opacity=1) |  |  | Draw a filled 2d circle. 
 |  | template<typename tc > |  | CImg< T > & | draw_circle (const int x0, const int y0, int radius, const tc *const color, const float opacity, const unsigned int pattern) |  |  | Draw an outlined 2d circle. 
 |  | template<typename t > |  | CImg< T > & | draw_image (const int x0, const int y0, const int z0, const int c0, const CImg< t > &sprite, const float opacity=1) |  |  | Draw an image. 
 |  | CImg< T > & | draw_image (const int x0, const int y0, const int z0, const int c0, const CImg< T > &sprite, const float opacity=1) |  |  | Draw an image [specialization]. 
 |  | template<typename t > |  | CImg< T > & | draw_image (const int x0, const int y0, const int z0, const CImg< t > &sprite, const float opacity=1) |  |  | Draw an image [overloading]. 
 |  | template<typename t > |  | CImg< T > & | draw_image (const int x0, const int y0, const CImg< t > &sprite, const float opacity=1) |  |  | Draw an image [overloading]. 
 |  | template<typename t > |  | CImg< T > & | draw_image (const int x0, const CImg< t > &sprite, const float opacity=1) |  |  | Draw an image [overloading]. 
 |  | template<typename t > |  | CImg< T > & | draw_image (const CImg< t > &sprite, const float opacity=1) |  |  | Draw an image [overloading]. 
 |  | template<typename ti , typename tm > |  | CImg< T > & | draw_image (const int x0, const int y0, const int z0, const int c0, const CImg< ti > &sprite, const CImg< tm > &mask, const float opacity=1, const float mask_max_value=1) |  |  | Draw a masked image. 
 |  | template<typename ti , typename tm > |  | CImg< T > & | draw_image (const int x0, const int y0, const int z0, const CImg< ti > &sprite, const CImg< tm > &mask, const float opacity=1, const float mask_max_value=1) |  |  | Draw a masked image [overloading]. 
 |  | template<typename ti , typename tm > |  | CImg< T > & | draw_image (const int x0, const int y0, const CImg< ti > &sprite, const CImg< tm > &mask, const float opacity=1, const float mask_max_value=1) |  |  | Draw a image [overloading]. 
 |  | template<typename ti , typename tm > |  | CImg< T > & | draw_image (const int x0, const CImg< ti > &sprite, const CImg< tm > &mask, const float opacity=1, const float mask_max_value=1) |  |  | Draw a image [overloading]. 
 |  | template<typename ti , typename tm > |  | CImg< T > & | draw_image (const CImg< ti > &sprite, const CImg< tm > &mask, const float opacity=1, const float mask_max_value=1) |  |  | Draw an image. 
 |  | template<typename tc1 , typename tc2 , typename t > |  | CImg< T > & | draw_text (const int x0, const int y0, const char *const text, const tc1 *const foreground_color, const tc2 *const background_color, const float opacity, const CImgList< t > &font,...) |  |  | Draw a text string. 
 |  | template<typename tc , typename t > |  | CImg< T > & | draw_text (const int x0, const int y0, const char *const text, const tc *const foreground_color, const int, const float opacity, const CImgList< t > &font,...) |  |  | Draw a text string [overloading]. 
 |  | template<typename tc , typename t > |  | CImg< T > & | draw_text (const int x0, const int y0, const char *const text, const int, const tc *const background_color, const float opacity, const CImgList< t > &font,...) |  |  | Draw a text string [overloading]. 
 |  | template<typename tc1 , typename tc2 > |  | CImg< T > & | draw_text (const int x0, const int y0, const char *const text, const tc1 *const foreground_color, const tc2 *const background_color, const float opacity=1, const unsigned int font_height=13,...) |  |  | Draw a text string [overloading]. 
 |  | template<typename tc > |  | CImg< T > & | draw_text (const int x0, const int y0, const char *const text, const tc *const foreground_color, const int background_color=0, const float opacity=1, const unsigned int font_height=13,...) |  |  | Draw a text string [overloading]. 
 |  | template<typename tc > |  | CImg< T > & | draw_text (const int x0, const int y0, const char *const text, const int, const tc *const background_color, const float opacity=1, const unsigned int font_height=13,...) |  |  | Draw a text string [overloading]. 
 |  | template<typename t1 , typename t2 > |  | CImg< T > & | draw_quiver (const CImg< t1 > &flow, const t2 *const color, const float opacity=1, const unsigned int sampling=25, const float factor=-20, const bool is_arrow=true, const unsigned int pattern=~0U) |  |  | Draw a 2d vector field. 
 |  | template<typename t1 , typename t2 > |  | CImg< T > & | draw_quiver (const CImg< t1 > &flow, const CImg< t2 > &color, const float opacity=1, const unsigned int sampling=25, const float factor=-20, const bool is_arrow=true, const unsigned int pattern=~0U) |  |  | Draw a 2d vector field, using a field of colors. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_axis (const CImg< t > &values_x, const int y, const tc *const color, const float opacity=1, const unsigned int pattern=~0U, const unsigned int font_height=13, const bool allow_zero=true) |  |  | Draw a labeled horizontal axis. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_axis (const int x, const CImg< t > &values_y, const tc *const color, const float opacity=1, const unsigned int pattern=~0U, const unsigned int font_height=13, const bool allow_zero=true) |  |  | Draw a labeled vertical axis. 
 |  | template<typename tx , typename ty , typename tc > |  | CImg< T > & | draw_axes (const CImg< tx > &values_x, const CImg< ty > &values_y, const tc *const color, const float opacity=1, const unsigned int pattern_x=~0U, const unsigned int pattern_y=~0U, const unsigned int font_height=13, const bool allow_zero=true) |  |  | Draw labeled horizontal and vertical axes. 
 |  | template<typename tc > |  | CImg< T > & | draw_axes (const float x0, const float x1, const float y0, const float y1, const tc *const color, const float opacity=1, const int subdivisionx=-60, const int subdivisiony=-60, const float precisionx=0, const float precisiony=0, const unsigned int pattern_x=~0U, const unsigned int pattern_y=~0U, const unsigned int font_height=13) |  |  | Draw labeled horizontal and vertical axes [overloading]. 
 |  | template<typename tx , typename ty , typename tc > |  | CImg< T > & | draw_grid (const CImg< tx > &values_x, const CImg< ty > &values_y, const tc *const color, const float opacity=1, const unsigned int pattern_x=~0U, const unsigned int pattern_y=~0U) |  |  | Draw 2d grid. 
 |  | template<typename tc > |  | CImg< T > & | draw_grid (const float delta_x, const float delta_y, const float offsetx, const float offsety, const bool invertx, const bool inverty, const tc *const color, const float opacity=1, const unsigned int pattern_x=~0U, const unsigned int pattern_y=~0U) |  |  | Draw 2d grid [simplification]. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_graph (const CImg< t > &data, const tc *const color, const float opacity=1, const unsigned int plot_type=1, const int vertex_type=1, const double ymin=0, const double ymax=0, const unsigned int pattern=~0U) |  |  | Draw 1d graph. 
 |  | template<typename tc , typename t > |  | CImg< T > & | draw_fill (const int x, const int y, const int z, const tc *const color, const float opacity, CImg< t > ®ion, const float sigma=0, const bool is_high_connexity=false) |  |  | Draw filled 3d region with the flood fill algorithm. 
 |  | template<typename tc > |  | CImg< T > & | draw_fill (const int x, const int y, const int z, const tc *const color, const float opacity=1, const float sigma=0, const bool is_high_connexity=false) |  |  | Draw filled 3d region with the flood fill algorithm [simplification]. 
 |  | template<typename tc > |  | CImg< T > & | draw_fill (const int x, const int y, const tc *const color, const float opacity=1, const float sigma=0, const bool is_high_connexity=false) |  |  | Draw filled 2d region with the flood fill algorithm [simplification]. 
 |  | CImg< T > & | draw_plasma (const float alpha=1, const float beta=0, const unsigned int scale=8) |  |  | Draw a random plasma texture. 
 |  | template<typename tc > |  | CImg< T > & | draw_mandelbrot (const int x0, const int y0, const int x1, const int y1, const CImg< tc > &colormap, const float opacity=1, const double z0r=-2, const double z0i=-2, const double z1r=2, const double z1i=2, const unsigned int iteration_max=255, const bool is_normalized_iteration=false, const bool is_julia_set=false, const double param_r=0, const double param_i=0) |  |  | Draw a quadratic Mandelbrot or Julia 2d fractal. 
 |  | template<typename tc > |  | CImg< T > & | draw_mandelbrot (const CImg< tc > &colormap, const float opacity=1, const double z0r=-2, const double z0i=-2, const double z1r=2, const double z1i=2, const unsigned int iteration_max=255, const bool is_normalized_iteration=false, const bool is_julia_set=false, const double param_r=0, const double param_i=0) |  |  | Draw a quadratic Mandelbrot or Julia 2d fractal [overloading]. 
 |  | template<typename tc > |  | CImg< T > & | draw_gaussian (const float xc, const float sigma, const tc *const color, const float opacity=1) |  |  | Draw a 1d gaussian function. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_gaussian (const float xc, const float yc, const CImg< t > &tensor, const tc *const color, const float opacity=1) |  |  | Draw a 2d gaussian function. 
 |  | template<typename tc > |  | CImg< T > & | draw_gaussian (const int xc, const int yc, const float r1, const float r2, const float ru, const float rv, const tc *const color, const float opacity=1) |  |  | Draw a 2d gaussian function [overloading]. 
 |  | template<typename tc > |  | CImg< T > & | draw_gaussian (const float xc, const float yc, const float sigma, const tc *const color, const float opacity=1) |  |  | Draw a 2d gaussian function [overloading]. 
 |  | template<typename t , typename tc > |  | CImg< T > & | draw_gaussian (const float xc, const float yc, const float zc, const CImg< t > &tensor, const tc *const color, const float opacity=1) |  |  | Draw a 3d gaussian function [overloading]. 
 |  | template<typename tc > |  | CImg< T > & | draw_gaussian (const float xc, const float yc, const float zc, const float sigma, const tc *const color, const float opacity=1) |  |  | Draw a 3d gaussian function [overloading]. 
 |  | template<typename tp , typename tf , typename tc , typename to > |  | CImg< T > & | draw_object3d (const float x0, const float y0, const float z0, const CImg< tp > &vertices, const CImgList< tf > &primitives, const CImgList< tc > &colors, const CImg< to > &opacities, const unsigned int render_type=4, const bool is_double_sided=false, const float focale=700, const float lightx=0, const float lighty=0, const float lightz=-5e8, const float specular_lightness=0.2f, const float specular_shininess=0.1f) |  |  | Draw a 3d object. 
 |  | template<typename tp , typename tf , typename tc , typename to , typename tz > |  | CImg< T > & | draw_object3d (const float x0, const float y0, const float z0, const CImg< tp > &vertices, const CImgList< tf > &primitives, const CImgList< tc > &colors, const CImg< to > &opacities, const unsigned int render_type, const bool is_double_sided, const float focale, const float lightx, const float lighty, const float lightz, const float specular_lightness, const float specular_shininess, CImg< tz > &zbuffer) |  |  | Draw a 3d object [simplification]. 
 |  | template<typename tp , typename tf , typename tc , typename to > |  | CImg< T > & | draw_object3d (const float x0, const float y0, const float z0, const CImg< tp > &vertices, const CImgList< tf > &primitives, const CImgList< tc > &colors, const CImgList< to > &opacities, const unsigned int render_type=4, const bool is_double_sided=false, const float focale=700, const float lightx=0, const float lighty=0, const float lightz=-5e8, const float specular_lightness=0.2f, const float specular_shininess=0.1f) |  |  | Draw a 3d object [simplification]. 
 |  | template<typename tp , typename tf , typename tc , typename to , typename tz > |  | CImg< T > & | draw_object3d (const float x0, const float y0, const float z0, const CImg< tp > &vertices, const CImgList< tf > &primitives, const CImgList< tc > &colors, const CImgList< to > &opacities, const unsigned int render_type, const bool is_double_sided, const float focale, const float lightx, const float lighty, const float lightz, const float specular_lightness, const float specular_shininess, CImg< tz > &zbuffer) |  |  | Draw a 3d object [simplification]. 
 |  | template<typename tp , typename tf , typename tc > |  | CImg< T > & | draw_object3d (const float x0, const float y0, const float z0, const CImg< tp > &vertices, const CImgList< tf > &primitives, const CImgList< tc > &colors, const unsigned int render_type=4, const bool is_double_sided=false, const float focale=700, const float lightx=0, const float lighty=0, const float lightz=-5e8, const float specular_lightness=0.2f, const float specular_shininess=0.1f) |  |  | Draw a 3d object [simplification]. 
 |  | template<typename tp , typename tf , typename tc , typename tz > |  | CImg< T > & | draw_object3d (const float x0, const float y0, const float z0, const CImg< tp > &vertices, const CImgList< tf > &primitives, const CImgList< tc > &colors, const unsigned int render_type, const bool is_double_sided, const float focale, const float lightx, const float lighty, const float lightz, const float specular_lightness, const float specular_shininess, CImg< tz > &zbuffer) |  |  | Draw a 3d object [simplification]. 
 |  
| 
Data Input |  | CImg< T > & | select (CImgDisplay &disp, const unsigned int feature_type=2, unsigned int *const XYZ=0) |  |  | Launch simple interface to select a shape from an image. 
 |  | CImg< T > & | select (const char *const title, const unsigned int feature_type=2, unsigned int *const XYZ=0) |  |  | Simple interface to select a shape from an image [overloading]. 
 |  | CImg< intT > | get_select (CImgDisplay &disp, const unsigned int feature_type=2, unsigned int *const XYZ=0) const |  |  | Simple interface to select a shape from an image [new-instance version]. 
 |  | CImg< intT > | get_select (const char *const title, const unsigned int feature_type=2, unsigned int *const XYZ=0) const |  |  | Simple interface to select a shape from an image [new-instance version]. 
 |  | CImg< intT > | get_select_graph (CImgDisplay &disp, const unsigned int plot_type=1, const unsigned int vertex_type=1, const char *const labelx=0, const double xmin=0, const double xmax=0, const char *const labely=0, const double ymin=0, const double ymax=0) const |  |  | Select sub-graph in a graph. 
 |  | CImg< T > & | load (const char *const filename) |  |  | Load image from a file. 
 |  | CImg< T > & | load_ascii (const char *const filename) |  |  | Load image from an ascii file. 
 |  | CImg< T > & | load_ascii (std::FILE *const file) |  |  | Load image from an ascii file [overloading]. 
 |  | CImg< T > & | load_dlm (const char *const filename) |  |  | Load image from a DLM file. 
 |  | CImg< T > & | load_dlm (std::FILE *const file) |  |  | Load image from a DLM file [overloading]. 
 |  | CImg< T > & | load_bmp (const char *const filename) |  |  | Load image from a BMP file. 
 |  | CImg< T > & | load_bmp (std::FILE *const file) |  |  | Load image from a BMP file [overloading]. 
 |  | CImg< T > & | load_jpeg (const char *const filename) |  |  | Load image from a JPEG file. 
 |  | CImg< T > & | load_jpeg (std::FILE *const file) |  |  | Load image from a JPEG file [overloading]. 
 |  | CImg< T > & | load_magick (const char *const filename) |  |  | Load image from a file, using Magick++ library. 
 |  | CImg< T > & | load_png (const char *const filename) |  |  | Load image from a PNG file. 
 |  | CImg< T > & | load_png (std::FILE *const file) |  |  | Load image from a PNG file [overloading]. 
 |  | CImg< T > & | load_pnm (const char *const filename) |  |  | Load image from a PNM file. 
 |  | CImg< T > & | load_pnm (std::FILE *const file) |  |  | Load image from a PNM file [overloading]. 
 |  | CImg< T > & | load_pfm (const char *const filename) |  |  | Load image from a PFM file. 
 |  | CImg< T > & | load_pfm (std::FILE *const file) |  |  | Load image from a PFM file [overloading]. 
 |  | CImg< T > & | load_rgb (const char *const filename, const unsigned int dimw, const unsigned int dimh=1) |  |  | Load image from a RGB file. 
 |  | CImg< T > & | load_rgb (std::FILE *const file, const unsigned int dimw, const unsigned int dimh=1) |  |  | Load image from a RGB file [overloading]. 
 |  | CImg< T > & | load_rgba (const char *const filename, const unsigned int dimw, const unsigned int dimh=1) |  |  | Load image from a RGBA file. 
 |  | CImg< T > & | load_rgba (std::FILE *const file, const unsigned int dimw, const unsigned int dimh=1) |  |  | Load image from a RGBA file [overloading]. 
 |  | CImg< T > & | load_tiff (const char *const filename, const unsigned int first_frame=0, const unsigned int last_frame=~0U, const unsigned int step_frame=1) |  |  | Load image from a TIFF file. 
 |  | CImg< T > & | load_minc2 (const char *const filename) |  |  | Load image from a MINC2 file. 
 |  | CImg< T > & | load_analyze (const char *const filename, float *const voxel_size=0) |  |  | Load image from an ANALYZE7.5/NIFTI file. 
 |  | CImg< T > & | load_analyze (std::FILE *const file, float *const voxel_size=0) |  |  | Load image from an ANALYZE7.5/NIFTI file [overloading]. 
 |  | CImg< T > & | load_cimg (const char *const filename, const char axis='z', const float align=0) |  |  | Load image from a .cimg[z] file. 
 |  | CImg< T > & | load_cimg (std::FILE *const file, const char axis='z', const float align=0) |  |  | Load image from a .cimg[z] file [overloading]. 
 |  | CImg< T > & | load_cimg (const char *const filename, const unsigned int n0, const unsigned int n1, const unsigned int x0, const unsigned int y0, const unsigned int z0, const unsigned int c0, const unsigned int x1, const unsigned int y1, const unsigned int z1, const unsigned int c1, const char axis='z', const float align=0) |  |  | Load sub-images of a .cimg file. 
 |  | CImg< T > & | load_cimg (std::FILE *const file, const unsigned int n0, const unsigned int n1, const unsigned int x0, const unsigned int y0, const unsigned int z0, const unsigned int c0, const unsigned int x1, const unsigned int y1, const unsigned int z1, const unsigned int c1, const char axis='z', const float align=0) |  |  | Load sub-images of a .cimg file [overloading]. 
 |  | CImg< T > & | load_inr (const char *const filename, float *const voxel_size=0) |  |  | Load image from an INRIMAGE-4 file. 
 |  | CImg< T > & | load_inr (std::FILE *const file, float *const voxel_size=0) |  |  | Load image from an INRIMAGE-4 file [overloading]. 
 |  | CImg< T > & | load_exr (const char *const filename) |  |  | Load image from a EXR file. 
 |  | CImg< T > & | load_pandore (const char *const filename) |  |  | Load image from a PANDORE-5 file. 
 |  | CImg< T > & | load_pandore (std::FILE *const file) |  |  | Load image from a PANDORE-5 file [overloading]. 
 |  | CImg< T > & | load_parrec (const char *const filename, const char axis='c', const float align=0) |  |  | Load image from a PAR-REC (Philips) file. 
 |  | CImg< T > & | load_raw (const char *const filename, const unsigned int size_x=0, const unsigned int size_y=1, const unsigned int size_z=1, const unsigned int size_c=1, const bool is_multiplexed=false, const bool invert_endianness=false) |  |  | Load image from a raw binary file. 
 |  | CImg< T > & | load_raw (std::FILE *const file, const unsigned int size_x=0, const unsigned int size_y=1, const unsigned int size_z=1, const unsigned int size_c=1, const bool is_multiplexed=false, const bool invert_endianness=false) |  |  | Load image from a raw binary file [overloading]. 
 |  | CImg< T > & | load_ffmpeg (const char *const filename, const unsigned int first_frame=0, const unsigned int last_frame=~0U, const unsigned int step_frame=1, const bool pixel_format=true, const bool resume=false, const char axis='z', const float align=0) |  |  | Load image sequence using FFMPEG av's libraries. 
 |  | CImg< T > & | load_yuv (const char *const filename, const unsigned int size_x, const unsigned int size_y=1, const unsigned int first_frame=0, const unsigned int last_frame=~0U, const unsigned int step_frame=1, const bool yuv2rgb=true, const char axis='z') |  |  | Load image sequence from a YUV file. 
 |  | CImg< T > & | load_yuv (std::FILE *const file, const unsigned int size_x, const unsigned int size_y=1, const unsigned int first_frame=0, const unsigned int last_frame=~0U, const unsigned int step_frame=1, const bool yuv2rgb=true, const char axis='z') |  |  | Load image sequence from a YUV file [overloading]. 
 |  | template<typename tf , typename tc > |  | CImg< T > & | load_off (CImgList< tf > &primitives, CImgList< tc > &colors, const char *const filename) |  |  | Load 3d object from a .OFF file. 
 |  | template<typename tf , typename tc > |  | CImg< T > & | load_off (CImgList< tf > &primitives, CImgList< tc > &colors, std::FILE *const file) |  |  | Load 3d object from a .OFF file [overloading]. 
 |  | CImg< T > & | load_ffmpeg_external (const char *const filename, const char axis='z', const float align=0) |  |  | Load image sequence using FFMPEG's external tool 'ffmpeg'. 
 |  | CImg< T > & | load_gif_external (const char *const filename, const char axis='z', const float align=0) |  |  | Load gif file, using Imagemagick or GraphicsMagicks's external tools. 
 |  | CImg< T > & | load_graphicsmagick_external (const char *const filename) |  |  | Load image using GraphicsMagick's external tool 'gm'. 
 |  | CImg< T > & | load_gzip_external (const char *const filename) |  |  | Load gzipped image file, using external tool 'gunzip'. 
 |  | CImg< T > & | load_imagemagick_external (const char *const filename) |  |  | Load image using ImageMagick's external tool 'convert'. 
 |  | CImg< T > & | load_medcon_external (const char *const filename) |  |  | Load image from a DICOM file, using XMedcon's external tool 'medcon'. 
 |  | CImg< T > & | load_dcraw_external (const char *const filename) |  |  | Load image from a RAW Color Camera file, using external tool 'dcraw'. 
 |  | CImg< T > & | load_camera (const unsigned int camera_index=0, const unsigned int skip_frames=0, const bool release_camera=false, const unsigned int capture_width=0, const unsigned int capture_height=0) |  |  | Load image from a camera stream, using OpenCV. 
 |  | CImg< T > & | load_other (const char *const filename) |  |  | Load image using various non-native ways. 
 |  | static CImg< T > | get_load (const char *const filename) |  |  | Load image from a file [new-instance version]. 
 |  | static CImg< T > | get_load_ascii (const char *const filename) |  |  | Load image from an ascii file [in-place version]. 
 |  | static CImg< T > | get_load_ascii (std::FILE *const file) |  |  | Loadimage from an ascii file [new-instance version]. 
 |  | static CImg< T > | get_load_dlm (const char *const filename) |  |  | Load image from a DLM file [new-instance version]. 
 |  | static CImg< T > | get_load_dlm (std::FILE *const file) |  |  | Load image from a DLM file [new-instance version]. 
 |  | static CImg< T > | get_load_bmp (const char *const filename) |  |  | Load image from a BMP file [new-instance version]. 
 |  | static CImg< T > | get_load_bmp (std::FILE *const file) |  |  | Load image from a BMP file [new-instance version]. 
 |  | static CImg< T > | get_load_jpeg (const char *const filename) |  |  | Load image from a JPEG file [new-instance version]. 
 |  | static CImg< T > | get_load_jpeg (std::FILE *const file) |  |  | Load image from a JPEG file [new-instance version]. 
 |  | static CImg< T > | get_load_magick (const char *const filename) |  |  | Load image from a file, using Magick++ library [new-instance version]. 
 |  | static CImg< T > | get_load_png (const char *const filename) |  |  | Load image from a PNG file [new-instance version]. 
 |  | static CImg< T > | get_load_png (std::FILE *const file) |  |  | Load image from a PNG file [new-instance version]. 
 |  | static CImg< T > | get_load_pnm (const char *const filename) |  |  | Load image from a PNM file [new-instance version]. 
 |  | static CImg< T > | get_load_pnm (std::FILE *const file) |  |  | Load image from a PNM file [new-instance version]. 
 |  | static CImg< T > | get_load_pfm (const char *const filename) |  |  | Load image from a PFM file [new-instance version]. 
 |  | static CImg< T > | get_load_pfm (std::FILE *const file) |  |  | Load image from a PFM file [new-instance version]. 
 |  | static CImg< T > | get_load_rgb (const char *const filename, const unsigned int dimw, const unsigned int dimh=1) |  |  | Load image from a RGB file [new-instance version]. 
 |  | static CImg< T > | get_load_rgb (std::FILE *const file, const unsigned int dimw, const unsigned int dimh=1) |  |  | Load image from a RGB file [new-instance version]. 
 |  | static CImg< T > | get_load_rgba (const char *const filename, const unsigned int dimw, const unsigned int dimh=1) |  |  | Load image from a RGBA file [new-instance version]. 
 |  | static CImg< T > | get_load_rgba (std::FILE *const file, const unsigned int dimw, const unsigned int dimh=1) |  |  | Load image from a RGBA file [new-instance version]. 
 |  | static CImg< T > | get_load_tiff (const char *const filename, const unsigned int first_frame=0, const unsigned int last_frame=~0U, const unsigned int step_frame=1) |  |  | Load image from a TIFF file [new-instance version]. 
 |  | static CImg< T > | get_load_minc2 (const char *const filename) |  |  | Load image from a MINC2 file [new-instance version]. 
 |  | static CImg< T > | get_load_analyze (const char *const filename, float *const voxel_size=0) |  |  | Load image from an ANALYZE7.5/NIFTI file [new-instance version]. 
 |  | static CImg< T > | get_load_analyze (std::FILE *const file, float *const voxel_size=0) |  |  | Load image from an ANALYZE7.5/NIFTI file [new-instance version]. 
 |  | static CImg< T > | get_load_cimg (const char *const filename, const char axis='z', const float align=0) |  |  | Load image from a .cimg[z] file [new-instance version] 
 |  | static CImg< T > | get_load_cimg (std::FILE *const file, const char axis='z', const float align=0) |  |  | Load image from a .cimg[z] file [new-instance version] 
 |  | static CImg< T > | get_load_cimg (const char *const filename, const unsigned int n0, const unsigned int n1, const unsigned int x0, const unsigned int y0, const unsigned int z0, const unsigned int c0, const unsigned int x1, const unsigned int y1, const unsigned int z1, const unsigned int c1, const char axis='z', const float align=0) |  |  | Load sub-images of a .cimg file [new-instance version]. 
 |  | static CImg< T > | get_load_cimg (std::FILE *const file, const unsigned int n0, const unsigned int n1, const unsigned int x0, const unsigned int y0, const unsigned int z0, const unsigned int c0, const unsigned int x1, const unsigned int y1, const unsigned int z1, const unsigned int c1, const char axis='z', const float align=0) |  |  | Load sub-images of a .cimg file [new-instance version]. 
 |  | static CImg< T > | get_load_inr (const char *const filename, float *const voxel_size=0) |  |  | Load image from an INRIMAGE-4 file [new-instance version]. 
 |  | static CImg< T > | get_load_inr (std::FILE *const file, float *voxel_size=0) |  |  | Load image from an INRIMAGE-4 file [new-instance version]. 
 |  | static CImg< T > | get_load_exr (const char *const filename) |  |  | Load image from a EXR file [new-instance version]. 
 |  | static CImg< T > | get_load_pandore (const char *const filename) |  |  | Load image from a PANDORE-5 file [new-instance version]. 
 |  | static CImg< T > | get_load_pandore (std::FILE *const file) |  |  | Load image from a PANDORE-5 file [new-instance version]. 
 |  | static CImg< T > | get_load_parrec (const char *const filename, const char axis='c', const float align=0) |  |  | Load image from a PAR-REC (Philips) file [new-instance version]. 
 |  | static CImg< T > | get_load_raw (const char *const filename, const unsigned int size_x=0, const unsigned int size_y=1, const unsigned int size_z=1, const unsigned int size_c=1, const bool is_multiplexed=false, const bool invert_endianness=false) |  |  | Load image from a raw binary file [new-instance version]. 
 |  | static CImg< T > | get_load_raw (std::FILE *const file, const unsigned int size_x=0, const unsigned int size_y=1, const unsigned int size_z=1, const unsigned int size_c=1, const bool is_multiplexed=false, const bool invert_endianness=false) |  |  | Load image from a raw binary file [new-instance version]. 
 |  | static CImg< T > | get_load_ffmpeg (const char *const filename, const unsigned int first_frame=0, const unsigned int last_frame=~0U, const unsigned int step_frame=1, const bool pixel_format=true, const bool resume=false, const char axis='z', const float align=0) |  |  | Load image sequence using FFMPEG av's libraries [new-instance version]. 
 |  | static CImg< T > | get_load_yuv (const char *const filename, const unsigned int size_x, const unsigned int size_y=1, const unsigned int first_frame=0, const unsigned int last_frame=~0U, const unsigned int step_frame=1, const bool yuv2rgb=true, const char axis='z') |  |  | Load image sequence from a YUV file [new-instance version]. 
 |  | static CImg< T > | get_load_yuv (std::FILE *const file, const unsigned int size_x, const unsigned int size_y=1, const unsigned int first_frame=0, const unsigned int last_frame=~0U, const unsigned int step_frame=1, const bool yuv2rgb=true, const char axis='z') |  |  | Load image sequence from a YUV file [new-instance version]. 
 |  | template<typename tf , typename tc > |  | static CImg< T > | get_load_off (CImgList< tf > &primitives, CImgList< tc > &colors, const char *const filename) |  |  | Load 3d object from a .OFF file [new-instance version]. 
 |  | template<typename tf , typename tc > |  | static CImg< T > | get_load_off (CImgList< tf > &primitives, CImgList< tc > &colors, std::FILE *const file) |  |  | Load 3d object from a .OFF file [new-instance version]. 
 |  | static CImg< T > | get_load_ffmpeg_external (const char *const filename, const char axis='z', const float align=0) |  |  | Load image sequence using FFMPEG's external tool 'ffmpeg' [new-instance version]. 
 |  | static CImg< T > | get_load_gif_external (const char *const filename, const char axis='z', const float align=0) |  |  | Load gif file, using ImageMagick or GraphicsMagick's external tool 'convert' [new-instance version]. 
 |  | static CImg< T > | get_load_graphicsmagick_external (const char *const filename) |  |  | Load image using GraphicsMagick's external tool 'gm' [new-instance version]. 
 |  | static CImg< T > | get_load_gzip_external (const char *const filename) |  |  | Load gzipped image file, using external tool 'gunzip' [new-instance version]. 
 |  | static CImg< T > | get_load_imagemagick_external (const char *const filename) |  |  | Load image using ImageMagick's external tool 'convert' [new-instance version]. 
 |  | static CImg< T > | get_load_medcon_external (const char *const filename) |  |  | Load image from a DICOM file, using XMedcon's external tool 'medcon' [new-instance version]. 
 |  | static CImg< T > | get_load_dcraw_external (const char *const filename) |  |  | Load image from a RAW Color Camera file, using external tool 'dcraw' [new-instance version]. 
 |  | static CImg< T > | get_load_camera (const unsigned int camera_index=0, const unsigned int skip_frames=0, const bool release_camera=false, const unsigned int capture_width=0, const unsigned int capture_height=0) |  |  | Load image from a camera stream, using OpenCV [new-instance version]. 
 |  | static CImg< T > | get_load_other (const char *const filename) |  |  | Load image using various non-native ways [new-instance version]. 
 |  
| 
Data Output |  | const CImg< T > & | print (const char *const title=0, const bool display_stats=true) const |  |  | Display informations about the image data. 
 |  | const CImg< T > & | display (CImgDisplay &disp) const |  |  | Display image into a CImgDisplay window. 
 |  | const CImg< T > & | display (CImgDisplay &disp, const bool display_info, unsigned int *const XYZ=0) const |  |  | Display image into a CImgDisplay window, in an interactive way. 
 |  | const CImg< T > & | display (const char *const title=0, const bool display_info=true, unsigned int *const XYZ=0) const |  |  | Display image into an interactive window. 
 |  | template<typename tp , typename tf , typename tc , typename to > |  | const CImg< T > & | display_object3d (CImgDisplay &disp, const CImg< tp > &vertices, const CImgList< tf > &primitives, const CImgList< tc > &colors, const to &opacities, const bool centering=true, const int render_static=4, const int render_motion=1, const bool is_double_sided=true, const float focale=700, const float light_x=0, const float light_y=0, const float light_z=-5000, const float specular_lightness=0.2f, const float specular_shininess=0.1f, const bool display_axes=true, float *const pose_matrix=0) const |  |  | Display object 3d in an interactive window. 
 |  | template<typename tp , typename tf , typename tc , typename to > |  | const CImg< T > & | display_object3d (const char *const title, const CImg< tp > &vertices, const CImgList< tf > &primitives, const CImgList< tc > &colors, const to &opacities, const bool centering=true, const int render_static=4, const int render_motion=1, const bool is_double_sided=true, const float focale=700, const float light_x=0, const float light_y=0, const float light_z=-5000, const float specular_lightness=0.2f, const float specular_shininess=0.1f, const bool display_axes=true, float *const pose_matrix=0) const |  |  | Display object 3d in an interactive window [simplification]. 
 |  | template<typename tp , typename tf , typename tc > |  | const CImg< T > & | display_object3d (CImgDisplay &disp, const CImg< tp > &vertices, const CImgList< tf > &primitives, const CImgList< tc > &colors, const bool centering=true, const int render_static=4, const int render_motion=1, const bool is_double_sided=true, const float focale=700, const float light_x=0, const float light_y=0, const float light_z=-5000, const float specular_lightness=0.2f, const float specular_shininess=0.1f, const bool display_axes=true, float *const pose_matrix=0) const |  |  | Display object 3d in an interactive window [simplification]. 
 |  | template<typename tp , typename tf , typename tc > |  | const CImg< T > & | display_object3d (const char *const title, const CImg< tp > &vertices, const CImgList< tf > &primitives, const CImgList< tc > &colors, const bool centering=true, const int render_static=4, const int render_motion=1, const bool is_double_sided=true, const float focale=700, const float light_x=0, const float light_y=0, const float light_z=-5000, const float specular_lightness=0.2f, const float specular_shininess=0.1f, const bool display_axes=true, float *const pose_matrix=0) const |  |  | Display object 3d in an interactive window [simplification]. 
 |  | template<typename tp , typename tf > |  | const CImg< T > & | display_object3d (CImgDisplay &disp, const CImg< tp > &vertices, const CImgList< tf > &primitives, const bool centering=true, const int render_static=4, const int render_motion=1, const bool is_double_sided=true, const float focale=700, const float light_x=0, const float light_y=0, const float light_z=-5000, const float specular_lightness=0.2f, const float specular_shininess=0.1f, const bool display_axes=true, float *const pose_matrix=0) const |  |  | Display object 3d in an interactive window [simplification]. 
 |  | template<typename tp , typename tf > |  | const CImg< T > & | display_object3d (const char *const title, const CImg< tp > &vertices, const CImgList< tf > &primitives, const bool centering=true, const int render_static=4, const int render_motion=1, const bool is_double_sided=true, const float focale=700, const float light_x=0, const float light_y=0, const float light_z=-5000, const float specular_lightness=0.2f, const float specular_shininess=0.1f, const bool display_axes=true, float *const pose_matrix=0) const |  |  | Display object 3d in an interactive window [simplification]. 
 |  | template<typename tp > |  | const CImg< T > & | display_object3d (CImgDisplay &disp, const CImg< tp > &vertices, const bool centering=true, const int render_static=4, const int render_motion=1, const bool is_double_sided=true, const float focale=700, const float light_x=0, const float light_y=0, const float light_z=-5000, const float specular_lightness=0.2f, const float specular_shininess=0.1f, const bool display_axes=true, float *const pose_matrix=0) const |  |  | Display object 3d in an interactive window [simplification]. 
 |  | template<typename tp > |  | const CImg< T > & | display_object3d (const char *const title, const CImg< tp > &vertices, const bool centering=true, const int render_static=4, const int render_motion=1, const bool is_double_sided=true, const float focale=700, const float light_x=0, const float light_y=0, const float light_z=-5000, const float specular_lightness=0.2f, const float specular_shininess=0.1f, const bool display_axes=true, float *const pose_matrix=0) const |  |  | Display object 3d in an interactive window [simplification]. 
 |  | const CImg< T > & | display_graph (CImgDisplay &disp, const unsigned int plot_type=1, const unsigned int vertex_type=1, const char *const labelx=0, const double xmin=0, const double xmax=0, const char *const labely=0, const double ymin=0, const double ymax=0) const |  |  | Display 1d graph in an interactive window. 
 |  | const CImg< T > & | display_graph (const char *const title=0, const unsigned int plot_type=1, const unsigned int vertex_type=1, const char *const labelx=0, const double xmin=0, const double xmax=0, const char *const labely=0, const double ymin=0, const double ymax=0) const |  |  | Display 1d graph in an interactive window [overloading]. 
 |  | const CImg< T > & | save (const char *const filename, const int number=-1, const unsigned int digits=6) const |  |  | Save image as a file. 
 |  | const CImg< T > & | save_ascii (const char *const filename) const |  |  | Save image as an ascii file. 
 |  | const CImg< T > & | save_ascii (std::FILE *const file) const |  |  | Save image as an ascii file [overloading]. 
 |  | const CImg< T > & | save_cpp (const char *const filename) const |  |  | Save image as a .cpp source file. 
 |  | const CImg< T > & | save_cpp (std::FILE *const file) const |  |  | Save image as a .cpp source file [overloading]. 
 |  | const CImg< T > & | save_dlm (const char *const filename) const |  |  | Save image as a DLM file. 
 |  | const CImg< T > & | save_dlm (std::FILE *const file) const |  |  | Save image as a DLM file [overloading]. 
 |  | const CImg< T > & | save_bmp (const char *const filename) const |  |  | Save image as a BMP file. 
 |  | const CImg< T > & | save_bmp (std::FILE *const file) const |  |  | Save image as a BMP file [overloading]. 
 |  | const CImg< T > & | save_jpeg (const char *const filename, const unsigned int quality=100) const |  |  | Save image as a JPEG file. 
 |  | const CImg< T > & | save_jpeg (std::FILE *const file, const unsigned int quality=100) const |  |  | Save image as a JPEG file [overloading]. 
 |  | const CImg< T > & | save_magick (const char *const filename, const unsigned int bytes_per_pixel=0) const |  |  | Save image, using built-in ImageMagick++ library. 
 |  | const CImg< T > & | save_png (const char *const filename, const unsigned int bytes_per_pixel=0) const |  |  | Save image as a PNG file. 
 |  | const CImg< T > & | save_png (std::FILE *const file, const unsigned int bytes_per_pixel=0) const |  |  | Save image as a PNG file [overloading]. 
 |  | const CImg< T > & | save_pnm (const char *const filename, const unsigned int bytes_per_pixel=0) const |  |  | Save image as a PNM file. 
 |  | const CImg< T > & | save_pnm (std::FILE *const file, const unsigned int bytes_per_pixel=0) const |  |  | Save image as a PNM file [overloading]. 
 |  | const CImg< T > & | save_pnk (const char *const filename) const |  |  | Save image as a PNK file. 
 |  | const CImg< T > & | save_pnk (std::FILE *const file) const |  |  | Save image as a PNK file [overloading]. 
 |  | const CImg< T > & | save_pfm (const char *const filename) const |  |  | Save image as a PFM file. 
 |  | const CImg< T > & | save_pfm (std::FILE *const file) const |  |  | Save image as a PFM file [overloading]. 
 |  | const CImg< T > & | save_rgb (const char *const filename) const |  |  | Save image as a RGB file. 
 |  | const CImg< T > & | save_rgb (std::FILE *const file) const |  |  | Save image as a RGB file [overloading]. 
 |  | const CImg< T > & | save_rgba (const char *const filename) const |  |  | Save image as a RGBA file. 
 |  | const CImg< T > & | save_rgba (std::FILE *const file) const |  |  | Save image as a RGBA file [overloading]. 
 |  | const CImg< T > & | save_tiff (const char *const filename, const unsigned int compression_type=0) const |  |  | Save image as a TIFF file. 
 |  | const CImg< T > & | save_minc2 (const char *const filename, const char *const imitate_file=0) const |  |  | Save image as a MINC2 file. 
 |  | const CImg< T > & | save_analyze (const char *const filename, const float *const voxel_size=0) const |  |  | Save image as an ANALYZE7.5 or NIFTI file. 
 |  | const CImg< T > & | save_cimg (const char *const filename, const bool is_compressed=false) const |  |  | Save image as a .cimg file. 
 |  | const CImg< T > & | save_cimg (std::FILE *const file, const bool is_compressed=false) const |  |  | Save image as a .cimg file [overloading]. 
 |  | const CImg< T > & | save_cimg (const char *const filename, const unsigned int n0, const unsigned int x0, const unsigned int y0, const unsigned int z0, const unsigned int c0) const |  |  | Save image as a sub-image into an existing .cimg file. 
 |  | const CImg< T > & | save_cimg (std::FILE *const file, const unsigned int n0, const unsigned int x0, const unsigned int y0, const unsigned int z0, const unsigned int c0) const |  |  | Save image as a sub-image into an existing .cimg file [overloading]. 
 |  | const CImg< T > & | save_inr (const char *const filename, const float *const voxel_size=0) const |  |  | Save image as an INRIMAGE-4 file. 
 |  | const CImg< T > & | save_inr (std::FILE *const file, const float *const voxel_size=0) const |  |  | Save image as an INRIMAGE-4 file [overloading]. 
 |  | const CImg< T > & | save_exr (const char *const filename) const |  |  | Save image as an OpenEXR file. 
 |  | const CImg< T > & | save_pandore (const char *const filename, const unsigned int colorspace=0) const |  |  | Save image as a Pandore-5 file. 
 |  | const CImg< T > & | save_pandore (std::FILE *const file, const unsigned int colorspace=0) const |  |  | Save image as a Pandore-5 file [overloading]. 
 |  | const CImg< T > & | save_raw (const char *const filename, const bool is_multiplexed=false) const |  |  | Save image as a raw data file. 
 |  | const CImg< T > & | save_raw (std::FILE *const file, const bool is_multiplexed=false) const |  |  | Save image as a raw data file [overloading]. 
 |  | const CImg< T > & | save_ffmpeg (const char *const filename, const unsigned int fps=25, const unsigned int bitrate=2048) const |  |  | Save image as a video file, using the FFmpeg library. 
 |  | const CImg< T > & | save_yuv (const char *const filename, const bool is_rgb=true) const |  |  | Save image as a .yuv video file. 
 |  | const CImg< T > & | save_yuv (std::FILE *const file, const bool is_rgb=true) const |  |  | Save image as a .yuv video file [overloading]. 
 |  | template<typename tf , typename tc > |  | const CImg< T > & | save_off (const CImgList< tf > &primitives, const CImgList< tc > &colors, const char *const filename) const |  |  | Save 3d object as an Object File Format (.off) file. 
 |  | template<typename tf , typename tc > |  | const CImg< T > & | save_off (const CImgList< tf > &primitives, const CImgList< tc > &colors, std::FILE *const file) const |  |  | Save 3d object as an Object File Format (.off) file [overloading]. 
 |  | const CImg< T > & | save_ffmpeg_external (const char *const filename, const char *const codec=0, const unsigned int fps=25, const unsigned int bitrate=2048) const |  |  | Save volumetric image as a video, using ffmpeg external binary. 
 |  | const CImg< T > & | save_gzip_external (const char *const filename) const |  |  | Save image using gzip external binary. 
 |  | const CImg< T > & | save_graphicsmagick_external (const char *const filename, const unsigned int quality=100) const |  |  | Save image using GraphicsMagick's external binary. 
 |  | const CImg< T > & | save_imagemagick_external (const char *const filename, const unsigned int quality=100) const |  |  | Save image using ImageMagick's external binary. 
 |  | const CImg< T > & | save_medcon_external (const char *const filename) const |  |  | Save image as a Dicom file. 
 |  | const CImg< T > & | save_other (const char *const filename, const unsigned int quality=100) const |  | static void | save_empty_cimg (const char *const filename, const unsigned int dx, const unsigned int dy=1, const unsigned int dz=1, const unsigned int dc=1) |  |  | Save blank image as a .cimg file. 
 |  | static void | save_empty_cimg (std::FILE *const file, const unsigned int dx, const unsigned int dy=1, const unsigned int dz=1, const unsigned int dc=1) |  |  | Save blank image as a .cimg file [overloading]. 
 |  Detailed Descriptiontemplate<typename T>struct cimg_library::CImg< T >
Class representing an image (up to 4 dimensions wide), each pixel being of type T. This is the main class of the CImg Library. It declares and constructs an image, allows access to its pixel values, and is able to perform various image operations. Image representation
 A CImg image is defined as an instance of the container CImg<T>, which contains a regular grid of pixels, each pixel value being of typeT. The image grid can have up to 4 dimensions: width, height, depth and number of channels. Usually, the three first dimensions are used to describe spatial coordinates(x,y,z), while the number of channels is rather used as a vector-valued dimension (it may describe the R,G,B color channels for instance). If you need a fifth dimension, you can use image listsCImgList<T>rather than simple imagesCImg<T>. Thus, the CImg<T>class is able to represent volumetric images of vector-valued pixels, as well as images with less dimensions (1d scalar signal, 2d color images, ...). Most member functions of the class CImg<T>are designed to handle this maximum case of (3+1) dimensions. Concerning the pixel value type T:fully supported template types are the basic C++ types:unsigned char, char, short, unsigned int, int, unsigned long, long, float, double, ... . Typically, fast image display can be done usingCImg<unsigned char>images, while complex image processing algorithms may be rather coded usingCImg<float>orCImg<double>images that have floating-point pixel values. The default value for the template T isfloat. Using your own template types may be possible. However, you will certainly have to define the complete set of arithmetic and logical operators for your class. Image structure
 The CImg<T>structure contains six fields: 
_widthdefines the number of columns of the image (size along the X-axis)._heightdefines the number of rows of the image (size along the Y-axis)._depthdefines the number of slices of the image (size along the Z-axis)._spectrumdefines the number of channels of the image (size along the C-axis)._datadefines a pointer to the pixel data (of typeT)._is_sharedis a boolean that tells if the memory bufferdatais shared with another image. You can access these fields publicly although it is recommended to use the dedicated functions width(), height(), depth(), spectrum() and ptr() to do so. Image dimensions are not limited to a specific range (as long as you got enough available memory). A value of 1 usually means that the corresponding dimension is flat. If one of the dimensions is 0, or if the data pointer is null, the image is considered as empty. Empty images should not contain any pixel data and thus, will not be processed by CImg member functions (a CImgInstanceException will be thrown instead). Pixel data are stored in memory, in a non interlaced mode (See How pixel data are stored with CImg.). Image declaration and construction
 Declaring an image can be done by using one of the several available constructors. Here is a list of the most used: 
Construct images from arbitrary dimensions:
CImg<char> img;declares an empty image.CImg<unsigned char> img(128,128);declares a 128x128 greyscale image withunsignedcharpixel values.CImg<double> img(3,3);declares a 3x3 matrix withdoublecoefficients.CImg<unsigned char> img(256,256,1,3);declares a 256x256x1x3 (color) image (colors are stored as an image with three channels).CImg<double> img(128,128,128);declares a 128x128x128 volumetric and greyscale image (withdoublepixel values).CImg<> img(128,128,128,3);declares a 128x128x128 volumetric color image (withfloatpixels, which is the default value of the template parameterT).Note: images pixels are not automatically initialized to 0. You may use the function fill()to do it, or use the specific constructor taking 5 parameters like this:CImg<> img(128,128,128,3,0);declares a 128x128x128 volumetric color image with all pixel values to 0. 
Construct images from filenames:
CImg<unsigned char> img("image.jpg");reads a JPEG color image from the file "image.jpg".CImg<float> img("analyze.hdr");reads a volumetric image (ANALYZE7.5 format) from the file "analyze.hdr".Note: You need to install ImageMagick to be able to read common compressed image formats (JPG,PNG, ...) (See Files IO in CImg.). Most useful functions
 The CImg<T>class contains a lot of functions that operates on images. Some of the most useful are:Member Typedef Documentation
Simple iterator type, to loop through each pixel value of an image instance.  Note
The CImg<T>::iteratortype is defined to be aT*.You will seldom have to use iterators in CImg, most classical operations being achieved (often in a faster way) using methods of CImg<T>.
 ExampleCImg<float> img("reference.jpg");                                          for (CImg<float>::iterator it = img.begin(), it<img.end(); ++it) *it = 0;  img.fill(0);                                                              
 
Simple const iterator type, to loop through each pixel value of a constimage instance. Note
The CImg<T>::const_iteratortype is defined to be aconstT*.You will seldom have to use iterators in CImg, most classical operations being achieved (often in a faster way) using methods of CImg<T>.
 Exampleconst CImg<float> img("reference.jpg");                                     float sum = 0; for (CImg<float>::iterator it = img.begin(), it<img.end(); ++it) sum+=*it;  const float sum2 = img.sum();                                              
 
Pixel value type.  Refer to the type of the pixel values of an image instance.  Note
The CImg<T>::value_typetype of aCImg<T>is defined to be aT.CImg<T>::value_typeis actually not used in CImg methods. It has been mainly defined for compatibility with STL naming conventions.
 Constructor & Destructor Documentation
Destroy image.  Note
The pixel buffer data() is deallocated if necessary, e.g. for non-empty and non-shared image instances.Destroying an empty or shared image does nothing actually. 
 Warning
When destroying a non-shared image, make sure that you will not operate on a remaining shared image that shares its buffer with the destroyed instance, in order to avoid further invalid memory access (to a deallocated buffer). 
 
Construct empty image.  Note
An empty image has no pixel data and all of its dimensions width(), height(), depth(), spectrum() are set to 0, as well as its pixel buffer pointer data().An empty image may be re-assigned afterwards, e.g. with the family of assign(unsigned int,unsigned int,unsigned int,unsigned int) methods, or by operator=(const CImg<t>&). In all cases, the type of pixels stays T.An empty image is never shared. 
 ExampleCImg<float> img1, img2;       img1.assign(256,256,1,3);     img2 = img1.get_rand(0,255);  img2.assign();               
 
  
  | 
        
          | CImg | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y = 1, |  
          |  |  | const unsigned int | size_z = 1, |  
          |  |  | const unsigned int | size_c = 1 |  
          |  | ) |  |  |  | explicit |  
Construct image with specified size.  Parameters
  
  
 Note
It is able to create only non-shared images, and allocates thus a pixel buffer data() for each constructed image instance.Setting one dimension size_x,size_y,size_zorsize_cto0leads to the construction of an empty image.A CImgInstanceExceptionis thrown when the pixel buffer cannot be allocated (e.g. when requested size is too big for available memory).
 Warning
 ExampleCImg<float> img1(256,256,1,3);    CImg<float> img2(256,256,1,3,0); 
 
      
        
          | CImg | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c, |  
          |  |  | const T | value |  
          |  | ) |  |  |  
Construct image with specified size and initialize pixel values.  Parameters
  
  
 Note
 Warning
It cannot be used to construct a vector-valued image and initialize it with vector-valued pixels (e.g. RGB vector, for color images). For this task, you may use fillC() after construction. 
 
      
        
          | CImg | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c, |  
          |  |  | const int | value0, |  
          |  |  | const int | value1, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Construct image with specified size and initialize pixel values from a sequence of integers.  Construct a new image instance of size size_xxsize_yxsize_zxsize_c, with pixels of typeT, and initialize pixel values from the specified sequence of integersvalue0,value1,... Parameters
  
    | size_x | Image width(). |  | size_y | Image height(). |  | size_z | Image depth(). |  | size_c | Image spectrum() (number of channels). |  | value0 | First value of the initialization sequence (must be an integer). |  | value1 | Second value of the initialization sequence (must be an integer). |  | ... |  | 
 Note
 Warning
You must specify exactly size_x*initialization sequence. Otherwise, the constructor may crash or fill your image pixels with garbage.size_y*thesize_z*insize_cintegers
 Exampleconst CImg<float> img(2,2,1,3,                             0,255,0,255,                         0,0,255,255,                         64,64,64,64);  img.resize(150,150).display();
 
      
        
          | CImg | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c, |  
          |  |  | const double | value0, |  
          |  |  | const double | value1, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Construct image with specified size and initialize pixel values from a sequence of doubles.  Construct a new image instance of size size_xxsize_yxsize_zxsize_c, with pixels of typeT, and initialize pixel values from the specified sequence of doublesvalue0,value1,... Parameters
  
    | size_x | Image width(). |  | size_y | Image height(). |  | size_z | Image depth(). |  | size_c | Image spectrum() (number of channels). |  | value0 | First value of the initialization sequence (must be a double). |  | value1 | Second value of the initialization sequence (must be a double). |  | ... |  | 
 Note
Similar to CImg(unsigned int,unsigned int,unsigned int,unsigned int,int,int,...), but takes a sequence of double values instead of integers. 
 Warning
You must specify exactly dx*initialization sequence. Otherwise, the constructor may crash or fill your image with garbage. For instance, the code below will probably crash on most platforms:dy*thedz*indcdoublesconst CImg<float> img(2,2,1,1, 0.5,0.5,255,255); 
 
      
        
          | CImg | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c, |  
          |  |  | const char *const | values, |  
          |  |  | const bool | repeat_values |  
          |  | ) |  |  |  
Construct image with specified size and initialize pixel values from a value string.  Construct a new image instance of size size_xxsize_yxsize_zxsize_c, with pixels of typeT, and initializes pixel values from the specified stringvalues. Parameters
  
    | size_x | Image width(). |  | size_y | Image height(). |  | size_z | Image depth(). |  | size_c | Image spectrum() (number of channels). |  | values | Value string describing the way pixel values are set. |  | repeat_values | Tells if the value filling process is repeated over the image. | 
 Note
Similar to CImg(unsigned int,unsigned int,unsigned int,unsigned int), but it also fills the pixel buffer with values described in the value string values.Value string valuesmay describe two different filling processes:
Either valuesis a sequences of values assigned to the image pixels, as in"1,2,3,7,8,2". In this case, setrepeat_valuestotrueto periodically fill the image with the value sequence.Either, valuesis a formula, as in"cos(x/10)*sin(y/20)". In this case, parameterrepeat_valuesis pointless.For both cases, specifying repeat_valuesis mandatory. It disambiguates the possible overloading of constructor CImg(unsigned int,unsigned int,unsigned int,unsigned int,T) withTbeing aconst char*.A CImgArgumentExceptionis thrown when an invalid value stringvaluesis specified.
 Exampleconst CImg<float> img1(129,129,1,3,"0,64,128,192,255",true),                                      img2(129,129,1,3,"if(c==0,255*abs(cos(x/10)),1.8*y)",false); 
 
      
        
          | CImg | ( | const t *const | values, |  
          |  |  | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y = 1, |  
          |  |  | const unsigned int | size_z = 1, |  
          |  |  | const unsigned int | size_c = 1, |  
          |  |  | const bool | is_shared = false |  
          |  | ) |  |  |  
Construct image with specified size and initialize pixel values from a memory buffer.  Construct a new image instance of size size_xxsize_yxsize_zxsize_c, with pixels of typeT, and initializes pixel values from the specifiedt*memory buffer. Parameters
  
    | values | Pointer to the input memory buffer. |  | size_x | Image width(). |  | size_y | Image height(). |  | size_z | Image depth(). |  | size_c | Image spectrum() (number of channels). |  | is_shared | Tells if input memory buffer must be shared by the current instance. | 
 Note
If is_sharedisfalse, the image instance allocates its own pixel buffer, and values from the specified input buffer are copied to the instance buffer. If buffer typesTandtare different, a regular static cast is performed during buffer copy.Otherwise, the image instance does not allocate a new buffer, and uses the input memory buffer as its own pixel buffer. This case requires that types Tandtare the same. Later, destroying such a shared image will not deallocate the pixel buffer, this task being obviously charged to the initial buffer allocator.A CImgInstanceExceptionis thrown when the pixel buffer cannot be allocated (e.g. when requested size is too big for available memory).
 Warning
You must take care when operating on a shared image, since it may have an invalid pixel buffer pointer data() (e.g. already deallocated). 
 Exampleunsigned char tab[256*256] = { 0 }; CImg<unsigned char> img1(tab,256,256,1,1,false),                      img2(tab,256,256,1,1,true);   tab[1024] = 255;                                 
 
  
  | 
        
          | CImg | ( | const char *const | filename | ) |  |  | explicit |  
Construct image from reading an image file.  Construct a new image instance with pixels of type T, and initialize pixel values with the data read from an image file. Parameters
  
    | filename | Filename, as a C-string. | 
 Note
Similar to CImg(unsigned int,unsigned int,unsigned int,unsigned int), but it reads the image dimensions and pixel values from the specified image file.The recognition of the image file format by CImg higly depends on the tools installed on your system and on the external libraries you used to link your code against.Considered pixel type Tshould better fit the file format specification, or data loss may occur during file load (e.g. constructing aCImg<unsigned char>from a float-valued image file).A CImgIOExceptionis thrown when the specifiedfilenamecannot be read, or if the file format is not recognized.
 Exampleconst CImg<float> img("reference.jpg"); img.display();
 
Construct image copy.  Construct a new image instance with pixels of type T, as a copy of an existingCImg<t>instance. Parameters
  
  
 Note
Constructed copy has the same size width() x height() x depth() x spectrum() and pixel values as the input image img.If input image imgis shared and if typesTandtare the same, the constructed copy is also shared, and shares its pixel buffer withimg. Modifying a pixel value in the constructed copy will thus also modifies it in the input imageimg. This behavior is needful to allow functions to return shared images.Otherwise, the constructed copy allocates its own pixel buffer, and copies pixel values from the input image imginto its buffer. The copied pixel values may be eventually statically casted if typesTandtare different.Constructing a copy from an image imgwhen typestandTare the same is significantly faster than with different types.A CImgInstanceExceptionis thrown when the pixel buffer cannot be allocated (e.g. not enough available memory).
 
      
        
          | CImg | ( | const CImg< t > & | img, |  
          |  |  | const bool | is_shared |  
          |  | ) |  |  |  
Advanced copy constructor.  Construct a new image instance with pixels of type T, as a copy of an existingCImg<t>instance, while forcing the shared state of the constructed copy. Parameters
  
    | img | Input image to copy. |  | is_shared | Tells about the shared state of the constructed copy. | 
 Note
Similar to CImg(const CImg<t>&), except that it allows to decide the shared state of the constructed image, which does not depend anymore on the shared state of the input image img:
If is_sharedistrue, the constructed copy will share its pixel buffer with the input imageimg. For that case, the pixel typesTandtmust be the same.If is_sharedisfalse, the constructed copy will allocate its own pixel buffer, whether the input imageimgis shared or not.A CImgArgumentExceptionis thrown when a shared copy is requested with different pixel typesTandt.
 
      
        
          | CImg | ( | const CImg< t > & | img, |  
          |  |  | const char *const | dimensions |  
          |  | ) |  |  |  
Construct image with dimensions borrowed from another image.  Construct a new image instance with pixels of type T, and size get from some dimensions of an existingCImg<t>instance. Parameters
  
    | img | Input image from which dimensions are borrowed. |  | dimensions | C-string describing the image size along the X,Y,Z and C-dimensions. | 
 Note
 Exampleconst CImg<float> img1(256,128,1,3),                         img2(img1,"xyzc"),                         img3(img1,"y,x,z,c"),                      img4(img1,"c,x,y,3",0), 
 
      
        
          | CImg | ( | const CImg< t > & | img, |  
          |  |  | const char *const | dimensions, |  
          |  |  | const T | value |  
          |  | ) |  |  |  
Construct image with dimensions borrowed from another image and initialize pixel values.  Construct a new image instance with pixels of type T, and size get from the dimensions of an existingCImg<t>instance, and set all pixel values to specifiedvalue. Parameters
  
    | img | Input image from which dimensions are borrowed. |  | dimensions | String describing the image size along the X,Y,Z and V-dimensions. |  | value | Value used for initialization. | 
 Note
 
Construct image from a display window.  Construct a new image instance with pixels of type T, as a snapshot of an existingCImgDisplayinstance. Parameters
  
    | disp | Input display window. | 
 Note
The width() and height() of the constructed image instance are the same as the specified CImgDisplay.The depth() and spectrum() of the constructed image instance are respectively set to 1and3(i.e. a 2d color image).The image pixels are read as 8-bits RGB values. 
 Member Function Documentation
Construct empty image [in-place version].  In-place version of the default constructor CImg(). It simply resets the instance to an empty image.  
      
        
          | CImg<T>& assign | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y = 1, |  
          |  |  | const unsigned int | size_z = 1, |  
          |  |  | const unsigned int | size_c = 1 |  
          |  | ) |  |  |  
      
        
          | CImg<T>& assign | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c, |  
          |  |  | const T | value |  
          |  | ) |  |  |  
      
        
          | CImg<T>& assign | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c, |  
          |  |  | const int | value0, |  
          |  |  | const int | value1, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Construct image with specified size and initialize pixel values from a sequence of integers [in-place version].  In-place version of the constructor CImg(unsigned int,unsigned int,unsigned int,unsigned int,int,int,...).  
      
        
          | CImg<T>& assign | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c, |  
          |  |  | const double | value0, |  
          |  |  | const double | value1, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Construct image with specified size and initialize pixel values from a sequence of doubles [in-place version].  In-place version of the constructor CImg(unsigned int,unsigned int,unsigned int,unsigned int,double,double,...).  
      
        
          | CImg<T>& assign | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c, |  
          |  |  | const char *const | values, |  
          |  |  | const bool | repeat_values |  
          |  | ) |  |  |  
      
        
          | CImg<T>& assign | ( | const t *const | values, |  
          |  |  | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y = 1, |  
          |  |  | const unsigned int | size_z = 1, |  
          |  |  | const unsigned int | size_c = 1 |  
          |  | ) |  |  |  
Construct image with specified size and initialize pixel values from a memory buffer [in-place version].  In-place version of the constructor CImg(const t*,unsigned int,unsigned int,unsigned int,unsigned int).  
      
        
          | CImg<T>& assign | ( | const char *const | filename | ) |  |  
Construct image from reading an image file [in-place version].  In-place version of the constructor CImg(const char*).  
      
        
          | CImg<T>& assign | ( | const CImg< t > & | img | ) |  |  
      
        
          | CImg<T>& assign | ( | const CImg< t > & | img, |  
          |  |  | const bool | is_shared |  
          |  | ) |  |  |  
      
        
          | CImg<T>& assign | ( | const CImg< t > & | img, |  
          |  |  | const char *const | dimensions |  
          |  | ) |  |  |  
      
        
          | CImg<T>& assign | ( | const CImg< t > & | img, |  
          |  |  | const char *const | dimensions, |  
          |  |  | const T | value |  
          |  | ) |  |  |  
Construct image with dimensions borrowed from another image and initialize pixel values [in-place version].  In-place version of the constructor CImg(const CImg<t>&,const char*,T).  
Construct empty image [in-place version].  Equivalent to assign().  Note
It has been defined for compatibility with STL naming conventions. 
 
Transfer content of an image instance into another one.  Transfer the dimensions and the pixel buffer content of an image instance into another one, and replace instance by an empty image. It avoids the copy of the pixel buffer when possible.  Parameters
  
  
 Note
Pixel types Tandtof source and destination images can be different, though the process is designed to be instantaneous whenTandtare the same.
 ExampleCImg<float> src(256,256,1,3,0),              dest(16,16);         src.move_to(dest);              
 
Transfer content of an image instance into a new image in an image list.  Transfer the dimensions and the pixel buffer content of an image instance into a newly inserted image at position posin specifiedCImgList<t>instance. Parameters
  
    | list | Destination list. |  | pos | Position of the newly inserted image in the list. | 
 Note
When optionnal parameter posis ommited, the image instance is transfered as a new image at the end of the specifiedlist.It is convenient to sequentially insert new images into image lists, with no additional copies of memory buffer. 
 ExampleCImgList<float> list;              CImg<float> img("reference.jpg");  img.move_to(list);                
 
Swap fields of two image instances.  Parameters
  
    | img | Image to swap fields with. | 
 Note
It can be used to interchange the content of two images in a very fast way. Can be convenient when dealing with algorithms requiring two swapping buffers. 
 ExampleCImg<float> img1("lena.jpg"),             img2("milla.jpg"); img1.swap(img2);               
 
  
  | 
        
          | static CImg<T>& empty | ( |  | ) |  |  | static |  
Return a reference to an empty image.  NoteThis function is useful mainly to declare optional parameters having type CImg<T>in functions prototypes, e.g.void f(const int x=0, const int y=0, const CImg<float>& img=CImg<float>::empty());
 
      
        
          | T& operator() | ( | const unsigned int | x, |  
          |  |  | const unsigned int | y = 0, |  
          |  |  | const unsigned int | z = 0, |  
          |  |  | const unsigned int | c = 0 |  
          |  | ) |  |  |  
Access to a pixel value.  Return a reference to a located pixel value of the image instance, being possibly const, whether the image instance is const or not. This is the standard method to get/set pixel values in CImg<T>images. Parameters
  
    | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. | 
 Note
Range of pixel coordinates start from (0,0,0,0)to(width()-1,height()-1,depth()-1,spectrum()-1).Due to the particular arrangement of the pixel buffers defined in CImg, you can omit one coordinate if the corresponding dimension is equal to 1. For instance, pixels of a 2d image (depth() equal to1) can be accessed byimg(x,y,c)instead ofimg(x,y,0,c).
 Warning
There is no boundary checking done in this operator, to make it as fast as possible. You must take care of out-of-bounds access by yourself, if necessary. For debuging purposes, you may want to define macro 'cimg_verbosity'>=3to enable additional boundary checking operations in this operator. In that case, warning messages will be printed on the error output when accessing out-of-bounds pixels.
 ExampleCImg<float> img(100,100,1,3,0);                    const float    valR = img(10,10,0,0),                             valG = img(10,10,0,1),                             valB = img(10,10,2),                               avg = (valR + valG + valB)/3;                   img(10,10,0) = img(10,10,1) = img(10,10,2) = avg; 
 
      
        
          | T& operator() | ( | const unsigned int | x, |  
          |  |  | const unsigned int | y, |  
          |  |  | const unsigned int | z, |  
          |  |  | const unsigned int | c, |  
          |  |  | const unsigned long | wh, |  
          |  |  | const unsigned long | whd = 0 |  
          |  | ) |  |  |  
Access to a pixel value.  Parameters
  
    | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. |  | wh | Precomputed offset, must be equal to width()*height(). |  | whd | Precomputed offset, must be equal to width()*height()*depth(). | 
 Note
Similar to (but faster than) operator()(). It uses precomputed offsets to optimize memory access. You may use it to optimize the reading/writing of several pixel values in the same image (e.g. in a loop). 
 
Implicitely cast an image into a T*. Implicitely cast a CImg<T>instance into aT*orconstT*pointer, whether the image instance is const or not. The returned pointer points on the first value of the image pixel buffer. Note
It simply returns the pointer data() to the pixel buffer.This implicit conversion is convenient to test the empty state of images (data() being 0in this case), e.g.CImg<float> img1(100,100), img2;  if (img1) {                         if (!img2) {                        std::printf("'img1' is not empty, 'img2' is empty.");   } }It also allows to use brackets to access pixel values, without need for a CImg<T>::operator[](), e.g.CImg<float> img(100,100); const float value = img[99];  img[510] = 255;              
 
      
        
          | CImg<T>& operator= | ( | const T | value | ) |  |  
Assign a value to all image pixels.  Assign specified valueto each pixel value of the image instance. Parameters
  
    | value | Value that will be assigned to image pixels. | 
 Note
The image size is never modified.The valuemay be casted to pixel typeTif necessary.
 ExampleCImg<char> img(100,100);  img = 0;                  img = 1.2;               
 
      
        
          | CImg<T>& operator= | ( | const char *const | expression | ) |  |  
Assign pixels values from a specified expression.  Initialize all pixel values from the specified string expression. Parameters
  
    | expression | Value string describing the way pixel values are set. | 
 Note
String parameter expressionmay describe different things:
If expressionis a list of values (as in"1,2,3,8,3,2"), or a formula (as in"(x*y)%255"), the pixel values are set from specifiedexpressionand the image size is not modified.If expressionis a filename (as in"reference.jpg"), the corresponding image file is loaded and replace the image instance. The image size is modified if necessary.
 ExampleCImg<float> img1(100,100), img2(img1), img3(img1);  img1 = "0,50,100,150,200,250,200,150,100,50";       img2 = "10*((x*y)%25)";                             img3 = "reference.jpg";                            
 
      
        
          | CImg<T>& operator= | ( | const CImg< t > & | img | ) |  |  
Copy an image into the current image instance.  Similar to the in-place copy constructor assign(const CImg<t>&).  
      
        
          | CImg<T>& operator+= | ( | const t | value | ) |  |  
In-place addition operator.  Add specified valueto all pixels of an image instance. Parameters
  
  
 Note
Resulting pixel values are casted to fit the pixel type T. For instance, adding0.2to aCImg<char>is possible but does nothing indeed.Overflow values are treated as with standard C++ numeric types. For instance, CImg<unsigned char> img(100,100,1,1,255);  img+=1;                                   To prevent value overflow, you may want to consider pixel type Tasfloatordouble, and use cut() after addition.
 ExampleCImg<unsigned char> img1("reference.jpg");           CImg<float> img2(img1);                              img2+=100;                                           img2.cut(0,255);                                     img1 = img2;                                         const CImg<unsigned char> img3 = (img1 + 100).cut (0,255); 
 
      
        
          | CImg<T>& operator+= | ( | const char *const | expression | ) |  |  
In-place addition operator.  Add values to image pixels, according to the specified string expression. Parameters
  
    | expression | Value string describing the way pixel values are added. | 
 Note
Similar to operator=(const char*), except that it adds values to the pixels of the current image instance, instead of assigning them. 
 
      
        
          | CImg<T>& operator+= | ( | const CImg< t > & | img | ) |  |  
In-place addition operator.  Add values to image pixels, according to the values of the input image img. Parameters
  
  
 Note
The size of the image instance is never modified.It is not mandatory that input image imghas the same size as the image instance. If less values are available inimg, then the values are added cyclically. For instance, adding one WxH scalar image (spectrum() equal to1) to one WxH color image (spectrum() equal to3) means each color channel will be incremented with the same values at the same locations.
 ExampleCImg<float> img1("reference.jpg");                                    const CImg<float> img2(img1.width(),img.height(),1,1,"255*(x/w)^2");  img1+=img2;                                                           img1.cut(0,255);                                                     
 
In-place increment operator (prefix).  Add 1to all image pixels, and return a reference to the current incremented image instance. Note
Writing ++imgis equivalent toimg+=1.
 
      
        
          | CImg<T> operator++ | ( | int |  | ) |  |  
In-place increment operator (postfix).  Add 1to all image pixels, and return a new copy of the initial (pre-incremented) image instance. Note
Use the prefixed version operator++() if you don't need a copy of the initial (pre-incremented) image instance, since a useless image copy may be expensive in terms of memory usage. 
 
      
        
          | CImg<T> operator+ | ( |  | ) | const |  
Return a non-shared copy of the image instance.  Note
Use this operator to ensure you get a non-shared copy of an image instance with same pixel type T. Indeed, the usual copy constructor CImg<T>(const CImg<T>&) returns a shared copy of a shared input image, and it may be not desirable to work on a regular copy (e.g. for a resize operation) if you have no informations about the shared state of the input image.Writing (+img) is equivalent toCImg<T>(img,false).
 
      
        
          | CImg< typename cimg::superset<T,t>::type > operator+ | ( | const t | value | ) | const |  
Addition operator.  Similar to operator+=(const t), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg<Tfloat> operator+ | ( | const char *const | expression | ) | const |  
Addition operator.  Similar to operator+=(const char*), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg< typename cimg::superset<T,t>::type > operator+ | ( | const CImg< t > & | img | ) | const |  
Addition operator.  Similar to operator+=(const CImg<t>&), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg<T>& operator-= | ( | const t | value | ) |  |  
In-place substraction operator.  Similar to operator+=(const t), except that it performs a substraction instead of an addition.  
      
        
          | CImg<T>& operator-= | ( | const char *const | expression | ) |  |  
In-place substraction operator.  Similar to operator+=(const char*), except that it performs a substraction instead of an addition.  
      
        
          | CImg<T>& operator-= | ( | const CImg< t > & | img | ) |  |  
In-place substraction operator.  Similar to operator+=(const CImg<t>&), except that it performs a substraction instead of an addition.  
In-place decrement operator (prefix).  Similar to operator++(), except that it performs a decrement instead of an increment.  
      
        
          | CImg<T> operator-- | ( | int |  | ) |  |  
In-place decrement operator (postfix).  Similar to operator++(int), except that it performs a decrement instead of an increment.  
      
        
          | CImg<T> operator- | ( |  | ) | const |  
Replace each pixel by its opposite value.  Note
If the computed opposite values are out-of-range, they are treated as with standard C++ numeric types. For instance, the unsignedcharopposite of1is255.
 Exampleconst CImg<unsigned char>   img1("reference.jpg"),      img2 = -img1;            
 
      
        
          | CImg< typename cimg::superset<T,t>::type > operator- | ( | const t | value | ) | const |  
Substraction operator.  Similar to operator-=(const t), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg<Tfloat> operator- | ( | const char *const | expression | ) | const |  
Substraction operator.  Similar to operator-=(const char*), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg< typename cimg::superset<T,t>::type > operator- | ( | const CImg< t > & | img | ) | const |  
Substraction operator.  Similar to operator-=(const CImg<t>&), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg<T>& operator*= | ( | const t | value | ) |  |  
In-place multiplication operator.  Similar to operator+=(const t), except that it performs a multiplication instead of an addition.  
      
        
          | CImg<T>& operator*= | ( | const char *const | expression | ) |  |  
In-place multiplication operator.  Similar to operator+=(const char*), except that it performs a multiplication instead of an addition.  
      
        
          | CImg<T>& operator*= | ( | const CImg< t > & | img | ) |  |  
In-place multiplication operator.  Replace the image instance by the matrix multiplication between the image instance and the specified matrix img. Parameters
  
    | img | Second operand of the matrix multiplication. | 
 Note
It does not compute a pointwise multiplication between two images. For this purpose, use mul(const CImg<t>&) instead.The size of the image instance can be modified by this operator. 
 ExampleCImg<float> A(2,2,1,1, 1,2,3,4);    const CImg<float> X(1,2,1,1, 1,2);  A*=X;                              
 
      
        
          | CImg< typename cimg::superset<T,t>::type > operator* | ( | const t | value | ) | const |  
Multiplication operator.  Similar to operator*=(const t), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg<Tfloat> operator* | ( | const char *const | expression | ) | const |  
Multiplication operator.  Similar to operator*=(const char*), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg< typename cimg::superset<T,t>::type > operator* | ( | const CImg< t > & | img | ) | const |  
Multiplication operator.  Similar to operator*=(const CImg<t>&), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg<T>& operator/= | ( | const t | value | ) |  |  
In-place division operator.  Similar to operator+=(const t), except that it performs a division instead of an addition.  
      
        
          | CImg<T>& operator/= | ( | const char *const | expression | ) |  |  
In-place division operator.  Similar to operator+=(const char*), except that it performs a division instead of an addition.  
      
        
          | CImg<T>& operator/= | ( | const CImg< t > & | img | ) |  |  
In-place division operator.  Replace the image instance by the (right) matrix division between the image instance and the specified matrix img. Parameters
  
    | img | Second operand of the matrix division. | 
 Note
It does not compute a pointwise division between two images. For this purpose, use div(const CImg<t>&) instead.It returns the matrix operation A*inverse(img).The size of the image instance can be modified by this operator. 
 
      
        
          | CImg< typename cimg::superset<T,t>::type > operator/ | ( | const t | value | ) | const |  
Division operator.  Similar to operator/=(const t), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg<Tfloat> operator/ | ( | const char *const | expression | ) | const |  
Division operator.  Similar to operator/=(const char*), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg< typename cimg::superset<T,t>::type > operator/ | ( | const CImg< t > & | img | ) | const |  
Division operator.  Similar to operator/=(const CImg<t>&), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg<T>& operator%= | ( | const t | value | ) |  |  
In-place modulo operator.  Similar to operator+=(const t), except that it performs a modulo operation instead of an addition.  
      
        
          | CImg<T>& operator%= | ( | const char *const | expression | ) |  |  
In-place modulo operator.  Similar to operator+=(const char*), except that it performs a modulo operation instead of an addition.  
      
        
          | CImg<T>& operator%= | ( | const CImg< t > & | img | ) |  |  
In-place modulo operator.  Similar to operator+=(const CImg<t>&), except that it performs a modulo operation instead of an addition.  
      
        
          | CImg< typename cimg::superset<T,t>::type > operator% | ( | const t | value | ) | const |  
Modulo operator.  Similar to operator%=(const t), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg<Tfloat> operator% | ( | const char *const | expression | ) | const |  
Modulo operator.  Similar to operator%=(const char*), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg< typename cimg::superset<T,t>::type > operator% | ( | const CImg< t > & | img | ) | const |  
Modulo operator.  Similar to operator%=(const CImg<t>&), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image may be a superset of the initial pixel type T, if necessary. 
      
        
          | CImg<T>& operator&= | ( | const t | value | ) |  |  
In-place bitwise AND operator.  Similar to operator+=(const t), except that it performs a bitwise AND operation instead of an addition.  
      
        
          | CImg<T>& operator&= | ( | const char *const | expression | ) |  |  
In-place bitwise AND operator.  Similar to operator+=(const char*), except that it performs a bitwise AND operation instead of an addition.  
      
        
          | CImg<T>& operator&= | ( | const CImg< t > & | img | ) |  |  
In-place bitwise AND operator.  Similar to operator+=(const CImg<t>&), except that it performs a bitwise AND operation instead of an addition.  
      
        
          | CImg<T> operator& | ( | const t | value | ) | const |  
Bitwise AND operator.  Similar to operator&=(const t), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator& | ( | const char *const | expression | ) | const |  
Bitwise AND operator.  Similar to operator&=(const char*), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator& | ( | const CImg< t > & | img | ) | const |  
Bitwise AND operator.  Similar to operator&=(const CImg<t>&), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T>& operator|= | ( | const t | value | ) |  |  
In-place bitwise OR operator.  Similar to operator+=(const t), except that it performs a bitwise OR operation instead of an addition.  
      
        
          | CImg<T>& operator|= | ( | const char *const | expression | ) |  |  
In-place bitwise OR operator.  Similar to operator+=(const char*), except that it performs a bitwise OR operation instead of an addition.  
      
        
          | CImg<T>& operator|= | ( | const CImg< t > & | img | ) |  |  
In-place bitwise OR operator.  Similar to operator+=(const CImg<t>&), except that it performs a bitwise OR operation instead of an addition.  
      
        
          | CImg<T> operator| | ( | const t | value | ) | const |  
Bitwise OR operator.  Similar to operator|=(const t), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator| | ( | const char *const | expression | ) | const |  
Bitwise OR operator.  Similar to operator|=(const char*), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator| | ( | const CImg< t > & | img | ) | const |  
Bitwise OR operator.  Similar to operator|=(const CImg<t>&), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T>& operator^= | ( | const t | value | ) |  |  
In-place bitwise XOR operator.  Similar to operator+=(const t), except that it performs a bitwise XOR operation instead of an addition.  Warning
It does not compute the power of pixel values. For this purpose, use pow(const t) instead. 
 
      
        
          | CImg<T>& operator^= | ( | const char *const | expression | ) |  |  
In-place bitwise XOR operator.  Similar to operator+=(const char*), except that it performs a bitwise XOR operation instead of an addition.  Warning
It does not compute the power of pixel values. For this purpose, use pow(const char*) instead. 
 
      
        
          | CImg<T>& operator^= | ( | const CImg< t > & | img | ) |  |  
In-place bitwise XOR operator.  Similar to operator+=(const CImg<t>&), except that it performs a bitwise XOR operation instead of an addition.  Warning
It does not compute the power of pixel values. For this purpose, use pow(const CImg<t>&) instead. 
 
      
        
          | CImg<T> operator^ | ( | const t | value | ) | const |  
Bitwise XOR operator.  Similar to operator^=(const t), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator^ | ( | const char *const | expression | ) | const |  
Bitwise XOR operator.  Similar to operator^=(const char*), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator^ | ( | const CImg< t > & | img | ) | const |  
Bitwise XOR operator.  Similar to operator^=(const CImg<t>&), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T>& operator<<= | ( | const t | value | ) |  |  
In-place bitwise left shift operator.  Similar to operator+=(const t), except that it performs a bitwise left shift instead of an addition.  
      
        
          | CImg<T>& operator<<= | ( | const char *const | expression | ) |  |  
In-place bitwise left shift operator.  Similar to operator+=(const char*), except that it performs a bitwise left shift instead of an addition.  
      
        
          | CImg<T>& operator<<= | ( | const CImg< t > & | img | ) |  |  
In-place bitwise left shift operator.  Similar to operator+=(const CImg<t>&), except that it performs a bitwise left shift instead of an addition.  
      
        
          | CImg<T> operator<< | ( | const t | value | ) | const |  
Bitwise left shift operator.  Similar to operator<<=(const t), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator<< | ( | const char *const | expression | ) | const |  
Bitwise left shift operator.  Similar to operator<<=(const char*), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator<< | ( | const CImg< t > & | img | ) | const |  
Bitwise left shift operator.  Similar to operator<<=(const CImg<t>&), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T>& operator>>= | ( | const t | value | ) |  |  
In-place bitwise right shift operator.  Similar to operator+=(const t), except that it performs a bitwise right shift instead of an addition.  
      
        
          | CImg<T>& operator>>= | ( | const char *const | expression | ) |  |  
In-place bitwise right shift operator.  Similar to operator+=(const char*), except that it performs a bitwise right shift instead of an addition.  
      
        
          | CImg<T>& operator>>= | ( | const CImg< t > & | img | ) |  |  
In-place bitwise right shift operator.  Similar to operator+=(const CImg<t>&), except that it performs a bitwise right shift instead of an addition.  
      
        
          | CImg<T> operator>> | ( | const t | value | ) | const |  
Bitwise right shift operator.  Similar to operator>>=(const t), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator>> | ( | const char *const | expression | ) | const |  
Bitwise right shift operator.  Similar to operator>>=(const char*), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator>> | ( | const CImg< t > & | img | ) | const |  
Bitwise right shift operator.  Similar to operator>>=(const CImg<t>&), except that it returns a new image instance instead of operating in-place. The pixel type of the returned image is T. 
      
        
          | CImg<T> operator~ | ( |  | ) | const |  
Bitwise inversion operator.  Similar to operator-(), except that it compute the bitwise inverse instead of the opposite value.  
      
        
          | bool operator== | ( | const t | value | ) | const |  
Test if all pixels of an image have the same value.  Return trueis all pixels of the image instance are equal to the specifiedvalue. Parameters
  
    | value | Reference value to compare with. | 
 
      
        
          | bool operator== | ( | const char *const | expression | ) | const |  
Test if all pixel values of an image follow a specified expression.  Return trueis all pixels of the image instance are equal to the specifiedexpression. Parameters
  
    | expression | Value string describing the way pixel values are compared. | 
 
      
        
          | bool operator== | ( | const CImg< t > & | img | ) | const |  
Test if two images have the same size and values.  Return trueif the image instance and the input imageimghave the same dimensions and pixel values, andfalseotherwise. Parameters
  
    | img | Input image to compare with. | 
 Note
The pixel buffer pointers data() of the two compared images do not have to be the same for operator==() to return true. Only the dimensions and the pixel values matter. Thus, the comparison can betrueeven for different pixel typesTandt.
 Exampleconst CImg<float> img1(1,3,1,1, 0,1,2);  const CImg<char> img2(1,3,1,1, 0,1,2);   if (img1==img2) {                          std::printf("'img1' and 'img2' have same dimensions and values."); }
 
      
        
          | bool operator!= | ( | const t | value | ) | const |  
Test if pixels of an image are all different from a value.  Return trueis all pixels of the image instance are different than the specifiedvalue. Parameters
  
    | value | Reference value to compare with. | 
 
      
        
          | bool operator!= | ( | const char *const | expression | ) | const |  
Test if all pixel values of an image are different from a specified expression.  Return trueis all pixels of the image instance are different to the specifiedexpression. Parameters
  
    | expression | Value string describing the way pixel values are compared. | 
 
      
        
          | bool operator!= | ( | const CImg< t > & | img | ) | const |  
Test if two images have different sizes or values.  Return trueif the image instance and the input imageimghave different dimensions or pixel values, andfalseotherwise. Parameters
  
    | img | Input image to compare with. | 
 Note
Writing img1!=img2is equivalent to!(img1==img2).
 
      
        
          | CImgList< typename cimg::superset<T,t>::type > operator, | ( | const CImg< t > & | img | ) | const |  
Construct an image list from two images.  Return a new list of image (CImgListinstance) containing exactly two elements: 
A copy of the image instance, at position [0].A copy of the specified image img, at position [1]. Parameters
  
    | img | Input image that will be the second image of the resulting list. | 
 Note
The family of operator,() is convenient to easily create list of images, but it is also quite slow in practice (see warning below).Constructed lists contain no shared images. If image instance or input image imgare shared, they are inserted as new non-shared copies in the resulting list.The pixel type of the returned list may be a superset of the initial pixel type T, if necessary.
 Warning
 Exampleconst CImg<float>    img1("reference.jpg"),    img2 = img1.get_mirror('x'),    img3 = img2.get_blur(5); const CImgList<float> list = (img1,img2); 
 
      
        
          | CImgList< typename cimg::superset<T,t>::type > operator, | ( | const CImgList< t > & | list | ) | const |  
Construct an image list from image instance and an input image list.  Return a new list of images (CImgListinstance) containing exactlylist.size()+1elements: 
A copy of the image instance, at position [0].A copy of the specified image list list, from positions [1] to [list.size()]. Parameters
  
    | list | Input image list that will be appended to the image instance. | 
 Note
 
      
        
          | CImgList<T> operator< | ( | const char | axis | ) | const |  
Split image along specified axis.  Return a new list of images (CImgListinstance) containing the splitted components of the instance image along the specified axis. Parameters
  
    | axis | Splitting axis (can be ' x','y','z'or 'c') | 
 Note
 Exampleconst CImg<unsigned char> img("reference.jpg");  const CImgList<unsigned char> list = (img<'c'); 
 
  
  | 
        
          | static const char* pixel_type | ( |  | ) |  |  | static |  
Return the type of image pixel values as a C string.  Return a char*string containing the usual type name of the image pixel values (i.e. a stringified version of the template parameterT). Note
The returned string may contain spaces (as in "unsigned char").If the pixel type Tdoes not correspond to a registered type, the string"unknown"is returned.
 
Return the number of image columns.  Return the image width, i.e. the image dimension along the X-axis.  Note
The width() of an empty image is equal to 0.width() is typically equal to 1when considering images as vectors for matrix calculations.width() returns an int, although the image width is internally stored as anunsignedint. Using anintis safer and prevents arithmetic traps possibly encountered when doing calculations involvingunsignedintvariables. Access to the initialunsignedintvariable is possible (though not recommended) by(*this)._width.
 
Return the number of image rows.  Return the image height, i.e. the image dimension along the Y-axis.  Note
The height() of an empty image is equal to 0.height() returns an int, although the image height is internally stored as anunsignedint. Using anintis safer and prevents arithmetic traps possibly encountered when doing calculations involvingunsignedintvariables. Access to the initialunsignedintvariable is possible (though not recommended) by(*this)._height.
 
Return the number of image slices.  Return the image depth, i.e. the image dimension along the Z-axis.  Note
The depth() of an empty image is equal to 0.depth() is typically equal to 1when considering usual 2d images. When depth()>1, the image is said to be volumetric.depth() returns an int, although the image depth is internally stored as anunsignedint. Using anintis safer and prevents arithmetic traps possibly encountered when doing calculations involvingunsignedintvariables. Access to the initialunsignedintvariable is possible (though not recommended) by(*this)._depth.
 
Return the number of image channels.  Return the number of image channels, i.e. the image dimension along the C-axis.  Note
The spectrum() of an empty image is equal to 0.spectrum() is typically equal to 1when considering scalar-valued images, to3for RGB-coded color images, and to4for RGBA-coded color images (with alpha-channel). The number of channels of an image instance is not limited. The meaning of the pixel values is not linked up to the number of channels (e.g. a 4-channel image may indifferently stands for a RGBA or CMYK color image).spectrum() returns an int, although the image spectrum is internally stored as anunsignedint. Using anintis safer and prevents arithmetic traps possibly encountered when doing calculations involvingunsignedintvariables. Access to the initialunsignedintvariable is possible (though not recommended) by(*this)._spectrum.
 
      
        
          | unsigned long size | ( |  | ) | const |  
Return the total number of pixel values.  Return width()*height()*depth()*spectrum(), i.e. the total number of values of typeTin the pixel buffer of the image instance. Note
The size() of an empty image is equal to 0.The allocated memory size for a pixel buffer of a non-shared CImg<T>instance is equal tosize()*sizeof(T).
 Exampleconst CImg<float> img(100,100,1,3);                if (img.size()==30000)                               std::printf("Pixel buffer uses %lu bytes",               img.size()*sizeof(float));
 
Return a pointer to the first pixel value.  Return a T*, or aconstT*pointer to the first value in the pixel buffer of the image instance, whether the instance isconstor not. Note
 
      
        
          | T* data | ( | const unsigned int | x, |  
          |  |  | const unsigned int | y = 0, |  
          |  |  | const unsigned int | z = 0, |  
          |  |  | const unsigned int | c = 0 |  
          |  | ) |  |  |  
Return a pointer to a located pixel value.  Return a T*, or aconstT*pointer to the value located at (x,y,z,c) in the pixel buffer of the image instance, whether the instance isconstor not. Parameters
  
    | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. | 
 Note
Writing img.data(x,y,z,c)is equivalent to&(img(x,y,z,c)). Thus, this method has the same properties as operator()(unsigned int,unsigned int,unsigned int,unsigned int).
 
      
        
          | long offset | ( | const int | x, |  
          |  |  | const int | y = 0, |  
          |  |  | const int | z = 0, |  
          |  |  | const int | c = 0 |  
          |  | ) |  | const |  
Return the offset to a located pixel value, with respect to the beginning of the pixel buffer.  Parameters
  
    | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. | 
 Note
Writing img.data(x,y,z,c)is equivalent to&(img(x,y,z,c)) - img.data(). Thus, this method has the same properties as operator()(unsigned int,unsigned int,unsigned int,unsigned int).
 Exampleconst CImg<float> img(100,100,1,3);       const long off = img.offset(10,10,0,2);   const float val = img[off];              
 
Return a CImg<T>::iterator pointing to the first pixel value.  Note
Equivalent to data().It has been mainly defined for compatibility with STL naming conventions. 
 
Return a CImg<T>::iterator pointing next to the last pixel value.  Note
Writing img.end()is equivalent toimg.data() + img.size().It has been mainly defined for compatibility with STL naming conventions. 
 Warning
The returned iterator actually points to a value located outside the acceptable bounds of the pixel buffer. Trying to read or write the content of the returned iterator will probably result in a crash. Use it mainly as an strict upper bound for a CImg<T>::iterator. 
 ExampleCImg<float> img(100,100,1,3);                                      for (CImg<float>::iterator it = img.begin(); it<img.end(); ++it)     *it = 0;
 
Return a reference to the first pixel value.  Note
Writing img.front()is equivalent toimg[0], orimg(0,0,0,0).It has been mainly defined for compatibility with STL naming conventions. 
 
Return a reference to the last pixel value.  Note
Writing img.end()is equivalent toimg[img.size()-1], orimg(img.width()-1,img.height()-1,img.depth()-1,img.spectrum()-1).It has been mainly defined for compatibility with STL naming conventions. 
 
      
        
          | T& at | ( | const int | offset, |  
          |  |  | const T | out_value |  
          |  | ) |  |  |  
Access to a pixel value at a specified offset, using Dirichlet boundary conditions.  Return a reference to the pixel value of the image instance located at a specified offset, or to a specified default value in case of out-of-bounds access. Parameters
  
    | offset | Offset to the desired pixel value. |  | out_value | Default value returned if offsetis outside image bounds. | 
 Note
Writing img.at(offset,out_value)is similar toimg[offset], except that ifoffsetis outside bounds (e.g.offset<0oroffset>=img.size()), a reference to a valueout_valueis safely returned instead.Due to the additional boundary checking operation, this method is slower than operator()(). Use it when you are not sure about the validity of the specified pixel offset. 
 
      
        
          | T& at | ( | const int | offset | ) |  |  
Access to a pixel value at a specified offset, using Neumann boundary conditions.  Return a reference to the pixel value of the image instance located at a specified offset, or to the nearest pixel location in the image instance in case of out-of-bounds access. Parameters
  
    | offset | Offset to the desired pixel value. | 
 Note
Similar to at(int,const T), except that an out-of-bounds access returns the value of the nearest pixel in the image instance, regarding the specified offset, i.e.
If offset<0, thenimg[0] is returned.If offset>=img.size(), thenimg[img.size()-1] is returned.Due to the additional boundary checking operation, this method is slower than operator()(). Use it when you are not sure about the validity of the specified pixel offset.If you know your image instance is not empty, you may rather use the slightly faster method _at(int).
 
      
        
          | T& atX | ( | const int | x, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value |  
          |  | ) |  |  |  
Access to a pixel value, using Dirichlet boundary conditions for the X-coordinate.  Return a reference to the pixel value of the image instance located at (x,y,z,c), or to a specified default value in case of out-of-bounds access along the X-axis. Parameters
  
    | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. |  | out_value | Default value returned if (x,y,z,c) is outside image bounds. | 
 Note
Similar to operator()(), except that an out-of-bounds access along the X-axis returns the specified value out_value.Due to the additional boundary checking operation, this method is slower than operator()(). Use it when you are not sure about the validity of the specified pixel coordinates. 
 Warning
There is no boundary checking performed for the Y,Z and C-coordinates, so they must be inside image bounds. 
 
      
        
          | T& atX | ( | const int | x, |  
          |  |  | const int | y = 0, |  
          |  |  | const int | z = 0, |  
          |  |  | const int | c = 0 |  
          |  | ) |  |  |  
Access to a pixel value, using Neumann boundary conditions for the X-coordinate.  Return a reference to the pixel value of the image instance located at (x,y,z,c), or to the nearest pixel location in the image instance in case of out-of-bounds access along the X-axis. Parameters
  
    | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. | 
 Note
Similar to at(int,int,int,int,const T), except that an out-of-bounds access returns the value of the nearest pixel in the image instance, regarding the specified X-coordinate.Due to the additional boundary checking operation, this method is slower than operator()(). Use it when you are not sure about the validity of the specified pixel coordinates.If you know your image instance is not empty, you may rather use the slightly faster method _at(int,int,int,int).
 Warning
There is no boundary checking performed for the Y,Z and C-coordinates, so they must be inside image bounds. 
 
      
        
          | T& atXY | ( | const int | x, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value |  
          |  | ) |  |  |  
Access to a pixel value, using Dirichlet boundary conditions for the X and Y-coordinates.  Similar to atX(int,int,int,int,const T), except that boundary checking is performed both on X and Y-coordinates.  
      
        
          | T& atXY | ( | const int | x, |  
          |  |  | const int | y, |  
          |  |  | const int | z = 0, |  
          |  |  | const int | c = 0 |  
          |  | ) |  |  |  
Access to a pixel value, using Neumann boundary conditions for the X and Y-coordinates.  Similar to atX(int,int,int,int), except that boundary checking is performed both on X and Y-coordinates.  Note
If you know your image instance is not empty, you may rather use the slightly faster method _atXY(int,int,int,int).
 
      
        
          | T& atXYZ | ( | const int | x, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value |  
          |  | ) |  |  |  
Access to a pixel value, using Dirichlet boundary conditions for the X,Y and Z-coordinates.  Similar to atX(int,int,int,int,const T), except that boundary checking is performed both on X,Y and Z-coordinates.  
      
        
          | T& atXYZ | ( | const int | x, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const int | c = 0 |  
          |  | ) |  |  |  
Access to a pixel value, using Neumann boundary conditions for the X,Y and Z-coordinates.  Similar to atX(int,int,int,int), except that boundary checking is performed both on X,Y and Z-coordinates.  Note
If you know your image instance is not empty, you may rather use the slightly faster method _atXYZ(int,int,int,int).
 
      
        
          | T& atXYZC | ( | const int | x, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value |  
          |  | ) |  |  |  
Access to a pixel value, using Dirichlet boundary conditions.  Similar to atX(int,int,int,int,const T), except that boundary checking is performed on all X,Y,Z and C-coordinates.  
      
        
          | T& atXYZC | ( | const int | x, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const int | c |  
          |  | ) |  |  |  
Access to a pixel value, using Neumann boundary conditions.  Similar to atX(int,int,int,int), except that boundary checking is performed on all X,Y,Z and C-coordinates.  Note
If you know your image instance is not empty, you may rather use the slightly faster method _atXYZC(int,int,int,int).
 
      
        
          | Tfloat linear_atX | ( | const float | fx, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value |  
          |  | ) |  | const |  
Return pixel value, using linear interpolation and Dirichlet boundary conditions for the X-coordinate.  Return a linearly-interpolated pixel value of the image instance located at (fx,y,z,c), or a specified default value in case of out-of-bounds access along the X-axis. Parameters
  
    | fx | X-coordinate of the pixel value (float-valued). |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. |  | out_value | Default value returned if (fx,y,z,c) is outside image bounds. | 
 Note
Similar to atX(int,int,int,int,const T), except that the returned pixel value is approximated by a linear interpolation along the X-axis, if corresponding coordinates are not integers.The type of the returned pixel value is extended to float, if the pixel typeTis not float-valued.
 Warning
There is no boundary checking performed for the Y,Z and C-coordinates, so they must be inside image bounds. 
 
      
        
          | Tfloat linear_atX | ( | const float | fx, |  
          |  |  | const int | y = 0, |  
          |  |  | const int | z = 0, |  
          |  |  | const int | c = 0 |  
          |  | ) |  | const |  
Return pixel value, using linear interpolation and Neumann boundary conditions for the X-coordinate.  Return a linearly-interpolated pixel value of the image instance located at (fx,y,z,c), or the value of the nearest pixel location in the image instance in case of out-of-bounds access along the X-axis. Parameters
  
    | fx | X-coordinate of the pixel value (float-valued). |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. | 
 Note
Similar to linear_atX(float,int,int,int,const T) const, except that an out-of-bounds access returns the value of the nearest pixel in the image instance, regarding the specified X-coordinate.If you know your image instance is not empty, you may rather use the slightly faster method _linear_atX(float,int,int,int).
 Warning
There is no boundary checking performed for the Y,Z and C-coordinates, so they must be inside image bounds. 
 
      
        
          | Tfloat linear_atXY | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value |  
          |  | ) |  | const |  
Return pixel value, using linear interpolation and Dirichlet boundary conditions for the X and Y-coordinates.  Similar to linear_atX(float,int,int,int,const T) const, except that the linear interpolation and the boundary checking are achieved both for X and Y-coordinates.  
      
        
          | Tfloat linear_atXY | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const int | z = 0, |  
          |  |  | const int | c = 0 |  
          |  | ) |  | const |  
Return pixel value, using linear interpolation and Neumann boundary conditions for the X and Y-coordinates.  Similar to linear_atX(float,int,int,int) const, except that the linear interpolation and the boundary checking are achieved both for X and Y-coordinates.  Note
If you know your image instance is not empty, you may rather use the slightly faster method _linear_atXY(float,float,int,int).
 
      
        
          | Tfloat linear_atXYZ | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const float | fz, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value |  
          |  | ) |  | const |  
Return pixel value, using linear interpolation and Dirichlet boundary conditions for the X,Y and Z-coordinates.  Similar to linear_atX(float,int,int,int,const T) const, except that the linear interpolation and the boundary checking are achieved both for X,Y and Z-coordinates.  
      
        
          | Tfloat linear_atXYZ | ( | const float | fx, |  
          |  |  | const float | fy = 0, |  
          |  |  | const float | fz = 0, |  
          |  |  | const int | c = 0 |  
          |  | ) |  | const |  
Return pixel value, using linear interpolation and Neumann boundary conditions for the X,Y and Z-coordinates.  Similar to linear_atX(float,int,int,int) const, except that the linear interpolation and the boundary checking are achieved both for X,Y and Z-coordinates.  Note
If you know your image instance is not empty, you may rather use the slightly faster method _linear_atXYZ(float,float,float,int).
 
      
        
          | Tfloat linear_atXYZC | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const float | fz, |  
          |  |  | const float | fc, |  
          |  |  | const T | out_value |  
          |  | ) |  | const |  
Return pixel value, using linear interpolation and Dirichlet boundary conditions for all X,Y,Z and C-coordinates.  Similar to linear_atX(float,int,int,int,const T) const, except that the linear interpolation and the boundary checking are achieved for all X,Y,Z and C-coordinates.  
      
        
          | Tfloat linear_atXYZC | ( | const float | fx, |  
          |  |  | const float | fy = 0, |  
          |  |  | const float | fz = 0, |  
          |  |  | const float | fc = 0 |  
          |  | ) |  | const |  
Return pixel value, using linear interpolation and Neumann boundary conditions for all X,Y,Z and C-coordinates.  Similar to linear_atX(float,int,int,int) const, except that the linear interpolation and the boundary checking are achieved for all X,Y,Z and C-coordinates.  Note
If you know your image instance is not empty, you may rather use the slightly faster method _linear_atXYZC(float,float,float,float).
 
      
        
          | Tfloat cubic_atX | ( | const float | fx, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value |  
          |  | ) |  | const |  
Return pixel value, using cubic interpolation and Dirichlet boundary conditions for the X-coordinate.  Return a cubicly-interpolated pixel value of the image instance located at (fx,y,z,c), or a specified default value in case of out-of-bounds access along the X-axis. Parameters
  
    | fx | d X-coordinate of the pixel value (float-valued). |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. |  | out_value | Default value returned if (fx,y,z,c) is outside image bounds. | 
 Note
Similar to linear_atX(float,int,int,int,const T) const, except that the returned pixel value is approximated by a cubic interpolation along the X-axis.The type of the returned pixel value is extended to float, if the pixel typeTis not float-valued.
 Warning
There is no boundary checking performed for the Y,Z and C-coordinates, so they must be inside image bounds. 
 
      
        
          | Tfloat cubic_atX | ( | const float | fx, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value, |  
          |  |  | const Tfloat | min_value, |  
          |  |  | const Tfloat | max_value |  
          |  | ) |  | const |  
Return damped pixel value, using cubic interpolation and Dirichlet boundary conditions for the X-coordinate.  Similar to cubic_atX(float,int,int,int,const T) const, except that you can specify the authorized minimum and maximum of the returned value.  
      
        
          | Tfloat cubic_atX | ( | const float | fx, |  
          |  |  | const int | y = 0, |  
          |  |  | const int | z = 0, |  
          |  |  | const int | c = 0 |  
          |  | ) |  | const |  
Return pixel value, using cubic interpolation and Neumann boundary conditions for the X-coordinate.  Return a cubicly-interpolated pixel value of the image instance located at (fx,y,z,c), or the value of the nearest pixel location in the image instance in case of out-of-bounds access along the X-axis. Parameters
  
    | fx | X-coordinate of the pixel value (float-valued). |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. | 
 Note
Similar to cubic_atX(float,int,int,int,const T) const, except that the returned pixel value is approximated by a cubic interpolation along the X-axis.If you know your image instance is not empty, you may rather use the slightly faster method _cubic_atX(float,int,int,int).
 Warning
There is no boundary checking performed for the Y,Z and C-coordinates, so they must be inside image bounds. 
 
      
        
          | Tfloat cubic_atX | ( | const float | fx, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const Tfloat | min_value, |  
          |  |  | const Tfloat | max_value |  
          |  | ) |  | const |  
Return damped pixel value, using cubic interpolation and Neumann boundary conditions for the X-coordinate.  Similar to cubic_atX(float,int,int,int) const, except that you can specify the authorized minimum and maximum of the returned value.  
      
        
          | Tfloat cubic_atXY | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value |  
          |  | ) |  | const |  
Return pixel value, using cubic interpolation and Dirichlet boundary conditions for the X and Y-coordinates.  Similar to cubic_atX(float,int,int,int,const T) const, except that the cubic interpolation and boundary checking are achieved both for X and Y-coordinates.  
      
        
          | Tfloat cubic_atXY | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value, |  
          |  |  | const Tfloat | min_value, |  
          |  |  | const Tfloat | max_value |  
          |  | ) |  | const |  
Return damped pixel value, using cubic interpolation and Dirichlet boundary conditions for the X and Y-coordinates.  Similar to cubic_atXY(float,float,int,int,const T) const, except that you can specify the authorized minimum and maximum of the returned value.  
      
        
          | Tfloat cubic_atXY | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const int | z = 0, |  
          |  |  | const int | c = 0 |  
          |  | ) |  | const |  
Return pixel value, using cubic interpolation and Neumann boundary conditions for the X and Y-coordinates.  Similar to cubic_atX(float,int,int,int) const, except that the cubic interpolation and boundary checking are achieved for both X and Y-coordinates.  Note
If you know your image instance is not empty, you may rather use the slightly faster method _cubic_atXY(float,float,int,int).
 
      
        
          | Tfloat cubic_atXY | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const int | z, |  
          |  |  | const int | c, |  
          |  |  | const Tfloat | min_value, |  
          |  |  | const Tfloat | max_value |  
          |  | ) |  | const |  
Return damped pixel value, using cubic interpolation and Neumann boundary conditions for the X and Y-coordinates.  Similar to cubic_atXY(float,float,int,int) const, except that you can specify the authorized minimum and maximum of the returned value.  
      
        
          | Tfloat cubic_atXYZ | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const float | fz, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value |  
          |  | ) |  | const |  
Return pixel value, using cubic interpolation and Dirichlet boundary conditions for the X,Y and Z-coordinates.  Similar to cubic_atX(float,int,int,int,const T) const, except that the cubic interpolation and boundary checking are achieved both for X,Y and Z-coordinates.  
      
        
          | Tfloat cubic_atXYZ | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const float | fz, |  
          |  |  | const int | c, |  
          |  |  | const T | out_value, |  
          |  |  | const Tfloat | min_value, |  
          |  |  | const Tfloat | max_value |  
          |  | ) |  | const |  
Return damped pixel value, using cubic interpolation and Dirichlet boundary conditions for the X,Y and Z-coordinates.  Similar to cubic_atXYZ(float,float,float,int,const T) const, except that you can specify the authorized minimum and maximum of the returned value.  
      
        
          | Tfloat cubic_atXYZ | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const float | fz, |  
          |  |  | const int | c = 0 |  
          |  | ) |  | const |  
Return pixel value, using cubic interpolation and Neumann boundary conditions for the X,Y and Z-coordinates.  Similar to cubic_atX(float,int,int,int) const, except that the cubic interpolation and boundary checking are achieved both for X,Y and Z-coordinates.  Note
If you know your image instance is not empty, you may rather use the slightly faster method _cubic_atXYZ(float,float,float,int).
 
      
        
          | Tfloat cubic_atXYZ | ( | const float | fx, |  
          |  |  | const float | fy, |  
          |  |  | const float | fz, |  
          |  |  | const int | c, |  
          |  |  | const Tfloat | min_value, |  
          |  |  | const Tfloat | max_value |  
          |  | ) |  | const |  
Return damped pixel value, using cubic interpolation and Neumann boundary conditions for the X,Y and Z-coordinates.  Similar to cubic_atXYZ(float,float,float,int) const, except that you can specify the authorized minimum and maximum of the returned value.  
      
        
          | CImg<T>& set_linear_atXY | ( | const T & | value, |  
          |  |  | const float | fx, |  
          |  |  | const float | fy = 0, |  
          |  |  | const int | z = 0, |  
          |  |  | const int | c = 0, |  
          |  |  | const bool | is_added = false |  
          |  | ) |  |  |  
Set pixel value, using linear interpolation for the X and Y-coordinates.  Set pixel value at specified coordinates (fx,fy,z,c) in the image instance, in a way that the value is spread amongst several neighbors if the pixel coordinates are indeed float-valued. Parameters
  
    | value | Pixel value to set. |  | fx | X-coordinate of the pixel value (float-valued). |  | fy | Y-coordinate of the pixel value (float-valued). |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. |  | is_added | Tells if the pixel value is added to ( true), or simply replace (false) the current image pixel(s). | 
 ReturnsA reference to the current image instance. 
 Note
If specified coordinates are outside image bounds, no operations are performed. 
 
      
        
          | CImg<T>& set_linear_atXYZ | ( | const T & | value, |  
          |  |  | const float | fx, |  
          |  |  | const float | fy = 0, |  
          |  |  | const float | fz = 0, |  
          |  |  | const int | c = 0, |  
          |  |  | const bool | is_added = false |  
          |  | ) |  |  |  
      
        
          | CImg<charT> value_string | ( | const char | separator = ',', |  
          |  |  | const unsigned int | max_size = 0 |  
          |  | ) |  | const |  
Return a C-string containing a list of all values of the image instance.  Return a new CImg<char>image whose buffer data() is achar*string describing the list of all pixel values of the image instance (written in base 10), separated by specifiedseparatorcharacter. Parameters
  
    | separator | A charcharacter which specifies the separator between values in the returned C-string. |  | max_size | Maximum size of the returned image. | 
 Note
The returned image is never empty.For an empty image instance, the returned string is "".If max_sizeis equal to0, there are no limits on the size of the returned string.Otherwise, if the maximum number of string characters is exceeded, the value string is cut off and terminated by character '\0'. In that case, the returned image size ismax_size + 1.
 
Test shared state of the pixel buffer.  Return trueif image instance has a shared memory buffer, andfalseotherwise. Note
A shared image do not own his pixel buffer data() and will not deallocate it on destruction.Most of the time, a CImg<T>image instance will not be shared.A shared image can only be obtained by a limited set of constructors and methods (see list below). 
 
Test if image instance is empty.  Return true, if image instance is empty, i.e. does not contain any pixel values, has dimensions0x0x0x0and a pixel buffer pointer set to0(null pointer), andfalseotherwise. 
Test if image instance contains a 'inf' value.  Return true, if image instance contains a 'inf' value, andfalseotherwise. 
Test if image instance contains a 'nan' value.  Return true, if image instance contains a 'nan' value, andfalseotherwise. 
      
        
          | bool is_sameXY | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y |  
          |  | ) |  | const |  
      
        
          | bool is_sameXY | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool is_sameXZ | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_z |  
          |  | ) |  | const |  
      
        
          | bool is_sameXZ | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool is_sameXC | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_c |  
          |  | ) |  | const |  
      
        
          | bool is_sameXC | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool is_sameYZ | ( | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z |  
          |  | ) |  | const |  
      
        
          | bool is_sameYZ | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool is_sameYC | ( | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_c |  
          |  | ) |  | const |  
      
        
          | bool is_sameYC | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool is_sameZC | ( | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c |  
          |  | ) |  | const |  
      
        
          | bool is_sameZC | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool is_sameXYZ | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z |  
          |  | ) |  | const |  
      
        
          | bool is_sameXYZ | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool is_sameXYC | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_c |  
          |  | ) |  | const |  
      
        
          | bool is_sameXYC | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool is_sameXZC | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c |  
          |  | ) |  | const |  
      
        
          | bool is_sameXZC | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool is_sameYZC | ( | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c |  
          |  | ) |  | const |  
      
        
          | bool is_sameYZC | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool is_sameXYZC | ( | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y, |  
          |  |  | const unsigned int | size_z, |  
          |  |  | const unsigned int | size_c |  
          |  | ) |  | const |  
      
        
          | bool is_sameXYZC | ( | const CImg< t > & | img | ) | const |  
      
        
          | bool containsXYZC | ( | const int | x, |  
          |  |  | const int | y = 0, |  
          |  |  | const int | z = 0, |  
          |  |  | const int | c = 0 |  
          |  | ) |  | const |  
Test if specified coordinates are inside image bounds.  Return trueif pixel located at (x,y,z,c) is inside bounds of the image instance, andfalseotherwise. Parameters
  
    | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. |  | c | C-coordinate of the pixel value. | 
 Note
Return trueonly if all these conditions are verified:
 
      
        
          | bool contains | ( | const T & | pixel, |  
          |  |  | t & | x, |  
          |  |  | t & | y, |  
          |  |  | t & | z, |  
          |  |  | t & | c |  
          |  | ) |  | const |  
Test if pixel value is inside image bounds and get its X,Y,Z and C-coordinates.  Return true, if specified reference refers to a pixel value inside bounds of the image instance, andfalseotherwise. Parameters
  
    |  | pixel | Reference to pixel value to test. |  | [out] | x | X-coordinate of the pixel value, if test succeeds. |  | [out] | y | Y-coordinate of the pixel value, if test succeeds. |  | [out] | z | Z-coordinate of the pixel value, if test succeeds. |  | [out] | c | C-coordinate of the pixel value, if test succeeds. | 
 Note
Useful to convert an offset to a buffer value into pixel value coordinates: const CImg<float> img(100,100,1,3);       const unsigned long offset = 1249;        unsigned int x,y,z,c; if (img.contains(img[offset],x,y,z,c)) {    std::printf("Offset %u refers to pixel located at (%u,%u,%u,%u).\n",               offset,x,y,z,c); }
 
      
        
          | bool contains | ( | const T & | pixel, |  
          |  |  | t & | x, |  
          |  |  | t & | y, |  
          |  |  | t & | z |  
          |  | ) |  | const |  
      
        
          | bool contains | ( | const T & | pixel, |  
          |  |  | t & | x, |  
          |  |  | t & | y |  
          |  | ) |  | const |  
      
        
          | bool contains | ( | const T & | pixel, |  
          |  |  | t & | x |  
          |  | ) |  | const |  
      
        
          | bool contains | ( | const T & | pixel | ) | const |  
      
        
          | bool is_overlapped | ( | const CImg< t > & | img | ) | const |  
Test if pixel buffers of instance and input images overlap.  Return true, if pixel buffers attached to image instance and input imageimgoverlap, andfalseotherwise. Parameters
  
    | img | Input image to compare with. | 
 Note
Buffer overlapping may happen when manipulating shared images.If two image buffers overlap, operating on one of the image will probably modify the other one.Most of the time, CImg<T>instances are non-shared and do not overlap between each others.
 Exampleconst CImg<float>   img1("reference.jpg"),                img2 = img1.get_shared_channel(1);  if (img1.is_overlapped(img2)) {         std::printf("Buffers overlap!\n"); }
 
      
        
          | bool is_object3d | ( | const CImgList< tp > & | primitives, |  
          |  |  | const CImgList< tc > & | colors, |  
          |  |  | const to & | opacities, |  
          |  |  | const bool | is_full_check = true, |  
          |  |  | char *const | error_message = 0 |  
          |  | ) |  | const |  
Test if the set {*this,primitives,colors,opacities}defines a valid 3d object. Return trueis the 3d object represented by the set {*this,primitives,colors,opacities}defines a valid 3d object, andfalseotherwise. The vertex coordinates are defined by the instance image. Parameters
  
    |  | primitives | List of primitives of the 3d object. |  |  | colors | List of colors of the 3d object. |  |  | opacities | List (or image) of opacities of the 3d object. |  |  | is_full_check | Tells if full checking of the 3d object must be performed. |  | [out] | error_message | C-string to contain the error message, if the test does not succeed. | 
 Note
Set is_full_checkingtofalseto speed-up the 3d object checking. In this case, only the size of each 3d object component is checked.Size of the string error_messageshould be at least 128-bytes long, to be able to contain the error message.
 
      
        
          | bool is_CImg3d | ( | const bool | is_full_check = true, |  
          |  |  | char *const | error_message = 0 |  
          |  | ) |  | const |  
Test if image instance represents a valid serialization of a 3d object.  Return trueif the image instance represents a valid serialization of a 3d object, andfalseotherwise. Parameters
  
    |  | is_full_check | Tells if full checking of the instance must be performed. |  | [out] | error_message | C-string to contain the error message, if the test does not succeed. | 
 Note
Set is_full_checkingtofalseto speed-up the 3d object checking. In this case, only the size of each 3d object component is checked.Size of the string error_messageshould be at least 128-bytes long, to be able to contain the error message.
 
Compute the square value of each pixel value.  Replace each pixel value  of the image instance by its square value  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 Exampleconst CImg<float> img("reference.jpg"); (img,img.get_sqr().normalize(0,255)).display ();
 
Compute the square root of each pixel value.  Replace each pixel value  of the image instance by its square root  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 Exampleconst CImg<float> img("reference.jpg"); (img,img.get_sqrt().normalize(0,255)).display ();
 
Compute the exponential of each pixel value.  Replace each pixel value  of the image instance by its exponential  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the logarithm of each pixel value.  Replace each pixel value  of the image instance by its logarithm  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the base-2 logarithm of each pixel value.  Replace each pixel value  of the image instance by its base-2 logarithm  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the base-10 logarithm of each pixel value.  Replace each pixel value  of the image instance by its base-10 logarithm  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the absolute value of each pixel value.  Replace each pixel value  of the image instance by its absolute value  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the sign of each pixel value.  Replace each pixel value  of the image instance by its sign  . Note
The sign is set to:
1if pixel value is strictly positive.-1if pixel value is strictly negative.0if pixel value is equal to0.The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the cosine of each pixel value.  Replace each pixel value  of the image instance by its cosine  . Note
Pixel values are regarded as being in radian.The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the sine of each pixel value.  Replace each pixel value  of the image instance by its sine  . Note
Pixel values are regarded as being in radian.The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the sinc of each pixel value.  Replace each pixel value  of the image instance by its sinc  . Note
Pixel values are regarded as being exin radian.The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the tangent of each pixel value.  Replace each pixel value  of the image instance by its tangent  . Note
Pixel values are regarded as being exin radian.The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the hyperbolic cosine of each pixel value.  Replace each pixel value  of the image instance by its hyperbolic cosine  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the hyperbolic sine of each pixel value.  Replace each pixel value  of the image instance by its hyperbolic sine  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the hyperbolic tangent of each pixel value.  Replace each pixel value  of the image instance by its hyperbolic tangent  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the arccosine of each pixel value.  Replace each pixel value  of the image instance by its arccosine  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the arcsine of each pixel value.  Replace each pixel value  of the image instance by its arcsine  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the arctangent of each pixel value.  Replace each pixel value  of the image instance by its arctangent  . Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 
Compute the arctangent2 of each pixel value.  Replace each pixel value  of the image instance by its arctangent2  . Parameters
  
    | img | Image whose pixel values specify the second argument of the atan2()function. | 
 Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 Exampleconst CImg<float>    img_x(100,100,1,1,"x-w/2",false),       img_y(100,100,1,1,"y-h/2",false),       img_atan2 = img_y.get_atan2(img_x); 
 
In-place pointwise multiplication.  Compute the pointwise multiplication between the image instance and the specified input image img. Parameters
  
    | img | Input image, as the second operand of the multiplication. | 
 Note
 ExampleCImg<float>   img("reference.jpg"),   shade(img.width,img.height(),1,1,"-(x-w/2)^2-(y-h/2)^2",false); shade.normalize(0,1); (img,shade,img.get_mul(shade)).display ();
 
In-place pointwise division.  Similar to mul(const CImg<t>&), except that it performs a pointwise division instead of a multiplication.  
      
        
          | CImg<T>& pow | ( | const double | p | ) |  |  
Raise each pixel value to a specified power.  Replace each pixel value  of the image instance by its power  . Parameters
  
  
 Note
The [in-place version] of this method statically casts the computed values to the pixel type T.The [new-instance version] returns a CImg<float>image, if the pixel typeTis not float-valued.
 Exampleconst CImg<float>   img0("reference.jpg"),              img1 = (img0/255).pow (1.8)*=255,   img2 = (img0/255).pow (0.5)*=255; 
 
      
        
          | CImg<T>& pow | ( | const char *const | expression | ) |  |  
Raise each pixel value to a power, specified from an expression.  Similar to operator+=(const char*), except it performs a pointwise exponentiation instead of an addition.  
Raise each pixel value to a power, pointwisely specified from another image.  Similar to operator+=(const CImg<t>& img), except that it performs an exponentiation instead of an addition.  
      
        
          | CImg<T>& rol | ( | const unsigned int | n = 1 | ) |  |  
Compute the bitwise left rotation of each pixel value.  Similar to operator<<=(unsigned int), except that it performs a left rotation instead of a left shift.  
      
        
          | CImg<T>& rol | ( | const char *const | expression | ) |  |  
Compute the bitwise left rotation of each pixel value.  Similar to operator<<=(const char*), except that it performs a left rotation instead of a left shift.  
Compute the bitwise left rotation of each pixel value.  Similar to operator<<=(const CImg<t>&), except that it performs a left rotation instead of a left shift.  
      
        
          | CImg<T>& ror | ( | const unsigned int | n = 1 | ) |  |  
Compute the bitwise right rotation of each pixel value.  Similar to operator>>=(unsigned int), except that it performs a right rotation instead of a right shift.  
      
        
          | CImg<T>& ror | ( | const char *const | expression | ) |  |  
Compute the bitwise right rotation of each pixel value.  Similar to operator>>=(const char*), except that it performs a right rotation instead of a right shift.  
Compute the bitwise right rotation of each pixel value.  Similar to operator>>=(const CImg<t>&), except that it performs a right rotation instead of a right shift.  
      
        
          | CImg<T>& min | ( | const T | val | ) |  |  
Pointwise min operator between instance image and a value.  Parameters
  
    | val | Value used as the reference argument of the min operator. | 
 NoteReplace each pixel value  of the image instance by  .
 
Pointwise min operator between two images.  Parameters
  
    | img | Image used as the reference argument of the min operator. | 
 NoteReplace each pixel value  of the image instance by  .
 
      
        
          | CImg<T>& min | ( | const char *const | expression | ) |  |  
Pointwise min operator between an image and an expression.  Parameters
  
    | expression | Math formula as a C-string. | 
 NoteReplace each pixel value  of the image instance by  .
 
      
        
          | CImg<T>& max | ( | const T | val | ) |  |  
Pointwise max operator between instance image and a value.  Parameters
  
    | val | Value used as the reference argument of the max operator. | 
 NoteReplace each pixel value  of the image instance by  .
 
Pointwise max operator between two images.  Parameters
  
    | img | Image used as the reference argument of the max operator. | 
 NoteReplace each pixel value  of the image instance by  .
 
      
        
          | CImg<T>& max | ( | const char *const | expression | ) |  |  
Pointwise max operator between an image and an expression.  Parameters
  
    | expression | Math formula as a C-string. | 
 NoteReplace each pixel value  of the image instance by  .
 
      
        
          | T& min_max | ( | t & | max_val | ) |  |  
Return a reference to the minimum pixel value as well as the maximum pixel value.  Parameters
  
    | [out] | max_val | Maximum pixel value. | 
 
      
        
          | T& max_min | ( | t & | min_val | ) |  |  
Return a reference to the maximum pixel value as well as the minimum pixel value.  Parameters
  
    | [out] | min_val | Minimum pixel value. | 
 
      
        
          | T kth_smallest | ( | const unsigned int | k | ) | const |  
Return the kth smallest pixel value.  Parameters
  
    | k | Rank of the search smallest element. | 
 
      
        
          | Tdouble variance | ( | const unsigned int | variance_method = 1 | ) | const |  
      
        
          | Tdouble variance_mean | ( | const unsigned int | variance_method, |  
          |  |  | t & | mean |  
          |  | ) |  | const |  
Return the variance as well as the average of the pixel values.  Parameters
  
  
 
      
        
          | Tdouble variance_noise | ( | const unsigned int | variance_method = 2 | ) | const |  
      
        
          | Tdouble MSE | ( | const CImg< t > & | img | ) | const |  
Compute the MSE (Mean-Squared Error) between two images.  Parameters
  
    | img | Image used as the second argument of the MSE operator. | 
 
      
        
          | Tdouble PSNR | ( | const CImg< t > & | img, |  
          |  |  | const Tdouble | max_value = 255 |  
          |  | ) |  | const |  
Compute the PSNR (Peak Signal-to-Noise Ratio) between two images.  Parameters
  
    | img | Image used as the second argument of the PSNR operator. |  | max_value | Maximum theoretical value of the signal. | 
 
      
        
          | double eval | ( | const char *const | expression, |  
          |  |  | const double | x = 0, |  
          |  |  | const double | y = 0, |  
          |  |  | const double | z = 0, |  
          |  |  | const double | c = 0 |  
          |  | ) |  | const |  
Evaluate math formula.  Parameters
  
    | expression | Math formula, as a C-string. |  | x | Value of the pre-defined variable x. |  | y | Value of the pre-defined variable y. |  | z | Value of the pre-defined variable z. |  | c | Value of the pre-defined variable c. | 
 
      
        
          | CImg<doubleT> eval | ( | const char *const | expression, |  
          |  |  | const CImg< t > & | xyzc |  
          |  | ) |  | const |  
Evaluate math formula on a set of variables.  Parameters
  
    | expression | Math formula, as a C-string. |  | xyzc | Set of values (x,y,z,c) used for the evaluation. | 
 
      
        
          | Tdouble magnitude | ( | const int | magnitude_type = 2 | ) | const |  
Compute norm of the image, viewed as a matrix.  Parameters
  
    | magnitude_type | Norm type. Can be: 
-1: Linf-norm0: L2-norm1: L1-norm | 
 
      
        
          | Tdouble dot | ( | const CImg< t > & | img | ) | const |  
Compute the dot product between instance and argument, viewed as matrices.  Parameters
  
    | img | Image used as a second argument of the dot product. | 
 
      
        
          | CImg<T> get_vector_at | ( | const unsigned int | x, |  
          |  |  | const unsigned int | y = 0, |  
          |  |  | const unsigned int | z = 0 |  
          |  | ) |  | const |  
Get vector-valued pixel located at specified position.  Parameters
  
    | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. | 
 
      
        
          | CImg<T> get_matrix_at | ( | const unsigned int | x = 0, |  
          |  |  | const unsigned int | y = 0, |  
          |  |  | const unsigned int | z = 0 |  
          |  | ) |  | const |  
Get (square) matrix-valued pixel located at specified position.  Parameters
  
    | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. | 
 Note- The spectrum() of the image must be a square. 
 
      
        
          | CImg<T> get_tensor_at | ( | const unsigned int | x, |  
          |  |  | const unsigned int | y = 0, |  
          |  |  | const unsigned int | z = 0 |  
          |  | ) |  | const |  
Get tensor-valued pixel located at specified position.  Parameters
  
    | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. | 
 
      
        
          | CImg<T>& set_vector_at | ( | const CImg< t > & | vec, |  
          |  |  | const unsigned int | x, |  
          |  |  | const unsigned int | y = 0, |  
          |  |  | const unsigned int | z = 0 |  
          |  | ) |  |  |  
Set vector-valued pixel at specified position.  Parameters
  
    | vec | Vector to put on the instance image. |  | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. | 
 
      
        
          | CImg<T>& set_matrix_at | ( | const CImg< t > & | mat, |  
          |  |  | const unsigned int | x = 0, |  
          |  |  | const unsigned int | y = 0, |  
          |  |  | const unsigned int | z = 0 |  
          |  | ) |  |  |  
Set (square) matrix-valued pixel at specified position.  Parameters
  
    | mat | Matrix to put on the instance image. |  | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. | 
 
      
        
          | CImg<T>& set_tensor_at | ( | const CImg< t > & | ten, |  
          |  |  | const unsigned int | x = 0, |  
          |  |  | const unsigned int | y = 0, |  
          |  |  | const unsigned int | z = 0 |  
          |  | ) |  |  |  
Set tensor-valued pixel at specified position.  Parameters
  
    | ten | Tensor to put on the instance image. |  | x | X-coordinate of the pixel value. |  | y | Y-coordinate of the pixel value. |  | z | Z-coordinate of the pixel value. | 
 
Unroll pixel values along axis y. NoteEquivalent to . 
 
Resize image to become a diagonal matrix.  NoteTransform the image as a diagonal matrix so that each of its initial value becomes a diagonal coefficient. 
 
      
        
          | CImg<T>& identity_matrix | ( |  | ) |  |  
Replace the image by an identity matrix.  NoteIf the instance image is not square, it is resized to a square matrix using its maximum dimension as a reference. 
 
      
        
          | CImg<T>& sequence | ( | const T | a0, |  
          |  |  | const T | a1 |  
          |  | ) |  |  |  
Fill image with a linear sequence of values.  Parameters
  
    | a0 | Starting value of the sequence. |  | a1 | Ending value of the sequence. | 
 
Transpose the image, viewed as a matrix.  NoteEquivalent to  
 
Compute the cross product between two 1x3images, viewed as 3d vectors. Parameters
  
    | img | Image used as the second argument of the cross product. | 
 NoteThe first argument of the cross product is *this.
 
      
        
          | CImg<T>& invert | ( | const bool | use_LU = true | ) |  |  
Invert the instance image, viewed as a matrix.  Parameters
  
    | use_LU | Choose the inverting algorithm. Can be: 
true:LU-based matrix inversion.false:SVD-based matrix inversion. | 
 
Solve a system of linear equations.  Parameters
  
    | A | Matrix of the linear system. | 
 NoteSolve AX=BwhereB=*this.
 
      
        
          | CImg<T>& solve_tridiagonal | ( | const CImg< t > & | A | ) |  |  
Solve a tridiagonal system of linear equations.  Parameters
  
    | A | Coefficients of the tridiagonal system. A is a tridiagonal matrix A = [ b0,c0,0,...; a1,b1,c1,0,... ; ... ; ...,0,aN,bN ], stored as a 3 columns matrix | 
 NoteSolve AX=B where B=*this, using the Thomas algorithm.
 
      
        
          | const CImg<T>& eigen | ( | CImg< t > & | val, |  
          |  |  | CImg< t > & | vec |  
          |  | ) |  | const |  
Compute eigenvalues and eigenvectors of the instance image, viewed as a matrix.  Parameters
  
    | [out] | val | Vector of the estimated eigenvalues, in decreasing order. |  | [out] | vec | Matrix of the estimated eigenvalues, sorted by columns. | 
 
Compute eigenvalues and eigenvectors of the instance image, viewed as a matrix.  ReturnsA list of two images [val; vec], whose meaning is similar as in eigen(CImg<t>&,CImg<t>&) const.
 
      
        
          | const CImg<T>& symmetric_eigen | ( | CImg< t > & | val, |  
          |  |  | CImg< t > & | vec |  
          |  | ) |  | const |  
Compute eigenvalues and eigenvectors of the instance image, viewed as a symmetric matrix.  Parameters
  
    | [out] | val | Vector of the estimated eigenvalues, in decreasing order. |  | [out] | vec | Matrix of the estimated eigenvalues, sorted by columns. | 
 
      
        
          | CImgList<Tfloat> get_symmetric_eigen | ( |  | ) | const |  
Compute eigenvalues and eigenvectors of the instance image, viewed as a symmetric matrix.  ReturnsA list of two images [val; vec], whose meaning are similar as in symmetric_eigen(CImg<t>&,CImg<t>&) const.
 
      
        
          | CImg<T>& sort | ( | CImg< t > & | permutations, |  
          |  |  | const bool | is_increasing = true |  
          |  | ) |  |  |  
Sort pixel values and get sorting permutations.  Parameters
  
    | [out] | permutations | Permutation map used for the sorting. |  |  | is_increasing | Tells if pixel values are sorted in an increasing ( true) or decreasing (false) way. | 
 
      
        
          | CImg<T>& sort | ( | const bool | is_increasing = true, |  
          |  |  | const char | axis = 0 |  
          |  | ) |  |  |  
Sort pixel values.  Parameters
  
    | is_increasing | Tells if pixel values are sorted in an increasing ( true) or decreasing (false) way. |  | axis | Tells if the value sorting must be done along a specific axis. Can be: 
0: All pixel values are sorted, independently on their initial position.'x': Image columns are sorted, according to the first value in each column.'y': Image rows are sorted, according to the first value in each row.'z': Image slices are sorted, according to the first value in each slice.'c': Image channels are sorted, according to the first value in each channel. | 
 
      
        
          | const CImg<T>& SVD | ( | CImg< t > & | U, |  
          |  |  | CImg< t > & | S, |  
          |  |  | CImg< t > & | V, |  
          |  |  | const bool | sorting = true, |  
          |  |  | const unsigned int | max_iteration = 40, |  
          |  |  | const float | lambda = 0 |  
          |  | ) |  | const |  
Compute the SVD of the instance image, viewed as a general matrix.  Compute the SVD decomposition *this=U*S*V'whereUandVare orthogonal matrices andSis a diagonal matrix.V'denotes the matrix transpose ofV. Parameters
  
    | [out] | U | First matrix of the SVD product. |  | [out] | S | Coefficients of the second (diagonal) matrix of the SVD product. These coefficients are stored as a vector. |  | [out] | V | Third matrix of the SVD product. |  |  | sorting | Tells if the diagonal coefficients are sorted (in decreasing order). |  |  | max_iteration | Maximum number of iterations considered for the algorithm convergence. |  |  | lambda | Epsilon used for the algorithm convergence. | 
 NoteThe instance matrix can be computed from U,SandVbyconst CImg<> A;   CImg<> U,S,V; A.SVD(U,S,V)
 
      
        
          | CImgList<Tfloat> get_SVD | ( | const bool | sorting = true, |  
          |  |  | const unsigned int | max_iteration = 40, |  
          |  |  | const float | lambda = 0 |  
          |  | ) |  | const |  
  
  | 
        
          | static CImg<T> dijkstra | ( | const tf & | distance, |  
          |  |  | const unsigned int | nb_nodes, |  
          |  |  | const unsigned int | starting_node, |  
          |  |  | const unsigned int | ending_node, |  
          |  |  | CImg< t > & | previous_node |  
          |  | ) |  |  |  | static |  
Compute minimal path in a graph, using the Dijkstra algorithm.  Parameters
  
    | distance | An object having operator()(unsigned int i, unsigned int j) which returns distance between two nodes (i,j). |  | nb_nodes | Number of graph nodes. |  | starting_node | Indice of the starting node. |  | ending_node | Indice of the ending node (set to ~0U to ignore ending node). |  | previous_node | Array that gives the previous node indice in the path to the starting node (optional parameter). | 
 ReturnsArray of distances of each node to the starting node. 
 
      
        
          | CImg<T>& dijkstra | ( | const unsigned int | starting_node, |  
          |  |  | const unsigned int | ending_node, |  
          |  |  | CImg< t > & | previous_node |  
          |  | ) |  |  |  
Return minimal path in a graph, using the Dijkstra algorithm.  Parameters
  
    | starting_node | Indice of the starting node. |  | ending_node | Indice of the ending node. |  | previous_node | Array that gives the previous node indice in the path to the starting node (optional parameter). | 
 ReturnsArray of distances of each node to the starting node. 
 Noteimage instance corresponds to the adjacency matrix of the graph. 
 
  
  | 
        
          | static CImg<T> string | ( | const char *const | str, |  
          |  |  | const bool | is_last_zero = true |  
          |  | ) |  |  |  | static |  
Return an image containing the ascii codes of the specified string.  Parameters
  
    | str | input C-string to encode as an image. |  | is_last_zero | Tells if the ending '0'character appear in the resulting image. | 
 
  
  | 
        
          | static CImg<T> vector | ( | const T & | a0 | ) |  |  | static |  
Return a 1x1image containing specified value. Parameters
  
  
 
  
  | 
        
          | static CImg<T> vector | ( | const T & | a0, |  
          |  |  | const T & | a1 |  
          |  | ) |  |  |  | static |  
Return a 1x2image containing specified values. Parameters
  
    | a0 | First vector value. |  | a1 | Second vector value. | 
 
  
  | 
        
          | static CImg<T> vector | ( | const T & | a0, |  
          |  |  | const T & | a1, |  
          |  |  | const T & | a2 |  
          |  | ) |  |  |  | static |  
Return a 1x3image containing specified values. Parameters
  
    | a0 | First vector value. |  | a1 | Second vector value. |  | a2 | Third vector value. | 
 
  
  | 
        
          | static CImg<T> vector | ( | const T & | a0, |  
          |  |  | const T & | a1, |  
          |  |  | const T & | a2, |  
          |  |  | const T & | a3 |  
          |  | ) |  |  |  | static |  
Return a 1x4image containing specified values. Parameters
  
    | a0 | First vector value. |  | a1 | Second vector value. |  | a2 | Third vector value. |  | a3 | Fourth vector value. | 
 
  
  | 
        
          | static CImg<T> matrix | ( | const T & | a0 | ) |  |  | static |  
Return a 1x1 matrix containing specified coefficients.  Parameters
  
  
 NoteEquivalent to vector(const T&). 
 
  
  | 
        
          | static CImg<T> matrix | ( | const T & | a0, |  
          |  |  | const T & | a1, |  
          |  |  | const T & | a2, |  
          |  |  | const T & | a3 |  
          |  | ) |  |  |  | static |  
Return a 2x2 matrix containing specified coefficients.  Parameters
  
    | a0 | First matrix value. |  | a1 | Second matrix value. |  | a2 | Third matrix value. |  | a3 | Fourth matrix value. | 
 
  
  | 
        
          | static CImg<T> matrix | ( | const T & | a0, |  
          |  |  | const T & | a1, |  
          |  |  | const T & | a2, |  
          |  |  | const T & | a3, |  
          |  |  | const T & | a4, |  
          |  |  | const T & | a5, |  
          |  |  | const T & | a6, |  
          |  |  | const T & | a7, |  
          |  |  | const T & | a8 |  
          |  | ) |  |  |  | static |  
Return a 3x3 matrix containing specified coefficients.  Parameters
  
    | a0 | First matrix value. |  | a1 | Second matrix value. |  | a2 | Third matrix value. |  | a3 | Fourth matrix value. |  | a4 | Fifth matrix value. |  | a5 | Sixth matrix value. |  | a6 | Seventh matrix value. |  | a7 | Eighth matrix value. |  | a8 | Nineth matrix value. | 
 
  
  | 
        
          | static CImg<T> tensor | ( | const T & | a0 | ) |  |  | static |  
Return a 1x1 symmetric matrix containing specified coefficients.  Parameters
  
  
 NoteEquivalent to vector(const T&). 
 
  
  | 
        
          | static CImg<T> identity_matrix | ( | const unsigned int | N | ) |  |  | static |  
Return a NxN identity matrix.  Parameters
  
    | N | Dimension of the matrix. | 
 
  
  | 
        
          | static CImg<T> sequence | ( | const unsigned int | N, |  
          |  |  | const T | a0, |  
          |  |  | const T | a1 |  
          |  | ) |  |  |  | static |  
Return a N-numbered sequence vector from a0toa1. Parameters
  
    | N | Size of the resulting vector. |  | a0 | Starting value of the sequence. |  | a1 | Ending value of the sequence. | 
 
  
  | 
        
          | static CImg<T> rotation_matrix | ( | const float | x, |  
          |  |  | const float | y, |  
          |  |  | const float | z, |  
          |  |  | const float | w, |  
          |  |  | const bool | is_quaternion = false |  
          |  | ) |  |  |  | static |  
Return a 3x3 rotation matrix along the (x,y,z)-axis with an angle w.  Parameters
  
    | x | X-coordinate of the rotation axis, or first quaternion coordinate. |  | y | Y-coordinate of the rotation axis, or second quaternion coordinate. |  | z | Z-coordinate of the rotation axis, or third quaternion coordinate. |  | w | Angle of the rotation axis, or fourth quaternion coordinate. |  | is_quaternion | Tell is the four arguments denotes a set { axis + angle } or a quaternion. | 
 
      
        
          | CImg<T>& fill | ( | const T | val | ) |  |  
Fill all pixel values with specified value.  Parameters
  
  
 
      
        
          | CImg<T>& fill | ( | const T | val0, |  
          |  |  | const T | val1 |  
          |  | ) |  |  |  
Fill sequentially all pixel values with specified values.  Parameters
  
    | val0 | First fill value. |  | val1 | Second fill value. | 
 
      
        
          | CImg<T>& fill | ( | const char *const | expression, |  
          |  |  | const bool | repeat_flag |  
          |  | ) |  |  |  
Fill sequentially pixel values according to a given expression.  Parameters
  
    | expression | C-string describing a math formula, or a list of values. |  | repeat_flag | In case a list of values is provided, tells if this list must be repeated for the filling. | 
 
      
        
          | CImg<T>& fill | ( | const CImg< t > & | values, |  
          |  |  | const bool | repeat_values = true |  
          |  | ) |  |  |  
Fill sequentially pixel values according to the values found in another image.  Parameters
  
    | values | Image containing the values used for the filling. |  | repeat_values | In case there are less values than necessary in values, tells if these values must be repeated for the filling. | 
 
      
        
          | CImg<T>& fillX | ( | const unsigned int | y, |  
          |  |  | const unsigned int | z, |  
          |  |  | const unsigned int | c, |  
          |  |  | const int | a0, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Fill pixel values along the X-axis at a specified pixel position.  Parameters
  
    | y | Y-coordinate of the filled column. |  | z | Z-coordinate of the filled column. |  | c | C-coordinate of the filled column. |  | a0 | First fill value. | 
 
      
        
          | CImg<T>& fillY | ( | const unsigned int | x, |  
          |  |  | const unsigned int | z, |  
          |  |  | const unsigned int | c, |  
          |  |  | const int | a0, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Fill pixel values along the Y-axis at a specified pixel position.  Parameters
  
    | x | X-coordinate of the filled row. |  | z | Z-coordinate of the filled row. |  | c | C-coordinate of the filled row. |  | a0 | First fill value. | 
 
      
        
          | CImg<T>& fillZ | ( | const unsigned int | x, |  
          |  |  | const unsigned int | y, |  
          |  |  | const unsigned int | c, |  
          |  |  | const int | a0, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Fill pixel values along the Z-axis at a specified pixel position.  Parameters
  
    | x | X-coordinate of the filled slice. |  | y | Y-coordinate of the filled slice. |  | c | C-coordinate of the filled slice. |  | a0 | First fill value. | 
 
      
        
          | CImg<T>& fillC | ( | const unsigned int | x, |  
          |  |  | const unsigned int | y, |  
          |  |  | const unsigned int | z, |  
          |  |  | const int | a0, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Fill pixel values along the C-axis at a specified pixel position.  Parameters
  
    | x | X-coordinate of the filled channel. |  | y | Y-coordinate of the filled channel. |  | z | Z-coordinate of the filled channel. |  | a0 | First filling value. | 
 
      
        
          | CImg<T>& discard | ( | const T | value | ) |  |  
Discard specified value in the image buffer.  Parameters
  
  
 NoteDiscarded values will change the image geometry, so the resulting image is returned as a one-column vector. 
 
      
        
          | CImg<T>& discard | ( | const CImg< t > & | values | ) |  |  
Discard specified sequence of values in the image buffer.  Parameters
  
    | values | Sequence of values to discard. | 
 NoteDiscarded values will change the image geometry, so the resulting image is returned as a one-column vector. 
 
      
        
          | CImg<T>& rand | ( | const T | val_min, |  
          |  |  | const T | val_max |  
          |  | ) |  |  |  
Fill image with random values in specified range.  Parameters
  
    | val_min | Minimal random value. |  | val_max | Maximal random value. | 
 NoteRandom samples are following a uniform distribution. 
 
      
        
          | CImg<T>& round | ( | const double | y = 1, |  
          |  |  | const int | rounding_type = 0 |  
          |  | ) |  |  |  
Round pixel values.  Parameters
  
    | y | Rounding precision. |  | rounding_type | Rounding type. Can be: 
-1: Backward.0: Nearest.1: Forward. | 
 
      
        
          | CImg<T>& noise | ( | const double | sigma, |  
          |  |  | const unsigned int | noise_type = 0 |  
          |  | ) |  |  |  
Add random noise to pixel values.  Parameters
  
    | sigma | Amplitude of the random additive noise. If sigma<0, it stands for a percentage of the global value range. |  | noise_type | Type of additive noise (can be 0=gaussian,1=uniform,2=Saltand Pepper,3=Poissonor4=Rician). | 
 ReturnsA reference to the modified image instance. 
 Note
For Poisson noise (noise_type=3), parametersigmais ignored, as Poisson noise only depends on the image value itself.Function CImg<T>::get_noise()is also defined. It returns a non-shared modified copy of the image instance.
 Exampleconst CImg<float> img("reference.jpg"), res = img.get_noise(40); (img,res.normalize(0,255)).display ();
 
      
        
          | CImg<T>& normalize | ( | const T | min_value, |  
          |  |  | const T | max_value |  
          |  | ) |  |  |  
Linearly normalize pixel values.  Parameters
  
    | min_value | Minimum desired value of the resulting image. |  | max_value | Maximum desired value of the resulting image. | 
 Exampleconst CImg<float> img("reference.jpg"), res = img.get_normalize(160,220);
 
Normalize multi-valued pixels of the image instance, with respect to their L2-norm.  Exampleconst CImg<float> img("reference.jpg"), res = img.get_normalize(); (img,res.normalize(0,255)).display ();
 
      
        
          | CImg<T>& norm | ( | const int | norm_type = 2 | ) |  |  
Compute L2-norm of each multi-valued pixel of the image instance.  Parameters
  
    | norm_type | Type of computed vector norm (can be 0=Linf,1=L1or2=L2). | 
 Exampleconst CImg<float> img("reference.jpg"), res = img.get_norm(); (img,res.normalize(0,255)).display ();
 
      
        
          | CImg<T>& cut | ( | const T | min_value, |  
          |  |  | const T | max_value |  
          |  | ) |  |  |  
Cut pixel values in specified range.  Parameters
  
    | min_value | Minimum desired value of the resulting image. |  | max_value | Maximum desired value of the resulting image. | 
 Exampleconst CImg<float> img("reference.jpg"), res = img.get_cut(160,220);
 
      
        
          | CImg<T>& quantize | ( | const unsigned int | nb_levels, |  
          |  |  | const bool | keep_range = true |  
          |  | ) |  |  |  
Uniformly quantize pixel values.  Parameters
  
    | nb_levels | Number of quantization levels. |  | keep_range | Tells if resulting values keep the same range as the original ones. | 
 Exampleconst CImg<float> img("reference.jpg"), res = img.get_quantize(4);
 
      
        
          | CImg<T>& threshold | ( | const T | value, |  
          |  |  | const bool | soft_threshold = false, |  
          |  |  | const bool | strict_threshold = false |  
          |  | ) |  |  |  
Threshold pixel values.  Parameters
  
    | value | Threshold value |  | soft_threshold | Tells if soft thresholding must be applied (instead of hard one). |  | strict_threshold | Tells if threshold value is strict. | 
 Exampleconst CImg<float> img("reference.jpg"), res = img.get_threshold(128); (img,res.normalize(0,255)).display ();
 
      
        
          | CImg<T>& histogram | ( | const unsigned int | nb_levels, |  
          |  |  | const T | min_value = (T)0, |  
          |  |  | const T | max_value = (T)0 |  
          |  | ) |  |  |  
Compute the histogram of pixel values.  Parameters
  
    | nb_levels | Number of desired histogram levels. |  | min_value | Minimum pixel value considered for the histogram computation. All pixel values lower than min_valuewill not be counted. |  | max_value | Maximum pixel value considered for the histogram computation. All pixel values higher than max_valuewill not be counted. | 
 Note
The histogram H of an image I is the 1d function where H(x) counts the number of occurences of the value x in the image I.If min_value==max_value==0(default behavior), the function first estimates the whole range of pixel values then uses it to compute the histogram.The resulting histogram is always defined in 1d. Histograms of multi-valued images are not multi-dimensional. 
 Exampleconst CImg<float> img = CImg<float>("reference.jpg" ).histogram (256); img.display_graph(0,3);
 
      
        
          | CImg<T>& equalize | ( | const unsigned int | nb_levels, |  
          |  |  | const T | min_value = (T)0, |  
          |  |  | const T | max_value = (T)0 |  
          |  | ) |  |  |  
Equalize histogram of pixel values.  Parameters
  
    | nb_levels | Number of histogram levels used for the equalization. |  | min_value | Minimum pixel value considered for the histogram computation. All pixel values lower than min_valuewill not be counted. |  | max_value | Maximum pixel value considered for the histogram computation. All pixel values higher than max_valuewill not be counted. | 
 Note
If min_value==max_value==0(default behavior), the function first estimates the whole range of pixel values then uses it to equalize the histogram.
 Exampleconst CImg<float> img("reference.jpg"), res = img.get_equalize(256);
 
      
        
          | CImg<T>& index | ( | const CImg< t > & | colormap, |  
          |  |  | const float | dithering = 1, |  
          |  |  | const bool | map_indexes = false |  
          |  | ) |  |  |  
Index multi-valued pixels regarding to a specified colormap.  Parameters
  
    | colormap | Multi-valued colormap used as the basis for multi-valued pixel indexing. |  | dithering | Level of dithering (0=disable, 1=standard level). |  | map_indexes | Tell if the values of the resulting image are the colormap indices or the colormap vectors. | 
 Note
img.index(colormap,dithering,1)is equivalent toimg.index(colormap,dithering,0).map(colormap).
 Exampleconst CImg<float> img("reference.jpg"), colormap(3,1,1,3, 0,128,255, 0,128,255, 0,128,255); const CImg<float> res = img.get_index(colormap,1,true);
 
      
        
          | CImg<T>& map | ( | const CImg< t > & | colormap | ) |  |  
Map predefined colormap on the scalar (indexed) image instance.  Parameters
  
    | colormap | Multi-valued colormap used for mapping the indexes. | 
 Exampleconst CImg<float> img("reference.jpg"),                   colormap1(3,1,1,3, 0,128,255, 0,128,255, 0,128,255),                   colormap2(3,1,1,3, 255,0,0, 0,255,0, 0,0,255),                   res = img.get_index(colormap1,0).map(colormap2);
 
      
        
          | CImg<T>& label | ( | const bool | is_high_connectivity = false, |  
          |  |  | const Tfloat | tolerance = 0 |  
          |  | ) |  |  |  
Label connected components.  Parameters
  
    | is_high_connectivity | Boolean that choose between 4(false)- or 8(true)-connectivity in 2d case, and between 6(false)- or 26(true)-connectivity in 3d case. |  | tolerance | Tolerance used to determine if two neighboring pixels belong to the same region. | 
 NoteThe algorithm of connected components computation has been primarily done by A. Meijster, according to the publication: 'W.H. Hesselink, A. Meijster, C. Bron, "Concurrent Determination of Connected Components.", In: Science of Computer Programming 41 (2001), pp. 173–194'. The submitted code has then been modified to fit CImg coding style and constraints. 
 
      
        
          | CImg<T>& label | ( | const CImg< t > & | connectivity_mask, |  
          |  |  | const Tfloat | tolerance = 0 |  
          |  | ) |  |  |  
Label connected components [overloading].  Parameters
  
    | connectivity_mask | Mask of the neighboring pixels. |  | tolerance | Tolerance used to determine if two neighboring pixels belong to the same region. | 
 
  
  | 
        
          | static const CImg<Tuchar>& default_LUT256 | ( |  | ) |  |  | static |  
Return colormap "default", containing 256 colors entries in RGB.  ReturnsThe following 256x1x1x3colormap is returned:
 
  
  | 
        
          | static const CImg<Tuchar>& HSV_LUT256 | ( |  | ) |  |  | static |  
Return colormap "HSV", containing 256 colors entries in RGB.  ReturnsThe following 256x1x1x3colormap is returned:
 
  
  | 
        
          | static const CImg<Tuchar>& lines_LUT256 | ( |  | ) |  |  | static |  
Return colormap "lines", containing 256 colors entries in RGB.  ReturnsThe following 256x1x1x3colormap is returned:
 
  
  | 
        
          | static const CImg<Tuchar>& hot_LUT256 | ( |  | ) |  |  | static |  
Return colormap "hot", containing 256 colors entries in RGB.  ReturnsThe following 256x1x1x3colormap is returned:
 
  
  | 
        
          | static const CImg<Tuchar>& cool_LUT256 | ( |  | ) |  |  | static |  
Return colormap "cool", containing 256 colors entries in RGB.  ReturnsThe following 256x1x1x3colormap is returned:
 
  
  | 
        
          | static const CImg<Tuchar>& jet_LUT256 | ( |  | ) |  |  | static |  
Return colormap "jet", containing 256 colors entries in RGB.  ReturnsThe following 256x1x1x3colormap is returned:
 
  
  | 
        
          | static const CImg<Tuchar>& flag_LUT256 | ( |  | ) |  |  | static |  
Return colormap "flag", containing 256 colors entries in RGB.  ReturnsThe following 256x1x1x3colormap is returned:
 
  
  | 
        
          | static const CImg<Tuchar>& cube_LUT256 | ( |  | ) |  |  | static |  
Return colormap "cube", containing 256 colors entries in RGB.  ReturnsThe following 256x1x1x3colormap is returned:
 
Convert pixel values from RGB to XYZ_709 color spaces.  NoteUses the standard D65 white point. 
 
Convert RGB color image to a Bayer-coded scalar image.  NoteFirst (upper-left) pixel if the red component of the pixel color. 
 
      
        
          | CImg<T>& resize | ( | const int | size_x, |  
          |  |  | const int | size_y = -100, |  
          |  |  | const int | size_z = -100, |  
          |  |  | const int | size_c = -100, |  
          |  |  | const int | interpolation_type = 1, |  
          |  |  | const unsigned int | boundary_conditions = 0, |  
          |  |  | const float | centering_x = 0, |  
          |  |  | const float | centering_y = 0, |  
          |  |  | const float | centering_z = 0, |  
          |  |  | const float | centering_c = 0 |  
          |  | ) |  |  |  
Resize image to new dimensions.  Parameters
  
    | size_x | Number of columns (new size along the X-axis). |  | size_y | Number of rows (new size along the Y-axis). |  | size_z | Number of slices (new size along the Z-axis). |  | size_c | Number of vector-channels (new size along the C-axis). |  | interpolation_type | Method of interpolation: 
-1 = no interpolation: raw memory resizing.0 = no interpolation: additional space is filled according to boundary_conditions.1 = nearest-neighbor interpolation.2 = moving average interpolation.3 = linear interpolation.4 = grid interpolation.5 = cubic interpolation.6 = lanczos interpolation.  |  | boundary_conditions | Border condition type. |  | centering_x | Set centering type (only if interpolation_type=0). |  | centering_y | Set centering type (only if interpolation_type=0). |  | centering_z | Set centering type (only if interpolation_type=0). |  | centering_c | Set centering type (only if interpolation_type=0). | 
 NoteIf pd[x,y,z,v]<0, it corresponds to a percentage of the original size (the default value is -100). 
 
      
        
          | CImg<T>& resize | ( | const CImg< t > & | src, |  
          |  |  | const int | interpolation_type = 1, |  
          |  |  | const unsigned int | boundary_conditions = 0, |  
          |  |  | const float | centering_x = 0, |  
          |  |  | const float | centering_y = 0, |  
          |  |  | const float | centering_z = 0, |  
          |  |  | const float | centering_c = 0 |  
          |  | ) |  |  |  
Resize image to dimensions of another image.  Parameters
  
    | src | Reference image used for dimensions. |  | interpolation_type | Interpolation method. |  | boundary_conditions | Boundary conditions. |  | centering_x | Set centering type (only if interpolation_type=0). |  | centering_y | Set centering type (only if interpolation_type=0). |  | centering_z | Set centering type (only if interpolation_type=0). |  | centering_c | Set centering type (only if interpolation_type=0). | 
 
      
        
          | CImg<T>& resize | ( | const CImgDisplay & | disp, |  
          |  |  | const int | interpolation_type = 1, |  
          |  |  | const unsigned int | boundary_conditions = 0, |  
          |  |  | const float | centering_x = 0, |  
          |  |  | const float | centering_y = 0, |  
          |  |  | const float | centering_z = 0, |  
          |  |  | const float | centering_c = 0 |  
          |  | ) |  |  |  
Resize image to dimensions of a display window.  Parameters
  
    | disp | Reference display window used for dimensions. |  | interpolation_type | Interpolation method. |  | boundary_conditions | Boundary conditions. |  | centering_x | Set centering type (only if interpolation_type=0). |  | centering_y | Set centering type (only if interpolation_type=0). |  | centering_z | Set centering type (only if interpolation_type=0). |  | centering_c | Set centering type (only if interpolation_type=0). | 
 
      
        
          | CImg<T>& resize_doubleXY | ( |  | ) |  |  
Resize image to double-size, using the Scale2X algorithm.  NoteUse anisotropic upscaling algorithm described here. 
 
      
        
          | CImg<T>& resize_tripleXY | ( |  | ) |  |  
Resize image to triple-size, using the Scale3X algorithm.  NoteUse anisotropic upscaling algorithm described here. 
 
      
        
          | CImg<T>& mirror | ( | const char | axis | ) |  |  
Mirror image content along specified axis.  Parameters
  
  
 
      
        
          | CImg<T>& mirror | ( | const char *const | axes | ) |  |  
Mirror image content along specified axes.  Parameters
  
    | axes | Mirror axes, as a C-string. | 
 Noteaxesmay contains multiple character, e.g."xyz"
 
      
        
          | CImg<T>& shift | ( | const int | delta_x, |  
          |  |  | const int | delta_y = 0, |  
          |  |  | const int | delta_z = 0, |  
          |  |  | const int | delta_c = 0, |  
          |  |  | const int | boundary_conditions = 0 |  
          |  | ) |  |  |  
Shift image content.  Parameters
  
    | delta_x | Amount of displacement along the X-axis. |  | delta_y | Amount of displacement along the Y-axis. |  | delta_z | Amount of displacement along the Z-axis. |  | delta_c | Amount of displacement along the C-axis. |  | boundary_conditions | Border condition. | 
 
boundary_conditionscan be:
0: Zero border condition (Dirichlet).1: Nearest neighbors (Neumann).2: Repeat Pattern (Fourier style).  
      
        
          | CImg<T>& permute_axes | ( | const char *const | order | ) |  |  
Permute axes order.  Parameters
  
    | order | Axes permutations, as a C-string of 4 characters. This function permutes image content regarding the specified axes permutation. | 
 
      
        
          | CImg<T>& unroll | ( | const char | axis | ) |  |  
Unroll pixel values along specified axis.  Parameters
  
    | axis | Unroll axis (can be 'x','y','z'or c 'c'). | 
 
      
        
          | CImg<T>& rotate | ( | const float | angle, |  
          |  |  | const unsigned int | interpolation = 1, |  
          |  |  | const unsigned int | boundary = 0 |  
          |  | ) |  |  |  
Rotate image with arbitrary angle.  Parameters
  
    | angle | Rotation angle, in degrees. |  | interpolation | Type of interpolation. Can be { 0=nearest | 1=linear | 2=cubic }. |  | boundary | Boundary conditions. Can be { 0=dirichlet | 1=neumann | 2=cyclic }. | 
 NoteMost of the time, size of the image is modified. 
 
      
        
          | CImg<T>& rotate | ( | const float | angle, |  
          |  |  | const float | cx, |  
          |  |  | const float | cy, |  
          |  |  | const float | zoom, |  
          |  |  | const unsigned int | interpolation = 1, |  
          |  |  | const unsigned int | boundary = 3 |  
          |  | ) |  |  |  
Rotate image with arbitrary angle, around a center point.  Parameters
  
    | angle | Rotation angle, in degrees. |  | cx | X-coordinate of the rotation center. |  | cy | Y-coordinate of the rotation center. |  | zoom | Zoom factor. |  | boundary_conditions | Boundary conditions. Can be { 0=dirichlet | 1=neumann | 2=cyclic }. |  | interpolation_type | Type of interpolation. Can be { 0=nearest | 1=linear | 2=cubic }. | 
 
      
        
          | CImg<T>& warp | ( | const CImg< t > & | warp, |  
          |  |  | const bool | is_relative = false, |  
          |  |  | const unsigned int | interpolation = 1, |  
          |  |  | const unsigned int | boundary_conditions = 0 |  
          |  | ) |  |  |  
Warp image content by a warping field.  Parameters
  
    | warp | Warping field. |  | is_relative | Tells if warping field gives absolute or relative warping coordinates. |  | interpolation | Can be { 0=nearest | 1=linear | 2=cubic }. |  | boundary_conditions | Boundary conditions. Can be { 0=dirichlet | 1=neumann | 2=cyclic }. | 
 
      
        
          | CImg<T> get_projections2d | ( | const unsigned int | x0, |  
          |  |  | const unsigned int | y0, |  
          |  |  | const unsigned int | z0 |  
          |  | ) |  | const |  
Generate a 2d representation of a 3d image, with XY,XZ and YZ views.  Parameters
  
    | x0 | X-coordinate of the projection point. |  | y0 | Y-coordinate of the projection point. |  | z0 | Z-coordinate of the projection point. | 
 
      
        
          | CImg<T>& crop | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | z0, |  
          |  |  | const int | c0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | z1, |  
          |  |  | const int | c1, |  
          |  |  | const bool | boundary_conditions = false |  
          |  | ) |  |  |  
Crop image region.  Parameters
  
    | x0 | = X-coordinate of the upper-left crop rectangle corner. |  | y0 | = Y-coordinate of the upper-left crop rectangle corner. |  | z0 | = Z-coordinate of the upper-left crop rectangle corner. |  | c0 | = C-coordinate of the upper-left crop rectangle corner. |  | x1 | = X-coordinate of the lower-right crop rectangle corner. |  | y1 | = Y-coordinate of the lower-right crop rectangle corner. |  | z1 | = Z-coordinate of the lower-right crop rectangle corner. |  | c1 | = C-coordinate of the lower-right crop rectangle corner. |  | boundary_conditions | = Dirichlet (false) or Neumann border conditions. | 
 
      
        
          | CImg<T>& autocrop | ( | const T *const | color = 0, |  
          |  |  | const char *const | axes = "zyx" |  
          |  | ) |  |  |  
Autocrop image region, regarding the specified background color.  Parameters
  
    | color | Color used for the crop. If 0, color is guessed. |  | axes | Axes used for the crop. | 
 
      
        
          | CImg<T> get_column | ( | const int | x0 | ) | const |  
Return specified image column.  Parameters
  
  
 
      
        
          | CImg<T>& columns | ( | const int | x0, |  
          |  |  | const int | x1 |  
          |  | ) |  |  |  
Return specified range of image columns.  Parameters
  
    | x0 | Starting image column. |  | x1 | Ending image column. | 
 
      
        
          | CImg<T>& row | ( | const int | y0 | ) |  |  
Return specified image row [in-place version].  Parameters
  
  
 
      
        
          | CImg<T> get_rows | ( | const int | y0, |  
          |  |  | const int | y1 |  
          |  | ) |  | const |  
Return specified range of image rows.  Parameters
  
    | y0 | Starting image row. |  | y1 | Ending image row. | 
 
      
        
          | CImg<T> get_slice | ( | const int | z0 | ) | const |  
Return specified image slice.  Parameters
  
  
 
      
        
          | CImg<T> get_slices | ( | const int | z0, |  
          |  |  | const int | z1 |  
          |  | ) |  | const |  
Return specified range of image slices.  Parameters
  
    | z0 | Starting image slice. |  | z1 | Ending image slice. | 
 
      
        
          | CImg<T> get_channel | ( | const int | c0 | ) | const |  
Return specified image channel.  Parameters
  
  
 
      
        
          | CImg<T> get_channels | ( | const int | c0, |  
          |  |  | const int | c1 |  
          |  | ) |  | const |  
Return specified range of image channels.  Parameters
  
    | c0 | Starting image channel. |  | c1 | Ending image channel. | 
 
  
  | 
        
          | static CImg<floatT> streamline | ( | const tfunc & | func, |  
          |  |  | const float | x, |  
          |  |  | const float | y, |  
          |  |  | const float | z, |  
          |  |  | const float | L = 256, |  
          |  |  | const float | dl = 0.1f, |  
          |  |  | const unsigned int | interpolation_type = 2, |  
          |  |  | const bool | is_backward_tracking = false, |  
          |  |  | const bool | is_oriented_only = false, |  
          |  |  | const float | x0 = 0, |  
          |  |  | const float | y0 = 0, |  
          |  |  | const float | z0 = 0, |  
          |  |  | const float | x1 = 0, |  
          |  |  | const float | y1 = 0, |  
          |  |  | const float | z1 = 0 |  
          |  | ) |  |  |  | static |  
Return stream line of a 3d vector field.  Parameters
  
    | func | Vector field function. |  | x | X-coordinate of the starting point of the streamline. |  | y | Y-coordinate of the starting point of the streamline. |  | z | Z-coordinate of the starting point of the streamline. |  | L | Streamline length. |  | dl | Streamline length increment. |  | interpolation_type | Type of interpolation. Can be { 0=nearest int | 1=linear | 2=2nd-order RK | 3=4th-order RK. }. |  | is_backward_tracking | Tells if the streamline is estimated forward or backward. |  | is_oriented_only | Tells if the direction of the vectors must be ignored. |  | x0 | X-coordinate of the first bounding-box vertex. |  | y0 | Y-coordinate of the first bounding-box vertex. |  | z0 | Z-coordinate of the first bounding-box vertex. |  | x1 | X-coordinate of the second bounding-box vertex. |  | y1 | Y-coordinate of the second bounding-box vertex. |  | z1 | Z-coordinate of the second bounding-box vertex. | 
 
      
        
          | CImg<T> get_shared_points | ( | const unsigned int | x0, |  
          |  |  | const unsigned int | x1, |  
          |  |  | const unsigned int | y0 = 0, |  
          |  |  | const unsigned int | z0 = 0, |  
          |  |  | const unsigned int | c0 = 0 |  
          |  | ) |  |  |  
Return a shared-memory image referencing a range of pixels of the image instance.  Parameters
  
    | x0 | X-coordinate of the starting pixel. |  | x1 | X-coordinate of the ending pixel. |  | y0 | Y-coordinate. |  | z0 | Z-coordinate. |  | c0 | C-coordinate. | 
 
      
        
          | CImg<T> get_shared_rows | ( | const unsigned int | y0, |  
          |  |  | const unsigned int | y1, |  
          |  |  | const unsigned int | z0 = 0, |  
          |  |  | const unsigned int | c0 = 0 |  
          |  | ) |  |  |  
Return a shared-memory image referencing a range of rows of the image instance.  Parameters
  
    | y0 | Y-coordinate of the starting row. |  | y1 | Y-coordinate of the ending row. |  | z0 | Z-coordinate. |  | c0 | C-coordinate. | 
 
      
        
          | CImg<T> get_shared_row | ( | const unsigned int | y0, |  
          |  |  | const unsigned int | z0 = 0, |  
          |  |  | const unsigned int | c0 = 0 |  
          |  | ) |  |  |  
Return a shared-memory image referencing one row of the image instance.  Parameters
  
    | y0 | Y-coordinate. |  | z0 | Z-coordinate. |  | c0 | C-coordinate. | 
 
      
        
          | CImg<T> get_shared_slices | ( | const unsigned int | z0, |  
          |  |  | const unsigned int | z1, |  
          |  |  | const unsigned int | c0 = 0 |  
          |  | ) |  |  |  
Return a shared memory image referencing a range of slices of the image instance.  Parameters
  
    | z0 | Z-coordinate of the starting slice. |  | z1 | Z-coordinate of the ending slice. |  | c0 | C-coordinate. | 
 
      
        
          | CImg<T> get_shared_slice | ( | const unsigned int | z0, |  
          |  |  | const unsigned int | c0 = 0 |  
          |  | ) |  |  |  
Return a shared-memory image referencing one slice of the image instance.  Parameters
  
    | z0 | Z-coordinate. |  | c0 | C-coordinate. | 
 
      
        
          | CImg<T> get_shared_channels | ( | const unsigned int | c0, |  
          |  |  | const unsigned int | c1 |  
          |  | ) |  |  |  
Return a shared-memory image referencing a range of channels of the image instance.  Parameters
  
    | c0 | C-coordinate of the starting channel. |  | c1 | C-coordinate of the ending channel. | 
 
      
        
          | CImg<T> get_shared_channel | ( | const unsigned int | c0 | ) |  |  
Return a shared-memory image referencing one channel of the image instance.  Parameters
  
  
 
      
        
          | CImgList<T> get_split | ( | const char | axis, |  
          |  |  | const int | nb = 0 |  
          |  | ) |  | const |  
Split image into a list along specified axis.  Parameters
  
    | axis | Splitting axis. Can be { 'x' | 'y' | 'z' | 'c' }. |  | nb | Number of splitted parts. | 
 Note
If nb==0, there are as much splitted parts as the image size along the specified axis.If nb<=0, instance image is splitted into blocs of -nbpixel wide.If nb>0, instance image is splitted intonbblocs.
 
      
        
          | CImgList<T> get_split | ( | const T | value, |  
          |  |  | const bool | keep_values, |  
          |  |  | const bool | is_shared |  
          |  | ) |  | const |  
Split image into a list of one-column vectors, according to a specified splitting value.  Parameters
  
    | value | Splitting value. |  | keep_values | Tells if the splitting value must be kept in the splitted blocs. |  | is_shared | Tells if the splitted blocs have shared memory buffers. | 
 
      
        
          | CImgList<T> get_split | ( | const CImg< t > & | values, |  
          |  |  | const bool | keep_values, |  
          |  |  | const bool | is_shared |  
          |  | ) |  | const |  
Split image into a list of one-column vectors, according to a specified splitting value sequence.  Parameters
  
    | values | Splitting value sequence. |  | keep_values | Tells if the splitting sequence must be kept in the splitted blocs. |  | is_shared | Tells if the splitted blocs have shared memory buffers. | 
 
      
        
          | CImg<T>& append | ( | const CImg< t > & | img, |  
          |  |  | const char | axis = 'x', |  
          |  |  | const float | align = 0 |  
          |  | ) |  |  |  
Append two images along specified axis.  Parameters
  
    | img | Image to append with instance image. |  | axis | Appending axis. Can be { 'x' | 'y' | 'z' | 'c' }. |  | align | Append alignment in [0,1]. | 
 
      
        
          | CImg<T>& correlate | ( | const CImg< t > & | mask, |  
          |  |  | const unsigned int | boundary_conditions = 1, |  
          |  |  | const bool | is_normalized = false |  
          |  | ) |  |  |  
Correlate image by a mask.  Parameters
  
    | mask | = the correlation kernel. |  | boundary_conditions | = the border condition type (0=zero, 1=dirichlet) |  | is_normalized | = enable local normalization. | 
 Note
The correlation of the image instance *thisby the maskmaskis defined to be: res(x,y,z) = sum_{i,j,k} (*this)(x+i,y+j,z+k)*mask(i,j,k).
 
      
        
          | CImg<T>& convolve | ( | const CImg< t > & | mask, |  
          |  |  | const unsigned int | boundary_conditions = 1, |  
          |  |  | const bool | is_normalized = false |  
          |  | ) |  |  |  
Convolve image by a mask.  Parameters
  
    | mask | = the correlation kernel. |  | boundary_conditions | = the border condition type (0=zero, 1=dirichlet) |  | is_normalized | = enable local normalization. | 
 Note
The result resof the convolution of an imageimgby a maskmaskis defined to be: res(x,y,z) = sum_{i,j,k} img(x-i,y-j,z-k)*mask(i,j,k)
 
      
        
          | CImg<T>& erode | ( | const CImg< t > & | mask, |  
          |  |  | const unsigned int | boundary_conditions = 1, |  
          |  |  | const bool | is_normalized = false |  
          |  | ) |  |  |  
Erode image by a structuring element.  Parameters
  
    | mask | Structuring element. |  | boundary_conditions | Boundary conditions. |  | is_normalized | Tells if the erosion is locally normalized. | 
 
      
        
          | CImg<T>& erode | ( | const unsigned int | sx, |  
          |  |  | const unsigned int | sy, |  
          |  |  | const unsigned int | sz = 1 |  
          |  | ) |  |  |  
Erode image by a rectangular structuring element of specified size.  Parameters
  
    | sx | Width of the structuring element. |  | sy | Height of the structuring element. |  | sz | Depth of the structuring element. | 
 
      
        
          | CImg<T>& erode | ( | const unsigned int | s | ) |  |  
Erode the image by a square structuring element of specified size.  Parameters
  
    | s | Size of the structuring element. | 
 
      
        
          | CImg<T>& dilate | ( | const CImg< t > & | mask, |  
          |  |  | const unsigned int | boundary_conditions = 1, |  
          |  |  | const bool | is_normalized = false |  
          |  | ) |  |  |  
Dilate image by a structuring element.  Parameters
  
    | mask | Structuring element. |  | boundary_conditions | Boundary conditions. |  | is_normalized | Tells if the erosion is locally normalized. | 
 
      
        
          | CImg<T>& dilate | ( | const unsigned int | sx, |  
          |  |  | const unsigned int | sy, |  
          |  |  | const unsigned int | sz = 1 |  
          |  | ) |  |  |  
Dilate image by a rectangular structuring element of specified size.  Parameters
  
    | sx | Width of the structuring element. |  | sy | Height of the structuring element. |  | sz | Depth of the structuring element. | 
 
      
        
          | CImg<T>& dilate | ( | const unsigned int | s | ) |  |  
Dilate image by a square structuring element of specified size.  Parameters
  
    | s | Size of the structuring element. | 
 
      
        
          | CImg<T>& watershed | ( | const CImg< t > & | priority, |  
          |  |  | const bool | fill_lines = true |  
          |  | ) |  |  |  
Compute watershed transform.  Parameters
  
    | priority | Priority map. |  | fill_lines | Tells if watershed lines must be filled or not. | 
 NoteNon-zero values of the instance instance are propagated to zero-valued ones according to specified the priority map. 
 
      
        
          | CImg<T>& deriche | ( | const float | sigma, |  
          |  |  | const int | order = 0, |  
          |  |  | const char | axis = 'x', |  
          |  |  | const bool | boundary_conditions = true |  
          |  | ) |  |  |  
Apply recursive Deriche filter.  Parameters
  
    | sigma | Standard deviation of the filter. |  | order | Order of the filter. Can be { 0=smooth-filter | 1=1st-derivative | 2=2nd-derivative }. |  | axis | Axis along which the filter is computed. Can be { 'x' | 'y' | 'z' | 'c' }. |  | boundary_conditions | Boundary conditions. Can be { 0=dirichlet | 1=neumann }. | 
 
      
        
          | CImg<T>& vanvliet | ( | const float | sigma, |  
          |  |  | const int | order, |  
          |  |  | const char | axis = 'x', |  
          |  |  | const bool | boundary_conditions = true |  
          |  | ) |  |  |  
Van Vliet recursive Gaussian filter.  Parameters
  
    | sigma | standard deviation of the Gaussian filter |  | order | the order of the filter 0,1,2,3 |  | axis | Axis along which the filter is computed. Can be { 'x' | 'y' | 'z' | 'c' }. |  | boundary_conditions | Boundary conditions. Can be { 0=dirichlet | 1=neumann }. | 
 Notedirichlet boundary condition has a strange behavior
 Ian T. Young, Lucas J. van Vliet, Recursive implementation of the Gaussian filter, Signal Processing, Volume 44, Issue 2, June 1995, Pages 139-151,  
      
        
          | CImg<T>& blur | ( | const float | sigma_x, |  
          |  |  | const float | sigma_y, |  
          |  |  | const float | sigma_z, |  
          |  |  | const bool | boundary_conditions = true, |  
          |  |  | const bool | is_gaussian = false |  
          |  | ) |  |  |  
Blur image.  Parameters
  
    | sigma_x | Standard deviation of the blur, along the X-axis. |  | sigma_y | Standard deviation of the blur, along the Y-axis. |  | sigma_z | Standard deviation of the blur, along the Z-axis. |  | boundary_conditions | Boundary conditions. Can be { false=dirichlet | true=neumann }. |  | is_gaussian | Tells if the blur uses a gaussian ( true) or quasi-gaussian (false) kernel. | 
 Note
The blur is computed as a 0-order Deriche filter. This is not a gaussian blur.This is a recursive algorithm, not depending on the values of the standard deviations. 
 See Alsoderiche(), vanvliet(). 
 
      
        
          | CImg<T>& blur | ( | const float | sigma, |  
          |  |  | const bool | boundary_conditions = true, |  
          |  |  | const bool | is_gaussian = false |  
          |  | ) |  |  |  
Blur image isotropically.  Parameters
  
    | sigma | Standard deviation of the blur. |  | boundary_conditions | Boundary conditions. Can be { 0=dirichlet | 1=neumann }.a | 
 See Alsoderiche(), vanvliet(). 
 
      
        
          | CImg<T>& blur_anisotropic | ( | const CImg< t > & | G, |  
          |  |  | const float | amplitude = 60, |  
          |  |  | const float | dl = 0.8f, |  
          |  |  | const float | da = 30, |  
          |  |  | const float | gauss_prec = 2, |  
          |  |  | const unsigned int | interpolation_type = 0, |  
          |  |  | const bool | is_fast_approx = 1 |  
          |  | ) |  |  |  
Blur image anisotropically, directed by a field of diffusion tensors.  Parameters
  
    | G | Field of square roots of diffusion tensors/vectors used to drive the smoothing. |  | amplitude | Amplitude of the smoothing. |  | dl | Spatial discretization. |  | da | Angular discretization. |  | gauss_prec | Precision of the diffusion process. |  | interpolation_type | Interpolation scheme. Can be { 0=nearest-neighbor | 1=linear | 2=Runge-Kutta }. |  | is_fast_approx | Tells if a fast approximation of the gaussian function is used or not. | 
 
      
        
          | CImg<T>& blur_anisotropic | ( | const float | amplitude, |  
          |  |  | const float | sharpness = 0.7f, |  
          |  |  | const float | anisotropy = 0.6f, |  
          |  |  | const float | alpha = 0.6f, |  
          |  |  | const float | sigma = 1.1f, |  
          |  |  | const float | dl = 0.8f, |  
          |  |  | const float | da = 30, |  
          |  |  | const float | gauss_prec = 2, |  
          |  |  | const unsigned int | interpolation_type = 0, |  
          |  |  | const bool | is_fast_approx = true |  
          |  | ) |  |  |  
Blur image anisotropically, in an edge-preserving way.  Parameters
  
    | amplitude | Amplitude of the smoothing. |  | sharpness | Sharpness. |  | anisotropy | Anisotropy. |  | alpha | Standard deviation of the gradient blur. |  | sigma | Standard deviation of the structure tensor blur. |  | dl | Spatial discretization. |  | da | Angular discretization. |  | gauss_prec | Precision of the diffusion process. |  | interpolation_type | Interpolation scheme. Can be { 0=nearest-neighbor | 1=linear | 2=Runge-Kutta }. |  | is_fast_approx | Tells if a fast approximation of the gaussian function is used or not. | 
 
      
        
          | CImg<T>& blur_bilateral | ( | const CImg< t > & | guide, |  
          |  |  | const float | sigma_x, |  
          |  |  | const float | sigma_y, |  
          |  |  | const float | sigma_z, |  
          |  |  | const float | sigma_r, |  
          |  |  | const int | bgrid_x, |  
          |  |  | const int | bgrid_y, |  
          |  |  | const int | bgrid_z, |  
          |  |  | const int | bgrid_r, |  
          |  |  | const bool | interpolation_type = true |  
          |  | ) |  |  |  
Blur image, with the joint bilateral filter.  Parameters
  
    | guide | Image used to model the smoothing weights. |  | sigma_x | Amount of blur along the X-axis. |  | sigma_y | Amount of blur along the Y-axis. |  | sigma_z | Amount of blur along the Z-axis. |  | sigma_r | Amount of blur along the value axis. |  | bgrid_x | Size of the bilateral grid along the X-axis. |  | bgrid_y | Size of the bilateral grid along the Y-axis. |  | bgrid_z | Size of the bilateral grid along the Z-axis. |  | bgrid_r | Size of the bilateral grid along the value axis. |  | interpolation_type | Use interpolation for image slicing. | 
 NoteThis algorithm uses the optimisation technique proposed by S. Paris and F. Durand, in ECCV'2006 (extended for 3d volumetric images). 
 
      
        
          | CImg<T>& blur_bilateral | ( | const CImg< t > & | guide, |  
          |  |  | const float | sigma_s, |  
          |  |  | const float | sigma_r, |  
          |  |  | const int | bgrid_s = -33, |  
          |  |  | const int | bgrid_r = 32, |  
          |  |  | const bool | interpolation_type = true |  
          |  | ) |  |  |  
Blur image using the joint bilateral filter.  Parameters
  
    | guide | Image used to model the smoothing weights. |  | sigma_s | Amount of blur along the XYZ-axes. |  | sigma_r | Amount of blur along the value axis. |  | bgrid_s | Size of the bilateral grid along the XYZ-axes. |  | bgrid_r | Size of the bilateral grid along the value axis. |  | interpolation_type | Use interpolation for image slicing. | 
 
      
        
          | CImg<T>& blur_patch | ( | const float | sigma_s, |  
          |  |  | const float | sigma_p, |  
          |  |  | const unsigned int | patch_size = 3, |  
          |  |  | const unsigned int | lookup_size = 4, |  
          |  |  | const float | smoothness = 0, |  
          |  |  | const bool | is_fast_approx = true |  
          |  | ) |  |  |  
Blur image using patch-based space.  Parameters
  
    | sigma_s | Amount of blur along the XYZ-axes. |  | sigma_p | Amount of blur along the value axis. |  | patch_size | Size of the patchs. |  | lookup_size | Size of the window to search similar patchs. |  | smoothness | Smoothness for the patch comparison. |  | is_fast_approx | Tells if a fast approximation of the gaussian function is used or not. | 
 
      
        
          | CImg<T>& blur_median | ( | const unsigned int | n | ) |  |  
Blur image with the median filter.  Parameters
  
    | n | Size of the median filter. | 
 
      
        
          | CImg<T>& sharpen | ( | const float | amplitude, |  
          |  |  | const bool | sharpen_type = false, |  
          |  |  | const float | edge = 1, |  
          |  |  | const float | alpha = 0, |  
          |  |  | const float | sigma = 0 |  
          |  | ) |  |  |  
Sharpen image.  Parameters
  
    | amplitude | Sharpening amplitude |  | sharpen_type | Select sharpening method. Can be { false=inverse diffusion | true=shock filters }. |  | edge | Edge threshold (shock filters only). |  | alpha | Gradient smoothness (shock filters only). |  | sigma | Tensor smoothness (shock filters only). | 
 
      
        
          | CImgList<Tfloat> get_gradient | ( | const char *const | axes = 0, |  
          |  |  | const int | scheme = 3 |  
          |  | ) |  | const |  
Return image gradient.  Parameters
  
    | axes | Axes considered for the gradient computation, as a C-string (e.g "xy"). |  | scheme | = Numerical scheme used for the gradient computation: 
-1 = Backward finite differences0 = Centered finite differences1 = Forward finite differences2 = Using Sobel masks3 = Using rotation invariant masks4 = Using Deriche recusrsive filter.5 = Using Van Vliet recusrsive filter.  | 
 
      
        
          | CImgList<Tfloat> get_hessian | ( | const char *const | axes = 0 | ) | const |  
Return image hessian.  Parameters
  
    | axes | Axes considered for the hessian computation, as a C-string (e.g "xy"). | 
 
      
        
          | CImg<T>& structure_tensors | ( | const unsigned int | scheme = 2 | ) |  |  
Compute the structure tensor field of an image.  Parameters
  
    | scheme | Numerical scheme. Can be { 0=central | 1=fwd/bwd1 | 2=fwd/bwd2 } | 
 
      
        
          | CImg<T>& diffusion_tensors | ( | const float | sharpness = 0.7f, |  
          |  |  | const float | anisotropy = 0.6f, |  
          |  |  | const float | alpha = 0.6f, |  
          |  |  | const float | sigma = 1.1f, |  
          |  |  | const bool | is_sqrt = false |  
          |  | ) |  |  |  
Compute field of diffusion tensors for edge-preserving smoothing.  Parameters
  
    | sharpness | Sharpness |  | anisotropy | Anisotropy |  | alpha | Standard deviation of the gradient blur. |  | sigma | Standard deviation of the structure tensor blur. |  | is_sqrt | Tells if the square root of the tensor field is computed instead. | 
 
      
        
          | CImg<T>& displacement | ( | const CImg< T > & | source, |  
          |  |  | const float | smoothness = 0.1f, |  
          |  |  | const float | precision = 5.0f, |  
          |  |  | const unsigned int | nb_scales = 0, |  
          |  |  | const unsigned int | iteration_max = 10000, |  
          |  |  | const bool | is_backward = false |  
          |  | ) |  |  |  
Estimate displacement field between two images.  Parameters
  
    | source | Reference image. |  | smoothness | Smoothness of estimated displacement field. |  | precision | Precision required for algorithm convergence. |  | nb_scales | Number of scales used to estimate the displacement field. |  | iteration_max | Maximum number of iterations allowed for one scale. |  | is_backward | If false, match I2(X+U(X)) = I1(X), else match I2(X) = I1(X-U(X)). | 
 
      
        
          | CImg<T>& distance | ( | const T | value, |  
          |  |  | const unsigned int | metric = 2 |  
          |  | ) |  |  |  
Compute Euclidean distance function to a specified value.  Parameters
  
    | value | Reference value. |  | metric | Type of metric. Can be { 0=Chebyshev | 1=Manhattan | 2=Euclidean | 3=Squared-euclidean }. | 
 NoteThe distance transform implementation has been submitted by A. Meijster, and implements the article 'W.H. Hesselink, A. Meijster, J.B.T.M. Roerdink, "A general algorithm for computing distance transforms in linear time.", In: Mathematical Morphology and its Applications to Image and Signal Processing, J. Goutsias, L. Vincent, and D.S. Bloomberg (eds.), Kluwer, 2000, pp. 331-340.' The submitted code has then been modified to fit CImg coding style and constraints. 
 
      
        
          | CImg<T>& distance | ( | const T | value, |  
          |  |  | const CImg< t > & | metric_mask |  
          |  | ) |  |  |  
Compute chamfer distance to a specified value, with a custom metric.  Parameters
  
    | value | Reference value. |  | metric_mask | Metric mask. | 
 NoteThe algorithm code has been initially proposed by A. Meijster, and modified by D. Tschumperlé. 
 
      
        
          | CImg<T>& distance_dijkstra | ( | const T | value, |  
          |  |  | const CImg< t > & | metric, |  
          |  |  | const bool | is_high_connectivity, |  
          |  |  | CImg< to > & | return_path |  
          |  | ) |  |  |  
Compute distance to a specified value, according to a custom metric (use dijkstra algorithm).  Parameters
  
    | value | Reference value. |  | metric | Field of distance potentials. |  | is_high_connectivity | Tells if the algorithm uses low or high connectivity. | 
 
      
        
          | CImg& distance_eikonal | ( | const T | value, |  
          |  |  | const CImg< t > & | metric |  
          |  | ) |  |  |  
Compute distance map to one source point, according to a custom metric (use fast marching algorithm).  Parameters
  
    | value | Reference value. |  | metric | Field of distance potentials. | 
 
      
        
          | CImg<T>& distance_eikonal | ( | const unsigned int | nb_iterations, |  
          |  |  | const float | band_size = 0, |  
          |  |  | const float | time_step = 0.5f |  
          |  | ) |  |  |  
Compute distance function to 0-valued isophotes, using the Eikonal PDE.  Parameters
  
    | nb_iterations | Number of PDE iterations. |  | band_size | Size of the narrow band. |  | time_step | Time step of the PDE iterations. | 
 
      
        
          | CImg<T>& haar | ( | const char | axis, |  
          |  |  | const bool | invert = false, |  
          |  |  | const unsigned int | nb_scales = 1 |  
          |  | ) |  |  |  
Compute Haar multiscale wavelet transform.  Parameters
  
    | axis | Axis considered for the transform. |  | invert | Set inverse of direct transform. |  | nb_scales | Number of scales used for the transform. | 
 
      
        
          | CImg<T>& haar | ( | const bool | invert = false, |  
          |  |  | const unsigned int | nb_scales = 1 |  
          |  | ) |  |  |  
Compute Haar multiscale wavelet transform [overloading].  Parameters
  
    | invert | Set inverse of direct transform. |  | nb_scales | Number of scales used for the transform. | 
 
      
        
          | CImgList<Tfloat> get_FFT | ( | const char | axis, |  
          |  |  | const bool | is_invert = false |  
          |  | ) |  | const |  
Compute 1d Fast Fourier Transform, along a specified axis.  Parameters
  
    | axis | Axis along which the FFT is computed. |  | is_invert | Tells if the forward ( false) or inverse (true) FFT is computed. | 
 
  
  | 
        
          | static void FFT | ( | CImg< T > & | real, |  
          |  |  | CImg< T > & | imag, |  
          |  |  | const char | axis, |  
          |  |  | const bool | is_invert = false |  
          |  | ) |  |  |  | static |  
Compute 1d Fast Fourier Transform, along a specified axis.  Parameters
  
    | [in,out] | real | Real part of the pixel values. |  | [in,out] | imag | Imaginary part of the pixel values. |  |  | axis | Axis along which the FFT is computed. |  |  | is_invert | Tells if the forward ( false) or inverse (true) FFT is computed. | 
 
  
  | 
        
          | static void FFT | ( | CImg< T > & | real, |  
          |  |  | CImg< T > & | imag, |  
          |  |  | const bool | is_invert = false, |  
          |  |  | const unsigned int | nb_threads = 0 |  
          |  | ) |  |  |  | static |  
Compute n-d Fast Fourier Transform.  Parameters
  
    | [in,out] | real | Real part of the pixel values. |  | [in,out] | imag | Imaginary part of the pixel values. |  |  | is_invert | Tells if the forward ( false) or inverse (true) FFT is computed. |  |  | nb_threads | Number of parallel threads used for the computation. Use 0to set this to the number of available cpus. | 
 
      
        
          | CImg<T>& shift_object3d | ( | const float | tx, |  
          |  |  | const float | ty = 0, |  
          |  |  | const float | tz = 0 |  
          |  | ) |  |  |  
Shift 3d object's vertices.  Parameters
  
    | tx | X-coordinate of the 3d displacement vector. |  | ty | Y-coordinate of the 3d displacement vector. |  | tz | Z-coordinate of the 3d displacement vector. | 
 
      
        
          | CImg<T>& shift_object3d | ( |  | ) |  |  
Shift 3d object's vertices, so that it becomes centered.  NoteThe object center is computed as its barycenter. 
 
      
        
          | CImg<T>& resize_object3d | ( | const float | sx, |  
          |  |  | const float | sy = -100, |  
          |  |  | const float | sz = -100 |  
          |  | ) |  |  |  
Resize 3d object.  Parameters
  
    | sx | Width of the 3d object's bounding box. |  | sy | Height of the 3d object's bounding box. |  | sz | Depth of the 3d object's bounding box. | 
 
      
        
          | CImg<T>& append_object3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const CImg< tp > & | obj_vertices, |  
          |  |  | const CImgList< tff > & | obj_primitives |  
          |  | ) |  |  |  
Merge two 3d objects together.  Parameters
  
    | [in,out] | primitives | Primitives data of the current 3d object. |  |  | obj_vertices | Vertices data of the additional 3d object. |  |  | obj_primitives | Primitives data of the additional 3d object. | 
 
Texturize primitives of a 3d object.  Parameters
  
    | [in,out] | primitives | Primitives data of the 3d object. |  | [in,out] | colors | Colors data of the 3d object. |  |  | texture | Texture image to map to 3d object. |  |  | coords | Texture-mapping coordinates. | 
 
      
        
          | CImg<floatT> get_elevation3d | ( | CImgList< tf > & | primitives, |  
          |  |  | CImgList< tc > & | colors, |  
          |  |  | const CImg< te > & | elevation |  
          |  | ) |  | const |  
Generate a 3d elevation of the image instance.  Parameters
  
    | [out] | primitives | The returned list of the 3d object primitives (template type tf should be at least unsigned int). |  | [out] | colors | The returned list of the 3d object colors. |  |  | elevation | The input elevation map. | 
 ReturnsThe N vertices (xi,yi,zi) of the 3d object as a Nx3 CImg<float> image (0<=i<=N-1). 
 Exampleconst CImg<float> img("reference.jpg"); CImgList<unsigned int> faces3d; CImgList<unsigned char> colors3d; const CImg<float> points3d = img.get_elevation3d(faces3d,colors3d,img.get_norm()*0.2); CImg<unsigned char>().display_object3d ("Elevation3d" ,points3d,faces3d,colors3d);
 
      
        
          | CImg<floatT> get_projections3d | ( | CImgList< tf > & | primitives, |  
          |  |  | CImgList< tc > & | colors, |  
          |  |  | const unsigned int | x0, |  
          |  |  | const unsigned int | y0, |  
          |  |  | const unsigned int | z0, |  
          |  |  | const bool | normalize_colors = false |  
          |  | ) |  | const |  
Generate the 3d projection planes of the image instance.  Parameters
  
    | [out] | primitives | Primitives data of the returned 3d object. |  | [out] | colors | Colors data of the returned 3d object. |  |  | x0 | X-coordinate of the projection point. |  |  | y0 | Y-coordinate of the projection point. |  |  | z0 | Z-coordinate of the projection point. |  |  | normalize_colors | Tells if the created textures have normalized colors. | 
 
      
        
          | CImg<floatT> get_isoline3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const float | isovalue, |  
          |  |  | const int | size_x = -100, |  
          |  |  | const int | size_y = -100 |  
          |  | ) |  | const |  
Generate a isoline of the image instance as a 3d object.  Parameters
  
    | [out] | primitives | The returned list of the 3d object primitives (template type tf should be at least unsigned int). |  |  | isovalue | The returned list of the 3d object colors. |  |  | size_x | The number of subdivisions along the X-axis. |  |  | size_y | The number of subdisivions along the Y-axis. | 
 ReturnsThe N vertices (xi,yi,zi) of the 3d object as a Nx3 CImg<float> image (0<=i<=N-1). 
 Exampleconst CImg<float> img("reference.jpg"); CImgList<unsigned int> faces3d; const CImg<float> points3d = img.get_isoline3d(faces3d,100);
 
      
        
          | CImg<floatT> get_isosurface3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const float | isovalue, |  
          |  |  | const int | size_x = -100, |  
          |  |  | const int | size_y = -100, |  
          |  |  | const int | size_z = -100 |  
          |  | ) |  | const |  
Generate an isosurface of the image instance as a 3d object.  Parameters
  
    | [out] | primitives | The returned list of the 3d object primitives (template type tf should be at least unsigned int). |  |  | isovalue | The returned list of the 3d object colors. |  |  | size_x | Number of subdivisions along the X-axis. |  |  | size_y | Number of subdisivions along the Y-axis. |  |  | size_z | Number of subdisivions along the Z-axis. | 
 ReturnsThe N vertices (xi,yi,zi) of the 3d object as a Nx3 CImg<float> image (0<=i<=N-1). 
 Exampleconst CImg<float> img = CImg<unsigned char>("reference.jpg" ).resize (-100,-100,20); CImgList<unsigned int> faces3d; const CImg<float> points3d = img.get_isosurface3d(faces3d,100); CImg<unsigned char>().display_object3d ("Isosurface3d" ,points3d,faces3d,colors3d);
 
  
  | 
        
          | static CImg<floatT> elevation3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const tfunc & | func, |  
          |  |  | const float | x0, |  
          |  |  | const float | y0, |  
          |  |  | const float | x1, |  
          |  |  | const float | y1, |  
          |  |  | const int | size_x = 256, |  
          |  |  | const int | size_y = 256 |  
          |  | ) |  |  |  | static |  
Compute 3d elevation of a function as a 3d object.  Parameters
  
    | [out] | primitives | Primitives data of the resulting 3d object. |  |  | func | Elevation function. Is of type float (*func)(const float x,const float y). |  |  | x0 | X-coordinate of the starting point. |  |  | y0 | Y-coordinate of the starting point. |  |  | x1 | X-coordinate of the ending point. |  |  | y1 | Y-coordinate of the ending point. |  |  | size_x | Resolution of the function along the X-axis. |  |  | size_y | Resolution of the function along the Y-axis. | 
 
  
  | 
        
          | static CImg<floatT> isoline3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const tfunc & | func, |  
          |  |  | const float | isovalue, |  
          |  |  | const float | x0, |  
          |  |  | const float | y0, |  
          |  |  | const float | x1, |  
          |  |  | const float | y1, |  
          |  |  | const int | size_x = 256, |  
          |  |  | const int | size_y = 256 |  
          |  | ) |  |  |  | static |  
Compute 0-isolines of a function, as a 3d object.  Parameters
  
    | [out] | primitives | Primitives data of the resulting 3d object. |  |  | func | Elevation function. Is of type float (*func)(const float x,const float y). |  |  | isovalue | Isovalue to extract from function. |  |  | x0 | X-coordinate of the starting point. |  |  | y0 | Y-coordinate of the starting point. |  |  | x1 | X-coordinate of the ending point. |  |  | y1 | Y-coordinate of the ending point. |  |  | size_x | Resolution of the function along the X-axis. |  |  | size_y | Resolution of the function along the Y-axis. | 
 NoteUse the marching squares algorithm for extracting the isolines. 
 
  
  | 
        
          | static CImg<floatT> isosurface3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const tfunc & | func, |  
          |  |  | const float | isovalue, |  
          |  |  | const float | x0, |  
          |  |  | const float | y0, |  
          |  |  | const float | z0, |  
          |  |  | const float | x1, |  
          |  |  | const float | y1, |  
          |  |  | const float | z1, |  
          |  |  | const int | size_x = 32, |  
          |  |  | const int | size_y = 32, |  
          |  |  | const int | size_z = 32 |  
          |  | ) |  |  |  | static |  
Compute isosurface of a function, as a 3d object.  Parameters
  
    | [out] | primitives | Primitives data of the resulting 3d object. |  |  | func | Implicit function. Is of type float (*func)(const float x, const float y, const float z). |  |  | isovalue | Isovalue to extract. |  |  | x0 | X-coordinate of the starting point. |  |  | y0 | Y-coordinate of the starting point. |  |  | z0 | Z-coordinate of the starting point. |  |  | x1 | X-coordinate of the ending point. |  |  | y1 | Y-coordinate of the ending point. |  |  | z1 | Z-coordinate of the ending point. |  |  | size_x | Resolution of the elevation function along the X-axis. |  |  | size_y | Resolution of the elevation function along the Y-axis. |  |  | size_z | Resolution of the elevation function along the Z-axis. | 
 NoteUse the marching cubes algorithm for extracting the isosurface. 
 
  
  | 
        
          | static CImg<floatT> box3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const float | size_x = 200, |  
          |  |  | const float | size_y = 100, |  
          |  |  | const float | size_z = 100 |  
          |  | ) |  |  |  | static |  
Generate a 3d box object.  Parameters
  
    | [out] | primitives | The returned list of the 3d object primitives (template type tf should be at least unsigned int). |  |  | size_x | The width of the box (dimension along the X-axis). |  |  | size_y | The height of the box (dimension along the Y-axis). |  |  | size_z | The depth of the box (dimension along the Z-axis). | 
 ReturnsThe N vertices (xi,yi,zi) of the 3d object as a Nx3 CImg<float> image (0<=i<=N-1). 
 ExampleCImgList<unsigned int> faces3d;
 
  
  | 
        
          | static CImg<floatT> cone3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const float | radius = 50, |  
          |  |  | const float | size_z = 100, |  
          |  |  | const unsigned int | subdivisions = 24 |  
          |  | ) |  |  |  | static |  
Generate a 3d cone.  Parameters
  
    | [out] | primitives | The returned list of the 3d object primitives (template type tf should be at least unsigned int). |  |  | radius | The radius of the cone basis. |  |  | size_z | The cone's height. |  |  | subdivisions | The number of basis angular subdivisions. | 
 ReturnsThe N vertices (xi,yi,zi) of the 3d object as a Nx3 CImg<float> image (0<=i<=N-1). 
 ExampleCImgList<unsigned int> faces3d;
 
  
  | 
        
          | static CImg<floatT> cylinder3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const float | radius = 50, |  
          |  |  | const float | size_z = 100, |  
          |  |  | const unsigned int | subdivisions = 24 |  
          |  | ) |  |  |  | static |  
Generate a 3d cylinder.  Parameters
  
    | [out] | primitives | The returned list of the 3d object primitives (template type tf should be at least unsigned int). |  |  | radius | The radius of the cylinder basis. |  |  | size_z | The cylinder's height. |  |  | subdivisions | The number of basis angular subdivisions. | 
 ReturnsThe N vertices (xi,yi,zi) of the 3d object as a Nx3 CImg<float> image (0<=i<=N-1). 
 ExampleCImgList<unsigned int> faces3d;
 
  
  | 
        
          | static CImg<floatT> torus3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const float | radius1 = 100, |  
          |  |  | const float | radius2 = 30, |  
          |  |  | const unsigned int | subdivisions1 = 24, |  
          |  |  | const unsigned int | subdivisions2 = 12 |  
          |  | ) |  |  |  | static |  
Generate a 3d torus.  Parameters
  
    | [out] | primitives | The returned list of the 3d object primitives (template type tf should be at least unsigned int). |  |  | radius1 | The large radius. |  |  | radius2 | The small radius. |  |  | subdivisions1 | The number of angular subdivisions for the large radius. |  |  | subdivisions2 | The number of angular subdivisions for the small radius. | 
 ReturnsThe N vertices (xi,yi,zi) of the 3d object as a Nx3 CImg<float> image (0<=i<=N-1). 
 ExampleCImgList<unsigned int> faces3d;
 
  
  | 
        
          | static CImg<floatT> plane3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const float | size_x = 100, |  
          |  |  | const float | size_y = 100, |  
          |  |  | const unsigned int | subdivisions_x = 10, |  
          |  |  | const unsigned int | subdivisions_y = 10 |  
          |  | ) |  |  |  | static |  
Generate a 3d XY-plane.  Parameters
  
    | [out] | primitives | The returned list of the 3d object primitives (template type tf should be at least unsigned int). |  |  | size_x | The width of the plane (dimension along the X-axis). |  |  | size_y | The height of the plane (dimensions along the Y-axis). |  |  | subdivisions_x | The number of planar subdivisions along the X-axis. |  |  | subdivisions_y | The number of planar subdivisions along the Y-axis. | 
 ReturnsThe N vertices (xi,yi,zi) of the 3d object as a Nx3 CImg<float> image (0<=i<=N-1). 
 ExampleCImgList<unsigned int> faces3d;
 
  
  | 
        
          | static CImg<floatT> sphere3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const float | radius = 50, |  
          |  |  | const unsigned int | subdivisions = 3 |  
          |  | ) |  |  |  | static |  
Generate a 3d sphere.  Parameters
  
    | [out] | primitives | The returned list of the 3d object primitives (template type tf should be at least unsigned int). |  |  | radius | The radius of the sphere (dimension along the X-axis). |  |  | subdivisions | The number of recursive subdivisions from an initial icosahedron. | 
 ReturnsThe N vertices (xi,yi,zi) of the 3d object as a Nx3 CImg<float> image (0<=i<=N-1). 
 ExampleCImgList<unsigned int> faces3d;
 
  
  | 
        
          | static CImg<floatT> ellipsoid3d | ( | CImgList< tf > & | primitives, |  
          |  |  | const CImg< t > & | tensor, |  
          |  |  | const unsigned int | subdivisions = 3 |  
          |  | ) |  |  |  | static |  
Generate a 3d ellipsoid.  Parameters
  
    | [out] | primitives | The returned list of the 3d object primitives (template type tf should be at least unsigned int). |  |  | tensor | The tensor which gives the shape and size of the ellipsoid. |  |  | subdivisions | The number of recursive subdivisions from an initial stretched icosahedron. | 
 ReturnsThe N vertices (xi,yi,zi) of the 3d object as a Nx3 CImg<float> image (0<=i<=N-1). 
 ExampleCImgList<unsigned int> faces3d;
 
      
        
          | CImg<T>& object3dtoCImg3d | ( | const CImgList< tp > & | primitives, |  
          |  |  | const CImgList< tc > & | colors, |  
          |  |  | const to & | opacities |  
          |  | ) |  |  |  
Convert 3d object into a CImg3d representation.  Parameters
  
    | primitives | Primitives data of the 3d object. |  | colors | Colors data of the 3d object. |  | opacities | Opacities data of the 3d object. | 
 
Convert CImg3d representation into a 3d object.  Parameters
  
    | [out] | primitives | Primitives data of the 3d object. |  | [out] | colors | Colors data of the 3d object. |  | [out] | opacities | Opacities data of the 3d object. | 
 
      
        
          | CImg<T>& draw_point | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | z0, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a 3d point.  Parameters
  
    | x0 | X-coordinate of the point. |  | y0 | Y-coordinate of the point. |  | z0 | Z-coordinate of the point. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. | 
 Note
To set pixel values without clipping needs, you should use the faster CImg::operator()() function. 
 Example:CImg<unsigned char> img(100,100,1,3,0); const unsigned char color[] = { 255,128,64 }; img.draw_point(50,50,color);
 
      
        
          | CImg<T>& draw_point | ( | const CImg< t > & | points, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Parameters
  
    | points | Image of vertices coordinates. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_line | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a 2d line.  Parameters
  
    | x0 | X-coordinate of the starting line point. |  | y0 | Y-coordinate of the starting line point. |  | x1 | X-coordinate of the ending line point. |  | y1 | Y-coordinate of the ending line point. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the line pattern. |  | init_hatch | Tells if a reinitialization of the hash state must be done. | 
 Note
Line routine uses Bresenham's algorithm.Set init_hatch= false to draw consecutive hatched segments without breaking the line pattern.
 Example:CImg<unsigned char> img(100,100,1,3,0); const unsigned char color[] = { 255,128,64 };  img.draw_line(40,40,80,70,color);
 
      
        
          | CImg<T>& draw_line | ( | CImg< tz > & | zbuffer, |  
          |  |  | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const float | z0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const float | z1, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a 2d line, with z-buffering.  Parameters
  
    | zbuffer | Zbuffer image. |  | x0 | X-coordinate of the starting point. |  | y0 | Y-coordinate of the starting point. |  | z0 | Z-coordinate of the starting point |  | x1 | X-coordinate of the ending point. |  | y1 | Y-coordinate of the ending point. |  | z1 | Z-coordinate of the ending point. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the line pattern. |  | init_hatch | Tells if a reinitialization of the hash state must be done. | 
 
      
        
          | CImg<T>& draw_line | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | z0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | z1, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a 3d line.  Parameters
  
    | x0 | X-coordinate of the starting point. |  | y0 | Y-coordinate of the starting point. |  | z0 | Z-coordinate of the starting point |  | x1 | X-coordinate of the ending point. |  | y1 | Y-coordinate of the ending point. |  | z1 | Z-coordinate of the ending point. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the line pattern. |  | init_hatch | Tells if a reinitialization of the hash state must be done. | 
 
      
        
          | CImg<T>& draw_line | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const CImg< tc > & | texture, |  
          |  |  | const int | tx0, |  
          |  |  | const int | ty0, |  
          |  |  | const int | tx1, |  
          |  |  | const int | ty1, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a textured 2d line.  Parameters
  
    | x0 | X-coordinate of the starting line point. |  | y0 | Y-coordinate of the starting line point. |  | x1 | X-coordinate of the ending line point. |  | y1 | Y-coordinate of the ending line point. |  | texture | Texture image defining the pixel colors. |  | tx0 | X-coordinate of the starting texture point. |  | ty0 | Y-coordinate of the starting texture point. |  | tx1 | X-coordinate of the ending texture point. |  | ty1 | Y-coordinate of the ending texture point. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the line pattern. |  | init_hatch | Tells if the hash variable must be reinitialized. | 
 Note
Line routine uses the well known Bresenham's algorithm. 
 Example:CImg<unsigned char> img(100,100,1,3,0), texture("texture256x256.ppm"); const unsigned char color[] = { 255,128,64 }; img.draw_line(40,40,80,70,texture,0,0,255,255);
 
      
        
          | CImg<T>& draw_line | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const float | z0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const float | z1, |  
          |  |  | const CImg< tc > & | texture, |  
          |  |  | const int | tx0, |  
          |  |  | const int | ty0, |  
          |  |  | const int | tx1, |  
          |  |  | const int | ty1, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a textured 2d line, with perspective correction.  Parameters
  
    | x0 | X-coordinate of the starting point. |  | y0 | Y-coordinate of the starting point. |  | z0 | Z-coordinate of the starting point |  | x1 | X-coordinate of the ending point. |  | y1 | Y-coordinate of the ending point. |  | z1 | Z-coordinate of the ending point. |  | texture | Texture image defining the pixel colors. |  | tx0 | X-coordinate of the starting texture point. |  | ty0 | Y-coordinate of the starting texture point. |  | tx1 | X-coordinate of the ending texture point. |  | ty1 | Y-coordinate of the ending texture point. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the line pattern. |  | init_hatch | Tells if the hash variable must be reinitialized. | 
 
      
        
          | CImg<T>& draw_line | ( | CImg< tz > & | zbuffer, |  
          |  |  | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const float | z0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const float | z1, |  
          |  |  | const CImg< tc > & | texture, |  
          |  |  | const int | tx0, |  
          |  |  | const int | ty0, |  
          |  |  | const int | tx1, |  
          |  |  | const int | ty1, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a textured 2d line, with perspective correction and z-buffering.  Parameters
  
    | zbuffer | Z-buffer image. |  | x0 | X-coordinate of the starting point. |  | y0 | Y-coordinate of the starting point. |  | z0 | Z-coordinate of the starting point |  | x1 | X-coordinate of the ending point. |  | y1 | Y-coordinate of the ending point. |  | z1 | Z-coordinate of the ending point. |  | texture | Texture image defining the pixel colors. |  | tx0 | X-coordinate of the starting texture point. |  | ty0 | Y-coordinate of the starting texture point. |  | tx1 | X-coordinate of the ending texture point. |  | ty1 | Y-coordinate of the ending texture point. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the line pattern. |  | init_hatch | Tells if the hash variable must be reinitialized. | 
 
      
        
          | CImg<T>& draw_line | ( | const CImg< t > & | points, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a set of consecutive lines.  Parameters
  
    | points | Coordinates of vertices, stored as a list of vectors. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the line pattern. |  | init_hatch | If set to true, init hatch motif. | 
 Note
This function uses several call to the single CImg::draw_line() procedure, depending on the vectors size in points.
 
      
        
          | CImg<T>& draw_arrow | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const float | angle = 30, |  
          |  |  | const float | length = -10, |  
          |  |  | const unsigned int | pattern = ~0U |  
          |  | ) |  |  |  
Draw a 2d arrow.  Parameters
  
    | x0 | X-coordinate of the starting arrow point (tail). |  | y0 | Y-coordinate of the starting arrow point (tail). |  | x1 | X-coordinate of the ending arrow point (head). |  | y1 | Y-coordinate of the ending arrow point (head). |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | angle | Aperture angle of the arrow head. |  | length | Length of the arrow head. If negative, describes a percentage of the arrow length. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the line pattern. | 
 
      
        
          | CImg<T>& draw_spline | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const float | u0, |  
          |  |  | const float | v0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const float | u1, |  
          |  |  | const float | v1, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const float | precision = 0.25, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a 2d spline.  Parameters
  
    | x0 | X-coordinate of the starting curve point |  | y0 | Y-coordinate of the starting curve point |  | u0 | X-coordinate of the starting velocity |  | v0 | Y-coordinate of the starting velocity |  | x1 | X-coordinate of the ending curve point |  | y1 | Y-coordinate of the ending curve point |  | u1 | X-coordinate of the ending velocity |  | v1 | Y-coordinate of the ending velocity |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | precision | Curve drawing precision. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the line pattern. |  | init_hatch | If true, init hatch motif. | 
 Note
The curve is a 2d cubic Bezier spline, from the set of specified starting/ending points and corresponding velocity vectors.The spline is drawn as a serie of connected segments. The precisionparameter sets the average number of pixels in each drawn segment.A cubic Bezier curve is sometimes defined by a set of 4 points { (x0,y0), (xa,ya), (xb,yb), (x1,y1) } where (x0,y0) is the starting point, (x1,y1) is the ending point and (xa,ya), (xb,yb) are two control points. The starting and ending velocities (u0,v0) and (u1,v1) can be deduced easily from the control points asu0= (xa-x0),v0= (ya-y0),u1= (x1-xb) andv1= (y1-yb).
 Example:CImg<unsigned char> img(100,100,1,3,0); const unsigned char color[] = { 255,255,255 }; img.draw_spline(30,30,0,100,90,40,0,-100,color);
 
      
        
          | CImg<T>& draw_spline | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | z0, |  
          |  |  | const float | u0, |  
          |  |  | const float | v0, |  
          |  |  | const float | w0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | z1, |  
          |  |  | const float | u1, |  
          |  |  | const float | v1, |  
          |  |  | const float | w1, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const float | precision = 4, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a 3d spline [overloading].  Note
 
      
        
          | CImg<T>& draw_spline | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const float | u0, |  
          |  |  | const float | v0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const float | u1, |  
          |  |  | const float | v1, |  
          |  |  | const CImg< t > & | texture, |  
          |  |  | const int | tx0, |  
          |  |  | const int | ty0, |  
          |  |  | const int | tx1, |  
          |  |  | const int | ty1, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const float | precision = 4, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a textured 2d spline.  Parameters
  
    | x0 | X-coordinate of the starting curve point |  | y0 | Y-coordinate of the starting curve point |  | u0 | X-coordinate of the starting velocity |  | v0 | Y-coordinate of the starting velocity |  | x1 | X-coordinate of the ending curve point |  | y1 | Y-coordinate of the ending curve point |  | u1 | X-coordinate of the ending velocity |  | v1 | Y-coordinate of the ending velocity |  | texture | Texture image defining line pixel colors. |  | tx0 | X-coordinate of the starting texture point. |  | ty0 | Y-coordinate of the starting texture point. |  | tx1 | X-coordinate of the ending texture point. |  | ty1 | Y-coordinate of the ending texture point. |  | precision | Curve drawing precision. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the line pattern. |  | init_hatch | if true, reinit hatch motif. | 
 
      
        
          | CImg<T>& draw_spline | ( | const CImg< tp > & | points, |  
          |  |  | const CImg< tt > & | tangents, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const bool | is_closed_set = false, |  
          |  |  | const float | precision = 4, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a set of consecutive splines.  Parameters
  
    | points | Vertices data. |  | tangents | Tangents data. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. |  | is_closed_set | Tells if the drawn spline set is closed. |  | precision | Precision of the drawing. |  | pattern | An integer whose bits describe the line pattern. |  | init_hatch | If true, init hatch motif. | 
 
      
        
          | CImg<T>& draw_spline | ( | const CImg< tp > & | points, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const bool | is_closed_set = false, |  
          |  |  | const float | precision = 4, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const bool | init_hatch = true |  
          |  | ) |  |  |  
Draw a set of consecutive splines [overloading].  Similar to previous function, with the point tangents automatically estimated from the given points set.  
      
        
          | CImg<T>& draw_triangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | x2, |  
          |  |  | const int | y2, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a filled 2d triangle.  Parameters
  
    | x0 | X-coordinate of the first vertex. |  | y0 | Y-coordinate of the first vertex. |  | x1 | X-coordinate of the second vertex. |  | y1 | Y-coordinate of the second vertex. |  | x2 | X-coordinate of the third vertex. |  | y2 | Y-coordinate of the third vertex. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_triangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | x2, |  
          |  |  | const int | y2, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity, |  
          |  |  | const unsigned int | pattern |  
          |  | ) |  |  |  
Draw a outlined 2d triangle.  Parameters
  
    | x0 | X-coordinate of the first vertex. |  | y0 | Y-coordinate of the first vertex. |  | x1 | X-coordinate of the second vertex. |  | y1 | Y-coordinate of the second vertex. |  | x2 | X-coordinate of the third vertex. |  | y2 | Y-coordinate of the third vertex. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the outline pattern. | 
 
      
        
          | CImg<T>& draw_triangle | ( | CImg< tz > & | zbuffer, |  
          |  |  | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const float | z0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const float | z1, |  
          |  |  | const int | x2, |  
          |  |  | const int | y2, |  
          |  |  | const float | z2, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const float | brightness = 1 |  
          |  | ) |  |  |  
Draw a filled 2d triangle, with z-buffering.  Parameters
  
    | zbuffer | Z-buffer image. |  | x0 | X-coordinate of the first vertex. |  | y0 | Y-coordinate of the first vertex. |  | z0 | Z-coordinate of the first vertex. |  | x1 | X-coordinate of the second vertex. |  | y1 | Y-coordinate of the second vertex. |  | z1 | Z-coordinate of the second vertex. |  | x2 | X-coordinate of the third vertex. |  | y2 | Y-coordinate of the third vertex. |  | z2 | Z-coordinate of the third vertex. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. |  | brightness | Brightness factor. | 
 
      
        
          | CImg<T>& draw_triangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | x2, |  
          |  |  | const int | y2, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | brightness0, |  
          |  |  | const float | brightness1, |  
          |  |  | const float | brightness2, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a Gouraud-shaded 2d triangle.  Parameters
  
    | x0 | X-coordinate of the first vertex in the image instance. |  | y0 | Y-coordinate of the first vertex in the image instance. |  | x1 | X-coordinate of the second vertex in the image instance. |  | y1 | Y-coordinate of the second vertex in the image instance. |  | x2 | X-coordinate of the third vertex in the image instance. |  | y2 | Y-coordinate of the third vertex in the image instance. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | brightness0 | Brightness factor of the first vertex (in [0,2]). |  | brightness1 | brightness factor of the second vertex (in [0,2]). |  | brightness2 | brightness factor of the third vertex (in [0,2]). |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_triangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | x2, |  
          |  |  | const int | y2, |  
          |  |  | const tc1 *const | color1, |  
          |  |  | const tc2 *const | color2, |  
          |  |  | const tc3 *const | color3, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a color-interpolated 2d triangle.  Parameters
  
    | x0 | X-coordinate of the first vertex in the image instance. |  | y0 | Y-coordinate of the first vertex in the image instance. |  | x1 | X-coordinate of the second vertex in the image instance. |  | y1 | Y-coordinate of the second vertex in the image instance. |  | x2 | X-coordinate of the third vertex in the image instance. |  | y2 | Y-coordinate of the third vertex in the image instance. |  | color1 | Pointer to spectrum()consecutive values of typeT, defining the color of the first vertex. |  | color2 | Pointer to spectrum()consecutive values of typeT, defining the color of the seconf vertex. |  | color3 | Pointer to spectrum()consecutive values of typeT, defining the color of the third vertex. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_triangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | x2, |  
          |  |  | const int | y2, |  
          |  |  | const CImg< tc > & | texture, |  
          |  |  | const int | tx0, |  
          |  |  | const int | ty0, |  
          |  |  | const int | tx1, |  
          |  |  | const int | ty1, |  
          |  |  | const int | tx2, |  
          |  |  | const int | ty2, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const float | brightness = 1 |  
          |  | ) |  |  |  
Draw a textured 2d triangle.  Parameters
  
    | x0 | X-coordinate of the first vertex in the image instance. |  | y0 | Y-coordinate of the first vertex in the image instance. |  | x1 | X-coordinate of the second vertex in the image instance. |  | y1 | Y-coordinate of the second vertex in the image instance. |  | x2 | X-coordinate of the third vertex in the image instance. |  | y2 | Y-coordinate of the third vertex in the image instance. |  | texture | Texture image used to fill the triangle. |  | tx0 | X-coordinate of the first vertex in the texture image. |  | ty0 | Y-coordinate of the first vertex in the texture image. |  | tx1 | X-coordinate of the second vertex in the texture image. |  | ty1 | Y-coordinate of the second vertex in the texture image. |  | tx2 | X-coordinate of the third vertex in the texture image. |  | ty2 | Y-coordinate of the third vertex in the texture image. |  | opacity | Drawing opacity. |  | brightness | Brightness factor of the drawing (in [0,2]). | 
 
      
        
          | CImg<T>& draw_triangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | x2, |  
          |  |  | const int | y2, |  
          |  |  | const tc *const | color, |  
          |  |  | const CImg< tl > & | light, |  
          |  |  | const int | lx0, |  
          |  |  | const int | ly0, |  
          |  |  | const int | lx1, |  
          |  |  | const int | ly1, |  
          |  |  | const int | lx2, |  
          |  |  | const int | ly2, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a Phong-shaded 2d triangle.  Parameters
  
    | x0 | X-coordinate of the first vertex in the image instance. |  | y0 | Y-coordinate of the first vertex in the image instance. |  | x1 | X-coordinate of the second vertex in the image instance. |  | y1 | Y-coordinate of the second vertex in the image instance. |  | x2 | X-coordinate of the third vertex in the image instance. |  | y2 | Y-coordinate of the third vertex in the image instance. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | light | Light image. |  | lx0 | X-coordinate of the first vertex in the light image. |  | ly0 | Y-coordinate of the first vertex in the light image. |  | lx1 | X-coordinate of the second vertex in the light image. |  | ly1 | Y-coordinate of the second vertex in the light image. |  | lx2 | X-coordinate of the third vertex in the light image. |  | ly2 | Y-coordinate of the third vertex in the light image. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_triangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | x2, |  
          |  |  | const int | y2, |  
          |  |  | const CImg< tc > & | texture, |  
          |  |  | const int | tx0, |  
          |  |  | const int | ty0, |  
          |  |  | const int | tx1, |  
          |  |  | const int | ty1, |  
          |  |  | const int | tx2, |  
          |  |  | const int | ty2, |  
          |  |  | const float | brightness0, |  
          |  |  | const float | brightness1, |  
          |  |  | const float | brightness2, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a textured Gouraud-shaded 2d triangle.  Parameters
  
    | x0 | X-coordinate of the first vertex in the image instance. |  | y0 | Y-coordinate of the first vertex in the image instance. |  | x1 | X-coordinate of the second vertex in the image instance. |  | y1 | Y-coordinate of the second vertex in the image instance. |  | x2 | X-coordinate of the third vertex in the image instance. |  | y2 | Y-coordinate of the third vertex in the image instance. |  | texture | Texture image used to fill the triangle. |  | tx0 | X-coordinate of the first vertex in the texture image. |  | ty0 | Y-coordinate of the first vertex in the texture image. |  | tx1 | X-coordinate of the second vertex in the texture image. |  | ty1 | Y-coordinate of the second vertex in the texture image. |  | tx2 | X-coordinate of the third vertex in the texture image. |  | ty2 | Y-coordinate of the third vertex in the texture image. |  | brightness0 | Brightness factor of the first vertex. |  | brightness1 | Brightness factor of the second vertex. |  | brightness2 | Brightness factor of the third vertex. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_triangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | x2, |  
          |  |  | const int | y2, |  
          |  |  | const CImg< tc > & | texture, |  
          |  |  | const int | tx0, |  
          |  |  | const int | ty0, |  
          |  |  | const int | tx1, |  
          |  |  | const int | ty1, |  
          |  |  | const int | tx2, |  
          |  |  | const int | ty2, |  
          |  |  | const CImg< tl > & | light, |  
          |  |  | const int | lx0, |  
          |  |  | const int | ly0, |  
          |  |  | const int | lx1, |  
          |  |  | const int | ly1, |  
          |  |  | const int | lx2, |  
          |  |  | const int | ly2, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a textured Phong-shaded 2d triangle.  Parameters
  
    | x0 | X-coordinate of the first vertex in the image instance. |  | y0 | Y-coordinate of the first vertex in the image instance. |  | x1 | X-coordinate of the second vertex in the image instance. |  | y1 | Y-coordinate of the second vertex in the image instance. |  | x2 | X-coordinate of the third vertex in the image instance. |  | y2 | Y-coordinate of the third vertex in the image instance. |  | texture | Texture image used to fill the triangle. |  | tx0 | X-coordinate of the first vertex in the texture image. |  | ty0 | Y-coordinate of the first vertex in the texture image. |  | tx1 | X-coordinate of the second vertex in the texture image. |  | ty1 | Y-coordinate of the second vertex in the texture image. |  | tx2 | X-coordinate of the third vertex in the texture image. |  | ty2 | Y-coordinate of the third vertex in the texture image. |  | light | Light image. |  | lx0 | X-coordinate of the first vertex in the light image. |  | ly0 | Y-coordinate of the first vertex in the light image. |  | lx1 | X-coordinate of the second vertex in the light image. |  | ly1 | Y-coordinate of the second vertex in the light image. |  | lx2 | X-coordinate of the third vertex in the light image. |  | ly2 | Y-coordinate of the third vertex in the light image. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_rectangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | z0, |  
          |  |  | const int | c0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | z1, |  
          |  |  | const int | c1, |  
          |  |  | const T | val, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a filled 4d rectangle.  Parameters
  
    | x0 | X-coordinate of the upper-left rectangle corner. |  | y0 | Y-coordinate of the upper-left rectangle corner. |  | z0 | Z-coordinate of the upper-left rectangle corner. |  | c0 | C-coordinate of the upper-left rectangle corner. |  | x1 | X-coordinate of the lower-right rectangle corner. |  | y1 | Y-coordinate of the lower-right rectangle corner. |  | z1 | Z-coordinate of the lower-right rectangle corner. |  | c1 | C-coordinate of the lower-right rectangle corner. |  | val | Scalar value used to fill the rectangle area. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_rectangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | z0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const int | z1, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a filled 3d rectangle.  Parameters
  
    | x0 | X-coordinate of the upper-left rectangle corner. |  | y0 | Y-coordinate of the upper-left rectangle corner. |  | z0 | Z-coordinate of the upper-left rectangle corner. |  | x1 | X-coordinate of the lower-right rectangle corner. |  | y1 | Y-coordinate of the lower-right rectangle corner. |  | z1 | Z-coordinate of the lower-right rectangle corner. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_rectangle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a filled 2d rectangle.  Parameters
  
    | x0 | X-coordinate of the upper-left rectangle corner. |  | y0 | Y-coordinate of the upper-left rectangle corner. |  | x1 | X-coordinate of the lower-right rectangle corner. |  | y1 | Y-coordinate of the lower-right rectangle corner. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_polygon | ( | const CImg< t > & | points, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a filled 2d polygon.  Parameters
  
    | points | Set of polygon vertices. |  | color | Pointer to spectrum()consecutive values of typeT, defining the drawing color. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_ellipse | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const float | r1, |  
          |  |  | const float | r2, |  
          |  |  | const float | angle, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a filled 2d ellipse.  Parameters
  
    | x0 | X-coordinate of the ellipse center. |  | y0 | Y-coordinate of the ellipse center. |  | r1 | First radius of the ellipse. |  | r2 | Second radius of the ellipse. |  | angle | Angle of the first radius. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_ellipse | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const CImg< t > & | tensor, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a filled 2d ellipse [overloading].  Parameters
  
    | x0 | X-coordinate of the ellipse center. |  | y0 | Y-coordinate of the ellipse center. |  | tensor | Diffusion tensor describing the ellipse. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_ellipse | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const float | r1, |  
          |  |  | const float | r2, |  
          |  |  | const float | angle, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity, |  
          |  |  | const unsigned int | pattern |  
          |  | ) |  |  |  
Draw an outlined 2d ellipse.  Parameters
  
    | x0 | X-coordinate of the ellipse center. |  | y0 | Y-coordinate of the ellipse center. |  | r1 | First radius of the ellipse. |  | r2 | Second radius of the ellipse. |  | angle | Angle of the first radius. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the outline pattern. | 
 
      
        
          | CImg<T>& draw_ellipse | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const CImg< t > & | tensor, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity, |  
          |  |  | const unsigned int | pattern |  
          |  | ) |  |  |  
Draw an outlined 2d ellipse [overloading].  Parameters
  
    | x0 | X-coordinate of the ellipse center. |  | y0 | Y-coordinate of the ellipse center. |  | tensor | Diffusion tensor describing the ellipse. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the outline pattern. | 
 
      
        
          | CImg<T>& draw_circle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | int | radius, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a filled 2d circle.  Parameters
  
    | x0 | X-coordinate of the circle center. |  | y0 | Y-coordinate of the circle center. |  | radius | Circle radius. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. | 
 Note
Circle version of the Bresenham's algorithm is used. 
 
      
        
          | CImg<T>& draw_circle | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | int | radius, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity, |  
          |  |  | const unsigned int | pattern |  
          |  | ) |  |  |  
Draw an outlined 2d circle.  Parameters
  
    | x0 | X-coordinate of the circle center. |  | y0 | Y-coordinate of the circle center. |  | radius | Circle radius. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern | An integer whose bits describe the outline pattern. | 
 
      
        
          | CImg<T>& draw_image | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | z0, |  
          |  |  | const int | c0, |  
          |  |  | const CImg< t > & | sprite, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw an image.  Parameters
  
    | sprite | Sprite image. |  | x0 | X-coordinate of the sprite position. |  | y0 | Y-coordinate of the sprite position. |  | z0 | Z-coordinate of the sprite position. |  | c0 | C-coordinate of the sprite position. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_image | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | z0, |  
          |  |  | const int | c0, |  
          |  |  | const CImg< ti > & | sprite, |  
          |  |  | const CImg< tm > & | mask, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const float | mask_max_value = 1 |  
          |  | ) |  |  |  
Draw a masked image.  Parameters
  
    | sprite | Sprite image. |  | mask | Mask image. |  | x0 | X-coordinate of the sprite position in the image instance. |  | y0 | Y-coordinate of the sprite position in the image instance. |  | z0 | Z-coordinate of the sprite position in the image instance. |  | c0 | C-coordinate of the sprite position in the image instance. |  | mask_max_value | Maximum pixel value of the mask image mask. |  | opacity | Drawing opacity. | 
 Note
Pixel values of maskset the opacity of the corresponding pixels insprite.Dimensions along x,y and z of spriteandmaskmust be the same.
 
      
        
          | CImg<T>& draw_text | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const char *const | text, |  
          |  |  | const tc1 *const | foreground_color, |  
          |  |  | const tc2 *const | background_color, |  
          |  |  | const float | opacity, |  
          |  |  | const CImgList< t > & | font, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Draw a text string.  Parameters
  
    | x0 | X-coordinate of the text in the image instance. |  | y0 | Y-coordinate of the text in the image instance. |  | text | Format of the text ('printf'-style format string). |  | foreground_color | Pointer to spectrum()consecutive values, defining the foreground drawing color. |  | background_color | Pointer to spectrum()consecutive values, defining the background drawing color. |  | opacity | Drawing opacity. |  | font | Font used for drawing text. | 
 
      
        
          | CImg<T>& draw_text | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const char *const | text, |  
          |  |  | const tc *const | foreground_color, |  
          |  |  | const int | , |  
          |  |  | const float | opacity, |  
          |  |  | const CImgList< t > & | font, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Draw a text string [overloading].  NoteA transparent background is used for the text. 
 
      
        
          | CImg<T>& draw_text | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const char *const | text, |  
          |  |  | const int | , |  
          |  |  | const tc *const | background_color, |  
          |  |  | const float | opacity, |  
          |  |  | const CImgList< t > & | font, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Draw a text string [overloading].  NoteA transparent foreground is used for the text. 
 
      
        
          | CImg<T>& draw_text | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const char *const | text, |  
          |  |  | const tc1 *const | foreground_color, |  
          |  |  | const tc2 *const | background_color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | font_height = 13, |  
          |  |  |  | ... |  
          |  | ) |  |  |  
Draw a text string [overloading].  Parameters
  
    | x0 | X-coordinate of the text in the image instance. |  | y0 | Y-coordinate of the text in the image instance. |  | text | Format of the text ('printf'-style format string). |  | foreground_color | Array of spectrum() values of type T, defining the foreground color (0 means 'transparent'). |  | background_color | Array of spectrum() values of type T, defining the background color (0 means 'transparent'). |  | opacity | Drawing opacity. |  | font_height | Height of the text font (exact match for 13,24,32,57, interpolated otherwise). | 
 
      
        
          | CImg<T>& draw_quiver | ( | const CImg< t1 > & | flow, |  
          |  |  | const t2 *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | sampling = 25, |  
          |  |  | const float | factor = -20, |  
          |  |  | const bool | is_arrow = true, |  
          |  |  | const unsigned int | pattern = ~0U |  
          |  | ) |  |  |  
Draw a 2d vector field.  Parameters
  
    | flow | Image of 2d vectors used as input data. |  | color | Image of spectrum()-D vectors corresponding to the color of each arrow. |  | opacity | Drawing opacity. |  | sampling | Length (in pixels) between each arrow. |  | factor | Length factor of each arrow (if <0, computed as a percentage of the maximum length). |  | is_arrow | Tells if arrows must be drawn, instead of oriented segments. |  | pattern | Used pattern to draw lines. | 
 NoteClipping is supported. 
 
      
        
          | CImg<T>& draw_quiver | ( | const CImg< t1 > & | flow, |  
          |  |  | const CImg< t2 > & | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | sampling = 25, |  
          |  |  | const float | factor = -20, |  
          |  |  | const bool | is_arrow = true, |  
          |  |  | const unsigned int | pattern = ~0U |  
          |  | ) |  |  |  
Draw a 2d vector field, using a field of colors.  Parameters
  
    | flow | Image of 2d vectors used as input data. |  | color | Image of spectrum()-D vectors corresponding to the color of each arrow. |  | opacity | Opacity of the drawing. |  | sampling | Length (in pixels) between each arrow. |  | factor | Length factor of each arrow (if <0, computed as a percentage of the maximum length). |  | is_arrow | Tells if arrows must be drawn, instead of oriented segments. |  | pattern | Used pattern to draw lines. | 
 NoteClipping is supported. 
 
      
        
          | CImg<T>& draw_axis | ( | const CImg< t > & | values_x, |  
          |  |  | const int | y, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const unsigned int | font_height = 13, |  
          |  |  | const bool | allow_zero = true |  
          |  | ) |  |  |  
Draw a labeled horizontal axis.  Parameters
  
    | values_x | Values along the horizontal axis. |  | y | Y-coordinate of the horizontal axis in the image instance. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern | Drawing pattern. |  | font_height | Height of the labels (exact match for 13,24,32,57, interpolated otherwise). |  | allow_zero | Enable/disable the drawing of label '0' if found. | 
 
      
        
          | CImg<T>& draw_axis | ( | const int | x, |  
          |  |  | const CImg< t > & | values_y, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern = ~0U, |  
          |  |  | const unsigned int | font_height = 13, |  
          |  |  | const bool | allow_zero = true |  
          |  | ) |  |  |  
Draw a labeled vertical axis.  Parameters
  
    | x | X-coordinate of the vertical axis in the image instance. |  | values_y | Values along the Y-axis. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern | Drawing pattern. |  | font_height | Height of the labels (exact match for 13,24,32,57, interpolated otherwise). |  | allow_zero | Enable/disable the drawing of label '0' if found. | 
 
      
        
          | CImg<T>& draw_axes | ( | const CImg< tx > & | values_x, |  
          |  |  | const CImg< ty > & | values_y, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern_x = ~0U, |  
          |  |  | const unsigned int | pattern_y = ~0U, |  
          |  |  | const unsigned int | font_height = 13, |  
          |  |  | const bool | allow_zero = true |  
          |  | ) |  |  |  
Draw labeled horizontal and vertical axes.  Parameters
  
    | values_x | Values along the X-axis. |  | values_y | Values along the Y-axis. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern_x | Drawing pattern for the X-axis. |  | pattern_y | Drawing pattern for the Y-axis. |  | font_height | Height of the labels (exact match for 13,24,32,57, interpolated otherwise). |  | allow_zero | Enable/disable the drawing of label '0' if found. | 
 
      
        
          | CImg<T>& draw_grid | ( | const CImg< tx > & | values_x, |  
          |  |  | const CImg< ty > & | values_y, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | pattern_x = ~0U, |  
          |  |  | const unsigned int | pattern_y = ~0U |  
          |  | ) |  |  |  
Draw 2d grid.  Parameters
  
    | values_x | X-coordinates of the vertical lines. |  | values_y | Y-coordinates of the horizontal lines. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. |  | pattern_x | Drawing pattern for vertical lines. |  | pattern_y | Drawing pattern for horizontal lines. | 
 
      
        
          | CImg<T>& draw_graph | ( | const CImg< t > & | data, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const unsigned int | plot_type = 1, |  
          |  |  | const int | vertex_type = 1, |  
          |  |  | const double | ymin = 0, |  
          |  |  | const double | ymax = 0, |  
          |  |  | const unsigned int | pattern = ~0U |  
          |  | ) |  |  |  
Draw 1d graph.  Parameters
  
    | data | Image containing the graph values I = f(x). |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. |  | plot_type | Define the type of the plot: 
0 = No plot.1 = Plot using segments.2 = Plot using cubic splines.3 = Plot with bars.  |  | vertex_type | Define the type of points: 
0 = No points.1 = Point.2 = Straight cross.3 = Diagonal cross.4 = Filled circle.5 = Outlined circle.6 = Square.7 = Diamond.  |  | ymin | Lower bound of the y-range. |  | ymax | Upper bound of the y-range. |  | pattern | Drawing pattern. | 
 Note
if ymin==ymax==0, the y-range is computed automatically from the input samples.
 
      
        
          | CImg<T>& draw_fill | ( | const int | x, |  
          |  |  | const int | y, |  
          |  |  | const int | z, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity, |  
          |  |  | CImg< t > & | region, |  
          |  |  | const float | sigma = 0, |  
          |  |  | const bool | is_high_connexity = false |  
          |  | ) |  |  |  
Draw filled 3d region with the flood fill algorithm.  Parameters
  
    |  | x | X-coordinate of the starting point of the region to fill. |  |  | y | Y-coordinate of the starting point of the region to fill. |  |  | z | Z-coordinate of the starting point of the region to fill. |  |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | [out] | region | Image that will contain the mask of the filled region mask, as an output. |  |  | sigma | Tolerance concerning neighborhood values. |  |  | opacity | Opacity of the drawing. |  |  | is_high_connexity | Tells if 8-connexity must be used (only for 2d images). | 
 Returnsregionis initialized with the binary mask of the filled region.
 
      
        
          | CImg<T>& draw_plasma | ( | const float | alpha = 1, |  
          |  |  | const float | beta = 0, |  
          |  |  | const unsigned int | scale = 8 |  
          |  | ) |  |  |  
Draw a random plasma texture.  Parameters
  
    | alpha | Alpha-parameter. |  | beta | Beta-parameter. |  | scale | Scale-parameter. | 
 NoteUse the mid-point algorithm to render. 
 
      
        
          | CImg<T>& draw_mandelbrot | ( | const int | x0, |  
          |  |  | const int | y0, |  
          |  |  | const int | x1, |  
          |  |  | const int | y1, |  
          |  |  | const CImg< tc > & | colormap, |  
          |  |  | const float | opacity = 1, |  
          |  |  | const double | z0r = -2, |  
          |  |  | const double | z0i = -2, |  
          |  |  | const double | z1r = 2, |  
          |  |  | const double | z1i = 2, |  
          |  |  | const unsigned int | iteration_max = 255, |  
          |  |  | const bool | is_normalized_iteration = false, |  
          |  |  | const bool | is_julia_set = false, |  
          |  |  | const double | param_r = 0, |  
          |  |  | const double | param_i = 0 |  
          |  | ) |  |  |  
Draw a quadratic Mandelbrot or Julia 2d fractal.  Parameters
  
    | x0 | X-coordinate of the upper-left pixel. |  | y0 | Y-coordinate of the upper-left pixel. |  | x1 | X-coordinate of the lower-right pixel. |  | y1 | Y-coordinate of the lower-right pixel. |  | colormap | Colormap. |  | opacity | Drawing opacity. |  | z0r | Real part of the upper-left fractal vertex. |  | z0i | Imaginary part of the upper-left fractal vertex. |  | z1r | Real part of the lower-right fractal vertex. |  | z1i | Imaginary part of the lower-right fractal vertex. |  | iteration_max | Maximum number of iterations for each estimated point. |  | is_normalized_iteration | Tells if iterations are normalized. |  | is_julia_set | Tells if the Mandelbrot or Julia set is rendered. |  | param_r | Real part of the Julia set parameter. |  | param_i | Imaginary part of the Julia set parameter. | 
 NoteFractal rendering is done by the Escape Time Algorithm. 
 
      
        
          | CImg<T>& draw_gaussian | ( | const float | xc, |  
          |  |  | const float | sigma, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a 1d gaussian function.  Parameters
  
    | xc | X-coordinate of the gaussian center. |  | sigma | Standard variation of the gaussian distribution. |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_gaussian | ( | const float | xc, |  
          |  |  | const float | yc, |  
          |  |  | const CImg< t > & | tensor, |  
          |  |  | const tc *const | color, |  
          |  |  | const float | opacity = 1 |  
          |  | ) |  |  |  
Draw a 2d gaussian function.  Parameters
  
    | xc | X-coordinate of the gaussian center. |  | yc | Y-coordinate of the gaussian center. |  | tensor | Covariance matrix (must be 2x2). |  | color | Pointer to spectrum()consecutive values, defining the drawing color. |  | opacity | Drawing opacity. | 
 
      
        
          | CImg<T>& draw_object3d | ( | const float | x0, |  
          |  |  | const float | y0, |  
          |  |  | const float | z0, |  
          |  |  | const CImg< tp > & | vertices, |  
          |  |  | const CImgList< tf > & | primitives, |  
          |  |  | const CImgList< tc > & | colors, |  
          |  |  | const CImg< to > & | opacities, |  
          |  |  | const unsigned int | render_type = 4, |  
          |  |  | const bool | is_double_sided = false, |  
          |  |  | const float | focale = 700, |  
          |  |  | const float | lightx = 0, |  
          |  |  | const float | lighty = 0, |  
          |  |  | const float | lightz = -5e8, |  
          |  |  | const float | specular_lightness = 0.2f, |  
          |  |  | const float | specular_shininess = 0.1f |  
          |  | ) |  |  |  
Draw a 3d object.  Parameters
  
    | x0 | X-coordinate of the 3d object position |  | y0 | Y-coordinate of the 3d object position |  | z0 | Z-coordinate of the 3d object position |  | vertices | Image Nx3 describing 3d point coordinates |  | primitives | List of P primitives |  | colors | List of P color (or textures) |  | opacities | Image or list of P opacities |  | render_type | d Render type (0=Points, 1=Lines, 2=Faces (no light), 3=Faces (flat), 4=Faces(Gouraud) |  | is_double_sided | Tells if object faces have two sides or are oriented. |  | focale | length of the focale (0 for parallel projection) |  | lightx | X-coordinate of the light |  | lighty | Y-coordinate of the light |  | lightz | Z-coordinate of the light |  | specular_lightness | Amount of specular light. |  | specular_shininess | Shininess of the object | 
 
      
        
          | CImg<T>& select | ( | CImgDisplay & | disp, |  
          |  |  | const unsigned int | feature_type = 2, |  
          |  |  | unsigned int *const | XYZ = 0 |  
          |  | ) |  |  |  
Launch simple interface to select a shape from an image.  Parameters
  
    | disp | Display window to use. |  | feature_type | Type of feature to select. Can be { 0=point | 1=line | 2=rectangle | 3=ellipse }. |  | XYZ | Pointer to 3 values X,Y,Z which tells about the projection point coordinates, for volumetric images. | 
 
      
        
          | CImg<T>& load | ( | const char *const | filename | ) |  |  
Load image from a file.  Parameters
  
    | filename | Filename, as a C-string. | 
 NoteThe extension of filenamedefines the file format. If no filename extension is provided, CImg<T>::get_load() will try to load the file as a .cimg or .cimgz file.
 
      
        
          | CImg<T>& load_ascii | ( | const char *const | filename | ) |  |  
Load image from an ascii file.  Parameters
  
    | filename | Filename, as a C -string. | 
 
      
        
          | CImg<T>& load_dlm | ( | const char *const | filename | ) |  |  
Load image from a DLM file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_bmp | ( | const char *const | filename | ) |  |  
Load image from a BMP file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_jpeg | ( | const char *const | filename | ) |  |  
Load image from a JPEG file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_magick | ( | const char *const | filename | ) |  |  
Load image from a file, using Magick++ library.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_png | ( | const char *const | filename | ) |  |  
Load image from a PNG file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_pnm | ( | const char *const | filename | ) |  |  
Load image from a PNM file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_pfm | ( | const char *const | filename | ) |  |  
Load image from a PFM file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_rgb | ( | const char *const | filename, |  
          |  |  | const unsigned int | dimw, |  
          |  |  | const unsigned int | dimh = 1 |  
          |  | ) |  |  |  
Load image from a RGB file.  Parameters
  
    | filename | Filename, as a C-string. |  | dimw | Width of the image buffer. |  | dimh | Height of the image buffer. | 
 
      
        
          | CImg<T>& load_rgba | ( | const char *const | filename, |  
          |  |  | const unsigned int | dimw, |  
          |  |  | const unsigned int | dimh = 1 |  
          |  | ) |  |  |  
Load image from a RGBA file.  Parameters
  
    | filename | Filename, as a C-string. |  | dimw | Width of the image buffer. |  | dimh | Height of the image buffer. | 
 
      
        
          | CImg<T>& load_tiff | ( | const char *const | filename, |  
          |  |  | const unsigned int | first_frame = 0, |  
          |  |  | const unsigned int | last_frame = ~0U, |  
          |  |  | const unsigned int | step_frame = 1 |  
          |  | ) |  |  |  
Load image from a TIFF file.  Parameters
  
    | filename | Filename, as a C-string. |  | first_frame | First frame to read (for multi-pages tiff). |  | last_frame | Last frame to read (for multi-pages tiff). |  | step_frame | Step value of frame reading. | 
 Note
libtiff support is enabled by defining the precompilation directive cimg_use_tif.When libtiff is enabled, 2D and 3D (multipage) several channel per pixel are supported for char,uchar,short,ushort,floatanddoublepixel types.If cimg_use_tifis not defined at compilation time the function uses CImg<T>& load_other(const char*).
 
      
        
          | CImg<T>& load_minc2 | ( | const char *const | filename | ) |  |  
Load image from a MINC2 file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_analyze | ( | const char *const | filename, |  
          |  |  | float *const | voxel_size = 0 |  
          |  | ) |  |  |  
Load image from an ANALYZE7.5/NIFTI file.  Parameters
  
    |  | filename | Filename, as a C-string. |  | [out] | voxel_size | Pointer to the three voxel sizes read from the file. | 
 
      
        
          | CImg<T>& load_cimg | ( | const char *const | filename, |  
          |  |  | const char | axis = 'z', |  
          |  |  | const float | align = 0 |  
          |  | ) |  |  |  
Load image from a .cimg[z] file.  Parameters
  
    | filename | Filename, as a C-string. |  | axis | Appending axis, if file contains multiple images. Can be { 'x' | 'y' | 'z' | 'c' }. |  | align | Appending alignment. | 
 
      
        
          | CImg<T>& load_cimg | ( | const char *const | filename, |  
          |  |  | const unsigned int | n0, |  
          |  |  | const unsigned int | n1, |  
          |  |  | const unsigned int | x0, |  
          |  |  | const unsigned int | y0, |  
          |  |  | const unsigned int | z0, |  
          |  |  | const unsigned int | c0, |  
          |  |  | const unsigned int | x1, |  
          |  |  | const unsigned int | y1, |  
          |  |  | const unsigned int | z1, |  
          |  |  | const unsigned int | c1, |  
          |  |  | const char | axis = 'z', |  
          |  |  | const float | align = 0 |  
          |  | ) |  |  |  
Load sub-images of a .cimg file.  Parameters
  
    | filename | Filename, as a C-string. |  | n0 | Starting frame. |  | n1 | Ending frame. |  | x0 | X-coordinate of the starting sub-image vertex. |  | y0 | Y-coordinate of the starting sub-image vertex. |  | z0 | Z-coordinate of the starting sub-image vertex. |  | c0 | C-coordinate of the starting sub-image vertex. |  | x1 | X-coordinate of the ending sub-image vertex. |  | y1 | Y-coordinate of the ending sub-image vertex. |  | z1 | Z-coordinate of the ending sub-image vertex. |  | c1 | C-coordinate of the ending sub-image vertex. |  | axis | Appending axis, if file contains multiple images. Can be { 'x' | 'y' | 'z' | 'c' }. |  | align | Appending alignment. | 
 
      
        
          | CImg<T>& load_inr | ( | const char *const | filename, |  
          |  |  | float *const | voxel_size = 0 |  
          |  | ) |  |  |  
Load image from an INRIMAGE-4 file.  Parameters
  
    |  | filename | Filename, as a C-string. |  | [out] | voxel_size | Pointer to the three voxel sizes read from the file. | 
 
      
        
          | CImg<T>& load_exr | ( | const char *const | filename | ) |  |  
Load image from a EXR file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_pandore | ( | const char *const | filename | ) |  |  
Load image from a PANDORE-5 file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_parrec | ( | const char *const | filename, |  
          |  |  | const char | axis = 'c', |  
          |  |  | const float | align = 0 |  
          |  | ) |  |  |  
Load image from a PAR-REC (Philips) file.  Parameters
  
    | filename | Filename, as a C-string. |  | axis | Appending axis, if file contains multiple images. Can be { 'x' | 'y' | 'z' | 'c' }. |  | align | Appending alignment. | 
 
      
        
          | CImg<T>& load_raw | ( | const char *const | filename, |  
          |  |  | const unsigned int | size_x = 0, |  
          |  |  | const unsigned int | size_y = 1, |  
          |  |  | const unsigned int | size_z = 1, |  
          |  |  | const unsigned int | size_c = 1, |  
          |  |  | const bool | is_multiplexed = false, |  
          |  |  | const bool | invert_endianness = false |  
          |  | ) |  |  |  
Load image from a raw binary file.  Parameters
  
    | filename | Filename, as a C-string. |  | size_x | Width of the image buffer. |  | size_y | Height of the image buffer. |  | size_z | Depth of the image buffer. |  | size_c | Spectrum of the image buffer. |  | is_multiplexed | Tells if the image values are multiplexed along the C-axis. |  | invert_endianness | Tells if the endianness of the image buffer must be inverted. | 
 
      
        
          | CImg<T>& load_ffmpeg | ( | const char *const | filename, |  
          |  |  | const unsigned int | first_frame = 0, |  
          |  |  | const unsigned int | last_frame = ~0U, |  
          |  |  | const unsigned int | step_frame = 1, |  
          |  |  | const bool | pixel_format = true, |  
          |  |  | const bool | resume = false, |  
          |  |  | const char | axis = 'z', |  
          |  |  | const float | align = 0 |  
          |  | ) |  |  |  
Load image sequence using FFMPEG av's libraries.  Parameters
  
    | filename | Filename, as a C-string. |  | first_frame | Index of the first frame to read. |  | last_frame | Index of the last frame to read. |  | step_frame | Step value for frame reading. |  | pixel_format | To be documented. |  | resume | To be documented. |  | axis | Appending axis, if file contains multiple images. Can be { 'x' | 'y' | 'z' | 'c' }. |  | align | Appending alignment. | 
 
      
        
          | CImg<T>& load_yuv | ( | const char *const | filename, |  
          |  |  | const unsigned int | size_x, |  
          |  |  | const unsigned int | size_y = 1, |  
          |  |  | const unsigned int | first_frame = 0, |  
          |  |  | const unsigned int | last_frame = ~0U, |  
          |  |  | const unsigned int | step_frame = 1, |  
          |  |  | const bool | yuv2rgb = true, |  
          |  |  | const char | axis = 'z' |  
          |  | ) |  |  |  
Load image sequence from a YUV file.  Parameters
  
    | filename | Filename, as a C-string. |  | size_x | Width of the frames. |  | size_y | Height of the frames. |  | first_frame | Index of the first frame to read. |  | last_frame | Index of the last frame to read. |  | step_frame | Step value for frame reading. |  | yuv2rgb | Tells if the YUV to RGB transform must be applied. |  | axis | Appending axis, if file contains multiple images. Can be { 'x' | 'y' | 'z' | 'c' }. | 
 
      
        
          | CImg<T>& load_off | ( | CImgList< tf > & | primitives, |  
          |  |  | CImgList< tc > & | colors, |  
          |  |  | const char *const | filename |  
          |  | ) |  |  |  
Load 3d object from a .OFF file.  Parameters
  
    | [out] | primitives | Primitives data of the 3d object. |  | [out] | colors | Colors data of the 3d object. |  |  | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_ffmpeg_external | ( | const char *const | filename, |  
          |  |  | const char | axis = 'z', |  
          |  |  | const float | align = 0 |  
          |  | ) |  |  |  
Load image sequence using FFMPEG's external tool 'ffmpeg'.  Parameters
  
    | filename | Filename, as a C-string. |  | axis | Appending axis, if file contains multiple images. Can be { 'x' | 'y' | 'z' | 'c' }. |  | align | Appending alignment. | 
 
      
        
          | CImg<T>& load_gif_external | ( | const char *const | filename, |  
          |  |  | const char | axis = 'z', |  
          |  |  | const float | align = 0 |  
          |  | ) |  |  |  
Load gif file, using Imagemagick or GraphicsMagicks's external tools.  Parameters
  
    | filename | Filename, as a C-string. |  | use_graphicsmagick | Tells if GraphicsMagick's tool 'gm' is used instead of ImageMagick's tool 'convert'. |  | axis | Appending axis, if file contains multiple images. Can be { 'x' | 'y' | 'z' | 'c' }. |  | align | Appending alignment. | 
 
      
        
          | CImg<T>& load_graphicsmagick_external | ( | const char *const | filename | ) |  |  
Load image using GraphicsMagick's external tool 'gm'.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_gzip_external | ( | const char *const | filename | ) |  |  
Load gzipped image file, using external tool 'gunzip'.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_imagemagick_external | ( | const char *const | filename | ) |  |  
Load image using ImageMagick's external tool 'convert'.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_medcon_external | ( | const char *const | filename | ) |  |  
Load image from a DICOM file, using XMedcon's external tool 'medcon'.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_dcraw_external | ( | const char *const | filename | ) |  |  
Load image from a RAW Color Camera file, using external tool 'dcraw'.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | CImg<T>& load_camera | ( | const unsigned int | camera_index = 0, |  
          |  |  | const unsigned int | skip_frames = 0, |  
          |  |  | const bool | release_camera = false, |  
          |  |  | const unsigned int | capture_width = 0, |  
          |  |  | const unsigned int | capture_height = 0 |  
          |  | ) |  |  |  
Load image from a camera stream, using OpenCV.  Parameters
  
    | camera_index | Index of the camera to capture images from. |  | skip_frames | Number of frames to skip before the capture. |  | release_camera | Tells if the camera ressource must be released at the end of the method. | 
 
      
        
          | CImg<T>& load_other | ( | const char *const | filename | ) |  |  
Load image using various non-native ways.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | const CImg<T>& print | ( | const char *const | title = 0, |  
          |  |  | const bool | display_stats = true |  
          |  | ) |  | const |  
Display informations about the image data.  Parameters
  
    | title | Name for the considered image. |  | display_stats | Tells to compute and display image statistics. | 
 
      
        
          | const CImg<T>& display | ( | CImgDisplay & | disp, |  
          |  |  | const bool | display_info, |  
          |  |  | unsigned int *const | XYZ = 0 |  
          |  | ) |  | const |  
Display image into a CImgDisplay window, in an interactive way.  Parameters
  
    | disp | Display window. |  | display_info | Tells if image informations are displayed on the standard output. | 
 
      
        
          | const CImg<T>& display | ( | const char *const | title = 0, |  
          |  |  | const bool | display_info = true, |  
          |  |  | unsigned int *const | XYZ = 0 |  
          |  | ) |  | const |  
Display image into an interactive window.  Parameters
  
    | title | Window title |  | display_info | Tells if image informations are displayed on the standard output. | 
 
      
        
          | const CImg<T>& display_object3d | ( | CImgDisplay & | disp, |  
          |  |  | const CImg< tp > & | vertices, |  
          |  |  | const CImgList< tf > & | primitives, |  
          |  |  | const CImgList< tc > & | colors, |  
          |  |  | const to & | opacities, |  
          |  |  | const bool | centering = true, |  
          |  |  | const int | render_static = 4, |  
          |  |  | const int | render_motion = 1, |  
          |  |  | const bool | is_double_sided = true, |  
          |  |  | const float | focale = 700, |  
          |  |  | const float | light_x = 0, |  
          |  |  | const float | light_y = 0, |  
          |  |  | const float | light_z = -5000, |  
          |  |  | const float | specular_lightness = 0.2f, |  
          |  |  | const float | specular_shininess = 0.1f, |  
          |  |  | const bool | display_axes = true, |  
          |  |  | float *const | pose_matrix = 0 |  
          |  | ) |  | const |  
Display object 3d in an interactive window.  Parameters
  
    | disp | Display window. |  | vertices | Vertices data of the 3d object. |  | primitives | Primitives data of the 3d object. |  | colors | Colors data of the 3d object. |  | opacities | Opacities data of the 3d object. |  | centering | Tells if the 3d object must be centered for the display. |  | render_static | Rendering mode. |  | render_motion | Rendering mode, when the 3d object is moved. |  | is_double_sided | Tells if the object primitives are double-sided. |  | focale | Focale |  | light_x | X-coordinate of the light source. |  | light_y | Y-coordinate of the light source. |  | light_z | Z-coordinate of the light source. |  | specular_lightness | Amount of specular light. |  | specular_shininess | Shininess of the object material. |  | display_axes | Tells if the 3d axes are displayed. |  | pose_matrix | Pointer to 12 values, defining a 3d pose (as a 4x3 matrix). | 
 
      
        
          | const CImg<T>& display_graph | ( | CImgDisplay & | disp, |  
          |  |  | const unsigned int | plot_type = 1, |  
          |  |  | const unsigned int | vertex_type = 1, |  
          |  |  | const char *const | labelx = 0, |  
          |  |  | const double | xmin = 0, |  
          |  |  | const double | xmax = 0, |  
          |  |  | const char *const | labely = 0, |  
          |  |  | const double | ymin = 0, |  
          |  |  | const double | ymax = 0 |  
          |  | ) |  | const |  
Display 1d graph in an interactive window.  Parameters
  
    | disp | Display window. |  | plot_type | Plot type. Can be { 0=points | 1=segments | 2=splines | 3=bars }. |  | vertex_type | Vertex type. |  | labelx | Title for the horizontal axis, as a C-string. |  | xmin | Minimum value along the X-axis. |  | xmax | Maximum value along the X-axis. |  | labely | Title for the vertical axis, as a C-string. |  | ymin | Minimum value along the X-axis. |  | ymax | Maximum value along the X-axis. | 
 
      
        
          | const CImg<T>& save | ( | const char *const | filename, |  
          |  |  | const int | number = -1, |  
          |  |  | const unsigned int | digits = 6 |  
          |  | ) |  | const |  
Save image as a file.  Parameters
  
    | filename | Filename, as a C-string. |  | number | When positive, represents an index added to the filename. Otherwise, no number is added. |  | digits | Number of digits used for adding the number to the filename. | 
 Note
The used file format is defined by the file extension in the filename filename.Parameter numbercan be used to add a 6-digit number to the filename before saving.
 
      
        
          | const CImg<T>& save_ascii | ( | const char *const | filename | ) | const |  
Save image as an ascii file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | const CImg<T>& save_cpp | ( | const char *const | filename | ) | const |  
Save image as a .cpp source file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | const CImg<T>& save_dlm | ( | const char *const | filename | ) | const |  
Save image as a DLM file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | const CImg<T>& save_bmp | ( | const char *const | filename | ) | const |  
Save image as a BMP file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | const CImg<T>& save_jpeg | ( | const char *const | filename, |  
          |  |  | const unsigned int | quality = 100 |  
          |  | ) |  | const |  
Save image as a JPEG file.  Parameters
  
    | filename | Filename, as a C-string. |  | quality | Image quality (in %) | 
 
      
        
          | const CImg<T>& save_magick | ( | const char *const | filename, |  
          |  |  | const unsigned int | bytes_per_pixel = 0 |  
          |  | ) |  | const |  
Save image, using built-in ImageMagick++ library.  Parameters
  
    | filename | Filename, as a C-string. |  | bytes_per_pixel | Force the number of bytes per pixel for the saving, when possible. | 
 
      
        
          | const CImg<T>& save_png | ( | const char *const | filename, |  
          |  |  | const unsigned int | bytes_per_pixel = 0 |  
          |  | ) |  | const |  
Save image as a PNG file.  Parameters
  
    | filename | Filename, as a C-string. |  | bytes_per_pixel | Force the number of bytes per pixels for the saving, when possible. | 
 
      
        
          | const CImg<T>& save_pnm | ( | const char *const | filename, |  
          |  |  | const unsigned int | bytes_per_pixel = 0 |  
          |  | ) |  | const |  
Save image as a PNM file.  Parameters
  
    | filename | Filename, as a C-string. |  | bytes_per_pixel | Force the number of bytes per pixels for the saving. | 
 
      
        
          | const CImg<T>& save_pnk | ( | const char *const | filename | ) | const |  
Save image as a PNK file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | const CImg<T>& save_pfm | ( | const char *const | filename | ) | const |  
Save image as a PFM file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | const CImg<T>& save_rgb | ( | const char *const | filename | ) | const |  
Save image as a RGB file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | const CImg<T>& save_rgba | ( | const char *const | filename | ) | const |  
Save image as a RGBA file.  Parameters
  
    | filename | Filename, as a C-string. | 
 
      
        
          | const CImg<T>& save_tiff | ( | const char *const | filename, |  
          |  |  | const unsigned int | compression_type = 0 |  
          |  | ) |  | const |  
Save image as a TIFF file.  Parameters
  
    | filename | Filename, as a C-string. |  | compression_type | Type of data compression. Can be { 1=None | 2=CCITTRLE | 3=CCITTFAX3 | 4=CCITTFAX4 | 5=LZW | 6=JPEG }. | 
 Note
libtiff support is enabled by defining the precompilation directive cimg_use_tif.When libtiff is enabled, 2D and 3D (multipage) several channel per pixel are supported for char,uchar,short,ushort,floatanddoublepixel types.If cimg_use_tifis not defined at compilation time the function uses CImg<T>&save_other(const char*).
 
      
        
          | const CImg<T>& save_minc2 | ( | const char *const | filename, |  
          |  |  | const char *const | imitate_file = 0 |  
          |  | ) |  | const |  
Save image as a MINC2 file.  Parameters
  
    | filename | Filename, as a C-string. |  | imitate_file | If non-zero, reference filename, as a C-string, to borrow header from. | 
 
      
        
          | const CImg<T>& save_analyze | ( | const char *const | filename, |  
          |  |  | const float *const | voxel_size = 0 |  
          |  | ) |  | const |  
Save image as an ANALYZE7.5 or NIFTI file.  Parameters
  
    | filename | Filename, as a C-string. |  | voxel_size | Pointer to 3 consecutive values that tell about the voxel sizes along the X,Y and Z dimensions. | 
 
      
        
          | const CImg<T>& save_cimg | ( | const char *const | filename, |  
          |  |  | const bool | is_compressed = false |  
          |  | ) |  | const |  
Save image as a .cimg file.  Parameters
  
    | filename | Filename, as a C-string. |  | is_compressed | Tells if the file contains compressed image data. | 
 
      
        
          | const CImg<T>& save_cimg | ( | const char *const | filename, |  
          |  |  | const unsigned int | n0, |  
          |  |  | const unsigned int | x0, |  
          |  |  | const unsigned int | y0, |  
          |  |  | const unsigned int | z0, |  
          |  |  | const unsigned int | c0 |  
          |  | ) |  | const |  
Save image as a sub-image into an existing .cimg file.  Parameters
  
    | filename | Filename, as a C-string. |  | n0 | Index of the image inside the file. |  | x0 | X-coordinate of the sub-image location. |  | y0 | Y-coordinate of the sub-image location. |  | z0 | Z-coordinate of the sub-image location. |  | c0 | C-coordinate of the sub-image location. | 
 
  
  | 
        
          | static void save_empty_cimg | ( | const char *const | filename, |  
          |  |  | const unsigned int | dx, |  
          |  |  | const unsigned int | dy = 1, |  
          |  |  | const unsigned int | dz = 1, |  
          |  |  | const unsigned int | dc = 1 |  
          |  | ) |  |  |  | static |  
Save blank image as a .cimg file.  Parameters
  
    | filename | Filename, as a C-string. |  | dx | Width of the image. |  | dy | Height of the image. |  | dz | Depth of the image. |  | dc | Number of channels of the image. | 
 Note
All pixel values of the saved image are set to 0.Use this method to save large images without having to instanciate and allocate them. 
 
  
  | 
        
          | static void save_empty_cimg | ( | std::FILE *const | file, |  
          |  |  | const unsigned int | dx, |  
          |  |  | const unsigned int | dy = 1, |  
          |  |  | const unsigned int | dz = 1, |  
          |  |  | const unsigned int | dc = 1 |  
          |  | ) |  |  |  | static |  
      
        
          | const CImg<T>& save_inr | ( | const char *const | filename, |  
          |  |  | const float *const | voxel_size = 0 |  
          |  | ) |  | const |  
Save image as an INRIMAGE-4 file.  Parameters
  
    | filename | Filename, as a C-string. |  | voxel_size | Pointer to 3 values specifying the voxel sizes along the X,Y and Z dimensions. | 
 
      
        
          | const CImg<T>& save_exr | ( | const char *const | filename | ) | const |  
Save image as an OpenEXR file.  Parameters
  
    | filename | Filename, as a C-string. | 
 NoteThe OpenEXR file format is described here. 
 
      
        
          | const CImg<T>& save_pandore | ( | const char *const | filename, |  
          |  |  | const unsigned int | colorspace = 0 |  
          |  | ) |  | const |  
Save image as a Pandore-5 file.  Parameters
  
    | filename | Filename, as a C-string. |  | colorspace | Colorspace data field in output file (see Pandore file specifications for more informations). | 
 
      
        
          | const CImg<T>& save_pandore | ( | std::FILE *const | file, |  
          |  |  | const unsigned int | colorspace = 0 |  
          |  | ) |  | const |  
      
        
          | const CImg<T>& save_raw | ( | const char *const | filename, |  
          |  |  | const bool | is_multiplexed = false |  
          |  | ) |  | const |  
Save image as a raw data file.  Parameters
  
    | filename | Filename, as a C-string. |  | is_multiplexed | Tells if the image channels are stored in a multiplexed way ( true) or not (false). | 
 NoteThe .raw format does not store the image dimensions in the output file, so you have to keep track of them somewhere to be able to read the file correctly afterwards. 
 
      
        
          | const CImg<T>& save_raw | ( | std::FILE *const | file, |  
          |  |  | const bool | is_multiplexed = false |  
          |  | ) |  | const |  
      
        
          | const CImg<T>& save_ffmpeg | ( | const char *const | filename, |  
          |  |  | const unsigned int | fps = 25, |  
          |  |  | const unsigned int | bitrate = 2048 |  
          |  | ) |  | const |  
Save image as a video file, using the FFmpeg library.  Parameters
  
    | filename | Filename, as a C-string. |  | fps | Video framerate. |  | bitrate | Video bitrate. | 
 Note
Each slice of the instance image is considered to be a single frame of the output video file.This method uses functions provided by the FFmpeg library. Configuration macro cimg_use_ffmpegmust be set for the method to succeed natively. Otherwise, the method calls save_ffmpeg_external(const char*,unsigned int,unsigned int,const char*,unsigned int,unsigned int) const.
 
      
        
          | const CImg<T>& save_yuv | ( | const char *const | filename, |  
          |  |  | const bool | is_rgb = true |  
          |  | ) |  | const |  
Save image as a .yuv video file.  Parameters
  
    | filename | Filename, as a C-string. |  | is_rgb | Tells if pixel values of the instance image are RGB-coded ( true) or YUV-coded (false). | 
 NoteEach slice of the instance image is considered to be a single frame of the output video file. 
 
      
        
          | const CImg<T>& save_yuv | ( | std::FILE *const | file, |  
          |  |  | const bool | is_rgb = true |  
          |  | ) |  | const |  
      
        
          | const CImg<T>& save_off | ( | const CImgList< tf > & | primitives, |  
          |  |  | const CImgList< tc > & | colors, |  
          |  |  | const char *const | filename |  
          |  | ) |  | const |  
Save 3d object as an Object File Format (.off) file.  Parameters
  
    | filename | Filename, as a C-string. |  | primitives | List of 3d object primitives. |  | colors | List of 3d object colors. | 
 Note
Instance image contains the vertices data of the 3d object.Textured, transparent or sphere-shaped primitives cannot be managed by the .off file format. Such primitives will be lost or simplified during file saving.The .off file format is described here. 
 
      
        
          | const CImg<T>& save_off | ( | const CImgList< tf > & | primitives, |  
          |  |  | const CImgList< tc > & | colors, |  
          |  |  | std::FILE *const | file |  
          |  | ) |  | const |  
      
        
          | const CImg<T>& save_ffmpeg_external | ( | const char *const | filename, |  
          |  |  | const char *const | codec = 0, |  
          |  |  | const unsigned int | fps = 25, |  
          |  |  | const unsigned int | bitrate = 2048 |  
          |  | ) |  | const |  
Save volumetric image as a video, using ffmpeg external binary.  Parameters
  
    | filename | Filename, as a C-string. |  | codec | Video codec, as a C-string. |  | fps | Video framerate. |  | bitrate | Video bitrate. | 
 Note
Each slice of the instance image is considered to be a single frame of the output video file.This method uses ffmpeg, an external executable binary provided by FFmpeg. It must be installed for the method to succeed.
 
      
        
          | const CImg<T>& save_gzip_external | ( | const char *const | filename | ) | const |  
Save image using gzip external binary.  Parameters
  
    | filename | Filename, as a C-string. | 
 NoteThis method uses gzip, an external executable binary provided by gzip. It must be installed for the method to succeed.
 
      
        
          | const CImg<T>& save_graphicsmagick_external | ( | const char *const | filename, |  
          |  |  | const unsigned int | quality = 100 |  
          |  | ) |  | const |  
Save image using GraphicsMagick's external binary.  Parameters
  
    | filename | Filename, as a C-string. |  | quality | Image quality (expressed in percent), when the file format supports it. | 
 NoteThis method uses gm, an external executable binary provided by GraphicsMagick. It must be installed for the method to succeed.
 
      
        
          | const CImg<T>& save_imagemagick_external | ( | const char *const | filename, |  
          |  |  | const unsigned int | quality = 100 |  
          |  | ) |  | const |  
Save image using ImageMagick's external binary.  Parameters
  
    | filename | Filename, as a C-string. |  | quality | Image quality (expressed in percent), when the file format supports it. | 
 NoteThis method uses convert, an external executable binary provided by ImageMagick. It must be installed for the method to succeed.
 
      
        
          | const CImg<T>& save_medcon_external | ( | const char *const | filename | ) | const |  
Save image as a Dicom file.  Parameters
  
    | filename | Filename, as a C-string. | 
 NoteThis method uses medcon, an external executable binary provided by (X)Medcon. It must be installed for the method to succeed.
 
      
        
          | const CImg<T>& save_other | ( | const char *const | filename, |  
          |  |  | const unsigned int | quality = 100 |  
          |  | ) |  | const |  
Parameters
  
    | filename | Filename, as a C-string. |  | quality | Image quality (expressed in percent), when the file format supports it. | 
 Note
The filename extension tells about the desired file format.This method tries to save the instance image as a file, using external tools from ImageMagick or GraphicsMagick. At least one of these tool must be installed for the method to succeed.It is recommended to use the generic method save(const char*, int) const instead, as it can handle some file formats natively. 
 |