source: src/Tesselation/BoundaryPolygonSet.cpp@ beadd0

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
Last change on this file since beadd0 was 76096d, checked in by Frederik Heber <heber@…>, 12 years ago

FIX: Several fixes found through CppCheck.

  • strncpy does not always cap with \0.
  • mismatch in new[] with delete.
  • division by zero.
  • NULL pointer not checked.
  • Property mode set to 100644
File size: 9.7 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2010-2012 University of Bonn. All rights reserved.
5 *
6 *
7 * This file is part of MoleCuilder.
8 *
9 * MoleCuilder is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation, either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * MoleCuilder is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
21 */
22
23/*
24 * BoundaryPolygonSet.cpp
25 *
26 * Created on: Jul 29, 2010
27 * Author: heber
28 */
29
30// include config.h
31#ifdef HAVE_CONFIG_H
32#include <config.h>
33#endif
34
35#include "CodePatterns/MemDebug.hpp"
36
37#include "BoundaryPolygonSet.hpp"
38
39#include <iostream>
40
41#include "BoundaryLineSet.hpp"
42#include "BoundaryPointSet.hpp"
43#include "BoundaryTriangleSet.hpp"
44#include "Atom/TesselPoint.hpp"
45
46#include "CodePatterns/Assert.hpp"
47#include "CodePatterns/Info.hpp"
48#include "CodePatterns/Log.hpp"
49#include "CodePatterns/Verbose.hpp"
50#include "Helpers/helpers.hpp"
51#include "LinearAlgebra/Plane.hpp"
52#include "LinearAlgebra/Vector.hpp"
53
54using namespace std;
55
56/** Constructor for BoundaryPolygonSet.
57 */
58BoundaryPolygonSet::BoundaryPolygonSet() :
59 Nr(-1)
60{
61 //Info FunctionInfo(__func__);
62}
63;
64
65/** Destructor of BoundaryPolygonSet.
66 * Just clears endpoints.
67 * \note When removing triangles from a class Tesselation, use RemoveTesselationTriangle()
68 */
69BoundaryPolygonSet::~BoundaryPolygonSet()
70{
71 //Info FunctionInfo(__func__);
72 endpoints.clear();
73 LOG(5, "DEBUG: Erasing polygon Nr." << Nr << " itself.");
74}
75;
76
77/** Calculates the normal vector for this triangle.
78 * Is made unique by comparison with \a OtherVector to point in the other direction.
79 * \param &OtherVector direction vector to make normal vector unique.
80 * \return allocated vector in normal direction
81 */
82Vector * BoundaryPolygonSet::GetNormalVector(const Vector &OtherVector) const
83{
84 //Info FunctionInfo(__func__);
85 // get normal vector
86 Vector TemporaryNormal;
87 Vector *TotalNormal = new Vector;
88 PointSet::const_iterator Runner[3];
89 for (int i = 0; i < 3; i++) {
90 Runner[i] = endpoints.begin();
91 for (int j = 0; j < i; j++) { // go as much further
92 Runner[i]++;
93 if (Runner[i] == endpoints.end()) {
94 ELOG(0, "There are less than three endpoints in the polygon!");
95 performCriticalExit();
96 }
97 }
98 }
99 TotalNormal->Zero();
100 int counter = 0;
101 for (; Runner[2] != endpoints.end();) {
102 TemporaryNormal = Plane(((*Runner[0])->node->getPosition()),
103 ((*Runner[1])->node->getPosition()),
104 ((*Runner[2])->node->getPosition())).getNormal();
105 for (int i = 0; i < 3; i++) // increase each of them
106 Runner[i]++;
107 (*TotalNormal) += TemporaryNormal;
108 }
109 if (counter != 0.)
110 TotalNormal->Scale(1. / (double) counter);
111
112 // make it always point inward (any offset vector onto plane projected onto normal vector suffices)
113 if (TotalNormal->ScalarProduct(OtherVector) > 0.)
114 TotalNormal->Scale(-1.);
115 LOG(4, "DEBUG: Normal Vector is " << *TotalNormal << ".");
116
117 return TotalNormal;
118}
119;
120
121/** Calculates the center point of the triangle.
122 * Is third of the sum of all endpoints.
123 * \param *center central point on return.
124 */
125void BoundaryPolygonSet::GetCenter(Vector * const center) const
126{
127 //Info FunctionInfo(__func__);
128 center->Zero();
129 int counter = 0;
130 for(PointSet::const_iterator Runner = endpoints.begin(); Runner != endpoints.end(); Runner++) {
131 (*center) += ((*Runner)->node->getPosition());
132 counter++;
133 }
134 center->Scale(1. / (double) counter);
135 LOG(4, "DEBUG: Center of BoundaryPolygonSet is at " << *center << ".");
136}
137
138/** Checks whether the polygons contains all three endpoints of the triangle.
139 * \param *triangle triangle to test
140 * \return true - triangle is contained polygon, false - is not
141 */
142bool BoundaryPolygonSet::ContainsBoundaryTriangle(const BoundaryTriangleSet * const triangle) const
143{
144 //Info FunctionInfo(__func__);
145 return ContainsPresentTupel(triangle->endpoints, 3);
146}
147;
148
149/** Checks whether the polygons contains both endpoints of the line.
150 * \param *line line to test
151 * \return true - line is of the triangle, false - is not
152 */
153bool BoundaryPolygonSet::ContainsBoundaryLine(const BoundaryLineSet * const line) const
154{
155 //Info FunctionInfo(__func__);
156 return ContainsPresentTupel(line->endpoints, 2);
157}
158;
159
160/** Checks whether point is any of the three endpoints this triangle contains.
161 * \param *point point to test
162 * \return true - point is of the triangle, false - is not
163 */
164bool BoundaryPolygonSet::ContainsBoundaryPoint(const BoundaryPointSet * const point) const
165{
166 //Info FunctionInfo(__func__);
167 for (PointSet::const_iterator Runner = endpoints.begin(); Runner != endpoints.end(); Runner++) {
168 if (point == (*Runner)) {
169 LOG(4, "DEBUG: Checking against " << **Runner << ": Contained.");
170 return true;
171 }
172 }
173 return false;
174}
175;
176
177/** Checks whether point is any of the three endpoints this triangle contains.
178 * \param *point TesselPoint to test
179 * \return true - point is of the triangle, false - is not
180 */
181bool BoundaryPolygonSet::ContainsBoundaryPoint(const TesselPoint * const point) const
182{
183 //Info FunctionInfo(__func__);
184 for (PointSet::const_iterator Runner = endpoints.begin(); Runner != endpoints.end(); Runner++)
185 if (point == (*Runner)->node) {
186 LOG(4, "DEBUG: Checking against " << **Runner << ": Contained.");
187 return true;
188 }
189 return false;
190}
191;
192
193/** Checks whether given array of \a *Points coincide with polygons's endpoints.
194 * \param **Points pointer to an array of BoundaryPointSet
195 * \param dim dimension of array
196 * \return true - set of points is contained in polygon, false - is not
197 */
198bool BoundaryPolygonSet::ContainsPresentTupel(const BoundaryPointSet * const * Points, const int dim) const
199{
200 //Info FunctionInfo(__func__);
201 int counter = 0;
202 LOG(5, "DEBUG Polygon is " << *this);
203 for (int i = 0; i < dim; i++) {
204 LOG(5, "DEBUG: Testing endpoint " << *Points[i]);
205 if (ContainsBoundaryPoint(Points[i])) {
206 counter++;
207 }
208 }
209
210 if (counter == dim)
211 return true;
212 else
213 return false;
214}
215;
216
217/** Checks whether given PointList coincide with polygons's endpoints.
218 * \param &endpoints PointList
219 * \return true - set of points is contained in polygon, false - is not
220 */
221bool BoundaryPolygonSet::ContainsPresentTupel(const PointSet &endpoints) const
222{
223 //Info FunctionInfo(__func__);
224 size_t counter = 0;
225 LOG(5, "DEBUG: Polygon is " << *this);
226 for (PointSet::const_iterator Runner = endpoints.begin(); Runner != endpoints.end(); Runner++) {
227 LOG(5, "DEBUG: Testing endpoint " << **Runner);
228 if (ContainsBoundaryPoint(*Runner))
229 counter++;
230 }
231
232 if (counter == endpoints.size())
233 return true;
234 else
235 return false;
236}
237;
238
239/** Checks whether given set of \a *Points coincide with polygons's endpoints.
240 * \param *P pointer to BoundaryPolygonSet
241 * \return true - is the very triangle, false - is not
242 */
243bool BoundaryPolygonSet::ContainsPresentTupel(const BoundaryPolygonSet * const P) const
244{
245 return ContainsPresentTupel((const PointSet) P->endpoints);
246}
247;
248
249/** Gathers all the endpoints' triangles in a unique set.
250 * \return set of all triangles
251 */
252TriangleSet * BoundaryPolygonSet::GetAllContainedTrianglesFromEndpoints() const
253{
254 //Info FunctionInfo(__func__);
255 pair<TriangleSet::iterator, bool> Tester;
256 TriangleSet *triangles = new TriangleSet;
257
258 for (PointSet::const_iterator Runner = endpoints.begin(); Runner != endpoints.end(); Runner++)
259 for (LineMap::const_iterator Walker = (*Runner)->lines.begin(); Walker != (*Runner)->lines.end(); Walker++)
260 for (TriangleMap::const_iterator Sprinter = (Walker->second)->triangles.begin(); Sprinter != (Walker->second)->triangles.end(); Sprinter++) {
261 //LOG(0, " Testing triangle " << *(Sprinter->second));
262 if (ContainsBoundaryTriangle(Sprinter->second)) {
263 Tester = triangles->insert(Sprinter->second);
264 if (Tester.second)
265 LOG(4, "DEBUG: Adding triangle " << *(Sprinter->second));
266 }
267 }
268
269 LOG(3, "DEBUG: The Polygon of " << endpoints.size() << " endpoints has " << triangles->size() << " unique triangles in total.");
270 return triangles;
271}
272;
273
274/** Fills the endpoints of this polygon from the triangles attached to \a *line.
275 * \param *line lines with triangles attached
276 * \return true - polygon contains endpoints, false - line was NULL
277 */
278bool BoundaryPolygonSet::FillPolygonFromTrianglesOfLine(const BoundaryLineSet * const line)
279{
280 //Info FunctionInfo(__func__);
281 pair<PointSet::iterator, bool> Tester;
282 if (line == NULL)
283 return false;
284 LOG(3, "DEBUG: Filling polygon from line " << *line);
285 for (TriangleMap::const_iterator Runner = line->triangles.begin(); Runner != line->triangles.end(); Runner++) {
286 for (int i = 0; i < 3; i++) {
287 Tester = endpoints.insert((Runner->second)->endpoints[i]);
288 if (Tester.second)
289 LOG(4, "DEBUG: Inserting endpoint " << *((Runner->second)->endpoints[i]));
290 }
291 }
292
293 return true;
294}
295;
296
297/** output operator for BoundaryPolygonSet.
298 * \param &ost output stream
299 * \param &a boundary polygon
300 */
301ostream &operator <<(ostream &ost, const BoundaryPolygonSet &a)
302{
303 ost << "[" << a.Nr << "|";
304 for (PointSet::const_iterator Runner = a.endpoints.begin(); Runner != a.endpoints.end();) {
305 ost << (*Runner)->node->getName();
306 Runner++;
307 if (Runner != a.endpoints.end())
308 ost << ",";
309 }
310 ost << "]";
311 return ost;
312}
313;
314
Note: See TracBrowser for help on using the repository browser.