LAIFromNDVIImageTransform.cxxΒΆ

Example usage:

./LAIFromNDVIImageTransform Input/verySmallFSATSW.tif \
                            Output/siTvLAIFromNDVIImageTransformExampleTest_verySmallFSATSW.tif \
                            Output/verySmallFSATSW_visu.png \
                            Output/siTvLAIFromNDVIImageTransformExampleTest_verySmallFSATSW_visu.png \
                            1 \
                            4

Example source code (LAIFromNDVIImageTransform.cxx):

//
// This example presents a way to generate LAI (Leaf Area Index) image using formula dedicated to Formosat2.
// LAI Image is used as an input in Image Simulation process.
//
// Let's look at the minimal code required to use this algorithm. First, the
// following headers must be included.

#include "itkUnaryFunctorImageFilter.h"

#include "otbVegetationIndicesFunctor.h"
#include "otbImage.h"
#include "otbVectorImage.h"
#include "otbImageFileReader.h"
#include "otbImageFileWriter.h"

#include "itkRescaleIntensityImageFilter.h"

int main(int argc, char* argv[])
{
  if (argc != 7)
  {
    std::cerr << "Wrong Parameters " << std::endl;
    return EXIT_FAILURE;
  }

  const unsigned int Dimension = 2;
  using InputImageType         = otb::VectorImage<double, Dimension>;
  using OutputImageType        = otb::Image<double, Dimension>;
  using ImageVisuType          = otb::Image<unsigned char, Dimension>;
  using ReaderType             = otb::ImageFileReader<InputImageType>;
  using WriterType             = otb::ImageFileWriter<OutputImageType>;
  using VisuWriterType         = otb::ImageFileWriter<ImageVisuType>;
  using InWriterType           = otb::ImageFileWriter<InputImageType>;
  // Filter type is a generic \doxygen{itk}{UnaryFunctorImageFilter} using Formosat2 specific LAI
  //  \doxygen{otb}{LAIFromNDVIFormosat2Functor}.

  using FunctorType                = otb::Functor::LAIFromNDVIFormosat2Functor<InputImageType::InternalPixelType, OutputImageType::PixelType>;
  using LAIFRomNDVIImageFilterType = itk::UnaryFunctorImageFilter<InputImageType, OutputImageType, FunctorType>;

  // Instantiating object

  //  Next the filter is created by invoking the \code{New()}~method and
  //  assigning the result to a \doxygen{itk}{SmartPointer}.

  LAIFRomNDVIImageFilterType::Pointer filter = LAIFRomNDVIImageFilterType::New();

  ReaderType::Pointer     reader     = ReaderType::New();
  WriterType::Pointer     writer     = WriterType::New();
  InWriterType::Pointer   inWriter   = InWriterType::New();
  VisuWriterType::Pointer visuWriter = VisuWriterType::New();

  char* InputName   = argv[1];
  char* OutputName1 = argv[2];
  char* OutputName2 = argv[3];
  char* OutputName3 = argv[4];
  reader->SetFileName(InputName);


  // filter input is set with input image
  //

  filter->SetInput(reader->GetOutput());

  // then red and nir channels index are set using \code{SetRedIndex()} and  \code{SetNIRIndex()}
  //
  unsigned int redChannel = static_cast<unsigned int>(atoi(argv[5]));
  unsigned int nirChannel = static_cast<unsigned int>(atoi(argv[6]));
  filter->GetFunctor().SetBandIndex(CommonBandNames::RED, redChannel);
  filter->GetFunctor().SetBandIndex(CommonBandNames::NIR, nirChannel);

  //  The invocation of the \code{Update()} method triggers the
  //  execution of the pipeline.

  filter->Update();


  writer->SetFileName(OutputName1);
  writer->SetInput(filter->GetOutput());
  writer->Update();

  // rescale data

  inWriter->SetFileName(OutputName2);
  // typedef itk::RescaleIntensityImageFilter<InputImageType,
  //     OutputImageType> RescalerType;

  // RescalerType::Pointer     rescaler     = RescalerType::New();
  // rescaler->SetInput(reader->GetOutput());
  // rescaler->SetOutputMinimum(0);
  // rescaler->SetOutputMaximum(255);

  inWriter->SetInput(reader->GetOutput());
  inWriter->Update();


  visuWriter->SetFileName(OutputName3);
  using RescalerTypeOut = itk::RescaleIntensityImageFilter<OutputImageType, ImageVisuType>;

  RescalerTypeOut::Pointer rescaler = RescalerTypeOut::New();
  rescaler->SetInput(filter->GetOutput());
  rescaler->SetOutputMinimum(0);
  rescaler->SetOutputMaximum(255);

  visuWriter->SetInput(rescaler->GetOutput());
  visuWriter->Update();

  // \begin{figure}
  // \center
  // \includegraphics[width=0.44\textwidth]{verySmallFSATSW_visu.eps}
  // \includegraphics[width=0.44\textwidth]{siTvLAIFromNDVIImageTransformExampleTest_verySmallFSATSW_visu.eps}
  // \itkcaption[LAIFromNDVIImageTransform Filter]{LAI generation \emph{(right)} from NDVI applied on Formosat 2 Image \emph{(left)} .}
  // \label{fig:LAIFromNDVIImageTransform}
  // \end{figure}
  //
  //  Figure \ref{fig:LAIFromNDVIImageTransform} illustrates the LAI generation using Formosat 2 data.
  //


  return EXIT_SUCCESS;
}