source: src/unittests/AnalysisCorrelationToSurfaceUnitTest.cpp@ a564be

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 a564be 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
RevLine 
[bcf653]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
[c4d4df]8/*
9 * AnalysisCorrelationToSurfaceUnitTest.cpp
10 *
11 * Created on: Oct 13, 2009
12 * Author: heber
13 */
14
[bf3817]15// include config.h
16#ifdef HAVE_CONFIG_H
17#include <config.h>
18#endif
19
[c4d4df]20using namespace std;
21
22#include <cppunit/CompilerOutputter.h>
23#include <cppunit/extensions/TestFactoryRegistry.h>
24#include <cppunit/ui/text/TestRunner.h>
25
[49e1ae]26#include <cstring>
27
[c4d4df]28#include "analysis_correlation.hpp"
29#include "AnalysisCorrelationToSurfaceUnitTest.hpp"
30
[e65de8]31#include "Descriptors/MoleculeDescriptor.hpp"
32
[c4d4df]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"
[e6fdbe]40#include "World.hpp"
[8d2772]41#include "Helpers/Assert.hpp"
[c4d4df]42
[5be0eb]43#include "Helpers/Assert.hpp"
44
[9b6b2f]45#ifdef HAVE_TESTRUNNER
46#include "UnitTestMain.hpp"
47#endif /*HAVE_TESTRUNNER*/
[c4d4df]48
49/********************************************** Test classes **************************************/
50
51// Registers the fixture into the 'registry'
52CPPUNIT_TEST_SUITE_REGISTRATION( AnalysisCorrelationToSurfaceUnitTest );
53
54void AnalysisCorrelationToSurfaceUnitTest::setUp()
55{
[e0b6fd]56 ASSERT_DO(Assert::Throw);
[5be0eb]57
[d74077]58 setVerbosity(5);
59
[c4d4df]60 atom *Walker = NULL;
61
62 // init private all pointers to zero
[8cbb97]63 TestSurfaceMolecule = NULL;
[c4d4df]64 surfacemap = NULL;
65 binmap = NULL;
66 Surface = NULL;
67 LC = NULL;
68
[c78d44]69 // prepare element list
[4eb4fe]70 hydrogen = World::getInstance().getPeriode()->FindElement(1);
[c78d44]71 CPPUNIT_ASSERT(hydrogen != NULL && "hydrogen element not found");
72 elements.clear();
73
74 // construct molecule (tetraeder of hydrogens) base
[5f612ee]75 TestSurfaceMolecule = World::getInstance().createMolecule();
[a7b761b]76
[23b547]77 Walker = World::getInstance().createAtom();
[d74077]78 Walker->setType(hydrogen);
79 Walker->setPosition(Vector(1., 0., 1. ));
[8db598]80 TestSurfaceMolecule->AddAtom(Walker);
[a7b761b]81
[23b547]82 Walker = World::getInstance().createAtom();
[d74077]83 Walker->setType(hydrogen);
84 Walker->setPosition(Vector(0., 1., 1. ));
[8db598]85 TestSurfaceMolecule->AddAtom(Walker);
[a7b761b]86
[23b547]87 Walker = World::getInstance().createAtom();
[d74077]88 Walker->setType(hydrogen);
89 Walker->setPosition(Vector(1., 1., 0. ));
[8db598]90 TestSurfaceMolecule->AddAtom(Walker);
[a7b761b]91
[23b547]92 Walker = World::getInstance().createAtom();
[d74077]93 Walker->setType(hydrogen);
94 Walker->setPosition(Vector(0., 0., 0. ));
[8db598]95 TestSurfaceMolecule->AddAtom(Walker);
[c4d4df]96
97 // check that TestMolecule was correctly constructed
[a7b761b]98 CPPUNIT_ASSERT_EQUAL( TestSurfaceMolecule->getAtomCount(), 4 );
[c4d4df]99
[8db598]100 TestSurfaceMolecule->ActiveFlag = true;
[a5551b]101
[c4d4df]102 // init tesselation and linked cell
103 Surface = new Tesselation;
[af2c424]104 LC = new LinkedCell(*TestSurfaceMolecule, 5.);
[8db598]105 FindNonConvexBorder(TestSurfaceMolecule, Surface, (const LinkedCell *&)LC, 2.5, NULL);
[c4d4df]106
[bbc338]107 // add outer atoms
[4eb4fe]108 carbon = World::getInstance().getPeriode()->FindElement(6);
[8cbb97]109 TestSurfaceMolecule = World::getInstance().createMolecule();
[23b547]110 Walker = World::getInstance().createAtom();
[d74077]111 Walker->setType(carbon);
112 Walker->setPosition(Vector(4., 0., 4. ));
[8cbb97]113 TestSurfaceMolecule->AddAtom(Walker);
[a7b761b]114
[23b547]115 Walker = World::getInstance().createAtom();
[d74077]116 Walker->setType(carbon);
117 Walker->setPosition(Vector(0., 4., 4. ));
[8cbb97]118 TestSurfaceMolecule->AddAtom(Walker);
[a7b761b]119
[23b547]120 Walker = World::getInstance().createAtom();
[d74077]121 Walker->setType(carbon);
122 Walker->setPosition(Vector(4., 4., 0. ));
[8cbb97]123 TestSurfaceMolecule->AddAtom(Walker);
[a7b761b]124
[bbc338]125 // add inner atoms
[23b547]126 Walker = World::getInstance().createAtom();
[d74077]127 Walker->setType(carbon);
128 Walker->setPosition(Vector(0.5, 0.5, 0.5 ));
[8cbb97]129 TestSurfaceMolecule->AddAtom(Walker);
[a7b761b]130
[e65de8]131 World::getInstance().selectAllMolecules(AllMolecules());
132 allMolecules = World::getInstance().getSelectedMolecules();
133 CPPUNIT_ASSERT_EQUAL( (size_t) 2, allMolecules.size());
[bbc338]134
[c4d4df]135 // init maps
[bbc338]136 surfacemap = NULL;
[c4d4df]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
[776b64]149 delete(Surface);
150 // note that all the atoms are cleaned by TestMolecule
[c4d4df]151 delete(LC);
[23b547]152 World::purgeInstance();
[e6fdbe]153 logger::purgeInstance();
[c4d4df]154};
155
156
[8db598]157/** Checks whether setup() does the right thing.
158 */
159void AnalysisCorrelationToSurfaceUnitTest::SurfaceTest()
160{
[a7b761b]161 CPPUNIT_ASSERT_EQUAL( 4, TestSurfaceMolecule->getAtomCount() );
[e65de8]162 CPPUNIT_ASSERT_EQUAL( (size_t)2, allMolecules.size() );
[8db598]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
[c4d4df]168void AnalysisCorrelationToSurfaceUnitTest::CorrelationToSurfaceTest()
169{
170 // do the pair correlation
[c78d44]171 elements.push_back(hydrogen);
[e65de8]172 surfacemap = CorrelationToSurface( allMolecules, elements, Surface, LC );
[8db598]173// OutputCorrelationToSurface ( (ofstream *)&cout, surfacemap );
[c4d4df]174 CPPUNIT_ASSERT( surfacemap != NULL );
175 CPPUNIT_ASSERT_EQUAL( (size_t)4, surfacemap->size() );
176};
177
[bbc338]178void AnalysisCorrelationToSurfaceUnitTest::CorrelationToSurfaceHydrogenBinNoRangeTest()
[c4d4df]179{
180 BinPairMap::iterator tester;
[c78d44]181 elements.push_back(hydrogen);
[e65de8]182 surfacemap = CorrelationToSurface( allMolecules, elements, Surface, LC );
[c4d4df]183 // put pair correlation into bins and check with no range
[8db598]184// OutputCorrelationToSurface ( (ofstream *)&cout, surfacemap );
[e138de]185 binmap = BinData( surfacemap, 0.5, 0., 0. );
[c4d4df]186 CPPUNIT_ASSERT_EQUAL( (size_t)1, binmap->size() );
[8db598]187 OutputCorrelation ( (ofstream *)&cout, binmap );
[c4d4df]188 tester = binmap->begin();
189 CPPUNIT_ASSERT_EQUAL( 0., tester->first );
190 CPPUNIT_ASSERT_EQUAL( 4, tester->second );
191
192};
193
[bbc338]194void AnalysisCorrelationToSurfaceUnitTest::CorrelationToSurfaceHydrogenBinRangeTest()
[c4d4df]195{
196 BinPairMap::iterator tester;
[c78d44]197 elements.push_back(hydrogen);
[e65de8]198 surfacemap = CorrelationToSurface( allMolecules, elements, Surface, LC );
[8db598]199// OutputCorrelationToSurface ( (ofstream *)&cout, surfacemap );
[c4d4df]200 // ... and check with [0., 2.] range
[e138de]201 binmap = BinData( surfacemap, 0.5, 0., 2. );
[c4d4df]202 CPPUNIT_ASSERT_EQUAL( (size_t)5, binmap->size() );
[8db598]203// OutputCorrelation ( (ofstream *)&cout, binmap );
[c4d4df]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
[bbc338]213void AnalysisCorrelationToSurfaceUnitTest::CorrelationToSurfaceCarbonBinNoRangeTest()
214{
215 BinPairMap::iterator tester;
[c78d44]216 elements.push_back(carbon);
[e65de8]217 surfacemap = CorrelationToSurface( allMolecules, elements, Surface, LC );
[8db598]218// OutputCorrelationToSurface ( (ofstream *)&cout, surfacemap );
[bbc338]219 // put pair correlation into bins and check with no range
[e138de]220 binmap = BinData( surfacemap, 0.5, 0., 0. );
[3b9e34]221 //OutputCorrelation ( (ofstream *)&cout, binmap );
[c6394d]222 CPPUNIT_ASSERT_EQUAL( (size_t)9, binmap->size() );
[bbc338]223 // inside point is first and must have negative value
[8db598]224 tester = binmap->lower_bound(4.25-0.5); // start depends on the min value and
[bbc338]225 CPPUNIT_ASSERT( tester != binmap->end() );
226 CPPUNIT_ASSERT_EQUAL( 3, tester->second );
227 // inner point
[8db598]228 tester = binmap->lower_bound(0.);
[bbc338]229 CPPUNIT_ASSERT( tester != binmap->end() );
230 CPPUNIT_ASSERT_EQUAL( 1, tester->second );
231};
232
233void AnalysisCorrelationToSurfaceUnitTest::CorrelationToSurfaceCarbonBinRangeTest()
234{
235 BinPairMap::iterator tester;
[c78d44]236 elements.push_back(carbon);
[e65de8]237 surfacemap = CorrelationToSurface( allMolecules, elements, Surface, LC );
[8db598]238// OutputCorrelationToSurface ( (ofstream *)&cout, surfacemap );
[bbc338]239 // ... and check with [0., 2.] range
[e138de]240 binmap = BinData( surfacemap, 0.5, -2., 4. );
[3b9e34]241 //OutputCorrelation ( (ofstream *)&cout, binmap );
[bbc338]242 CPPUNIT_ASSERT_EQUAL( (size_t)13, binmap->size() );
243 // three outside points
[8db598]244 tester = binmap->lower_bound(4.25-0.5);
[bbc338]245 CPPUNIT_ASSERT( tester != binmap->end() );
246 CPPUNIT_ASSERT_EQUAL( 3, tester->second );
247 // inner point
[8db598]248 tester = binmap->lower_bound(0.);
[bbc338]249 CPPUNIT_ASSERT( tester != binmap->end() );
250 CPPUNIT_ASSERT_EQUAL( 1, tester->second );
251};
Note: See TracBrowser for help on using the repository browser.