source: src/FunctionApproximation/unittests/ExtractorsUnitTest.cpp@ 94791a

ForceAnnealing_goodresults ForceAnnealing_tocheck
Last change on this file since 94791a was 2124aa, checked in by Frederik Heber <heber@…>, 9 years ago

Extractors::reorderArgumentsByParticleTypes() rewritten to scan for all induced, connected subgraphs.

  • after filtering the arguments down to the required particle types, we use the adjacency graph that is passed down from creating the SaturatedFragments, stored in various FragmentationResultContainers and finally used to state whether in Extractors::gatherAllSymmetricDistances() a distance represents a bond or not. In this graph we look for all subgraphs that are homologous to the graph specified by the derived EmpiricalPotential. For each accepted subgraph we then gather again all symmetric distances and concatenate them all.
  • TESTFIX: Marked all potential fitting regression tests as XFAIL for the moment. On the one hand the homology container format changed (edges), and on the other hand we are in the middle of refactoring above function.
  • added test using edges for ExtractorsUnitTest.
  • lib dependency fixed for ..PotentialUnitTest.
  • NOTE: boost::graph is incompatible with CodePattern's MEMDEBUG. Hence, includes are placed prior to memdebug's.
  • Property mode set to 100644
File size: 3.5 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 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 * ExtractorsUnitTest.cpp
25 *
26 * Created on: Oct 16, 2012
27 * Author: heber
28 */
29
30// include config.h
31#ifdef HAVE_CONFIG_H
32#include <config.h>
33#endif
34
35using namespace std;
36
37#include <cppunit/CompilerOutputter.h>
38#include <cppunit/extensions/TestFactoryRegistry.h>
39#include <cppunit/ui/text/TestRunner.h>
40
41#include "ExtractorsUnitTest.hpp"
42
43#include <boost/assign.hpp>
44
45#include "CodePatterns/Assert.hpp"
46
47#include "FunctionApproximation/Extractors.hpp"
48#include "Potentials/helpers.hpp"
49
50using namespace boost::assign;
51
52#ifdef HAVE_TESTRUNNER
53#include "UnitTestMain.hpp"
54#endif /*HAVE_TESTRUNNER*/
55
56/********************************************** Test classes **************************************/
57
58// Registers the fixture into the 'registry'
59CPPUNIT_TEST_SUITE_REGISTRATION( ExtractorsTest );
60
61
62void ExtractorsTest::setUp()
63{
64 // failing asserts should be thrown
65 ASSERT_DO(Assert::Throw);
66
67}
68
69
70void ExtractorsTest::tearDown()
71{
72}
73
74/** UnitTest for gatherAllSymmetricDistances()
75 */
76void ExtractorsTest::gatherAllSymmetricDistancesTest()
77{
78 // create positions
79 Fragment::positions_t positions;
80 Fragment::position_t pos(3, 0.);
81 for (double i = 0; i < 5; i+=1.) {
82 pos[0] = i;
83 positions.push_back(pos);
84 }
85
86 // create charges
87 Fragment::atomicnumbers_t atomicnumbers;
88 atomicnumbers += 6, 6, 1, 1, 1;
89
90 // create distances
91 FragmentationEdges::edges_t edges; // maybe left empty
92 FunctionModel::arguments_t args =
93 Extractors::gatherAllSymmetricDistances(positions, atomicnumbers, edges, 0);
94 CPPUNIT_ASSERT_EQUAL( (size_t)(5*4/2), args.size() );
95
96 // check created args
97 for (size_t i=0; i< (5*4)/2; ++i)
98 CPPUNIT_ASSERT( (args[i].distance >= 0) && (args[i].distance <= 4));
99}
100
101/** UnitTest for gatherAllSymmetricDistances() with edges
102 */
103void ExtractorsTest::gatherAllSymmetricDistances_edgesTest()
104{
105 // create positions
106 Fragment::positions_t positions;
107 Fragment::position_t pos(3, 0.);
108 for (double i = 0; i < 5; i+=1.) {
109 pos[0] = i;
110 positions.push_back(pos);
111 }
112 FragmentationEdges::edges_t edges;
113 for (size_t i=1;i<5;++i)
114 edges += FragmentationEdges::edge_t(i-1, i);
115
116 // create charges
117 Fragment::atomicnumbers_t atomicnumbers;
118 atomicnumbers += 6, 6, 1, 1, 1;
119
120 // create distances
121 FunctionModel::arguments_t args =
122 Extractors::gatherAllSymmetricDistances(positions, atomicnumbers, edges, 0);
123 CPPUNIT_ASSERT_EQUAL( (size_t)(5*4/2), args.size() );
124
125 // check created args
126 for (size_t i=0; i< 5*4/2; ++i) {
127 CPPUNIT_ASSERT( (args[i].distance >= 0) && (args[i].distance <= 4));
128 if ((args[i].indices.first+1) == args[i].indices.second)
129 CPPUNIT_ASSERT( args[i].bonded );
130 }
131}
Note: See TracBrowser for help on using the repository browser.