IPSDK  4_1_0_2
IPSDK : Image Processing Software Development Kit
Equalize3dImgLvl1.h
1 // Equalize3dImgLvl1.h:
3 // -------------------
4 //
14 
15 #ifndef __IPSDKIPLINTENSITYTRANSFORM_EQUALIZE3DIMGLVL1_H__
16 #define __IPSDKIPLINTENSITYTRANSFORM_EQUALIZE3DIMGLVL1_H__
17 
22 
23 // Attributes headers
24 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Input/3d/InImg3d.h>
25 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/DataItem/InOptPIHistogram.h>
26 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/DataItem/InOutputRange.h>
27 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/DataItem/OutPIHistogram.h>
28 #include <IPSDKIPL/IPSDKIPLAttributes/Attribute/Image/Output/OutImg.h>
29 #include <IPSDKIPL/IPSDKIPLAttributes/DataItem/PlanIndexedIntensityLUT.h>
30 
31 namespace ipsdk {
32 namespace imaproc {
33 namespace itrans {
34 
37 
38 // declare processor class
39 IPSDK_DECLARE_LVL1_PROCESSOR(REP_ASYNC1, IPSDKIPLIntensityTransform, Equalize3dImg,
40  ipsdk::imaproc::matchSize(_pInImg3d, _pOutImg) &&
41  (ipsdk::imaproc::matchImageRange<ipsdk::imaproc::attr::Range::Min>(_pOutImg, _pInOutputRange) &&
42  ipsdk::imaproc::matchImageRange<ipsdk::imaproc::attr::Range::Max>(_pOutImg, _pInOutputRange)) &&
43  ipsdk::imaproc::is2d(_pOutPIHistogram) &&
44  ipsdk::imaproc::matchImagePlans(_pOutPIHistogram, _pInImg3d, eImagePlansMatchPolicy::eIPMP_CT) &&
45  ipsdk::processor::ifIsSet(_pInOptPIHistogram,
46  ipsdk::imaproc::is2d(_pInOptPIHistogram) &&
47  ((ipsdk::imaproc::isGrey(_pInOptPIHistogram) && ipsdk::imaproc::isSingle(_pInOptPIHistogram)) ||
48  ipsdk::imaproc::matchImagePlans(_pInOptPIHistogram, _pInImg3d, eImagePlansMatchPolicy::eIPMP_CT))),
49  (((ipsdk)(imaproc)(attr))(InImg3d))
50  (((ipsdk)(imaproc)(attr))(InOptPIHistogram))
51  (((ipsdk)(imaproc)(attr))(OutPIHistogram)(ipsdk::imaproc::fromImageButVolume)(_pInImg3d))
52  (((ipsdk)(imaproc)(attr))(InOutputRange))
53  (((ipsdk)(imaproc)(attr))(OutImg)(ipsdk::imaproc::duplicateInOut)(_pInImg3d)))
54 
55 // methods
56 public:
57 
58 protected:
59  processor::RetrievalResult provideProcessor(const boost::shared_ptr<core::BaseAction>& pProcessor,
60  const core::BasePriority& priority,
61  core::ActionProviderPtr& pProvider);
62 
63  processor::RetrievalResult histoMsr(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
64  processor::RetrievalResult equalize(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
65  processor::RetrievalResult lutTransform(const core::BasePriority& priority, core::ActionProviderPtr& pProvider);
66 
67 // attributes
68 protected:
71 
72 };
73 
76 
77 } // end of namespace itrans
78 } // end of namespace imaproc
79 } // end of namespace ipsdk
80 
81 #endif // __IPSDKIPLINTENSITYTRANSFORM_EQUALIZE3DIMGLVL1_H__
ProcessingResult< eRetrievalResultType > RetrievalResult
processor::OutputInitializerPtr fromImageButVolume(const boost::shared_ptr< OutputAttributeType > &pOutputAttribute, const ImageAttributeConstPtr &pInputAttribute)
#define IPSDK_DECLARE_LVL1_PROCESSOR(ProcType, libraryName, algoName, RuleString, attributeSeq)
IPSDKIPLINTENSITYTRANSFORM_API ipsdk::imaproc::attr::IntensityLUTPtr equalize(const ipsdk::imaproc::attr::HistogramDataConstPtr &pInHistogram, const ipsdk::imaproc::attr::RangeConstPtr &pInOutputRange)
wrapper function for equalization lut computation.
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)
Definition of import/export macro for library.
boost::shared_ptr< BaseActionProvider > ActionProviderPtr
boost::shared_ptr< ipsdk::imaproc::attr::PlanIndexedIntensityLUT > PlanIndexedIntensityLUTPtr
shared pointer to ipsdk::imaproc::attr::PlanIndexedIntensityLUT
Definition: PlanIndexedIntensityLUT.h:49