IPSDK  4_1_0_2
IPSDK : Image Processing Software Development Kit
SeededDistanceMap3dImgLvl1.h
1 // SeededDistanceMap3dImgLvl1.h:
3 // -----------------------------
4 //
14 
15 #ifndef __IPSDKIPLADVANCEDMORPHOLOGY_SEEDEDDISTANCEMAP3DIMGLVL1_H__
16 #define __IPSDKIPLADVANCEDMORPHOLOGY_SEEDEDDISTANCEMAP3DIMGLVL1_H__
17 
21 
22 // Attributes headers
23 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Input/3d/InBinImg3d.h>
24 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Input/3d/InBinSeedImg3d.h>
25 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptPixelXSize.h>
26 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptPixelYSize.h>
27 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptPixelZSize.h>
28 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Neighborhood/InOptNeighborhood3d.h>
29 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/DataItem/OutDistWeight3d.h>
30 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptMaxDistance.h>
31 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/OutDistImg.h>
32 #include <IPSDKIPL/IPSDKIPLAttributes/DataItem/DistWeight3d.h>
33 
34 namespace ipsdk {
35 namespace imaproc {
36 namespace advmorpho {
37 
40 
41 // declare processor class
42 IPSDK_DECLARE_LVL1_PROCESSOR(REP_ASYNC1, IPSDKIPLAdvancedMorphology, SeededDistanceMap3dImg,
43  (ipsdk::imaproc::matchSize(_pInBinImg3d, _pOutDistImg)) &&
44  (ipsdk::imaproc::matchSize(_pInBinSeedImg3d, _pOutDistImg)),
45  (((ipsdk)(imaproc)(attr))(InBinImg3d))
46  (((ipsdk)(imaproc)(attr))(InBinSeedImg3d))
47  (((ipsdk)(imaproc)(attr))(InOptPixelXSize))
48  (((ipsdk)(imaproc)(attr))(InOptPixelYSize))
49  (((ipsdk)(imaproc)(attr))(InOptPixelZSize))
50  (((ipsdk)(imaproc)(attr))(InOptNeighborhood3d))
51  (((ipsdk)(imaproc)(attr))(InOptMaxDistance))
52  (((ipsdk)(imaproc)(attr))(OutDistWeight3d)(allocate))
53  (((ipsdk)(imaproc)(attr))(OutDistImg)(ipsdk::imaproc::duplicateInOut)(_pInBinImg3d)(ipsdk::image::eImageBufferType::eIBT_Real32)))
54 
55 // methods
56 public:
57  processor::RetrievalResult provideProcessor(const boost::shared_ptr<core::BaseAction>& pProcessor,
58  const core::BasePriority& priority,
59  core::ActionProviderPtr& pProvider);
60 
61  processor::RetrievalResult genericSeededDistanceMap(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
62  processor::RetrievalResult multiplyScalar(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
63 
64 // attributes
65 protected:
67  ipUInt64 _scaleFactor;
68 
69 };
70 
73 
74 } // end of namespace advmorpho
75 } // end of namespace imaproc
76 } // end of namespace ipsdk
77 
78 #endif // __IPSDKIPLADVANCEDMORPHOLOGY_SEEDEDDISTANCEMAP3DIMGLVL1_H__
Definition of import/export macro for library.
ProcessingResult< eRetrievalResultType > RetrievalResult
#define IPSDK_DECLARE_LVL1_PROCESSOR(ProcType, libraryName, algoName, RuleString, attributeSeq)
uint64_t ipUInt64
processor::OutputInitializerPtr duplicateInOut(const boost::weak_ptr< OutputAttributeType > &pOutputAttribute, const boost::weak_ptr< InputAttributeType > &pInputAttribute, const eImageInitializerStoragePolicy &storagePolicy=eImageInitializerStoragePolicy::eIISP_Inherit)
boost::shared_ptr< BaseActionProvider > ActionProviderPtr