| 1 | /*
 | 
|---|
| 2 |  * Tesselation_InsideOutsideUnitTest.hpp
 | 
|---|
| 3 |  *
 | 
|---|
| 4 |  *  Created on: Dec 28, 2009
 | 
|---|
| 5 |  *      Author: heber
 | 
|---|
| 6 |  */
 | 
|---|
| 7 | 
 | 
|---|
| 8 | #ifndef TESSELATION_INSIDEOUTSIDEUNITTEST_HPP_
 | 
|---|
| 9 | #define TESSELATION_INSIDEOUTSIDEUNITTEST_HPP_
 | 
|---|
| 10 | 
 | 
|---|
| 11 | // include config.h
 | 
|---|
| 12 | #ifdef HAVE_CONFIG_H
 | 
|---|
| 13 | #include <config.h>
 | 
|---|
| 14 | #endif
 | 
|---|
| 15 | 
 | 
|---|
| 16 | /*********************************************** includes ***********************************/
 | 
|---|
| 17 | 
 | 
|---|
| 18 | #include <cppunit/extensions/HelperMacros.h>
 | 
|---|
| 19 | 
 | 
|---|
| 20 | #include <vector>
 | 
|---|
| 21 | 
 | 
|---|
| 22 | #include "LinearAlgebra/Vector.hpp"
 | 
|---|
| 23 | #include "LinearAlgebra/VectorSet.hpp"
 | 
|---|
| 24 | #include "LinkedCell/linkedcell.hpp"
 | 
|---|
| 25 | 
 | 
|---|
| 26 | class Tesselation;
 | 
|---|
| 27 | 
 | 
|---|
| 28 | /********************************************** Test classes **************************************/
 | 
|---|
| 29 | 
 | 
|---|
| 30 | class TesselationInOutsideTest : public CppUnit::TestFixture
 | 
|---|
| 31 | {
 | 
|---|
| 32 |     CPPUNIT_TEST_SUITE( TesselationInOutsideTest) ;
 | 
|---|
| 33 |     CPPUNIT_TEST ( IsInnerPointCubeTest );
 | 
|---|
| 34 |     CPPUNIT_TEST ( IsInnerPointSphereTest );
 | 
|---|
| 35 |     CPPUNIT_TEST ( IsInnerPointNonConvexTest );
 | 
|---|
| 36 |     CPPUNIT_TEST_SUITE_END();
 | 
|---|
| 37 | 
 | 
|---|
| 38 | public:
 | 
|---|
| 39 |       void setUp();
 | 
|---|
| 40 |       void tearDown();
 | 
|---|
| 41 |       void IsInnerPointCubeTest();
 | 
|---|
| 42 |       void IsInnerPointSphereTest();
 | 
|---|
| 43 |       void IsInnerPointNonConvexTest();
 | 
|---|
| 44 | 
 | 
|---|
| 45 | private:
 | 
|---|
| 46 |       void prepareCorners(const std::vector<Vector> &Vectors);
 | 
|---|
| 47 |       std::vector<Vector> translateAndexpand(
 | 
|---|
| 48 |           VECTORSET(std::vector) Vectors, const double factor, const Vector &offset) const;
 | 
|---|
| 49 |       std::vector<Vector> setupCube() const;
 | 
|---|
| 50 |       std::vector<Vector> setupSphere() const;
 | 
|---|
| 51 |       std::vector<Vector> setupNonConvex() const;
 | 
|---|
| 52 |       void prepareTesselation(const double SPHERERADIUS);
 | 
|---|
| 53 |       void removeTesselation();
 | 
|---|
| 54 | 
 | 
|---|
| 55 |       class Tesselation *TesselStruct;
 | 
|---|
| 56 |       TesselPointSTLList Corners;
 | 
|---|
| 57 |       class LinkedCell_deprecated *LinkedList;
 | 
|---|
| 58 | };
 | 
|---|
| 59 | 
 | 
|---|
| 60 | 
 | 
|---|
| 61 | #endif /* TESSELATION_INSIDEOUTSIDEUNITTEST_HPP_ */
 | 
|---|