IPSDK  4_1_0_2
IPSDK : Image Processing Software Development Kit
GaussianGradient2dImgLvl1.h
1 // GaussianGradient2dImgLvl1.h:
3 // ----------------------------
4 //
14 
15 #ifndef __IPSDKIPLFILTERING_GAUSSIANGRADIENT2DIMGLVL1_H__
16 #define __IPSDKIPLFILTERING_GAUSSIANGRADIENT2DIMGLVL1_H__
17 
23 
24 // Attributes headers
25 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Input/InImg.h>
26 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InStdDevX.h>
27 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Value/InStdDevY.h>
28 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/DataItem/InOptGradientGaussianCoverage.h>
29 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Optional/OutOptGradXImg.h>
30 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/Optional/OutOptGradYImg.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, GaussianGradient2dImg,
41  ((ipsdk::processor::isSet(_pOutOptGradXImg) || ipsdk::processor::isSet(_pOutOptGradYImg)) &&
42  (ipsdk::processor::ifIsSet(_pOutOptGradXImg,
43  ipsdk::imaproc::matchSize(_pInImg, _pOutOptGradXImg))) &&
44  (ipsdk::processor::ifIsSet(_pOutOptGradYImg,
45  ipsdk::imaproc::matchSize(_pInImg, _pOutOptGradYImg)))),
46  (((ipsdk)(imaproc)(attr))(InImg))
47  (((ipsdk)(imaproc)(attr))(InStdDevX))
48  (((ipsdk)(imaproc)(attr))(InStdDevY))
49  (((ipsdk)(imaproc)(attr))(InOptGradientGaussianCoverage))
50  (((ipsdk)(imaproc)(attr))(OutOptGradXImg)(promoteUnary)(_pInImg)(ipsdk::imaproc::ePromoteUnaryType::ePUT_UpperSigned))
51  (((ipsdk)(imaproc)(attr))(OutOptGradYImg)(promoteUnary)(_pInImg)(ipsdk::imaproc::ePromoteUnaryType::ePUT_UpperSigned)))
52 
53 // methods
54 public:
55 
56 protected:
60 
62  ipsdk::processor::RetrievalResult retrieveXGradXDerivationProvider(const ipsdk::core::BasePriority& priority,
64 
66  ipsdk::processor::RetrievalResult retrieveXGradYSmoothingProvider(const ipsdk::core::BasePriority& priority,
68 
70  ipsdk::processor::RetrievalResult retrieveYGradXSmoothingProvider(const ipsdk::core::BasePriority& priority,
72 
74  ipsdk::processor::RetrievalResult retrieveYGradYDerivationProvider(const ipsdk::core::BasePriority& priority,
76 
78  void clearIntermediateData();
79 
80 // attributes
81 protected:
84  KernelXYPtr _pXSmoothingKernel;
85  KernelXYPtr _pYSmoothingKernel;
86  KernelXYPtr _pXGradientKernel;
87  KernelXYPtr _pYGradientKernel;
89 
90  // border policy used for convolution
91  image::Border2dPolicyPtr _pBorder2dPolicy;
92 };
93 
96 
97 } // end of namespace filter
98 } // end of namespace imaproc
99 } // end of namespace ipsdk
100 
101 #endif // __IPSDKIPLFILTERING_GAUSSIANGRADIENT2DIMGLVL1_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
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)
boost::shared_ptr< Border2dPolicy > Border2dPolicyPtr
boost::shared_ptr< KernelXY > KernelXYPtr
boost::enable_if_c< AttributeType::g_bOptional, RulePtr >::type isSet(const boost::shared_ptr< AttributeType > &pAttribute)
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.