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
|
/*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: itkQuadEdgeMeshCountingCellsTest.cxx
Language: C++
Date: $Date$
Version: $Revision$
Copyright (c) Insight Software Consortium. All rights reserved.
See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.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 notices for more information.
=========================================================================*/
#include "itkQuadEdgeMesh.h"
#include "itkQuadEdgeMeshLineCell.h"
#include "itkQuadEdgeMeshPolygonCell.h"
#include "itkQuadEdgeMeshEulerOperatorsTestHelper.h"
int itkQuadEdgeMeshCountingCellsTest(int argc, char * argv[])
{
(void)argc;
(void)argv;
typedef itk::QuadEdgeMesh< double, 3 > MeshType;
typedef MeshType::Pointer MeshPointer;
typedef MeshType::QEType QEType;
typedef MeshType::PointIdentifier PointIdentifier;
typedef MeshType::PointType PointType;
typedef MeshType::CellType CellType;
typedef itk::QuadEdgeMeshLineCell< CellType > LineCellType;
MeshPointer mesh = MeshType::New();
CreateSquareTriangularMesh<MeshType>( mesh );
// The initial configuration and numbering of simpleSquare.vtk:
// Vertices: 25 , Edges: 56, Faces: 32, Boundary = 1, Chi = 1
//
// 20 --------- 21 --------- 22 --------- 23 --------- 24
// | __/ | __/ | __/ | __/ |
// | __/ | __/ | __/ | __/ |
// | __/ | __/ | __/ | __/ |
// | / | / | / | / |
// 15 --------- 16 --------- 17 --------- 18 --------- 19
// | __/ | __/ | __/ | __/ |
// | __/ | __/ | __/ | __/ |
// | __/ | __/ | __/ | __/ |
// | / | / | / | / |
// 10 --------- 11 --------- 12 --------- 13 --------- 14
// | __/ | __/ | __/ | __/ |
// | __/ | __/ | __/ | __/ |
// | __/ | __/ | __/ | __/ |
// | / | / | / | / |
// 5 ---------- 6 ---------- 7 ---------- 8 --------- 9
// | __/ | __/ | __/ | __/ |
// | __/ | __/ | __/ | __/ |
// | __/ | __/ | __/ | __/ |
// | / | / | / | / |
// 0 ---------- 1 ---------- 2 --------- 3 --------- 4
//
std::cout << "ITK API" << std::endl;
std::cout << "GetNumberOfCells - Get Number of cells (all cells, from container)";
std::cout << std::endl;
std::cout << "GetNumberOfPoints - Get Number of points (all points, from container)";
std::cout << std::endl;
std::cout << "ITK QE API" << std::endl;
std::cout << "ComputeNumberOfEdges - Only edges - one container traversal" << std::endl;
std::cout << "ComputeNumberOfFaces - Only faces - one container traversal" << std::endl;
std::cout << "ComputeNumberOfPoints- Only USED points - one container traversal" << std::endl;
std::cout << "GetNumberOfFaces - Only faces - member variable" << std::endl;
std::cout << "GetNumberOfEdges - Only Edges - member variable" << std::endl;
std::cout << std::endl;
std::cout << "START TEST" << std::endl;
std::cout << "ITK API" << std::endl;
std::cout << "GetNumberOfCells: " << mesh->GetNumberOfCells() << std::endl;
std::cout << "GetNumberOfPoints: "<< mesh->GetNumberOfPoints()<< std::endl;
std::cout << "ITK QE API" << std::endl;
std::cout << "ComputeNumberOfEdges: " << mesh->ComputeNumberOfEdges() << std::endl;
std::cout << "ComputeNumberOfFaces: " << mesh->ComputeNumberOfFaces() << std::endl;
std::cout << "ComputeNumberOfPoints: "<< mesh->ComputeNumberOfPoints()<< std::endl;
std::cout << "GetNumberOfFaces: " << mesh->GetNumberOfFaces() << std::endl;
std::cout << "GetNumberOfEdges: " << mesh->GetNumberOfEdges() << std::endl;
return EXIT_SUCCESS;
}
|