]> Creatis software - cpPlugins.git/blob - appli/examples/example_OtsuFilter.cxx
...
[cpPlugins.git] / appli / examples / example_OtsuFilter.cxx
1 #include <cstdlib>
2 #include <iostream>
3 #include <string>
4
5 #include <cpPlugins/Interface/Interface.h>
6 #include <cpPlugins/Interface/ProcessObject.h>
7
8 int main( int argc, char* argv[] )
9 {
10   if( argc < 4 )
11   {
12     std::cerr
13       << "Usage: " << argv[ 0 ]
14       << " plugins_file"
15       << " input_image output_image" << std::endl;
16     return( 1 );
17
18   } // fi
19
20   // Create interface
21   typedef cpPlugins::Interface::Interface TInterface;
22   typedef TInterface::TClasses            TClasses;
23   TInterface plugins;
24   if( !plugins.Load( argv[ 1 ] ) )
25   {
26     std::cerr << "Failed to load plugins." << std::endl;
27     return( 1 );
28
29   } // fi
30
31   // Create objects
32   typedef cpPlugins::Interface::ProcessObject TProcessObject;
33   typedef cpPlugins::Interface::Parameters    TParameters;
34   cpPlugins::Interface::ProcessObject::Pointer reader, writer, otsu;
35   reader = plugins.CreateProcessObject( "cpPlugins::ImageReader" );
36   writer = plugins.CreateProcessObject( "cpPlugins::ImageWriter" );
37   otsu = plugins.CreateProcessObject( "cpPlugins::OtsuThresholdImageFilter" );
38   if( reader.IsNull( ) || writer.IsNull( ) || otsu.IsNull( ) )
39   {
40     std::cerr << "No suitable objects found in plugins." << std::endl;
41     return( 1 );
42
43   } // fi
44
45   // Configure reader
46   TParameters reader_params = reader->GetDefaultParameters( );
47   for( int i = 2; i < argc - 1; ++i )
48     reader_params.AddValueToStringList( "FileNames", argv[ i ] );
49   reader->SetParameters( reader_params );
50
51   // Configure otsu
52   TParameters otsu_params = otsu->GetDefaultParameters( );
53   otsu_params.SetValueAsUint( "NumberOfHistogramBins", 100 );
54   otsu_params.SetValueAsReal( "InsideValue", 255 );
55   otsu_params.SetValueAsReal( "OutsideValue", 0 );
56   otsu_params.SetValueAsString( "OutputType", "uchar" );
57   otsu->SetParameters( otsu_params );
58
59   // Configure writer
60   TParameters writer_params = writer->GetDefaultParameters( );
61   writer_params.SetValueAsString( "FileName", argv[ argc - 1 ] );
62   writer->SetParameters( writer_params );
63
64   // Connect pipeline
65   otsu->SetInput( 0, reader->GetOutput( 0 ) );
66   writer->SetInput( 0, otsu->GetOutput( 0 ) );
67
68   // Execute pipeline
69   std::string err = writer->Update( );
70   if( err != "" )
71   {
72     std::cerr << "ERROR: " << err << std::endl;
73     return( 1 );
74
75   } // fi
76   return( 0 );
77 }
78
79 // eof - $RCSfile$