| DGtalTools 
    0.9.4
    | 
#include <imageProcessing/ATu0v1.h>


| Public Member Functions | |
| BOOST_STATIC_ASSERT ((KSpace::dimension==2)) | |
| ~ATu0v1 ()=default | |
| ATu0v1 (int _verbose=1) | |
| void | init (Clone< KSpace > K) | 
| ATu0v1 (const ATu0v1 &other)=delete | |
| ATu0v1 (ATu0v1 &&other)=delete | |
| ATu0v1 & | operator= (const ATu0v1 &other)=delete | 
| ATu0v1 & | operator= (ATu0v1 &&other)=delete | 
| template<typename Image , typename Function > | |
| void | addInput (const Image &image, const Function &f, bool perfect_data=false) | 
| void | setUFromInput () | 
| void | setAlpha (Scalar _alpha) | 
| void | setAlpha (Scalar _alpha, const PrimalForm0 &m) | 
| void | setLambda (Scalar _lambda) | 
| void | setEpsilon (Scalar _epsilon) | 
| Scalar | computeSNR () const | 
| Scalar | getAlpha () const | 
| Scalar | getLambda () const | 
| Scalar | getEpsilon () const | 
| const PrimalForm0 & | getG (int i) const | 
| const PrimalForm0 & | getU (int i) const | 
| const PrimalForm1 & | getV () const | 
| unsigned int | size0 () const | 
| unsigned int | size1 () const | 
| bool | solveU () | 
| bool | solveV () | 
| Scalar | computeVariation () | 
| Scalar | checkV () | 
| void | selfDisplay (std::ostream &out) const | 
| bool | isValid () const | 
|  Public Member Functions inherited from DGtal::DECImage2D< TKSpace, TLinearAlgebra > | |
| BOOST_CONCEPT_ASSERT ((concepts::CCellularGridSpaceND< KSpace >)) | |
| BOOST_STATIC_ASSERT ((KSpace::dimension==2)) | |
| ~DECImage2D ()=default | |
| DECImage2D (int _verbose=1) | |
| void | init (Clone< KSpace > aKSpace) | 
| DECImage2D (const DECImage2D &other)=delete | |
| DECImage2D (DECImage2D &&other)=delete | |
| DECImage2D & | operator= (const DECImage2D &other)=delete | 
| DECImage2D & | operator= (DECImage2D &&other)=delete | 
| Protected Attributes | |
| std::vector< PrimalForm0 > | g0 | 
| std::vector< PrimalForm0 > | i0 | 
| std::vector< PrimalForm0 > | u0 | 
| PrimalForm1 | v1 | 
| PrimalForm1 | former_v1 | 
| double | alpha | 
| double | lambda | 
| double | epsilon | 
| SolverU | solver_u | 
| SolverV | solver_v | 
| PrimalIdentity0 | alpha_Id0 | 
| std::vector< PrimalForm0 > | alpha_g0 | 
| PrimalIdentity1 | l_L1 | 
| PrimalForm1 | l_1_over_4 | 
| PrimalIdentity1 | left_V1 | 
| PrimalForm1 | l_1_over_4e | 
Aim: This class solves Ambrosio-Tortorelli functional in a plane for u a (vector of) 0-form(s) and v a 1-form. u is a regularized approximation of an input data g, while v represents the set of discontinuities of u.
Description of template class 'ATu0v1'
| TKSpace | any model of CCellularGridSpaceND, e.g KhalimskySpaceND | 
| TLinearAlgebra | any back-end for performing linear algebra, default is EigenLinearAlgebraBackend. | 
| typedef DECImage2D<TKSpace, TLinearAlgebra> DGtal::ATu0v1< TKSpace, TLinearAlgebra >::Base | 
| typedef DiscreteExteriorCalculus<2,2, LinearAlgebra> DGtal::DECImage2D< TKSpace, TLinearAlgebra >::Calculus | 
Definition at line 753 of file DECImageHelpers.h.
| typedef HyperRectDomain<Space> DGtal::DECImage2D< TKSpace, TLinearAlgebra >::Domain | 
Definition at line 752 of file DECImageHelpers.h.
| typedef Calculus::DualDerivative0 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::DualDerivative0 | 
Definition at line 764 of file DECImageHelpers.h.
| typedef Calculus::DualDerivative1 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::DualDerivative1 | 
Definition at line 765 of file DECImageHelpers.h.
| typedef Calculus::DualHodge0 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::DualHodge0 | 
Definition at line 773 of file DECImageHelpers.h.
| typedef Calculus::DualHodge1 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::DualHodge1 | 
Definition at line 774 of file DECImageHelpers.h.
| typedef Calculus::DualHodge2 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::DualHodge2 | 
Definition at line 775 of file DECImageHelpers.h.
| typedef Calculus::Index DGtal::DECImage2D< TKSpace, TLinearAlgebra >::Index | 
Definition at line 755 of file DECImageHelpers.h.
| typedef TKSpace DGtal::ATu0v1< TKSpace, TLinearAlgebra >::KSpace | 
| typedef TLinearAlgebra DGtal::ATu0v1< TKSpace, TLinearAlgebra >::LinearAlgebra | 
| typedef LinearAlgebra::SolverSimplicialLLT DGtal::ATu0v1< TKSpace, TLinearAlgebra >::LinearAlgebraSolver | 
| typedef Space::Point DGtal::DECImage2D< TKSpace, TLinearAlgebra >::Point | 
Definition at line 746 of file DECImageHelpers.h.
| typedef Calculus::PrimalDerivative0 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalDerivative0 | 
Definition at line 762 of file DECImageHelpers.h.
| typedef Calculus::PrimalDerivative1 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalDerivative1 | 
Definition at line 763 of file DECImageHelpers.h.
| typedef Calculus::PrimalForm0 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalForm0 | 
Definition at line 756 of file DECImageHelpers.h.
| typedef Calculus::PrimalForm1 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalForm1 | 
Definition at line 757 of file DECImageHelpers.h.
| typedef Calculus::PrimalForm2 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalForm2 | 
Definition at line 758 of file DECImageHelpers.h.
| typedef Calculus::PrimalHodge0 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalHodge0 | 
Definition at line 770 of file DECImageHelpers.h.
| typedef Calculus::PrimalHodge1 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalHodge1 | 
Definition at line 771 of file DECImageHelpers.h.
| typedef Calculus::PrimalHodge2 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalHodge2 | 
Definition at line 772 of file DECImageHelpers.h.
| typedef Calculus::PrimalIdentity0 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalIdentity0 | 
Definition at line 759 of file DECImageHelpers.h.
| typedef Calculus::PrimalIdentity1 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalIdentity1 | 
Definition at line 760 of file DECImageHelpers.h.
| typedef Calculus::PrimalIdentity2 DGtal::DECImage2D< TKSpace, TLinearAlgebra >::PrimalIdentity2 | 
Definition at line 761 of file DECImageHelpers.h.
| typedef Space::RealVector DGtal::DECImage2D< TKSpace, TLinearAlgebra >::RealVector | 
Definition at line 747 of file DECImageHelpers.h.
| typedef RealVector::Component DGtal::DECImage2D< TKSpace, TLinearAlgebra >::Scalar | 
Definition at line 748 of file DECImageHelpers.h.
| typedef KSpace::SCell DGtal::DECImage2D< TKSpace, TLinearAlgebra >::SCell | 
Definition at line 749 of file DECImageHelpers.h.
| typedef DiscreteExteriorCalculusSolver<Calculus, LinearAlgebraSolver, 0, PRIMAL, 0, PRIMAL> DGtal::ATu0v1< TKSpace, TLinearAlgebra >::SolverU | 
| typedef DiscreteExteriorCalculusSolver<Calculus, LinearAlgebraSolver, 1, PRIMAL, 1, PRIMAL> DGtal::ATu0v1< TKSpace, TLinearAlgebra >::SolverV | 
| typedef KSpace::Space DGtal::DECImage2D< TKSpace, TLinearAlgebra >::Space | 
Definition at line 745 of file DECImageHelpers.h.
| 
 | default | 
Destructor.
| DGtal::ATu0v1< TKSpace, TLinearAlgebra >::ATu0v1 | ( | int | _verbose = 1 | ) | 
Default constructor. The object needs to be initialized with init.
| _verbose | specifies the verbose level (0: silent, 1: more info ... ). | 
| 
 | delete | 
Copy constructor.
| other | the object to clone. | 
| 
 | delete | 
Move constructor.
| other | the object to move. | 
| void DGtal::ATu0v1< TKSpace, TLinearAlgebra >::addInput | ( | const Image & | image, | 
| const Function & | f, | ||
| bool | perfect_data = false | ||
| ) | 
Adds an input 0-form by filtering an image values.
| image | any image such that the domain of this space is included in the domain of the image. | 
| f | any functor associating a scalar to an image value. | 
| perfect_data | when 'false', this is normal input data, otherwise this is perfect data only used for SNR computation. | 
unsigned char, should be called asColor, should be called as | Image | any Image type. | 
| Function | any function type ( typename Image::Value ) -> Scalar. | 
| DGtal::ATu0v1< TKSpace, TLinearAlgebra >::BOOST_STATIC_ASSERT | ( | (KSpace::dimension==2) | ) | 
| Scalar DGtal::ATu0v1< TKSpace, TLinearAlgebra >::checkV | ( | ) | 
Checks that form v is between 0 and 1 and forces v to be in-between.
| Scalar DGtal::ATu0v1< TKSpace, TLinearAlgebra >::computeSNR | ( | ) | const | 
Computes the SNR of u wrt ideal input (should have been given.
| Scalar DGtal::ATu0v1< TKSpace, TLinearAlgebra >::computeVariation | ( | ) | 
Computes the variation of v after a call to solveV.
| 
 | inline | 
Definition at line 262 of file ATu0v1.h.
References DGtal::ATu0v1< TKSpace, TLinearAlgebra >::alpha.
| 
 | inline | 
Definition at line 268 of file ATu0v1.h.
References DGtal::ATu0v1< TKSpace, TLinearAlgebra >::epsilon.
| 
 | inline | 
| i | an integer (between 0 and the number of input forms). | 
Definition at line 272 of file ATu0v1.h.
References DGtal::ATu0v1< TKSpace, TLinearAlgebra >::g0.
| 
 | inline | 
Definition at line 265 of file ATu0v1.h.
References DGtal::ATu0v1< TKSpace, TLinearAlgebra >::lambda.
| 
 | inline | 
| i | an integer (between 0 and the number of input forms). | 
Definition at line 276 of file ATu0v1.h.
References DGtal::ATu0v1< TKSpace, TLinearAlgebra >::u0.
| 
 | inline | 
Definition at line 279 of file ATu0v1.h.
References DGtal::ATu0v1< TKSpace, TLinearAlgebra >::v1.
| void DGtal::ATu0v1< TKSpace, TLinearAlgebra >::init | ( | Clone< KSpace > | K | ) | 
Constructor from Khalimsky space, which specifies the domain of calculus.
| bool DGtal::ATu0v1< TKSpace, TLinearAlgebra >::isValid | ( | ) | const | 
Checks the validity/consistency of the object.
| 
 | delete | 
Copy assignment operator.
| other | the object to copy. | 
| 
 | delete | 
Move assignment operator.
| other | the object to move. | 
| void DGtal::ATu0v1< TKSpace, TLinearAlgebra >::selfDisplay | ( | std::ostream & | out | ) | const | 
Writes/Displays the object on an output stream.
| out | the output stream where the object is written. | 
| void DGtal::ATu0v1< TKSpace, TLinearAlgebra >::setAlpha | ( | Scalar | _alpha | ) | 
Sets the parameter \( alpha \) as global to the image. Should be set before setLambda and setEpsilon.
| _alpha | the \( \alpha \) parameter in AT functional ( in term \( \int \alpha | u - g |^2 \) ). Dimension theory tells that it is in 1/area unit, the lower the smoother will be the output. | 
| void DGtal::ATu0v1< TKSpace, TLinearAlgebra >::setAlpha | ( | Scalar | _alpha, | 
| const PrimalForm0 & | m | ||
| ) | 
Sets the parameter \( alpha \) of the image, as well as a weight for each input data as the primal 0-form m. Should be set before setLambda and setEpsilon.
| _alpha | the \( \alpha \) parameter in AT functional ( in term \( \int \alpha | u - g |^2 \) ). Dimension theory tells that it is in 1/area unit, the lower the smoother will be the output. | 
| m | a 0-form that specifies which input data is significant (1) or not be used (0). | 
| void DGtal::ATu0v1< TKSpace, TLinearAlgebra >::setEpsilon | ( | Scalar | _epsilon | ) | 
Sets the parameter \( \epsilon \) of AT functional. Should be set after setAlpha and setLambda.
| _epsilon | the \( \epsilon \) parameter in AT functional ( in terms \( \int \lambda \epsilon | v \grad u |^2 + \int \frac{\lambda}{4\epsilon} |1-v|^2 \) ). Dimension theory tells that it is in length unit, the lower the thinner is the set of discontinuities. | 
| void DGtal::ATu0v1< TKSpace, TLinearAlgebra >::setLambda | ( | Scalar | _lambda | ) | 
Sets the parameter \( \lambda \) of AT functional. Should be set after setAlpha and before setEpsilon.
| _lambda | the \( \lambda \) parameter in AT functional ( in terms \( \int \lambda \epsilon | v \grad u |^2 + \int \frac{\lambda}{4\epsilon} |1-v|^2 \) ). Dimension theory tells that it is in 1/length unit, the lower the longer is the set of discontinuities. | 
| void DGtal::ATu0v1< TKSpace, TLinearAlgebra >::setUFromInput | ( | ) | 
Sets approximation u to be equal to the input. Used for initializating u. Should be called once all addInput have been called.
| 
 | inline | 
Definition at line 282 of file ATu0v1.h.
References DGtal::ATu0v1< TKSpace, TLinearAlgebra >::alpha_Id0, and DGtal::LinearOperator< TCalculus, order_in, duality_in, order_out, duality_out >::myContainer.
| 
 | inline | 
Definition at line 285 of file ATu0v1.h.
References DGtal::KForm< TCalculus, order, duality >::myContainer, and DGtal::ATu0v1< TKSpace, TLinearAlgebra >::v1.
| bool DGtal::ATu0v1< TKSpace, TLinearAlgebra >::solveU | ( | ) | 
Computes a solution to function(s) u given the input g and current v.
| bool DGtal::ATu0v1< TKSpace, TLinearAlgebra >::solveV | ( | ) | 
Computes a solution to function v given the input g and current u.
| 
 | protected | 
Smoothness parameter alpha of AT (in 1/area unit)
Definition at line 351 of file ATu0v1.h.
Referenced by DGtal::ATu0v1< TKSpace, TLinearAlgebra >::getAlpha().
| 
 | protected | 
| 
 | protected | 
alpha Id0
Definition at line 363 of file ATu0v1.h.
Referenced by DGtal::ATu0v1< TKSpace, TLinearAlgebra >::size0().
| Scalar DGtal::ATu0v1< TKSpace, TLinearAlgebra >::delta_v_l1 | 
| Scalar DGtal::ATu0v1< TKSpace, TLinearAlgebra >::delta_v_l2 | 
| Scalar DGtal::ATu0v1< TKSpace, TLinearAlgebra >::delta_v_loo | 
| 
 | protected | 
Thickness of discontinuity set (in length unit).
Definition at line 355 of file ATu0v1.h.
Referenced by DGtal::ATu0v1< TKSpace, TLinearAlgebra >::getEpsilon().
| 
 | protected | 
| 
 | protected | 
The g 0-forms.
Definition at line 341 of file ATu0v1.h.
Referenced by DGtal::ATu0v1< TKSpace, TLinearAlgebra >::getG().
| 
 | protected | 
| PrimalIdentity1 DGtal::ATu0v1< TKSpace, TLinearAlgebra >::L1 | 
| 
 | protected | 
| 
 | protected | 
| 
 | protected | 
| 
 | protected | 
Amount of discontinuity parameter lambda (in 1/length unit).
Definition at line 353 of file ATu0v1.h.
Referenced by DGtal::ATu0v1< TKSpace, TLinearAlgebra >::getLambda().
| 
 | protected | 
| 
 | protected | 
| 
 | protected | 
| 
 | protected | 
The u 0-forms.
Definition at line 345 of file ATu0v1.h.
Referenced by DGtal::ATu0v1< TKSpace, TLinearAlgebra >::getU().
| 
 | protected | 
The v 1-form.
Definition at line 347 of file ATu0v1.h.
Referenced by DGtal::ATu0v1< TKSpace, TLinearAlgebra >::getV(), and DGtal::ATu0v1< TKSpace, TLinearAlgebra >::size1().
 1.8.10
 1.8.10