Changeset 1cf5df for src/tesselation.hpp
- Timestamp:
- Dec 17, 2009, 5:52:45 PM (16 years ago)
- Branches:
- Action_Thermostats, Add_AtomRandomPerturbation, Add_FitFragmentPartialChargesAction, Add_RotateAroundBondAction, Add_SelectAtomByNameAction, Added_ParseSaveFragmentResults, AddingActions_SaveParseParticleParameters, Adding_Graph_to_ChangeBondActions, Adding_MD_integration_tests, Adding_ParticleName_to_Atom, Adding_StructOpt_integration_tests, AtomFragments, Automaking_mpqc_open, AutomationFragmentation_failures, Candidate_v1.5.4, Candidate_v1.6.0, Candidate_v1.6.1, Candidate_v1.7.0, ChangeBugEmailaddress, ChangingTestPorts, ChemicalSpaceEvaluator, CombiningParticlePotentialParsing, Combining_Subpackages, Debian_Package_split, Debian_package_split_molecuildergui_only, Disabling_MemDebug, Docu_Python_wait, EmpiricalPotential_contain_HomologyGraph, EmpiricalPotential_contain_HomologyGraph_documentation, Enable_parallel_make_install, Enhance_userguide, Enhanced_StructuralOptimization, Enhanced_StructuralOptimization_continued, Example_ManyWaysToTranslateAtom, Exclude_Hydrogens_annealWithBondGraph, FitPartialCharges_GlobalError, Fix_BoundInBox_CenterInBox_MoleculeActions, Fix_ChargeSampling_PBC, Fix_ChronosMutex, Fix_FitPartialCharges, Fix_FitPotential_needs_atomicnumbers, Fix_ForceAnnealing, Fix_IndependentFragmentGrids, Fix_ParseParticles, Fix_ParseParticles_split_forward_backward_Actions, Fix_PopActions, Fix_QtFragmentList_sorted_selection, Fix_Restrictedkeyset_FragmentMolecule, Fix_StatusMsg, Fix_StepWorldTime_single_argument, Fix_Verbose_Codepatterns, Fix_fitting_potentials, Fixes, ForceAnnealing_goodresults, ForceAnnealing_oldresults, ForceAnnealing_tocheck, ForceAnnealing_with_BondGraph, ForceAnnealing_with_BondGraph_continued, ForceAnnealing_with_BondGraph_continued_betteresults, ForceAnnealing_with_BondGraph_contraction-expansion, FragmentAction_writes_AtomFragments, FragmentMolecule_checks_bonddegrees, GeometryObjects, Gui_Fixes, Gui_displays_atomic_force_velocity, ImplicitCharges, IndependentFragmentGrids, IndependentFragmentGrids_IndividualZeroInstances, IndependentFragmentGrids_IntegrationTest, IndependentFragmentGrids_Sole_NN_Calculation, JobMarket_RobustOnKillsSegFaults, JobMarket_StableWorkerPool, JobMarket_unresolvable_hostname_fix, MoreRobust_FragmentAutomation, ODR_violation_mpqc_open, PartialCharges_OrthogonalSummation, PdbParser_setsAtomName, PythonUI_with_named_parameters, QtGui_reactivate_TimeChanged_changes, Recreated_GuiChecks, Rewrite_FitPartialCharges, RotateToPrincipalAxisSystem_UndoRedo, SaturateAtoms_findBestMatching, SaturateAtoms_singleDegree, StoppableMakroAction, Subpackage_CodePatterns, Subpackage_JobMarket, Subpackage_LinearAlgebra, Subpackage_levmar, Subpackage_mpqc_open, Subpackage_vmg, Switchable_LogView, ThirdParty_MPQC_rebuilt_buildsystem, TrajectoryDependenant_MaxOrder, TremoloParser_IncreasedPrecision, TremoloParser_MultipleTimesteps, TremoloParser_setsAtomName, Ubuntu_1604_changes, stable
- Children:
- 1ca488f, 3930eb
- Parents:
- ebbd3d (diff), 73b510 (diff)
 Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
 Use the(diff)links above to see all the changes relative to each parent.
- File:
- 
      - 1 edited
 
 - 
          
  src/tesselation.hpp (modified) (11 diffs)
 
Legend:
- Unmodified
- Added
- Removed
- 
      src/tesselation.hpprebbd3d r1cf5df 23 23 #include <list> 24 24 #include <set> 25 #include <stack> 25 26 26 27 #include "atom_particleinfo.hpp" … … 47 48 #define VRMLSUffix ".wrl" 48 49 50 #define ParallelEpsilon 1e-3 51 49 52 // ======================================================= some template functions ========================================= 50 53 51 54 #define PointMap map < int, class BoundaryPointSet * > 55 #define PointSet set < class BoundaryPointSet * > 56 #define PointList list < class BoundaryPointSet * > 52 57 #define PointPair pair < int, class BoundaryPointSet * > 53 58 #define PointTestPair pair < PointMap::iterator, bool > 59 54 60 #define CandidateList list <class CandidateForTesselation *> 61 #define CandidateMap map <class BoundaryLineSet *, class CandidateForTesselation *> 55 62 56 63 #define LineMap multimap < int, class BoundaryLineSet * > 64 #define LineSet set < class BoundaryLineSet * > 65 #define LineList list < class BoundaryLineSet * > 57 66 #define LinePair pair < int, class BoundaryLineSet * > 58 67 #define LineTestPair pair < LineMap::iterator, bool > 59 68 60 69 #define TriangleMap map < int, class BoundaryTriangleSet * > 70 #define TriangleSet set < class BoundaryTriangleSet * > 71 #define TriangleList list < class BoundaryTriangleSet * > 61 72 #define TrianglePair pair < int, class BoundaryTriangleSet * > 62 73 #define TriangleTestPair pair < TrianglePair::iterator, bool > 63 74 75 #define PolygonMap map < int, class BoundaryPolygonSet * > 76 #define PolygonSet set < class BoundaryPolygonSet * > 77 #define PolygonList list < class BoundaryPolygonSet * > 78 64 79 #define DistanceMultiMap multimap <double, pair < PointMap::iterator, PointMap::iterator> > 65 80 #define DistanceMultiMapPair pair <double, pair < PointMap::iterator, PointMap::iterator> > 81 82 #define TesselPointList list <TesselPoint *> 83 #define TesselPointSet set <TesselPoint *> 66 84 67 85 /********************************************** declarations *******************************/ … … 114 132 TriangleMap triangles; 115 133 int Nr; 134 bool skipped; 116 135 }; 117 136 … … 139 158 class BoundaryLineSet *lines[3]; 140 159 Vector NormalVector; 160 Vector SphereCenter; 141 161 int Nr; 142 162 }; 143 163 144 164 ostream & operator << (ostream &ost, const BoundaryTriangleSet &a); 165 166 167 // ======================================================== class BoundaryTriangleSet ======================================= 168 169 /** Set of BoundaryPointSet. 170 * This is just meant as a container for a group of endpoints, extending the node, line, triangle concept. However, this has 171 * only marginally something to do with the tesselation. Hence, there is no incorporation into the bookkeeping of the Tesselation 172 * class (i.e. no allocation, no deletion). 173 * \note we assume that the set of endpoints reside (more or less) on a plane. 174 */ 175 class BoundaryPolygonSet { 176 public: 177 BoundaryPolygonSet(); 178 ~BoundaryPolygonSet(); 179 180 Vector * GetNormalVector(const Vector &NormalVector) const; 181 void GetCenter(Vector *center) const; 182 bool ContainsBoundaryLine(const BoundaryLineSet * const line) const; 183 bool ContainsBoundaryPoint(const BoundaryPointSet * const point) const; 184 bool ContainsBoundaryPoint(const TesselPoint * const point) const; 185 bool ContainsBoundaryTriangle(const BoundaryTriangleSet * const point) const; 186 bool ContainsPresentTupel(const BoundaryPointSet * const * Points, const int dim) const; 187 bool ContainsPresentTupel(const BoundaryPolygonSet * const P) const; 188 bool ContainsPresentTupel(const PointSet &endpoints) const; 189 TriangleSet * GetAllContainedTrianglesFromEndpoints() const; 190 bool FillPolygonFromTrianglesOfLine(const BoundaryLineSet * const line); 191 192 PointSet endpoints; 193 int Nr; 194 }; 195 196 ostream & operator << (ostream &ost, const BoundaryPolygonSet &a); 145 197 146 198 // =========================================================== class TESSELPOINT =========================================== … … 186 238 class CandidateForTesselation { 187 239 public : 240 CandidateForTesselation(BoundaryLineSet* currentBaseLine); 188 241 CandidateForTesselation(TesselPoint* candidate, BoundaryLineSet* currentBaseLine, Vector OptCandidateCenter, Vector OtherOptCandidateCenter); 189 242 ~CandidateForTesselation(); 190 243 191 TesselPoint *point;244 TesselPointList pointlist; 192 245 BoundaryLineSet *BaseLine; 193 246 Vector OptCenter; 194 247 Vector OtherOptCenter; 195 }; 248 double ShortestAngle; 249 double OtherShortestAngle; 250 }; 251 252 ostream & operator <<(ostream &ost, const CandidateForTesselation &a); 196 253 197 254 // =========================================================== class TESSELATION =========================================== … … 211 268 void AddTesselationTriangle(); 212 269 void AddTesselationTriangle(const int nr); 270 void AddCandidateTriangle(CandidateForTesselation CandidateLine); 213 271 void RemoveTesselationTriangle(class BoundaryTriangleSet *triangle); 214 272 void RemoveTesselationLine(class BoundaryLineSet *line); … … 219 277 void FindStartingTriangle(const double RADIUS, const LinkedCell *LC); 220 278 void FindSecondPointForTesselation(class TesselPoint* a, Vector Oben, class TesselPoint*& OptCandidate, double Storage[3], double RADIUS, const LinkedCell *LC); 221 void FindThirdPointForTesselation(Vector &NormalVector, Vector &SearchDirection, Vector &OldSphereCenter, class BoundaryLineSet *BaseLine, const class TesselPoint * const ThirdNode, CandidateList* &candidates, double *ShortestAngle, const double RADIUS, const LinkedCell *LC) const;222 bool FindNextSuitableTriangle( BoundaryLineSet &Line, BoundaryTriangleSet &T, const double& RADIUS, const LinkedCell *LC);279 void FindThirdPointForTesselation(Vector &NormalVector, Vector &SearchDirection, Vector &OldSphereCenter, CandidateForTesselation &CandidateLine, const class TesselPoint * const ThirdNode, const double RADIUS, const LinkedCell *LC) const; 280 bool FindNextSuitableTriangle(CandidateForTesselation &CandidateLine, BoundaryTriangleSet &T, const double& RADIUS, const LinkedCell *LC); 223 281 int CheckPresenceOfTriangle(class TesselPoint *Candidates[3]) const; 224 282 class BoundaryTriangleSet * GetPresentTriangle(TesselPoint *Candidates[3]); … … 236 294 void RemoveDegeneratedTriangles(); 237 295 void AddBoundaryPointByDegeneratedTriangle(class TesselPoint *point, LinkedCell *LC); 296 int CorrectAllDegeneratedPolygons(); 238 297 239 298 set<TesselPoint*> * GetAllConnectedPoints(const TesselPoint* const Point) const; … … 241 300 list<list<TesselPoint*> *> * GetPathsOfConnectedPoints(const TesselPoint* const Point) const; 242 301 list<list<TesselPoint*> *> * GetClosedPathsOfConnectedPoints(const TesselPoint* const Point) const; 243 list<TesselPoint*> * GetCircleOf ConnectedPoints(const TesselPoint* const Point, const Vector * const Reference = NULL) const;302 list<TesselPoint*> * GetCircleOfSetOfPoints(set<TesselPoint*> *SetOfNeighbours, const TesselPoint* const Point, const Vector * const Reference = NULL) const; 244 303 class BoundaryPointSet *GetCommonEndpoint(const BoundaryLineSet * line1, const BoundaryLineSet * line2) const; 245 304 list<BoundaryTriangleSet*> *FindTriangles(const TesselPoint* const Points[3]) const; … … 260 319 PointMap PointsOnBoundary; 261 320 LineMap LinesOnBoundary; 321 CandidateMap OpenLines; 262 322 TriangleMap TrianglesOnBoundary; 263 323 int PointsOnBoundaryCount; … … 287 347 mutable PointMap::const_iterator InternalPointer; 288 348 289 bool HasOtherBaselineBetterCandidate(const BoundaryLineSet * const BaseRay, const TesselPoint * const OptCandidate, double ShortestAngle, double RADIUS, const LinkedCell * const LC) const;349 //bool HasOtherBaselineBetterCandidate(const BoundaryLineSet * const BaseRay, const TesselPoint * const OptCandidate, double ShortestAngle, double RADIUS, const LinkedCell * const LC) const; 290 350 }; 291 351 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
