IPSDK  4_1_0_2
IPSDK : Image Processing Software Development Kit
GaussianHessian2dImgLvl1.h
1 // GaussianHessian2dImgLvl1.h:
3 // ---------------------------
4 //
14 
15 #ifndef __IPSDKIPLFILTERING_GAUSSIANHESSIAN2DIMGLVL1_H__
16 #define __IPSDKIPLFILTERING_GAUSSIANHESSIAN2DIMGLVL1_H__
17 
23 
24 // Attributes headers
25 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Input/InImg.h>
26 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/OutHxxImg.h>
27 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/OutHxyImg.h>
28 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/OutHyyImg.h>
29 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InStdDevX.h>
30 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InStdDevY.h>
31 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/DataItem/InOptHessianGaussianCoverage.h>
32 
33 namespace ipsdk {
34 namespace imaproc {
35 namespace filter {
36 
39 
40 // declare processor class
41 IPSDK_DECLARE_LVL1_PROCESSOR(REP_ASYNC1, IPSDKIPLFiltering, GaussianHessian2dImg,
42  ipsdk::imaproc::matchSize(_pInImg, _pOutHxxImg) &&
43  ipsdk::imaproc::matchSizeAndType(_pOutHxxImg, _pOutHxyImg) &&
44  ipsdk::imaproc::matchSizeAndType(_pOutHxxImg, _pOutHyyImg),
45  (((ipsdk)(imaproc)(attr))(InImg))
46  (((ipsdk)(imaproc)(attr))(InStdDevX))
47  (((ipsdk)(imaproc)(attr))(InStdDevY))
48  (((ipsdk)(imaproc)(attr))(InOptHessianGaussianCoverage))
49  (((ipsdk)(imaproc)(attr))(OutHxxImg)(promoteUnary)(_pInImg)(ipsdk::imaproc::ePromoteUnaryType::ePUT_UpperSigned))
50  (((ipsdk)(imaproc)(attr))(OutHxyImg)(promoteUnary)(_pInImg)(ipsdk::imaproc::ePromoteUnaryType::ePUT_UpperSigned))
51  (((ipsdk)(imaproc)(attr))(OutHyyImg)(promoteUnary)(_pInImg)(ipsdk::imaproc::ePromoteUnaryType::ePUT_UpperSigned)))
52 
53 // methods
54 public:
55 
56 protected:
60 
62  void clearIntermediateData();
63 
67  const ipsdk::image::ImageConstPtr& pInImg,
68  const KernelXYConstPtr& pKnl,
69  const ipsdk::image::ImagePtr pOutImg);
70 
71 // attributes
72 protected:
75  KernelXYPtr _pXSmoothingKernel;
76  KernelXYPtr _pYSmoothingKernel;
77  KernelXYPtr _pXGradientKernel;
78  KernelXYPtr _pYGradientKernel;
79  KernelXYPtr _pXHessianKernel;
80  KernelXYPtr _pYHessianKernel;
82 
83  // border policy used for convolution
84  image::Border2dPolicyPtr _pBorder2dPolicy;
85 
86 };
87 
90 
91 } // end of namespace filter
92 } // end of namespace imaproc
93 } // end of namespace ipsdk
94 
95 #endif // __IPSDKIPLFILTERING_GAUSSIANHESSIAN2DIMGLVL1_H__
#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
ipsdk::core::ExecResult preProcess()
method called before processing
boost::shared_ptr< Border2dPolicy > Border2dPolicyPtr
boost::shared_ptr< KernelXY > KernelXYPtr
boost::shared_ptr< const BaseImage > ImageConstPtr
boost::shared_ptr< const KernelXY > KernelXYConstPtr
boost::shared_ptr< BaseActionProvider > ActionProviderPtr
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
Definition of import/export macro for library.