IPSDK  4_1_0_2
IPSDK : Image Processing Software Development Kit
TopHat3dImgLvl1.h
1 // TopHat3dImgLvl1.h:
3 // ------------------
4 //
14 
15 #ifndef __IPSDKIPLBINARIZATION_TOPHAT3DIMGLVL1_H__
16 #define __IPSDKIPLBINARIZATION_TOPHAT3DIMGLVL1_H__
17 
22 
23 // Attributes headers
24 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Input/3d/InImg3d.h>
25 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/StructuringElement/InSEXYZ.h>
26 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Enumerate/InShapeGreyscaleType.h>
27 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InTopHatThreshold.h>
28 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Enumerate/InOptBorderExtensionPolicy.h>
29 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/Optional/OutOptWk1Img.h>
30 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/Optional/OutOptWk2Img.h>
31 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Working/OutWk1Img.h>
32 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/OutBinImg.h>
33 
34 namespace ipsdk {
35 namespace imaproc {
36 namespace bin {
37 
40 
41 // declare processor class
42 IPSDK_DECLARE_LVL1_PROCESSOR(REP_ASYNC1, IPSDKIPLBinarization, TopHat3dImg,
43  ((ipsdk::imaproc::matchSize(_pInImg3d, _pOutBinImg)) &&
44  (ipsdk::imaproc::matchSizeAndType(_pInImg3d, _pOutWk1Img)) &&
45  (ipsdk::imaproc::noInSitu(_pInImg3d, _pOutWk1Img)) &&
46  (ipsdk::processor::ifIsSet(_pOutOptWk1Img,
47  ipsdk::imaproc::customImageProperty(_pOutOptWk1Img, morpho::matchBorderExtension1(_pInImg3d, _pInSEXYZ, _pInOptBorderExtensionPolicy)))) &&
48  (ipsdk::processor::ifIsSet(_pOutOptWk2Img,
49  ipsdk::imaproc::customImageProperty(_pOutOptWk2Img, morpho::matchBorderExtension2(_pInImg3d, _pInSEXYZ, _pInOptBorderExtensionPolicy))))),
50  (((ipsdk)(imaproc)(attr))(InImg3d))
51  (((ipsdk)(imaproc)(attr))(InSEXYZ))
52  (((ipsdk)(imaproc)(attr))(InShapeGreyscaleType))
53  (((ipsdk)(imaproc)(attr))(InTopHatThreshold))
54  (((ipsdk)(imaproc)(attr))(InOptBorderExtensionPolicy))
55  (((ipsdk)(imaproc)(attr))(OutOptWk1Img))
56  (((ipsdk)(imaproc)(attr))(OutOptWk2Img))
57  (((ipsdk)(imaproc)(attr))(OutWk1Img)(ipsdk::imaproc::duplicateInOut)(_pInImg3d))
58  (((ipsdk)(imaproc)(attr))(OutBinImg)(ipsdk::imaproc::duplicateInOut)(_pInImg3d)(image::eImageBufferType::eIBT_Binary)))
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 closing(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
69  processor::RetrievalResult opening(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
70  processor::RetrievalResult subtract(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
71  processor::RetrievalResult threshold(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
72 
73 // attributes
74 protected:
75 
76 };
77 
80 
81 } // end of namespace bin
82 } // end of namespace imaproc
83 } // end of namespace ipsdk
84 
85 #endif // __IPSDKIPLBINARIZATION_TOPHAT3DIMGLVL1_H__
ProcessingResult< eRetrievalResultType > RetrievalResult
#define IPSDK_DECLARE_LVL1_PROCESSOR(ProcType, libraryName, algoName, RuleString, attributeSeq)
Utility functions for image attribute border extension rules management.
processor::OutputInitializerPtr duplicateInOut(const boost::weak_ptr< OutputAttributeType > &pOutputAttribute, const boost::weak_ptr< InputAttributeType > &pInputAttribute, const eImageInitializerStoragePolicy &storagePolicy=eImageInitializerStoragePolicy::eIISP_Inherit)
boost::enable_if_c< AttributeType::g_bOptional, RulePtr >::type ifIsSet(const boost::shared_ptr< AttributeType > &pAttribute, const RulePtr &pRuleTrue)
IPSDKIPLBASICMORPHOLOGY_API CustomCheckedImagePropertyPtr matchBorderExtension1(const ImageAttributeConstPtr &pInImg, const StructuringElementXYAttributeConstPtr &pSEXY, const boost::shared_ptr< const attr::InOptBorderExtensionPolicy > pInBorderExtensionPolicy)
function allowing to define rule applied on working 2d image for morphological algorithms with option...
Definition of import/export macro for library.
boost::shared_ptr< BaseActionProvider > ActionProviderPtr
IPSDKIPLBASICMORPHOLOGY_API CustomCheckedImagePropertyPtr matchBorderExtension2(const ImageAttributeConstPtr &pInImg, const StructuringElementXYAttributeConstPtr &pSEXY, const boost::shared_ptr< const attr::InOptBorderExtensionPolicy > pInBorderExtensionPolicy)
function allowing to define rule applied on working 2d image for morphological algorithms with option...