Public Member Functions | Public Attributes | List of all members
GammaFunctor Class Reference

Gamma correction. Intensity is mapped as f' = f^(gamma) More...

#include <GammaOp.h>

Inheritance diagram for GammaFunctor:
Inheritance graph
[legend]
Collaboration diagram for GammaFunctor:
Collaboration graph
[legend]

Public Member Functions

 GammaFunctor (double gamma=1.0)
 
 GammaFunctor (const GammaFunctor &ftor)
 
double operator() (double s) const
 
- Public Member Functions inherited from UnaryFunctor
 UnaryFunctor (const std::string &name, const std::string &description="", double scale=1.0, double bias=0.0)
 
- Public Member Functions inherited from Functor
void setScale (double scale, double bias=0.0)
 
virtual void updateBean () const override
 Called after setParameters()
 
- Public Member Functions inherited from BeanLike
virtual const std::string & getName () const
 Return the name of an instance.
 
virtual const std::string & getDescription () const
 Return a brief description.
 
bool hasParameters () const
 
template<class F >
getParameter (const std::string &p) const
 Gets a single parameter.
 
const ReferenceMapgetParameters () const
 
ReferenceMapgetParameters ()
 
template<class F >
void setParametersFromEntries (const F &args)
 
void setParameters (std::initializer_list< Variable::init_pair_t > args)
 Grants access to (if above hidden)
 
virtual void setParameters (const std::string &p, char assignmentSymbol='=', char separatorSymbol=0)
 Sets comma-separated parameters in a predetermined order "a,b,c" or by specifing them "b=2". More...
 
template<class T >
void setParameters (const std::map< std::string, T > &args)
 Set parameters.
 
template<class T >
void setParameters (const SmartMap< T > &args)
 Set parameters.
 
void setParameter (const std::string &p, const Castable &value)
 Sets a single parameter.
 
template<class T >
void setParameter (const std::string &p, const VariableT< T > &value)
 
template<class F >
void setParameter (const std::string &p, const F &value)
 Sets a single parameter. More...
 
template<class F >
void setParameter (const std::string &p, std::initializer_list< F > value)
 Sets a single parameter.
 
BeanLikeoperator= (const BeanLike &b)
 
virtual std::ostream & toStream (std::ostream &ostr, bool compact=true) const
 
 BeanLike (const BeanLike &b)
 
 BeanLike (const std::string &name, const std::string &description="")
 

Public Attributes

double gamma
 

Additional Inherited Members

- Protected Member Functions inherited from Functor
 Functor (const std::string &name, const std::string &description="", double scale=1.0, double bias=0.0)
 
 Functor (const Functor &fct)
 
virtual void updateScale () const
 
- Protected Member Functions inherited from BeanLike
virtual void storeLastArguments (const std::string &p)
 Called after setParameters()
 
- Protected Attributes inherited from Functor
double scale
 Relative scale, typically 1. Optional.
 
double bias
 "Relative" bias, typically 0. Optional.
 
double scaleFinal
 Scaling factor after encodings of src and dst images are known.
 
double biasFinal
 Scaling factor after encodings of src and dst images are known.
 
- Protected Attributes inherited from BeanLike
const std::string name
 
const std::string description
 
ReferenceMap parameters
 

Detailed Description

Gamma correction. Intensity is mapped as f' = f^(gamma)

Adjusts the brightness such that intensities remain monotonously inside the original scale. Unlike in direct linear scaling neither underflow nor overflow occurs and visual details remain detectable down to applied bit resolution.

Prior to calling this function it should be ensured that the source image has normalized scale (eg. with –physicalRange, -R ).

drainage image-gray.png -R 0:1 --iGamma 1.5 -o gamma-bright.png
drainage image-gray.png -R 0:1 --iGamma 2.0 -o gamma-bright.png
drainage image-gray.png -R 0:1 --iGamma 0.5 -o gamma-dark.png
drainage image-color.png -R 0:1 --iGamma 2.0 -o gamma-color-bright.png
drainage image-color.png -R 0:1 --iGamma 0.5 -o gamma-color-dark.png
See also
FunctorOp

NOTE. Design for parameters may vary in future, since multichannel image could be handled by giving a value for each: 1.2,1.4,0.7 for example.


The documentation for this class was generated from the following file: