source: molecuilder/src/triangleintersectionlist.hpp@ 2e06c4

Last change on this file since 2e06c4 was f7b476, checked in by Frederik Heber <heber@…>, 15 years ago

New class TriangleIntersection List and (hopefully) final fix of CorrelationToSurface().

  • Distances to surface were still calculated between the vector and the triangle plane not the triangle itself. Although functions such as BoundaryTriangleSet::GetClosestPointInsideTriangle had already been written.
  • As in class Tesselation there were many functions that all did the same: Calculate intersections between a point and all closeby triangles and then get the intersection or calculate this minimum distance and so ...
  • ... this was all put into a new class (in a new file): TriangleIntersectionList whose constructor scans all nearby triangles and put the calculates Intersections in the triangle into a list.
  • Functions as IsInside(), GetSmallestDistance(), GetClosestIntersection() and GetClosestTriangle() bring the desired functionality to the outside.
  • Respective functions in class Tesselation just make use of this new class and its member functions.
  • CorrelationToSurface() also directly instantiates this class to effectively use two of its functions.
  • Makefile.am has this new file in its SOURCES and HEADERS.
  • Tesselation:GetDistanceSquaredToSurface() -> Tesselation:GetDistanceToSurface(), FillBoxWithMolecule() has been adapted to this change.

AnalysisCorrelationToSurfaceUnitTest:

  • still has errors in it, as the distance were wrong before (because with respect to triangle plane, not triangle). Hence, the test was corrected.

Signed-off-by: Frederik Heber <heber@…>

  • Property mode set to 100644
File size: 1.6 KB
Line 
1/*
2 * TriangleIntersectionList.hpp
3 *
4 * Created on: Mar 1, 2010
5 * Author: heber
6 */
7
8#ifndef TRIANGLEINTERSECTIONLIST_HPP_
9#define TRIANGLEINTERSECTIONLIST_HPP_
10
11using namespace std;
12
13/*********************************************** includes ***********************************/
14
15// include config.h
16#ifdef HAVE_CONFIG_H
17#include <config.h>
18#endif
19
20#include <map>
21
22/****************************************** forward declarations *****************************/
23
24class BoundaryTriangleSet;
25class LinkedCell;
26class Tesselation;
27class Vector;
28
29/********************************************** definitions *********************************/
30
31#define TriangleVectorMap map < class BoundaryTriangleSet *, Vector *>
32#define DistanceTriangleMap map < double, class BoundaryTriangleSet *>
33
34// ======================================================== class TriangleIntersectionList =======================================
35
36/** Stores all intersection vectors to a list of triangles.
37 */
38class TriangleIntersectionList
39{
40public:
41 TriangleIntersectionList(const Vector *x, const Tesselation *surface, const LinkedCell* LC);
42 ~TriangleIntersectionList();
43
44 double GetSmallestDistance() const;
45 Vector GetClosestIntersection() const;
46 BoundaryTriangleSet * GetClosestTriangle() const;
47 bool IsInside() const;
48
49private:
50 void GatherIntersectionsWithTriangles();
51 TriangleVectorMap::const_iterator GetIteratortoSmallestDistance() const;
52 void FillDistanceList() const;
53
54 const Vector *Point;
55 const Tesselation *Tess;
56 const LinkedCell *Vicinity;
57 TriangleVectorMap IntersectionList;
58 mutable DistanceTriangleMap DistanceList;
59};
60
61#endif /* TRIANGLEINTERSECTIONLIST_HPP_ */
Note: See TracBrowser for help on using the repository browser.