From 4f6aadc0552db99c03057d4aa40a7fc4a1697350 Mon Sep 17 00:00:00 2001
From: David Sarrut <david.sarrut@gmail.com>
Date: Fri, 4 Nov 2011 10:23:03 +0100
Subject: [PATCH] First version of rel pos database builder

---
 ...kRelativePositionDataBaseBuilderFilter.txx | 160 ++++++++++++++++++
 .../clitkRelativePositionDataBaseBuilder.cxx  |  52 ++++++
 .../clitkRelativePositionDataBaseBuilder.ggo  |  25 +++
 ...tivePositionDataBaseBuilderGenericFilter.h |  76 +++++++++
 ...vePositionDataBaseBuilderGenericFilter.txx | 101 +++++++++++
 5 files changed, 414 insertions(+)
 create mode 100644 itk/clitkRelativePositionDataBaseBuilderFilter.txx
 create mode 100644 tools/clitkRelativePositionDataBaseBuilder.cxx
 create mode 100644 tools/clitkRelativePositionDataBaseBuilder.ggo
 create mode 100644 tools/clitkRelativePositionDataBaseBuilderGenericFilter.h
 create mode 100644 tools/clitkRelativePositionDataBaseBuilderGenericFilter.txx

diff --git a/itk/clitkRelativePositionDataBaseBuilderFilter.txx b/itk/clitkRelativePositionDataBaseBuilderFilter.txx
new file mode 100644
index 0000000..af482ca
--- /dev/null
+++ b/itk/clitkRelativePositionDataBaseBuilderFilter.txx
@@ -0,0 +1,160 @@
+/*=========================================================================
+  Program:   vv                     http://www.creatis.insa-lyon.fr/rio/vv
+
+  Authors belong to: 
+  - University of LYON              http://www.universite-lyon.fr/
+  - Léon Bérard cancer center       http://www.centreleonberard.fr
+  - CREATIS CNRS laboratory         http://www.creatis.insa-lyon.fr
+
+  This software is distributed WITHOUT ANY WARRANTY; without even
+  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+  PURPOSE.  See the copyright notices for more information.
+
+  It is distributed under dual licence
+
+  - BSD        See included LICENSE.txt file
+  - CeCILL-B   http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
+  ===========================================================================**/
+
+//--------------------------------------------------------------------
+template <class ImageType>
+clitk::RelativePositionDataBaseBuilderFilter<ImageType>::
+RelativePositionDataBaseBuilderFilter():
+  clitk::FilterBase(),
+  clitk::FilterWithAnatomicalFeatureDatabaseManagement(),
+  itk::ImageToImageFilter<ImageType, ImageType>()
+{
+  this->SetNumberOfRequiredInputs(0); // support
+  VerboseFlagOff();
+  SetBackgroundValue(0);
+  SetForegroundValue(1);
+  SetNumberOfBins(100);
+  SetNumberOfAngles(4);
+  SetAreaLossTolerance(0.01);
+  m_ListOfAngles.clear();
+  // SetSupportSize(0);
+  // SetTargetSize(0);
+  // SetSizeWithThreshold(0);
+  // SetSizeWithReverseThreshold(0);  
+}
+//--------------------------------------------------------------------
+
+
+//--------------------------------------------------------------------
+template <class ImageType>
+void 
+clitk::RelativePositionDataBaseBuilderFilter<ImageType>::
+PrintOptions() 
+{
+  DD("TODO");
+}
+//--------------------------------------------------------------------
+
+
+//--------------------------------------------------------------------
+template <class ImageType>
+void 
+clitk::RelativePositionDataBaseBuilderFilter<ImageType>::
+GenerateOutputInformation() 
+{ 
+  // ImagePointer input = dynamic_cast<ImageType*>(itk::ProcessObject::GetInput(0));
+  // ImagePointer outputImage = this->GetOutput(0);
+  // outputImage->SetRegions(outputImage->GetLargestPossibleRegion());
+}
+//--------------------------------------------------------------------
+
+
+//--------------------------------------------------------------------
+template <class ImageType>
+void 
+clitk::RelativePositionDataBaseBuilderFilter<ImageType>::
+GenerateInputRequestedRegion() 
+{
+  // Call default
+  // itk::ImageToImageFilter<ImageType, ImageType>::GenerateInputRequestedRegion();
+  // // Get input pointers and set requested region to common region
+  // ImagePointer input1 = dynamic_cast<ImageType*>(itk::ProcessObject::GetInput(0));
+  // input1->SetRequestedRegion(input1->GetLargestPossibleRegion());
+}
+//--------------------------------------------------------------------
+
+//--------------------------------------------------------------------
+template <class ImageType>
+void 
+clitk::RelativePositionDataBaseBuilderFilter<ImageType>::
+GenerateData() 
+{
+  // Load database of anatomical elements
+  static const unsigned int dim = ImageType::ImageDimension;
+  this->LoadAFDB();
+
+  // Get some information
+  std::string patient = this->GetAFDB()->GetTagValue("PatientID");
+
+  // Get input pointers
+  m_Support = this->GetAFDB()->template GetImage <ImageType>(GetSupportName());
+  m_Target = this->GetAFDB()->template GetImage <ImageType>(GetTargetName());
+
+  // Build the list of tested directions
+  m_ListOfAngles.clear();
+  for(uint i=0; i<GetNumberOfAngles(); i++) {
+    double a = i*360.0/GetNumberOfAngles();
+    if (a>180) a = 180-a;
+    m_ListOfAngles.push_back(clitk::deg2rad(a));
+    RelativePositionDirectionType r;
+    r.angle1 = clitk::deg2rad(a);
+    r.angle2 = 0;
+    r.notFlag = false;
+    m_ListOfDirections.push_back(r); // only one direction
+  }
+
+
+  // Perform the RelativePositionAnalyzerFilter for each objects
+  typedef typename clitk::RelativePositionAnalyzerFilter<ImageType> FilterType;
+  for (int i=0; i<GetNumberOfObjects(); i++) {
+    m_Object = this->GetAFDB()->template GetImage <ImageType>(GetObjectName(i));
+
+    for (int j=0; j<m_ListOfDirections.size(); j++) {
+      clitk::RelativePositionDirectionType direction = m_ListOfDirections[j];
+      
+      // Create the filter
+      typename FilterType::Pointer filter = FilterType::New();
+      filter->SetInputSupport(m_Support);
+      filter->SetInputTarget(m_Target);
+      filter->SetInputObject(m_Object); // FIXME do AndNot before + only compute supportSize once.
+      filter->SetNumberOfBins(GetNumberOfBins());
+      filter->SetAreaLossTolerance(GetAreaLossTolerance());
+      filter->SetDirection(direction);
+      filter->Update();
+
+      // Results
+      std::ostringstream s;
+      s << patient << " " 
+        << GetSupportName() << " " 
+        // << GetTargetName() << " " // No need
+        << GetObjectName(i) <<" ";
+      // Normal 
+      // if (filter->GetInfo().sizeAfterThreshold != filter->GetInfo().sizeBeforeThreshold) {
+        std::ostringstream os;
+        os << s.str();
+        direction.notFlag = false;
+        direction.Print(os);
+        filter->GetInfo().Print(os);
+        std::cout << os.str() << std::endl;
+      // }
+      // Inverse
+      // if (filter->GetInfoReverse().sizeAfterThreshold != filter->GetInfoReverse().sizeBeforeThreshold) {
+        std::ostringstream oos;
+        oos << s.str();
+        direction.notFlag = true;
+        direction.Print(oos);
+        filter->GetInfoReverse().Print(oos);
+        std::cout << oos.str() << std::endl;
+      // }
+    } // end direction
+
+  } // end object
+}
+//--------------------------------------------------------------------
+
+
diff --git a/tools/clitkRelativePositionDataBaseBuilder.cxx b/tools/clitkRelativePositionDataBaseBuilder.cxx
new file mode 100644
index 0000000..4c8db03
--- /dev/null
+++ b/tools/clitkRelativePositionDataBaseBuilder.cxx
@@ -0,0 +1,52 @@
+/*=========================================================================
+  Program:   vv                     http://www.creatis.insa-lyon.fr/rio/vv
+
+  Authors belong to:
+  - University of LYON              http://www.universite-lyon.fr/
+  - Léon Bérard cancer center       http://www.centreleonberard.fr
+  - CREATIS CNRS laboratory         http://www.creatis.insa-lyon.fr
+
+  This software is distributed WITHOUT ANY WARRANTY; without even
+  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+  PURPOSE.  See the copyright notices for more information.
+
+  It is distributed under dual licence
+
+  - BSD        See included LICENSE.txt file
+  - CeCILL-B   http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
+===========================================================================**/
+
+// clitk
+#include "clitkRelativePositionDataBaseBuilder_ggo.h"
+#include "clitkRelativePositionDataBaseBuilderGenericFilter.h"
+
+//--------------------------------------------------------------------
+int main(int argc, char * argv[]) {
+
+  // Init command line
+  GGO(clitkRelativePositionDataBaseBuilder, args_info);
+  CLITK_INIT;
+
+  // Filter
+  typedef clitk::RelativePositionDataBaseBuilderGenericFilter<args_info_clitkRelativePositionDataBaseBuilder> FilterType;
+  FilterType::Pointer filter = FilterType::New();
+  
+  // Set options
+  filter->SetArgsInfo(args_info);
+  
+  // Add an input to determine the type of image
+  NewAFDB(afdb, args_info.afdb_arg);
+  std::string f = afdb->GetTagValue(args_info.supportName_arg);
+  f = std::string(args_info.afdb_path_arg)+"/"+f;
+  filter->AddInputFilename(f);
+  
+  try {
+    filter->Update();
+  } catch(std::runtime_error e) {
+    std::cout << e.what() << std::endl;
+    return EXIT_FAILURE;
+  }
+
+  return EXIT_SUCCESS;
+} // This is the end, my friend
+//--------------------------------------------------------------------
diff --git a/tools/clitkRelativePositionDataBaseBuilder.ggo b/tools/clitkRelativePositionDataBaseBuilder.ggo
new file mode 100644
index 0000000..c71c462
--- /dev/null
+++ b/tools/clitkRelativePositionDataBaseBuilder.ggo
@@ -0,0 +1,25 @@
+#File clitkRelativePositionDataBaseBuilder.ggo
+package "clitkRelativePositionDataBaseBuilder"
+version "1.0"
+purpose "Analyze relative position of a target according to structures"
+
+section "General options"
+option "config"	  	-	"Config file"			  string  	no
+option "verbose"   	v   	"Verbose"			  flag		off
+option "imagetypes"     -       "Display allowed image types"     flag          off
+
+section "Input/Output"
+option "afdb"           a       "Input Anatomical Feature DB"           string yes
+option "afdb_path"      -       "Path to search image in afdb"          string no
+
+option "supportName"	i	"Input mask support name in afdb"	string yes
+option "targetName"	t	"Input mask target name in afdb"	string yes
+option "objectName"	j	"Input mask object name in afdb"	string yes multiple
+
+option "output"    	o   	"Output image "		                string yes
+
+section "Options for building the relative positions"
+option "bins"           b       "Number of histo bins for fuzzy map"      int default="100" no
+option "nb"             n       "Number of angles to test"                int default="4" no
+option "tol"            -       "Target area loss tolerance (|0-1])"      double default="0.01" no
+
diff --git a/tools/clitkRelativePositionDataBaseBuilderGenericFilter.h b/tools/clitkRelativePositionDataBaseBuilderGenericFilter.h
new file mode 100644
index 0000000..bf88269
--- /dev/null
+++ b/tools/clitkRelativePositionDataBaseBuilderGenericFilter.h
@@ -0,0 +1,76 @@
+/*=========================================================================
+  Program:   vv                     http://www.creatis.insa-lyon.fr/rio/vv
+
+  Authors belong to: 
+  - University of LYON              http://www.universite-lyon.fr/
+  - Léon Bérard cancer center       http://www.centreleonberard.fr
+  - CREATIS CNRS laboratory         http://www.creatis.insa-lyon.fr
+
+  This software is distributed WITHOUT ANY WARRANTY; without even
+  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+  PURPOSE.  See the copyright notices for more information.
+
+  It is distributed under dual licence
+
+  - BSD        See included LICENSE.txt file
+  - CeCILL-B   http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
+===========================================================================**/
+
+#ifndef CLITKRelativePositionDataBaseBuilderGENERICFILTER_H
+#define CLITKRelativePositionDataBaseBuilderGENERICFILTER_H
+
+// clitk 
+#include "clitkIO.h"
+#include "clitkImageToImageGenericFilter.h"
+#include "clitkRelativePositionDataBaseBuilderFilter.h"
+#include "clitkSliceBySliceRelativePositionFilter.h"
+
+//--------------------------------------------------------------------
+namespace clitk 
+{
+
+  template<class ArgsInfoType>
+  class ITK_EXPORT RelativePositionDataBaseBuilderGenericFilter:
+    public ImageToImageGenericFilter<RelativePositionDataBaseBuilderGenericFilter<ArgsInfoType> >
+  {
+  public:
+    //--------------------------------------------------------------------
+    RelativePositionDataBaseBuilderGenericFilter();
+  
+    //--------------------------------------------------------------------
+    typedef ImageToImageGenericFilter<RelativePositionDataBaseBuilderGenericFilter<ArgsInfoType> > Superclass;
+    typedef RelativePositionDataBaseBuilderGenericFilter Self;
+    typedef itk::SmartPointer<Self>       Pointer;
+    typedef itk::SmartPointer<const Self> ConstPointer;
+   
+    //--------------------------------------------------------------------
+    itkNewMacro(Self);  
+    itkTypeMacro(RelativePositionDataBaseBuilderGenericFilter, LightObject);
+
+    //--------------------------------------------------------------------
+    void SetArgsInfo(const ArgsInfoType & a);
+    template<class FilterType> 
+      void SetOptionsFromArgsInfoToFilter(FilterType * f) ;
+
+    //--------------------------------------------------------------------
+    // Main function called each time the filter is updated
+    template<class ImageType>  
+    void UpdateWithInputImageType();
+
+  protected:
+    template<unsigned int Dim> void InitializeImageType();
+      ArgsInfoType mArgsInfo;
+
+  private:
+    RelativePositionDataBaseBuilderGenericFilter(const Self&); //purposely not implemented
+    void operator=(const Self&); //purposely not implemented
+    
+  };// end class
+  //--------------------------------------------------------------------
+} // end namespace clitk
+
+#ifndef ITK_MANUAL_INSTANTIATION
+#include "clitkRelativePositionDataBaseBuilderGenericFilter.txx"
+#endif
+
+#endif // #define CLITKRelativePositionDataBaseBuilderGENERICFILTER_H
diff --git a/tools/clitkRelativePositionDataBaseBuilderGenericFilter.txx b/tools/clitkRelativePositionDataBaseBuilderGenericFilter.txx
new file mode 100644
index 0000000..6ce6a2a
--- /dev/null
+++ b/tools/clitkRelativePositionDataBaseBuilderGenericFilter.txx
@@ -0,0 +1,101 @@
+/*=========================================================================
+  Program:   vv                     http://www.creatis.insa-lyon.fr/rio/vv
+
+  Authors belong to: 
+  - University of LYON              http://www.universite-lyon.fr/
+  - Léon Bérard cancer center       http://www.centreleonberard.fr
+  - CREATIS CNRS laboratory         http://www.creatis.insa-lyon.fr
+
+  This software is distributed WITHOUT ANY WARRANTY; without even
+  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+  PURPOSE.  See the copyright notices for more information.
+
+  It is distributed under dual licence
+
+  - BSD        See included LICENSE.txt file
+  - CeCILL-B   http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
+  ===========================================================================**/
+
+//--------------------------------------------------------------------
+template<class ArgsInfoType>
+clitk::RelativePositionDataBaseBuilderGenericFilter<ArgsInfoType>::
+RelativePositionDataBaseBuilderGenericFilter():
+  ImageToImageGenericFilter<Self>("RelativePositionDataBaseBuilder")
+{
+  // Default values
+  cmdline_parser_clitkRelativePositionDataBaseBuilder_init(&mArgsInfo);
+  InitializeImageType<3>();
+}
+//--------------------------------------------------------------------
+
+
+//--------------------------------------------------------------------
+template<class ArgsInfoType>
+template<unsigned int Dim>
+void clitk::RelativePositionDataBaseBuilderGenericFilter<ArgsInfoType>::
+InitializeImageType() 
+{  
+  ADD_IMAGE_TYPE(Dim, uchar);
+}
+//--------------------------------------------------------------------
+  
+
+//--------------------------------------------------------------------
+template<class ArgsInfoType>
+void clitk::RelativePositionDataBaseBuilderGenericFilter<ArgsInfoType>::
+SetArgsInfo(const ArgsInfoType & a) 
+{
+  mArgsInfo=a;
+  SetIOVerbose(mArgsInfo.verbose_flag);
+  if (mArgsInfo.imagetypes_flag) this->PrintAvailableImageTypes();
+}
+//--------------------------------------------------------------------
+
+
+//--------------------------------------------------------------------
+// Update with the number of dimensions and the pixeltype
+//--------------------------------------------------------------------
+template<class ArgsInfoType>
+template<class FilterType>
+void clitk::RelativePositionDataBaseBuilderGenericFilter<ArgsInfoType>::
+SetOptionsFromArgsInfoToFilter(FilterType * f) 
+{
+  f->SetAFDBFilename(mArgsInfo.afdb_arg);
+  f->SetAFDBPath(mArgsInfo.afdb_path_arg);
+  f->SetNumberOfBins(mArgsInfo.bins_arg);
+  f->SetNumberOfAngles(mArgsInfo.nb_arg);
+  f->SetAreaLossTolerance(mArgsInfo.tol_arg);
+  f->SetSupportName(mArgsInfo.supportName_arg);
+  f->SetTargetName(mArgsInfo.targetName_arg);
+  for(int i=0; i<mArgsInfo.objectName_given; i++)
+    f->AddObjectName(mArgsInfo.objectName_arg[i]);  
+}
+//--------------------------------------------------------------------
+
+
+//--------------------------------------------------------------------
+// Update with the number of dimensions and the pixeltype
+//--------------------------------------------------------------------
+template<class ArgsInfoType>
+template<class ImageType>
+void clitk::RelativePositionDataBaseBuilderGenericFilter<ArgsInfoType>::
+UpdateWithInputImageType() 
+{ 
+  // Create filter
+  typedef clitk::RelativePositionDataBaseBuilderFilter<ImageType> FilterType;
+  typename FilterType::Pointer filter = FilterType::New();
+  
+  // Set global Options 
+  SetOptionsFromArgsInfoToFilter<FilterType>(filter);
+
+  // Go !
+  filter->Update();
+  
+  // Write/Save results
+  //  typename ImageType::Pointer output = filter->GetOutput();
+  //this->template SetNextOutput<ImageType>(output); 
+
+}
+//--------------------------------------------------------------------
+
+
-- 
2.47.1