source: src/Parser/unittests/ParserMpqcUnitTest.cpp@ 9eb71b3

Action_Thermostats Add_AtomRandomPerturbation Add_RotateAroundBondAction Add_SelectAtomByNameAction Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_StructOpt_integration_tests AutomationFragmentation_failures Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph_documentation Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph Fix_ChronosMutex 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_IntegrationTest JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks RotateToPrincipalAxisSystem_UndoRedo StoppableMakroAction TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps Ubuntu_1604_changes stable
Last change on this file since 9eb71b3 was 3fb9ab, checked in by Frederik Heber <heber@…>, 9 years ago

FIX: Preventing MPQC from using old temp files for restart.

  • TESTFIX: needed to add "checkstate=no" to file contents contained in unit test.
  • TESTFIX: needed to adapt all check .in files of MPQC and other regression tests.
  • Property mode set to 100644
File size: 12.6 KB
RevLine 
[9e4fd1]1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
[0aa122]4 * Copyright (C) 2010-2012 University of Bonn. All rights reserved.
[5aaa43]5 * Copyright (C) 2013 Frederik Heber. All rights reserved.
[94d5ac6]6 *
7 *
8 * This file is part of MoleCuilder.
9 *
10 * MoleCuilder is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * MoleCuilder is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
[9e4fd1]22 */
23
24/*
25 * ParserMpqcUnitTest.cpp
26 *
27 * Created on: Mar 3, 2010
28 * Author: metzler
29 */
30
31// include config.h
32#ifdef HAVE_CONFIG_H
33#include <config.h>
34#endif
35
36#include "ParserMpqcUnitTest.hpp"
37
38#include <cppunit/CompilerOutputter.h>
39#include <cppunit/extensions/TestFactoryRegistry.h>
40#include <cppunit/ui/text/TestRunner.h>
41
[61d69a4]42#include <boost/any.hpp>
43
[6f0841]44#include "Atom/atom.hpp"
[006e1e]45#include "Atom/AtomObserver.hpp"
46#include "CodePatterns/Assert.hpp"
47#include "Descriptors/AtomTypeDescriptor.hpp"
[3bdb6d]48#include "Element/element.hpp"
49#include "Element/periodentafel.hpp"
[765f16]50#include "Parser/ChangeTracker.hpp"
51#include "Parser/MpqcParser.hpp"
[006e1e]52#include "World.hpp"
[9e4fd1]53
54#ifdef HAVE_TESTRUNNER
55#include "UnitTestMain.hpp"
56#endif /*HAVE_TESTRUNNER*/
57
58using namespace std;
59
60// Registers the fixture into the 'registry'
61CPPUNIT_TEST_SUITE_REGISTRATION( ParserMpqcUnitTest );
62
[f31edc]63static string waterMpqc_CLHF ="% Created by MoleCuilder\n\
64mpqc: (\n\
[e3c4c5]65\tcheckpoint = no\n\
[3fb9ab]66\trestart = no\n\
[f31edc]67\tsavestate = no\n\
68\tdo_gradient = yes\n\
69\tmole<CLHF>: (\n\
70\t\tmolecule = $:molecule\n\
71\t\tbasis = $:basis\n\
[61d69a4]72\t\tmaxiter = 1000\n\
[f31edc]73\t\tmemory = 16000000\n\
74\t)\n\
75)\n\
76molecule<Molecule>: (\n\
77\tunit = angstrom\n\
78\t{ atoms geometry } = {\n\
[e9dc19]79\t\tO [ 0\t0\t0 ]\n\
80\t\tH [ 0.758602\t0\t0.504284 ]\n\
81\t\tH [ 0.758602\t0\t-0.504284 ]\n\
[f31edc]82\t}\n\
83)\n\
84basis<GaussianBasisSet>: (\n\
85\tname = \"3-21G\"\n\
86\tmolecule = $:molecule\n\
87)\n"; // tested with mpqc 3.0.0-alpha
88static string waterMpqc_CLKS ="% Created by MoleCuilder\n\
89mpqc: (\n\
[e3c4c5]90\tcheckpoint = no\n\
[3fb9ab]91\trestart = no\n\
[f31edc]92\tsavestate = no\n\
93\tdo_gradient = yes\n\
94\tmole<CLKS>: (\n\
95\t\tfunctional<StdDenFunctional>:(name=B3LYP)\n\
96\t\tmolecule = $:molecule\n\
97\t\tbasis = $:basis\n\
[61d69a4]98\t\tmaxiter = 1000\n\
[f31edc]99\t\tmemory = 16000000\n\
100\t)\n\
101)\n\
102molecule<Molecule>: (\n\
103\tunit = angstrom\n\
104\t{ atoms geometry } = {\n\
[e9dc19]105\t\tO [ 0\t0\t0 ]\n\
106\t\tH [ 0.758602\t0\t0.504284 ]\n\
107\t\tH [ 0.758602\t0\t-0.504284 ]\n\
[f31edc]108\t}\n\
109)\n\
110basis<GaussianBasisSet>: (\n\
111\tname = \"3-21G\"\n\
112\tmolecule = $:molecule\n\
113)\n"; // tested with mpqc 3.0.0-alpha
114static string waterMpqc_MBPT2 ="% Created by MoleCuilder\n\
[9e4fd1]115mpqc: (\n\
[e3c4c5]116\tcheckpoint = no\n\
[3fb9ab]117\trestart = no\n\
[9e4fd1]118\tsavestate = no\n\
119\tdo_gradient = yes\n\
120\tmole<MBPT2>: (\n\
121\t\tbasis = $:basis\n\
122\t\tmolecule = $:molecule\n\
[61d69a4]123\t\tmemory = 16000000\n\
[9e4fd1]124\t\treference<CLHF>: (\n\
[bb74ba]125\t\t\tmaxiter = 1000\n\
[9e4fd1]126\t\t\tbasis = $:basis\n\
127\t\t\tmolecule = $:molecule\n\
[61d69a4]128\t\t\tmemory = 16000000\n\
[9e4fd1]129\t\t)\n\
130\t)\n\
131)\n\
132molecule<Molecule>: (\n\
133\tunit = angstrom\n\
134\t{ atoms geometry } = {\n\
[e9dc19]135\t\tO [ 0\t0\t0 ]\n\
136\t\tH [ 0.758602\t0\t0.504284 ]\n\
137\t\tH [ 0.758602\t0\t-0.504284 ]\n\
[9e4fd1]138\t}\n\
139)\n\
140basis<GaussianBasisSet>: (\n\
141\tname = \"3-21G\"\n\
142\tmolecule = $:molecule\n\
[f31edc]143)\n"; // tested with mpqc 3.0.0-alpha
144static string waterMpqc_MBPT2_R12 ="% Created by MoleCuilder\n\
145mpqc: (\n\
[e3c4c5]146\tcheckpoint = no\n\
[3fb9ab]147\trestart = no\n\
[f31edc]148\tsavestate = no\n\
149\tdo_gradient = yes\n\
150\tmole<MBPT2_R12>: (\n\
151\t\tmolecule = $:molecule\n\
152\t\tbasis = $:basis\n\
153\t\taux_basis = $:abasis\n\
154\t\tstdapprox = \"A'\"\n\
155\t\tnfzc = 1\n\
156\t\tmemory = 16000000\n\
157\t\tintegrals<IntegralCints>:()\n\
158\t\treference<CLHF>: (\n\
159\t\t\tmolecule = $:molecule\n\
160\t\t\tbasis = $:basis\n\
161\t\t\tmaxiter = 1000\n\
162\t\t\tmemory = 16000000\n\
163\t\t\tintegrals<IntegralCints>:()\n\
164\t\t)\n\
165\t)\n\
166)\n\
167molecule<Molecule>: (\n\
168\tunit = angstrom\n\
169\t{ atoms geometry } = {\n\
[e9dc19]170\t\tO [ 0\t0\t0 ]\n\
171\t\tH [ 0.758602\t0\t0.504284 ]\n\
172\t\tH [ 0.758602\t0\t-0.504284 ]\n\
[f31edc]173\t}\n\
174)\n\
175basis<GaussianBasisSet>: (\n\
176\tname = \"3-21G\"\n\
177\tmolecule = $:molecule\n\
178)\n\
179% auxiliary basis set specification\n\
180\tabasis<GaussianBasisSet>: (\n\
181\tname = \"aug-cc-pVDZ\"\n\
182\tmolecule = $:molecule\n\
183)\n"; // basically tested with mpqc 3.0.0-alpha (no parse errors but did not calculate due to missing code)
[9e4fd1]184
[3308b6]185void ParserMpqcUnitTest::setUp()
186{
187 // failing asserts should be thrown
188 ASSERT_DO(Assert::Throw);
189
[765f16]190 parser = new FormatParser<mpqc>();
[61d69a4]191
[9e4fd1]192 World::getInstance();
193
194 setVerbosity(2);
195
196 // we need hydrogens and oxygens in the following tests
197 CPPUNIT_ASSERT(World::getInstance().getPeriode()->FindElement(1) != NULL);
198 CPPUNIT_ASSERT(World::getInstance().getPeriode()->FindElement(8) != NULL);
199}
200
[3308b6]201void ParserMpqcUnitTest::tearDown()
202{
[765f16]203 delete parser;
[9e4fd1]204 ChangeTracker::purgeInstance();
205 World::purgeInstance();
[708277]206 AtomObserver::purgeInstance();
[9e4fd1]207}
208
209/************************************ tests ***********************************/
210
[61d69a4]211void ParserMpqcUnitTest::ParameterDefaultTest() {
212 // check default values
[ee50c1]213 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::hessianParam) == std::string("no"));
214 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::savestateParam) == std::string("no"));
215 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::do_gradientParam) == std::string("yes"));
216 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::maxiterParam) == std::string("1000"));
217 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::memoryParam) == std::string("16000000"));
218 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::stdapproxParam) == std::string("A'"));
219 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::nfzcParam) == std::string("1"));
220 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::basisParam) == std::string("3-21G"));
221 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::aux_basisParam) == std::string("aug-cc-pVDZ"));
222 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::integrationParam) == std::string("IntegralCints"));
223 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::theoryParam) == std::string("MBPT2"));
[61d69a4]224}
225
[c1db05]226void ParserMpqcUnitTest::ParameterCloneTest() {
[765f16]227 FormatParser_Parameters *clone = parser->getParams().clone();
[ee50c1]228 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::theoryParam) == std::string("MBPT2"));
[c1db05]229 std::stringstream setvalue("theory = CLHF");
[765f16]230 setvalue >> parser->getParams();
[ee50c1]231 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::theoryParam) == std::string("CLHF"));
[765f16]232 parser->getParams().makeClone(*clone);
[ee50c1]233 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::theoryParam) == std::string("MBPT2"));
[c1db05]234}
235
[44fce5]236void ParserMpqcUnitTest::ParameterSetterTest() {
237 // test a string
238 {
239 std::stringstream setvalue("theory = CLHF");
[765f16]240 setvalue >> parser->getParams();
[44fce5]241// std::cout << "integration method is "
[765f16]242// << parser->getParams().getString(MpqcParser_Parameters::theoryParam) << std::endl;
[ee50c1]243 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::theoryParam) == std::string("CLHF"));
[44fce5]244 }
245 // test a bool
246 {
247 std::stringstream setvalue("Hessian = yes");
[765f16]248 setvalue >> parser->getParams();
[44fce5]249// std::cout << "Hessian is "
[765f16]250// << parser->getParams().getString(MpqcParser_Parameters::hessianParam) << std::endl;
[ee50c1]251 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::hessianParam) == std::string("yes"));
[44fce5]252 }
253 // test int
254 {
255 std::stringstream setvalue("maxiter = 500");
[765f16]256 setvalue >> parser->getParams();
[44fce5]257// std::cout << "maxiter is "
[765f16]258// << parser->getParams().getString(MpqcParser_Parameters::maxiterParam) << std::endl;
[ee50c1]259 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::maxiterParam) == std::string("500"));
[44fce5]260 }
261 // test whether unknown key fails
[311da7b]262 std::cout << "The following Assertion warning is desired and does not indicate a failure of the test." << std::endl;
[44fce5]263 {
264 std::stringstream setvalue("hessian = no");
[311da7b]265#ifndef NDEBUG
266 ASSERT_DO(Assert::Throw);
[765f16]267 CPPUNIT_ASSERT_THROW(setvalue >> parser->getParams(), Assert::AssertionFailure);
[311da7b]268#else
[765f16]269 setvalue >> parser->getParams();
[311da7b]270#endif
[44fce5]271// std::cout << "Hessian is still "
[765f16]272// << parser->getParams().getString(MpqcParser_Parameters::hessianParam) << std::endl;
[ee50c1]273 CPPUNIT_ASSERT(parser->getParams().getParameter(MpqcParser_Parameters::hessianParam) == std::string("yes"));
[44fce5]274 }
275}
276
[aa8ef2]277void ParserMpqcUnitTest::readMpqcTest() {
278 stringstream input(waterMpqc_CLHF);
[ee50c1]279 parser->getParams().setParameter(
280 MpqcParser_Parameters::theoryParam,
281 parser->getParams().getTheoryName(MpqcParser_Parameters::CLHF)
282 );
[765f16]283 parser->load(&input);
[aa8ef2]284
285 CPPUNIT_ASSERT_EQUAL(3, World::getInstance().numAtoms());
286}
287
[9e4fd1]288void ParserMpqcUnitTest::writeMpqcTest() {
289 // build up water molecule
[f31edc]290 string first;
291 string second;
[9e4fd1]292 atom *Walker = NULL;
293 Walker = World::getInstance().createAtom();
294 Walker->setType(8);
295 Walker->setPosition(Vector(0,0,0));
296 Walker = World::getInstance().createAtom();
297 Walker->setType(1);
298 Walker->setPosition(Vector(0.758602,0,0.504284));
299 Walker = World::getInstance().createAtom();
300 Walker->setType(1);
301 Walker->setPosition(Vector(0.758602,0,-0.504284));
302 CPPUNIT_ASSERT_EQUAL(3, World::getInstance().numAtoms());
303
304 // create two stringstreams, one stored, one created
[f31edc]305
[fac58f]306 std::vector<const atom *> atoms = const_cast<const World &>(World::getInstance()).
307 getAllAtoms();
[f31edc]308 {
309 // compare both configs for CLHF
310 stringstream output;
[ee50c1]311 parser->getParams().setParameter(
312 MpqcParser_Parameters::theoryParam,
313 parser->getParams().getTheoryName(MpqcParser_Parameters::CLHF)
314 );
[765f16]315 parser->save(&output, atoms);
[f31edc]316 stringstream input(waterMpqc_CLHF);
[120a86]317 // check for non-empty streams
318 input.peek();
319 output.peek();
320 CPPUNIT_ASSERT(input.good() && output.good());
321 // check equality of streams per line (for debugging)
[f31edc]322 for (; std::getline(input, first) && std::getline(output, second); ) {
323 //std::cout << "Comparing '" << first << "' to '" << second << "'" << std::endl;
324 CPPUNIT_ASSERT(first == second);
325 }
326 }
327 {
328 // compare both configs for CLKS
329 stringstream output;
[ee50c1]330 parser->getParams().setParameter(
331 MpqcParser_Parameters::theoryParam,
332 parser->getParams().getTheoryName(MpqcParser_Parameters::CLKS)
333 );
[120a86]334 parser->save(&output, atoms);
[f31edc]335 stringstream input(waterMpqc_CLKS);
[120a86]336 // check for non-empty streams
337 input.peek();
338 output.peek();
339 CPPUNIT_ASSERT(input.good() && output.good());
340 // check equality of streams per line (for debugging)
[f31edc]341 for (; std::getline(input, first) && std::getline(output, second); ) {
342 //std::cout << "Comparing '" << first << "' to '" << second << "'" << std::endl;
343 CPPUNIT_ASSERT(first == second);
344 }
345 }
346 {
347 // compare both configs for MBPT2
348 stringstream output;
[ee50c1]349 parser->getParams().setParameter(
350 MpqcParser_Parameters::theoryParam,
351 parser->getParams().getTheoryName(MpqcParser_Parameters::MBPT2)
352 );
[120a86]353 parser->save(&output, atoms);
[f31edc]354 stringstream input(waterMpqc_MBPT2);
[120a86]355 // check for non-empty streams
356 input.peek();
357 output.peek();
358 CPPUNIT_ASSERT(input.good() && output.good());
359 // check equality of streams per line (for debugging)
[f31edc]360 for (; std::getline(input, first) && std::getline(output, second); ) {
361 //std::cout << "Comparing '" << first << "' to '" << second << "'" << std::endl;
362 CPPUNIT_ASSERT(first == second);
363 }
364 }
365 {
366 // compare both configs for MBPT2_R12
367 stringstream output;
[ee50c1]368 parser->getParams().setParameter(
369 MpqcParser_Parameters::theoryParam,
370 parser->getParams().getTheoryName(MpqcParser_Parameters::MBPT2_R12)
371 );
[120a86]372 parser->save(&output, atoms);
[f31edc]373 stringstream input(waterMpqc_MBPT2_R12);
[120a86]374 // check for non-empty streams
375 input.peek();
376 output.peek();
377 CPPUNIT_ASSERT(input.good() && output.good());
378 // check equality of streams per line (for debugging)
[f31edc]379 for (; std::getline(input, first) && std::getline(output, second); ) {
380 //std::cout << "Comparing '" << first << "' to '" << second << "'" << std::endl;
381 CPPUNIT_ASSERT(first == second);
382 }
383 }
[9e4fd1]384}
Note: See TracBrowser for help on using the repository browser.