File: TestPhantomDensityCalculator.cxx

package info (click to toggle)
volview 3.4-3
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 25,204 kB
  • sloc: cpp: 132,585; ansic: 11,612; tcl: 236; sh: 64; makefile: 25; xml: 8
file content (51 lines) | stat: -rw-r--r-- 2,168 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
/*=========================================================================

  Copyright (c) Kitware, Inc.
  All rights reserved.
  See Copyright.txt or http://www.kitware.com/VolViewCopyright.htm for details.

     This software is distributed WITHOUT ANY WARRANTY; without even
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
     PURPOSE.  See the above copyright notice for more information.

=========================================================================*/

#include "itkPhantomDensityCalculator.h"
#include "itkImageFileReader.h"
#include <iostream>

int main( int argc, char *argv[] )
{
  if (argc < 8)
    {
    std::cerr << "Usage args : PhantomCTData.mha EstimateOfForeGroundDensity EstimateOfBackgroundDensity Center_x center_y center_z Radius " << std::endl;
    return EXIT_FAILURE;
    }

  typedef itk::Image< short, 3 > ImageType;
  typedef itk::PhantomDensityCalculator< ImageType > CalculatorType;

  itk::ImageFileReader< ImageType >::Pointer reader = 
    itk::ImageFileReader< ImageType >::New();
  reader->SetFileName( argv[1] );
  reader->Update();

  CalculatorType::Pointer calculator = CalculatorType::New();
  calculator->SetImage( reader->GetOutput() );
  calculator->SetEstimateOfForegroundDensity( atof( argv[2] ) );
  calculator->SetEstimateOfBackgroundDensity( atof( argv[3] ) );
  double c[3] = { atof(argv[4]), atof(argv[5]), atof(argv[6]) };
  calculator->SetCenter( c );
  calculator->SetRadius( atoi( argv[7] ) );
  calculator->EstimateBackgroundDensityOn();
  calculator->Compute();

  reader->GetOutput()->Print(std::cout);
  std::cout << "calculated FG: " << calculator->GetCalculatedForegroundDensity() << std::endl;
  std::cout << "calculated BG: " << calculator->GetCalculatedBackgroundDensity() << std::endl;
  std::cout << "calculated FGSD: " << calculator->GetCalculatedStandardDeviationInForegroundDensity() << std::endl;
  std::cout << "calculated BGSD: " << calculator->GetCalculatedStandardDeviationInBackgroundDensity() << std::endl;
  std::cout << "nPixelsUsedInevalBG: " << calculator->GetNumberOfPixelsUsedInEvaluatingBackgroundDensity() << std::endl;

  return EXIT_SUCCESS;
}