IPSDK  4_1_0_2
IPSDK : Image Processing Software Development Kit
RichardsonLucyDeblur3dImgLvl1.h
1 // RichardsonLucyDeblur3dImgLvl1.h:
3 // --------------------------------
4 //
14 
15 #ifndef __IPSDKIPLFILTERING_RICHARDSONLUCYDEBLUR3DIMGLVL1_H__
16 #define __IPSDKIPLFILTERING_RICHARDSONLUCYDEBLUR3DIMGLVL1_H__
17 
21 
22 // Attributes headers
23 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Input/3d/InImg3d.h>
24 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/OutImg.h>
25 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk1RealImg.h>
26 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/Optional/OutOptWk1Img.h>
27 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InNbIter.h>
28 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InStdDevX.h>
29 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InStdDevY.h>
30 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InStdDevZ.h>
31 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/DataItem/InOptSmoothingGaussianCoverage.h>
32 #include <IPSDKIPL/IPSDKIPLAttributes/DataItem/StatsResult.h>
33 
34 namespace ipsdk {
35 namespace imaproc {
36 namespace filter {
37 
40 
41 // declare processor class
42 IPSDK_DECLARE_LVL1_PROCESSOR(REP_ASYNC1, IPSDKIPLFiltering, RichardsonLucyDeblur3dImg,
43  ipsdk::imaproc::matchSize(_pInImg3d, _pOutWk1RealImg) &&
44  ipsdk::imaproc::matchSizeAndType(_pInImg3d, _pOutImg) &&
45  ipsdk::imaproc::noInSitu(_pInImg3d, _pOutWk1RealImg) &&
46  ipsdk::imaproc::noInSitu(_pOutImg, _pOutWk1RealImg) &&
48  ipsdk::imaproc::matchSizeAndType(_pInImg3d, _pOutOptWk1Img),
50  (((ipsdk)(imaproc)(attr))(InImg3d))
51  (((ipsdk)(imaproc)(attr))(InNbIter))
52  (((ipsdk)(imaproc)(attr))(InStdDevX))
53  (((ipsdk)(imaproc)(attr))(InStdDevY))
54  (((ipsdk)(imaproc)(attr))(InStdDevZ))
55  (((ipsdk)(imaproc)(attr))(InOptSmoothingGaussianCoverage))
56  (((ipsdk)(imaproc)(attr))(OutImg)(ipsdk::imaproc::duplicateInOut)(_pInImg3d))
57  (((ipsdk)(imaproc)(attr))(OutWk1RealImg)(ipsdk::imaproc::duplicateInOut)(_pInImg3d)(ipsdk::image::eImageBufferType::eIBT_Real32))
58  (((ipsdk)(imaproc)(attr))(OutOptWk1Img)))
59 
60 // methods
61 public:
62 
63 protected:
64  processor::RetrievalResult provideProcessor(const boost::shared_ptr<core::BaseAction>& pProcessor,
65  const core::BasePriority& priority,
66  core::ActionProviderPtr& pProvider);
67 
68  processor::RetrievalResult statsMsr(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
69  processor::RetrievalResult subtractScalar(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
70  processor::RetrievalResult copy(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
71  processor::RetrievalResult gaussSmooth(const core::BasePriority& priority, core::ActionProviderPtr& pProvider, const ipsdk::image::ImageConstPtr& pInImg);
72  processor::RetrievalResult divide(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
73  processor::RetrievalResult multiply(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
74  processor::RetrievalResult addScalar(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
75  processor::RetrievalResult histoMatch(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
76 
77 // attributes
78 protected:
80  ipUInt32 _nbIter;
81  ipReal32 _inStdDevX;
82  ipReal32 _inStdDevY;
83  ipReal32 _inStdDevZ;
84  attr::GaussianCoverageConstPtr _pInOptGaussianCoverage;
85  ipReal64 _minValue;
86 
88  attr::StatsResultPtr _pStatsPtr;
89  ipsdk::image::ImageConstPtr _pCurInImg;
90  ipsdk::image::ImagePtr _pCurOutImg;
91  ipsdk::image::ImagePtr _pCurWkImg;
92 
94  ipUInt32 _iterOffset;
95 
96 };
97 
100 
101 } // end of namespace filter
102 } // end of namespace imaproc
103 } // end of namespace ipsdk
104 
105 #endif // __IPSDKIPLFILTERING_RICHARDSONLUCYDEBLUR3DIMGLVL1_H__
ProcessingResult< eRetrievalResultType > RetrievalResult
IPSDK_FORCEINLINE void copy(T *dest, const T *src, ipUInt64 nbElts)
#define IPSDK_DECLARE_LVL1_PROCESSOR(ProcType, libraryName, algoName, RuleString, attributeSeq)
IPSDKBASEPROCESSING_API RulePtr none()
boost::shared_ptr< BaseImage > ImagePtr
processor::OutputInitializerPtr duplicateInOut(const boost::weak_ptr< OutputAttributeType > &pOutputAttribute, const boost::weak_ptr< InputAttributeType > &pInputAttribute, const eImageInitializerStoragePolicy &storagePolicy=eImageInitializerStoragePolicy::eIISP_Inherit)
double ipReal64
boost::shared_ptr< const ipsdk::imaproc::attr::GaussianCoverage > GaussianCoverageConstPtr
shared pointer to const ipsdk::imaproc::attr::GaussianCoverage
Definition: GaussianCoverage.h:134
boost::shared_ptr< const BaseImage > ImageConstPtr
boost::enable_if_c< AttributeType::g_bOptional, RulePtr >::type isSet(const boost::shared_ptr< AttributeType > &pAttribute)
boost::shared_ptr< BaseActionProvider > ActionProviderPtr
IPSDKBASEPROCESSING_API RulePtr If(const RulePtr &pPredicate, const RulePtr &pRuleTrue)
Definition of import/export macro for library.
boost::shared_ptr< ipsdk::imaproc::attr::StatsResult > StatsResultPtr
shared pointer to ipsdk::imaproc::attr::StatsResult
Definition: StatsResult.h:206
float ipReal32
uint32_t ipUInt32