File: TestContourStatistics.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 (100 lines) | stat: -rw-r--r-- 3,153 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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
/*=========================================================================

  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 "vtkPolyData.h"
#include "vtkContourStatistics.h"
#include "vtkImageData.h"
#include "vtkCell.h"
#include "vtkCellArray.h"
#include "vtkPoints.h"

int main()
{
  double contourPoints[4][3] = {{1.0,2.0,3.0},{5.2,1.1,3.0},{6.1,5.3,3.0},{0.6,4.8,3.0}};
  int imageExtent[6]  = {0,8,0,5,0,8};
  double imageSpacing[3] = {1.1,1.2,1.0};
  double imageOrigin[3]  = {0.0,0.0,0.0};
  unsigned int numberOfPoints = 4;
  vtkPoints *points = vtkPoints::New();
  vtkCellArray *lines = vtkCellArray::New();
  
  vtkIdType index = 0;
  
  points->SetNumberOfPoints(numberOfPoints);
  vtkIdType *lineIndices = new vtkIdType[numberOfPoints + 1];
  
  for ( unsigned int i=0; i<numberOfPoints; i++ )
    {
    points->InsertPoint( index, contourPoints[numberOfPoints-i-1] );
    lineIndices[index] = index;
    index++;
    }
      
  lineIndices[numberOfPoints] = 0;
  lines->InsertNextCell( numberOfPoints+1, lineIndices );
  delete [] lineIndices;
  
  vtkPolyData *contour = vtkPolyData::New();
  contour->SetPoints( points );
  contour->SetLines( lines );
  points->Delete();
  lines->Delete();

  vtkImageData *image = vtkImageData::New();
  image->SetExtent( imageExtent );
  image->SetSpacing( imageSpacing );
  image->SetOrigin( imageOrigin );
  image->SetScalarTypeToUnsignedChar();
  for (int z=imageExtent[4]; z<= imageExtent[5]; z++)
    {
    for (int y=imageExtent[2]; y<= imageExtent[3]; y++)
      {
      for (int x=imageExtent[0]; x<= imageExtent[1]; x++)
        {
        *((unsigned char *)(image->GetScalarPointer(x,y,z))) = (unsigned char)(x+y+z);
        }
      }
    }
  
  vtkContourStatistics *contourStats = vtkContourStatistics::New();
  contourStats->SetInput( contour );
  contourStats->SetImageData( image );
  double area = contourStats->GetArea();
  if ((area-17.025)>0.001) 
    {
    std::cerr << "Area:       " << area << std::endl;
    return EXIT_FAILURE;
    }
  
  double perimeter = contourStats->GetPerimeter();
  if ((perimeter-16.9418)>0.001) 
    {
    std::cout << "Perimeter:  " << perimeter << std::endl;
    return EXIT_FAILURE;
    }

  if (contourStats->GetStatisticsComputeFailed())
    {
    return EXIT_FAILURE;
    }
  std::cout << "Min:        " << contourStats->GetMinimum() << std::endl;
  std::cout << "Max:        " << contourStats->GetMaximum() << std::endl;
  std::cout << "Mean:       " << contourStats->GetMean() << std::endl;
  std::cout << "StdDev:     " << contourStats->GetStandardDeviation() << std::endl;
  std::cout << "NumberOfPix:" << contourStats->GetNumberOfPixelsInContour() << std::endl;

  contourStats->Delete();
  image->Delete();
  contour->Delete();
  
  return EXIT_SUCCESS;
}