-#include <plugins/ImageArithmeticFilters/PowImageFilter.h>
+#include <ImageArithmeticFilters/PowImageFilter.h>
#include <cpPlugins/DataObjects/Image.h>
+#include <cpPlugins/DataObjects/Image_Demanglers.h>
#include <itkPowImageFilter.h>
-#include <itkBinaryFunctorImageFilter.hxx>
// -------------------------------------------------------------------------
cpPluginsImageArithmeticFilters::PowImageFilter::
PowImageFilter( )
: Superclass( )
{
- this->_ConfigureInput< cpPlugins::DataObjects::Image >( "Input0", true, false );
- this->_ConfigureInput< cpPlugins::DataObjects::Image >( "Input1", false, false );
- this->_ConfigureOutput< cpPlugins::DataObjects::Image >( "Output" );
+ typedef cpPlugins::DataObjects::Image _TImage;
+ this->_ConfigureInput< _TImage >( "Input1", true, false );
+ this->_ConfigureInput< _TImage >( "Input2", true, false );
+ this->_ConfigureOutput< _TImage >( "Output" );
this->m_Parameters.ConfigureAsReal( "Constant" );
this->m_Parameters.SetReal( "Constant", 1 );
void cpPluginsImageArithmeticFilters::PowImageFilter::
_GenerateData( )
{
- auto o = this->GetInputData( "Input0" );
- cpPlugins_Demangle_ImageScalars_Dims( o, _GD0 );
- else this->_Error( "Invalid input image." );
+ auto o = this->GetInputData( "Input1" );
+ cpPlugins_Demangle_Image_ScalarPixels_AllDims_1( o, _GD0 )
+ this->_Error( "Invalid input image (0)." );
}
// -------------------------------------------------------------------------
-template< class _TImage >
+template< class _TInput1 >
void cpPluginsImageArithmeticFilters::PowImageFilter::
-_GD0( _TImage* image0 )
+_GD0( _TInput1* input1 )
{
- typedef itk::PowImageFilter< _TImage, _TImage > _TFilter;
+ auto input2 = this->GetInputData< _TInput1 >( "Input2" );
+ if( input2 == NULL )
+ this->_Error( "Incompatible second input image." );
+ this->_GD1( input2, input1 );
+}
+
+// -------------------------------------------------------------------------
+template< class _TInput2, class _TInput1 >
+void cpPluginsImageArithmeticFilters::PowImageFilter::
+_GD1( _TInput2* input2, _TInput1* input1 )
+{
+ typedef itk::PowImageFilter< _TInput1, _TInput2, _TInput1 > _TFilter;
// Configure filter
auto filter = this->_CreateITK< _TFilter >( );
- filter->SetInput1( image0 );
- auto image1 = this->GetInputData< _TImage >( "Input1" );
- if( image1 == NULL )
- filter->SetConstant( this->m_Parameters.GetReal( "Constant" ) );
- else
- filter->SetInput2( image1 );
+ filter->SetInput1( input1 );
+ filter->SetInput2( input2 );
filter->Update( );
// Connect output
}
// eof - $RCSfile$
+
+/* TODO
+ filter->SetInput1( image0 );
+ auto image1 = this->GetInputData< _TImage >( "Input1" );
+ if( image1 == NULL )
+ filter->SetConstant( this->m_Parameters.GetReal( "Constant" ) );
+ else
+ filter->SetInput2( image1 );
+ filter->Update( );
+
+ // Connect output
+ this->GetOutput( "Output" )->SetITK( filter->GetOutput( ) );
+*/
+
+// eof - $RCSfile$