IPSDK  4_1_0_2
IPSDK : Image Processing Software Development Kit
ZStackFocusPonderationImgLvl1.h
1 // ZStackFocusPonderationImgLvl1.h:
3 // --------------------------------
4 //
14 
15 #ifndef __IPSDKIPLFILTERING_ZSTACKFOCUSPONDERATIONIMGLVL1_H__
16 #define __IPSDKIPLFILTERING_ZSTACKFOCUSPONDERATIONIMGLVL1_H__
17 
22 
23 // Attributes headers
24 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Input/3d/InImg3d.h>
25 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/2d/OutImg2d.h>
26 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk1Img.h>
27 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk2Img.h>
28 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk3Img.h>
29 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/Optional/OutOptWk1Img.h>
30 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk1RealImg.h>
31 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk2RealImg.h>
32 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk1BinImg.h>
33 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk3RealImg.h>
34 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk4RealImg.h>
35 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk5RealImg.h>
36 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/Optional/OutOptWk1RealImg.h>
37 
38 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptZoomFactor.h>
39 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptContrastRadius.h>
40 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptMeanSmoothingValue.h>
41 
42 namespace ipsdk {
43 namespace imaproc {
44 namespace filter {
45 
48 
49 // declare processor class
50 IPSDK_DECLARE_LVL1_PROCESSOR(REP_ASYNC1, IPSDKIPLFiltering, ZStackFocusPonderationImg,
51  (ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_Z, _pInImg3d, _pOutWk1Img) &&
52  ipsdk::imaproc::matchSize(_pOutWk1Img, _pOutWk2Img) &&
53  ipsdk::processor::ifIsSet(_pOutOptWk1Img, (ipsdk::imaproc::isGrey(_pInImg3d) || ipsdk::imaproc::matchSize(_pOutWk1Img, _pOutOptWk1Img))) &&
54  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_3d, _pOutWk1Img, _pOutWk3Img) &&
55  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_2d, _pOutWk1Img, _pOutWk1RealImg) &&
56  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_3d, _pOutWk1Img, _pOutWk2RealImg) &&
57  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_3d, _pOutWk1Img, _pOutWk1BinImg) &&
58  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_3d, _pInImg3d, _pOutWk3RealImg) &&
59  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_2d, _pInImg3d, _pOutWk4RealImg) &&
60  ipsdk::processor::ifIsSet(_pOutOptWk1RealImg, (ipsdk::imaproc::isGrey(_pInImg3d) || ipsdk::imaproc::matchSize(_pInImg3d, _pOutOptWk1RealImg))) &&
61  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_2d, _pInImg3d, _pOutWk5RealImg) &&
62  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_2d, _pInImg3d, _pOutImg2d) &&
63  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_C, _pInImg3d, _pOutImg2d)),
64  (((ipsdk)(imaproc)(attr))(InImg3d))
65  (((ipsdk)(imaproc)(attr))(InOptZoomFactor))
66  (((ipsdk)(imaproc)(attr))(InOptContrastRadius))
67  (((ipsdk)(imaproc)(attr))(InOptMeanSmoothingValue))
68  (((ipsdk)(imaproc)(attr))(OutWk1Img)(customOutput)(outputZoom3d(_pInImg3d, _pInOptZoomFactor)))
69  (((ipsdk)(imaproc)(attr))(OutWk2Img)(customOutput)(outputZoom3d(_pInImg3d, _pInOptZoomFactor)))
70  (((ipsdk)(imaproc)(attr))(OutWk3Img)(customOutput)(outputZoom3dGrey(_pInImg3d, _pInOptZoomFactor)))
71  (((ipsdk)(imaproc)(attr))(OutOptWk1Img))
72  (((ipsdk)(imaproc)(attr))(OutWk1RealImg)(customOutput)(outputZoom2dGreyReal(_pInImg3d, _pInOptZoomFactor)))
73  (((ipsdk)(imaproc)(attr))(OutWk2RealImg)(customOutput)(outputZoom3dGreyReal(_pInImg3d, _pInOptZoomFactor)))
74  (((ipsdk)(imaproc)(attr))(OutWk1BinImg)(customOutput)(outputZoom3dGreyBin(_pInImg3d, _pInOptZoomFactor)))
75  (((ipsdk)(imaproc)(attr))(OutWk3RealImg)(customOutput)(duplicateGreyReal(_pInImg3d)))
76  (((ipsdk)(imaproc)(attr))(OutWk4RealImg)(customOutput)(duplicate2dGreyReal(_pInImg3d)))
77  (((ipsdk)(imaproc)(attr))(OutOptWk1RealImg))
78  (((ipsdk)(imaproc)(attr))(OutWk5RealImg)(customOutput)(duplicate2dReal(_pInImg3d)))
79  (((ipsdk)(imaproc)(attr))(OutImg2d)(duplicate2dInOut)(_pInImg3d)))
80 
81 // methods
82 public:
83 
84 protected:
88 
90  void clearIntermediateData();
91 
92 // attributes
93 protected:
94 
95 };
98 
99 } // end of namespace filter
100 } // end of namespace imaproc
101 } // end of namespace ipsdk
102 
103 #endif // __IPSDKIPLFILTERING_ZSTACKFOCUSPONDERATIONIMGLVL1_H__
#define IPSDK_DECLARE_LVL1_PROCESSOR(ProcType, libraryName, algoName, RuleString, attributeSeq)
IPSDKIPLFILTERING_API CustomImageInfoPtr duplicateGreyReal(const ImageAttributeConstPtr &pInputAttribute)
function allowing to create a ZFocus output image initializer
ipsdk::core::ExecResult preProcess()
method called before processing
boost::enable_if_c< AttributeType::g_bOptional, RulePtr >::type ifIsSet(const boost::shared_ptr< AttributeType > &pAttribute, const RulePtr &pRuleTrue)
processor::OutputInitializerPtr duplicate2dInOut(const boost::weak_ptr< OutputAttributeType > &pOutputAttribute, const boost::weak_ptr< InputAttributeType > &pInputAttribute, const eImageInitializerStoragePolicy &storagePolicy=eImageInitializerStoragePolicy::eIISP_Inherit)
Filtering functions for ZFocus output initializer management.
processor::OutputInitializerPtr customOutput(const boost::weak_ptr< OutputAttributeType > &pOutputAttribute, const CustomImageInfoPtr &pCustomImageInfo)
IPSDKIPLFILTERING_API CustomImageInfoPtr outputZoom3dGreyReal(const ImageAttributeConstPtr &pInputAttribute, const boost::shared_ptr< const attr::InOptZoomFactor > &pScaleAttribute)
function allowing to create a ZFocus output image initializer
IPSDKIPLFILTERING_API CustomImageInfoPtr outputZoom3dGreyBin(const ImageAttributeConstPtr &pInputAttribute, const boost::shared_ptr< const attr::InOptZoomFactor > &pScaleAttribute)
function allowing to create a ZFocus output image initializer
IPSDKIPLFILTERING_API CustomImageInfoPtr outputZoom2dGreyReal(const ImageAttributeConstPtr &pInputAttribute, const boost::shared_ptr< const attr::InOptZoomFactor > &pScaleAttribute)
function allowing to create a ZFocus output image initializer
IPSDK_DECLARE_GPU_PROCESSING_ALGORITHM(IPSDKIPLFiltering, Convolution2dImg, ipsdk::imaproc::matchSize(_pInSubGpuImg, _pOutImg),(((ipsdk)(imaproc)(attr))(InSubGpuImg))(((ipsdk)(imaproc)(attr))(InKnlXY))(((ipsdk)(imaproc)(attr))(InNormalize))(((ipsdk)(imaproc)(attr))(InConvolBorder2d))(((ipsdk)(imaproc)(attr))(OutImg))) IPSDKCUDA_DECLARE_ALGORITHM_FUNCTION_SELECTOR((InSubGpuImg)(OutImg)) public void clearIntermediateData()
method called before processing
IPSDKIPLFILTERING_API CustomImageInfoPtr duplicate2dReal(const ImageAttributeConstPtr &pInputAttribute)
function allowing to create a ZFocus output image initializer
IPSDKIPLFILTERING_API CustomImageInfoPtr outputZoom3dGrey(const ImageAttributeConstPtr &pInputAttribute, const boost::shared_ptr< const attr::InOptZoomFactor > &pScaleAttribute)
function allowing to create a ZFocus output image initializer
IPSDKIPLFILTERING_API CustomImageInfoPtr outputZoom3d(const ImageAttributeConstPtr &pInputAttribute, const boost::shared_ptr< const attr::InOptZoomFactor > &pScaleAttribute)
function allowing to create a ZFocus output image initializer
Definition of import/export macro for library.
IPSDKIPLFILTERING_API CustomImageInfoPtr duplicate2dGreyReal(const ImageAttributeConstPtr &pInputAttribute)
function allowing to create a ZFocus output image initializer