IPSDK  4_1_0_2
IPSDK : Image Processing Software Development Kit
LaplacianDoG3dImgLvl1.h
1 // LaplacianDoG3dImgLvl1.h:
3 // ------------------------
4 //
14 
15 #ifndef __IPSDKIPLFILTERING_LAPLACIANDOG3DIMGLVL1_H__
16 #define __IPSDKIPLFILTERING_LAPLACIANDOG3DIMGLVL1_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/OutWk1Img.h>
26 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InStdDev.h>
27 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InOptStdDevFactor.h>
28 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/DataItem/InOptSmoothingGaussianCoverage.h>
30 #include <IPSDKBaseData/Pattern/Kernel/KernelXYZ.h>
31 
32 namespace ipsdk {
33 namespace imaproc {
34 namespace filter {
35 
38 
39 // declare processor class
40 IPSDK_DECLARE_LVL1_PROCESSOR(REP_ASYNC1, IPSDKIPLFiltering, LaplacianDoG3dImg,
41  ipsdk::imaproc::matchSize(_pInImg3d, _pOutImg) &&
42  ipsdk::imaproc::matchSizeAndType(_pInImg3d, _pOutWk1Img) &&
43  ipsdk::imaproc::noInSitu(_pInImg3d, _pOutWk1Img) &&
44  ipsdk::imaproc::noInSitu(_pOutImg, _pOutWk1Img),
45  (((ipsdk)(imaproc)(attr))(InImg3d))
46  (((ipsdk)(imaproc)(attr))(InStdDev))
47  (((ipsdk)(imaproc)(attr))(InOptStdDevFactor))
48  (((ipsdk)(imaproc)(attr))(InOptSmoothingGaussianCoverage))
49  (((ipsdk)(imaproc)(attr))(OutImg)(ipsdk::imaproc::promoteUnary)(_pInImg3d)(ePromoteUnaryType::ePUT_UpperSigned))
50  (((ipsdk)(imaproc)(attr))(OutWk1Img)(ipsdk::imaproc::duplicateInOut)(_pInImg3d)))
51 
52 // methods
53 public:
57 
58  processor::RetrievalResult provideProcessor(const boost::shared_ptr<core::BaseAction>& pProcessor,
59  const core::BasePriority& priority,
60  core::ActionProviderPtr& pProvider);
61 
62  processor::RetrievalResult convolution(const core::BasePriority& priority, core::ActionProviderPtr& pProvider,
63  const ipsdk::image::ImageConstPtr& pInImg, const ipsdk::KernelXYZPtr& pKernel, ipsdk::image::ImagePtr& pOutImg);
64  processor::RetrievalResult subtract(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
65 
66 protected:
67 
68 // attributes
69 protected:
71  ipReal32 _excitatoryStdDev;
72  ipReal32 _inhibitoryStdDev;
73 
75  KernelXYZPtr _pXAxisExcitatoryKernel;
76  KernelXYZPtr _pYAxisExcitatoryKernel;
77  KernelXYZPtr _pZAxisExcitatoryKernel;
78  KernelXYZPtr _pXAxisInhibitoryKernel;
79  KernelXYZPtr _pYAxisInhibitoryKernel;
80  KernelXYZPtr _pZAxisInhibitoryKernel;
81 
83  ipsdk::image::Border3dPolicyPtr _pBorder3dPolicy;
84 
85 };
86 
89 
90 } // end of namespace filter
91 } // end of namespace imaproc
92 } // end of namespace ipsdk
93 
94 #endif // __IPSDKIPLFILTERING_LAPLACIANDOG3DIMGLVL1_H__
boost::shared_ptr< Border3dPolicy > Border3dPolicyPtr
ProcessingResult< eRetrievalResultType > RetrievalResult
#define IPSDK_DECLARE_LVL1_PROCESSOR(ProcType, libraryName, algoName, RuleString, attributeSeq)
processor::OutputInitializerPtr promoteUnary(const boost::weak_ptr< OutputAttributeType > &pOutputAttribute, const boost::weak_ptr< InputAttributeType > &pInputAttribute, const ePromoteUnaryType &promoteUnaryType)
ePUT_UpperSigned
boost::shared_ptr< BaseImage > ImagePtr
boost::shared_ptr< KernelXYZ > KernelXYZPtr
processor::OutputInitializerPtr duplicateInOut(const boost::weak_ptr< OutputAttributeType > &pOutputAttribute, const boost::weak_ptr< InputAttributeType > &pInputAttribute, const eImageInitializerStoragePolicy &storagePolicy=eImageInitializerStoragePolicy::eIISP_Inherit)
ipsdk::core::ExecResult preProcess()
method called before processing
boost::shared_ptr< const BaseImage > ImageConstPtr
boost::shared_ptr< BaseActionProvider > ActionProviderPtr
Definition of import/export macro for library.
float ipReal32