source: src/Analysis/unittests/AnalysisCorrelationToSurfaceUnitTest.cpp@ 57a770

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 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 57a770 was 0aa122, checked in by Frederik Heber <heber@…>, 13 years ago

Updated all source files's copyright note to current year 2012.

  • Property mode set to 100644
File size: 8.1 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 * 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/analysis_correlation.hpp"
29#include "Atom/atom.hpp"
30#include "CodePatterns/Assert.hpp"
31#include "Descriptors/MoleculeDescriptor.hpp"
32#include "Element/element.hpp"
33#include "Element/periodentafel.hpp"
34#include "LinkedCell/linkedcell.hpp"
35#include "LinkedCell/PointCloudAdaptor.hpp"
36#include "molecule.hpp"
37#include "MoleculeListClass.hpp"
38#include "Tesselation/boundary.hpp"
39#include "Tesselation/tesselation.hpp"
40#include "World.hpp"
41
42#include "AnalysisCorrelationToSurfaceUnitTest.hpp"
43
44#ifdef HAVE_TESTRUNNER
45#include "UnitTestMain.hpp"
46#endif /*HAVE_TESTRUNNER*/
47
48/********************************************** Test classes **************************************/
49
50// Registers the fixture into the 'registry'
51CPPUNIT_TEST_SUITE_REGISTRATION( AnalysisCorrelationToSurfaceUnitTest );
52
53void AnalysisCorrelationToSurfaceUnitTest::setUp()
54{
55 ASSERT_DO(Assert::Throw);
56
57 setVerbosity(5);
58
59 atom *Walker = NULL;
60
61 // init private all pointers to zero
62 TestSurfaceMolecule = NULL;
63 surfacemap = NULL;
64 binmap = NULL;
65 Surface = NULL;
66 LC = NULL;
67
68 // prepare element list
69 hydrogen = World::getInstance().getPeriode()->FindElement(1);
70 CPPUNIT_ASSERT(hydrogen != NULL && "hydrogen element not found");
71 elements.clear();
72
73 // construct molecule (tetraeder of hydrogens) base
74 TestSurfaceMolecule = World::getInstance().createMolecule();
75
76 Walker = World::getInstance().createAtom();
77 Walker->setType(hydrogen);
78 Walker->setPosition(Vector(1., 0., 1. ));
79 TestSurfaceMolecule->AddAtom(Walker);
80
81 Walker = World::getInstance().createAtom();
82 Walker->setType(hydrogen);
83 Walker->setPosition(Vector(0., 1., 1. ));
84 TestSurfaceMolecule->AddAtom(Walker);
85
86 Walker = World::getInstance().createAtom();
87 Walker->setType(hydrogen);
88 Walker->setPosition(Vector(1., 1., 0. ));
89 TestSurfaceMolecule->AddAtom(Walker);
90
91 Walker = World::getInstance().createAtom();
92 Walker->setType(hydrogen);
93 Walker->setPosition(Vector(0., 0., 0. ));
94 TestSurfaceMolecule->AddAtom(Walker);
95
96 // check that TestMolecule was correctly constructed
97 CPPUNIT_ASSERT_EQUAL( TestSurfaceMolecule->getAtomCount(), 4 );
98
99 TestSurfaceMolecule->ActiveFlag = true;
100
101 // init tesselation and linked cell
102 Surface = new Tesselation;
103 PointCloudAdaptor<molecule> cloud(TestSurfaceMolecule, TestSurfaceMolecule->name);
104 LC = new LinkedCell_deprecated(cloud, 5.);
105 FindNonConvexBorder(TestSurfaceMolecule, Surface, (const LinkedCell_deprecated *&)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 OutputCorrelationMap<BinPairMap> ( (ofstream *)&cout, binmap, OutputCorrelation_Header, OutputCorrelation_Value );
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.