source: src/unittests/AnalysisCorrelationToSurfaceUnitTest.cpp@ 9d457d

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 9d457d was af2c424, checked in by Frederik Heber <heber@…>, 15 years ago

LinkedCell constructor rewritten.

  • had to introduce getValue(iterator) to: molecule, tesselation, LinkedCell::LinkedNodes
  • LinkedCell::LinkedNodes is not a typedef anymore
  • new class LinkedCell::LinkedNodes derived from stl::list<TesselPoint *> to add getValue(iterator).
  • LinkedCell constructors changed:
    • use template for all classes that have begin(), end() and ... sigh ... getValue()
    • Argh! STL containers do all have begin() and end() but no consistent operator* (maps return pair<> ...)
    • specialized version for PointCloud derivatives
    • various functions had to be changed due to changed signature of LinkedCell constructor
  • Property mode set to 100644
File size: 7.8 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2010 University of Bonn. All rights reserved.
5 * Please see the LICENSE file or "Copyright notice" in builder.cpp for details.
6 */
7
8/*
9 * AnalysisCorrelationToSurfaceUnitTest.cpp
10 *
11 * Created on: Oct 13, 2009
12 * Author: heber
13 */
14
15// include config.h
16#ifdef HAVE_CONFIG_H
17#include <config.h>
18#endif
19
20using namespace std;
21
22#include <cppunit/CompilerOutputter.h>
23#include <cppunit/extensions/TestFactoryRegistry.h>
24#include <cppunit/ui/text/TestRunner.h>
25
26#include <cstring>
27
28#include "analysis_correlation.hpp"
29#include "AnalysisCorrelationToSurfaceUnitTest.hpp"
30
31#include "Descriptors/MoleculeDescriptor.hpp"
32
33#include "atom.hpp"
34#include "boundary.hpp"
35#include "element.hpp"
36#include "molecule.hpp"
37#include "linkedcell.hpp"
38#include "periodentafel.hpp"
39#include "tesselation.hpp"
40#include "World.hpp"
41#include "Helpers/Assert.hpp"
42
43#include "Helpers/Assert.hpp"
44
45#ifdef HAVE_TESTRUNNER
46#include "UnitTestMain.hpp"
47#endif /*HAVE_TESTRUNNER*/
48
49/********************************************** Test classes **************************************/
50
51// Registers the fixture into the 'registry'
52CPPUNIT_TEST_SUITE_REGISTRATION( AnalysisCorrelationToSurfaceUnitTest );
53
54void AnalysisCorrelationToSurfaceUnitTest::setUp()
55{
56 ASSERT_DO(Assert::Throw);
57
58 setVerbosity(5);
59
60 atom *Walker = NULL;
61
62 // init private all pointers to zero
63 TestSurfaceMolecule = NULL;
64 surfacemap = NULL;
65 binmap = NULL;
66 Surface = NULL;
67 LC = NULL;
68
69 // prepare element list
70 hydrogen = World::getInstance().getPeriode()->FindElement(1);
71 CPPUNIT_ASSERT(hydrogen != NULL && "hydrogen element not found");
72 elements.clear();
73
74 // construct molecule (tetraeder of hydrogens) base
75 TestSurfaceMolecule = World::getInstance().createMolecule();
76
77 Walker = World::getInstance().createAtom();
78 Walker->setType(hydrogen);
79 Walker->setPosition(Vector(1., 0., 1. ));
80 TestSurfaceMolecule->AddAtom(Walker);
81
82 Walker = World::getInstance().createAtom();
83 Walker->setType(hydrogen);
84 Walker->setPosition(Vector(0., 1., 1. ));
85 TestSurfaceMolecule->AddAtom(Walker);
86
87 Walker = World::getInstance().createAtom();
88 Walker->setType(hydrogen);
89 Walker->setPosition(Vector(1., 1., 0. ));
90 TestSurfaceMolecule->AddAtom(Walker);
91
92 Walker = World::getInstance().createAtom();
93 Walker->setType(hydrogen);
94 Walker->setPosition(Vector(0., 0., 0. ));
95 TestSurfaceMolecule->AddAtom(Walker);
96
97 // check that TestMolecule was correctly constructed
98 CPPUNIT_ASSERT_EQUAL( TestSurfaceMolecule->getAtomCount(), 4 );
99
100 TestSurfaceMolecule->ActiveFlag = true;
101
102 // init tesselation and linked cell
103 Surface = new Tesselation;
104 LC = new LinkedCell(*TestSurfaceMolecule, 5.);
105 FindNonConvexBorder(TestSurfaceMolecule, Surface, (const LinkedCell *&)LC, 2.5, NULL);
106
107 // add outer atoms
108 carbon = World::getInstance().getPeriode()->FindElement(6);
109 TestSurfaceMolecule = World::getInstance().createMolecule();
110 Walker = World::getInstance().createAtom();
111 Walker->setType(carbon);
112 Walker->setPosition(Vector(4., 0., 4. ));
113 TestSurfaceMolecule->AddAtom(Walker);
114
115 Walker = World::getInstance().createAtom();
116 Walker->setType(carbon);
117 Walker->setPosition(Vector(0., 4., 4. ));
118 TestSurfaceMolecule->AddAtom(Walker);
119
120 Walker = World::getInstance().createAtom();
121 Walker->setType(carbon);
122 Walker->setPosition(Vector(4., 4., 0. ));
123 TestSurfaceMolecule->AddAtom(Walker);
124
125 // add inner atoms
126 Walker = World::getInstance().createAtom();
127 Walker->setType(carbon);
128 Walker->setPosition(Vector(0.5, 0.5, 0.5 ));
129 TestSurfaceMolecule->AddAtom(Walker);
130
131 World::getInstance().selectAllMolecules(AllMolecules());
132 allMolecules = World::getInstance().getSelectedMolecules();
133 CPPUNIT_ASSERT_EQUAL( (size_t) 2, allMolecules.size());
134
135 // init maps
136 surfacemap = NULL;
137 binmap = NULL;
138
139};
140
141
142void AnalysisCorrelationToSurfaceUnitTest::tearDown()
143{
144 if (surfacemap != NULL)
145 delete(surfacemap);
146 if (binmap != NULL)
147 delete(binmap);
148
149 delete(Surface);
150 // note that all the atoms are cleaned by TestMolecule
151 delete(LC);
152 World::purgeInstance();
153 logger::purgeInstance();
154};
155
156
157/** Checks whether setup() does the right thing.
158 */
159void AnalysisCorrelationToSurfaceUnitTest::SurfaceTest()
160{
161 CPPUNIT_ASSERT_EQUAL( 4, TestSurfaceMolecule->getAtomCount() );
162 CPPUNIT_ASSERT_EQUAL( (size_t)2, allMolecules.size() );
163 CPPUNIT_ASSERT_EQUAL( (size_t)4, Surface->PointsOnBoundary.size() );
164 CPPUNIT_ASSERT_EQUAL( (size_t)6, Surface->LinesOnBoundary.size() );
165 CPPUNIT_ASSERT_EQUAL( (size_t)4, Surface->TrianglesOnBoundary.size() );
166};
167
168void AnalysisCorrelationToSurfaceUnitTest::CorrelationToSurfaceTest()
169{
170 // do the pair correlation
171 elements.push_back(hydrogen);
172 surfacemap = CorrelationToSurface( allMolecules, elements, Surface, LC );
173// OutputCorrelationToSurface ( (ofstream *)&cout, surfacemap );
174 CPPUNIT_ASSERT( surfacemap != NULL );
175 CPPUNIT_ASSERT_EQUAL( (size_t)4, surfacemap->size() );
176};
177
178void AnalysisCorrelationToSurfaceUnitTest::CorrelationToSurfaceHydrogenBinNoRangeTest()
179{
180 BinPairMap::iterator tester;
181 elements.push_back(hydrogen);
182 surfacemap = CorrelationToSurface( allMolecules, elements, Surface, LC );
183 // put pair correlation into bins and check with no range
184// OutputCorrelationToSurface ( (ofstream *)&cout, surfacemap );
185 binmap = BinData( surfacemap, 0.5, 0., 0. );
186 CPPUNIT_ASSERT_EQUAL( (size_t)1, binmap->size() );
187 OutputCorrelation ( (ofstream *)&cout, binmap );
188 tester = binmap->begin();
189 CPPUNIT_ASSERT_EQUAL( 0., tester->first );
190 CPPUNIT_ASSERT_EQUAL( 4, tester->second );
191
192};
193
194void AnalysisCorrelationToSurfaceUnitTest::CorrelationToSurfaceHydrogenBinRangeTest()
195{
196 BinPairMap::iterator tester;
197 elements.push_back(hydrogen);
198 surfacemap = CorrelationToSurface( allMolecules, elements, Surface, LC );
199// OutputCorrelationToSurface ( (ofstream *)&cout, surfacemap );
200 // ... and check with [0., 2.] range
201 binmap = BinData( surfacemap, 0.5, 0., 2. );
202 CPPUNIT_ASSERT_EQUAL( (size_t)5, binmap->size() );
203// OutputCorrelation ( (ofstream *)&cout, binmap );
204 tester = binmap->begin();
205 CPPUNIT_ASSERT_EQUAL( 0., tester->first );
206 CPPUNIT_ASSERT_EQUAL( 4, tester->second );
207 tester = binmap->find(1.);
208 CPPUNIT_ASSERT_EQUAL( 1., tester->first );
209 CPPUNIT_ASSERT_EQUAL( 0, tester->second );
210
211};
212
213void AnalysisCorrelationToSurfaceUnitTest::CorrelationToSurfaceCarbonBinNoRangeTest()
214{
215 BinPairMap::iterator tester;
216 elements.push_back(carbon);
217 surfacemap = CorrelationToSurface( allMolecules, elements, Surface, LC );
218// OutputCorrelationToSurface ( (ofstream *)&cout, surfacemap );
219 // put pair correlation into bins and check with no range
220 binmap = BinData( surfacemap, 0.5, 0., 0. );
221 //OutputCorrelation ( (ofstream *)&cout, binmap );
222 CPPUNIT_ASSERT_EQUAL( (size_t)9, binmap->size() );
223 // inside point is first and must have negative value
224 tester = binmap->lower_bound(4.25-0.5); // start depends on the min value and
225 CPPUNIT_ASSERT( tester != binmap->end() );
226 CPPUNIT_ASSERT_EQUAL( 3, tester->second );
227 // inner point
228 tester = binmap->lower_bound(0.);
229 CPPUNIT_ASSERT( tester != binmap->end() );
230 CPPUNIT_ASSERT_EQUAL( 1, tester->second );
231};
232
233void AnalysisCorrelationToSurfaceUnitTest::CorrelationToSurfaceCarbonBinRangeTest()
234{
235 BinPairMap::iterator tester;
236 elements.push_back(carbon);
237 surfacemap = CorrelationToSurface( allMolecules, elements, Surface, LC );
238// OutputCorrelationToSurface ( (ofstream *)&cout, surfacemap );
239 // ... and check with [0., 2.] range
240 binmap = BinData( surfacemap, 0.5, -2., 4. );
241 //OutputCorrelation ( (ofstream *)&cout, binmap );
242 CPPUNIT_ASSERT_EQUAL( (size_t)13, binmap->size() );
243 // three outside points
244 tester = binmap->lower_bound(4.25-0.5);
245 CPPUNIT_ASSERT( tester != binmap->end() );
246 CPPUNIT_ASSERT_EQUAL( 3, tester->second );
247 // inner point
248 tester = binmap->lower_bound(0.);
249 CPPUNIT_ASSERT( tester != binmap->end() );
250 CPPUNIT_ASSERT_EQUAL( 1, tester->second );
251};
Note: See TracBrowser for help on using the repository browser.