IPSDK  4_1_0_2
IPSDK : Image Processing Software Development Kit
ZStackFocusMaximumImgLvl1.h
1 // ZStackFocusMaximumImgLvl1.h:
3 // ----------------------------
4 //
14 
15 #ifndef __IPSDKIPLFILTERING_ZSTACKFOCUSMAXIMUMIMGLVL1_H__
16 #define __IPSDKIPLFILTERING_ZSTACKFOCUSMAXIMUMIMGLVL1_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 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/Optional/OutOptWk1LabelImg.h>
38 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/Optional/OutOptWk2LabelImg.h>
39 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/2d/Optional/OutOptLabelImg2d.h>
40 
41 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptZoomFactor.h>
42 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptContrastRadius.h>
43 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptMeanSmoothingValue.h>
44 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptDepthMap.h>
45 
46 namespace ipsdk {
47 namespace imaproc {
48 namespace filter {
49 
52 
53 // declare processor class
54 IPSDK_DECLARE_LVL1_PROCESSOR(REP_ASYNC1, IPSDKIPLFiltering, ZStackFocusMaximumImg,
55  (ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_Z, _pInImg3d, _pOutWk1Img) &&
56  ipsdk::imaproc::matchSize(_pOutWk1Img, _pOutWk2Img) &&
57  ipsdk::processor::ifIsSet(_pOutOptWk1Img, (ipsdk::imaproc::isGrey(_pInImg3d) || ipsdk::imaproc::matchSize(_pOutWk1Img, _pOutOptWk1Img))) &&
58  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_3d, _pOutWk1Img, _pOutWk3Img) &&
59  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_2d, _pOutWk1Img, _pOutWk1RealImg) &&
60  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_3d, _pOutWk1Img, _pOutWk2RealImg) &&
61  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_3d, _pOutWk1Img, _pOutWk1BinImg) &&
62  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_3d, _pInImg3d, _pOutWk3RealImg) &&
63  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_2d, _pInImg3d, _pOutWk4RealImg) &&
64  ipsdk::processor::ifIsSet(_pOutOptWk1RealImg, (ipsdk::imaproc::isGrey(_pInImg3d) || ipsdk::imaproc::matchSize(_pInImg3d, _pOutOptWk1RealImg))) &&
65  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_2d, _pInImg3d, _pOutWk5RealImg) &&
66  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_2d, _pInImg3d, _pOutImg2d) &&
67  ipsdk::imaproc::matchSize(eMatchImageSizeType::eMIST_C, _pInImg3d, _pOutImg2d)),
68  (((ipsdk)(imaproc)(attr))(InImg3d))
69  (((ipsdk)(imaproc)(attr))(InOptZoomFactor))
70  (((ipsdk)(imaproc)(attr))(InOptContrastRadius))
71  (((ipsdk)(imaproc)(attr))(InOptMeanSmoothingValue))
72  (((ipsdk)(imaproc)(attr))(InOptDepthMap))
73  (((ipsdk)(imaproc)(attr))(OutWk1Img)(customOutput)(outputZoom3d(_pInImg3d, _pInOptZoomFactor)))
74  (((ipsdk)(imaproc)(attr))(OutWk2Img)(customOutput)(outputZoom3d(_pInImg3d, _pInOptZoomFactor)))
75  (((ipsdk)(imaproc)(attr))(OutWk3Img)(customOutput)(outputZoom3dGrey(_pInImg3d, _pInOptZoomFactor)))
76  (((ipsdk)(imaproc)(attr))(OutOptWk1Img))
77  (((ipsdk)(imaproc)(attr))(OutWk1RealImg)(customOutput)(outputZoom2dGreyReal(_pInImg3d, _pInOptZoomFactor)))
78  (((ipsdk)(imaproc)(attr))(OutWk2RealImg)(customOutput)(outputZoom3dGreyReal(_pInImg3d, _pInOptZoomFactor)))
79  (((ipsdk)(imaproc)(attr))(OutWk1BinImg)(customOutput)(outputZoom3dGreyBin(_pInImg3d, _pInOptZoomFactor)))
80  (((ipsdk)(imaproc)(attr))(OutWk3RealImg)(customOutput)(duplicateGreyReal(_pInImg3d)))
81  (((ipsdk)(imaproc)(attr))(OutWk4RealImg)(customOutput)(duplicate2dGreyReal(_pInImg3d)))
82  (((ipsdk)(imaproc)(attr))(OutOptWk1RealImg))
83  (((ipsdk)(imaproc)(attr))(OutOptWk1LabelImg))
84  (((ipsdk)(imaproc)(attr))(OutOptWk2LabelImg))
85  (((ipsdk)(imaproc)(attr))(OutWk5RealImg)(customOutput)(duplicate2dReal(_pInImg3d)))
86  (((ipsdk)(imaproc)(attr))(OutOptLabelImg2d))
87  (((ipsdk)(imaproc)(attr))(OutImg2d)(duplicate2dInOut)(_pInImg3d)))
88 
89 // methods
90 public:
91 
92 protected:
96 
98  void clearIntermediateData();
99 
100 // attributes
101 protected:
102 
103 };
104 
107 
108 } // end of namespace filter
109 } // end of namespace imaproc
110 } // end of namespace ipsdk
111 
112 #endif // __IPSDKIPLFILTERING_ZSTACKFOCUSMAXIMUMIMGLVL1_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