source: src/Fragmentation/Exporters/unittests/SphericalPointDistributionUnitTest_assistant.hpp@ ca4b372

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_StructOpt_integration_tests Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator 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_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion GeometryObjects Gui_displays_atomic_force_velocity IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks RotateToPrincipalAxisSystem_UndoRedo StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps Ubuntu_1604_changes stable
Last change on this file since ca4b372 was 2ccdf4, checked in by Frederik Heber <heber@…>, 9 years ago

Fixing getConnectionTest() due to ambiguous tesselation.

  • with N=8 with polygonal faces. Similarly, with N=9,10,11,12,14 we also face ambiguities. As we only need up to N=8, we leave it at less strict test that only checks the number of edges to be within certain bounds.
  • FIX: Fixed memory leak in connection with TesselPointSTLList.
  • Property mode set to 100644
File size: 4.0 KB
Line 
1/*
2 * SphericalPointDistribution_assistant.hpp
3 *
4 * Created on: Jul 12, 2014
5 * Author: heber
6 */
7
8#ifndef SPHERICALPOINTDISTRIBUTION_ASSISTANT_HPP_
9#define SPHERICALPOINTDISTRIBUTION_ASSISTANT_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16#include "SphericalPointDistributionUnitTest.hpp"
17
18#include "CodePatterns/Log.hpp"
19
20#include "Atom/TesselPoint.hpp"
21#include "Fragmentation/Exporters/SphericalPointDistribution.hpp"
22#include "LinkedCell/linkedcell.hpp"
23#include "LinkedCell/PointCloudAdaptor.hpp"
24#include "Tesselation/BoundaryLineSet.hpp"
25#include "Tesselation/tesselation.hpp"
26
27
28// class generator: taken from www.cplusplus.com example std::generate
29struct c_unique {
30 unsigned int current;
31 c_unique() {current=0;}
32 unsigned int operator()() {return current++;}
33} UniqueNumber;
34
35struct VectorToTesselPoint
36{
37 TesselPoint * operator()(const Vector &_v, const unsigned int _index) {
38 TesselPoint *t = new TesselPoint();
39 t->setPosition(_v);
40 t->setNr(_index);
41 return t;
42 }
43};
44
45// is declared in cpp module
46void freeTesselPointSTLList(TesselPointSTLList &_Corners);
47
48/** UnitTest for getConnections()
49 */
50template <int N>
51void SphericalPointDistributionTest_assistant::getConnectionTest()
52{
53 SphericalPointDistribution SPD(1.);
54 // get the points and convert into TesselPoint list
55 SphericalPointDistribution::Polygon_t newpolygon = SPD.get<N>();
56 TesselPointSTLList Corners;
57 SphericalPointDistribution::IndexList_t indices(N);
58 std::generate(indices.begin(), indices.end(), UniqueNumber);
59 std::transform(
60 newpolygon.begin(), newpolygon.end(),
61 indices.begin(),
62 std::back_inserter(Corners),
63 VectorToTesselPoint());
64
65 // create the tesselation
66 const double SPHERERADIUS = 1.5;
67 Tesselation TesselStruct;
68 PointCloudAdaptor<TesselPointSTLList> cloud(&Corners, "TesselPointSTLList");
69 TesselStruct(cloud, SPHERERADIUS);
70
71 // create a adjacency list from a tesselation of the (convex set of) points
72 SphericalPointDistribution::adjacency_t adjacency;
73 for (LineMap::const_iterator iter = TesselStruct.LinesOnBoundary.begin();
74 iter != TesselStruct.LinesOnBoundary.end(); ++iter) {
75 const BoundaryLineSet * const line = iter->second;
76 {
77 std::pair< SphericalPointDistribution::adjacency_t::iterator, bool > inserter =
78 adjacency.insert(
79 std::make_pair(
80 line->endpoints[0]->Nr,
81 SphericalPointDistribution::IndexSet_t() ));
82 inserter.first->second.insert(line->endpoints[1]->Nr);
83 LOG(6, "DEBUG: Inserting " << line->endpoints[0]->Nr << "," << line->endpoints[1]->Nr);
84 }
85 {
86 std::pair< SphericalPointDistribution::adjacency_t::iterator, bool > inserter =
87 adjacency.insert(
88 std::make_pair(
89 line->endpoints[1]->Nr,
90 SphericalPointDistribution::IndexSet_t() ));
91 inserter.first->second.insert(line->endpoints[0]->Nr);
92 LOG(6, "DEBUG: Inserting " << line->endpoints[1]->Nr << "," << line->endpoints[0]->Nr);
93 }
94 }
95
96 // free allocated TesselPoints
97 freeTesselPointSTLList(Corners);
98
99 // get the implemented connections
100 SphericalPointDistribution::adjacency_t expected =
101 SPD.getConnections<N>();
102
103// // print the map: for debugging and extracting the edges for getConnections()
104// std::cout << "\tadjacency_t adjacency;" << std::endl;
105// for (SphericalPointDistribution::adjacency_t::const_iterator iter = adjacency.begin();
106// iter != adjacency.end(); ++iter) {
107// std::cout << "\tadjacency += make_pair<unsigned int, IndexSet_t >( "
108// << iter->first << ", list_of<unsigned int>";
109// for (SphericalPointDistribution::IndexSet_t::const_iterator indexiter = iter->second.begin();
110// indexiter != iter->second.end(); ++indexiter)
111// std::cout << "(" << *indexiter << ")";
112// std::cout << " );" << std::endl;
113// }
114
115 // and compare the two
116 CPPUNIT_ASSERT_EQUAL( expected, adjacency );
117}
118
119
120#endif /* SPHERICALPOINTDISTRIBUTION_ASSISTANT_HPP_ */
Note: See TracBrowser for help on using the repository browser.