ITK/Examples/EdgesAndGradients/GradientMagnitudeRecursiveGaussianImageFilter

From KitwarePublic
< ITK‎ | Examples
Revision as of 01:22, 12 December 2010 by Lorensen (talk | contribs) (Use QuickView)
Jump to navigationJump to search

This example demonstrates how to compute the magnitude of the gradient of an image. The original image and its gradient magnitude are displayed on the screen.

GradientMagnitudeRecursiveGaussianImageFilter.cxx

<source lang="cpp">

  1. include "itkImage.h"
  2. include "itkImageFileReader.h"
  3. include "itkImageFileWriter.h"
  4. include "itkGradientMagnitudeRecursiveGaussianImageFilter.h"
  1. include "QuickView.h"

int main(int argc, char * argv[]) {

 // Verify command line arguments
 if( argc < 2 )
   {
   std::cerr << "Usage: " << std::endl;
   std::cerr << argv[0] << " inputImageFile" << std::endl;
   return EXIT_FAILURE;
   }
 // Parse command line arguments
 std::string inputFilename = argv[1];
 // Setup types
 typedef itk::Image< float,  2 >        FloatImageType;
 typedef itk::Image< unsigned char, 2 > UnsignedCharImageType;
 typedef itk::ImageFileReader< UnsignedCharImageType >  readerType;
 typedef itk::GradientMagnitudeRecursiveGaussianImageFilter<

UnsignedCharImageType, FloatImageType > filterType;

 // Create and setup a reader
 readerType::Pointer reader = readerType::New();
 reader->SetFileName( inputFilename.c_str() );
 // Create and setup a gradient filter
 filterType::Pointer gradientFilter = filterType::New();
 gradientFilter->SetInput( reader->GetOutput() );
 QuickView viewer;
 viewer.AddImage<UnsignedCharImageType>(reader->GetOutput());
 viewer.AddImage<FloatImageType>(gradientFilter->GetOutput());
 viewer.Visualize();
 return EXIT_SUCCESS;

} </source>

CMakeLists.txt

<source lang="cmake"> cmake_minimum_required(VERSION 2.6)

PROJECT(GradientMagnitudeRecursiveGaussianImageFilter)

include_directories(/home/doriad/src/ITK/Wrapping/WrapITK/ExternalProjects/ItkVtkGlue/src/)

FIND_PACKAGE(VTK REQUIRED) INCLUDE(${VTK_USE_FILE})

FIND_PACKAGE(ITK REQUIRED) INCLUDE(${ITK_USE_FILE})

ADD_EXECUTABLE(GradientMagnitudeRecursiveGaussianImageFilter GradientMagnitudeRecursiveGaussianImageFilter.cxx) TARGET_LINK_LIBRARIES(GradientMagnitudeRecursiveGaussianImageFilter vtkHybrid ITKBasicFilters ITKIO ITKCommon)

</source>