1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
|
# -*- coding: utf-8 -*-
#
# Copyright (c) 2017, the cclib development team
#
# This file is part of cclib (http://cclib.github.io) and is distributed under
# the terms of the BSD 3-Clause License.
"""Test the CDA method in cclib"""
from __future__ import print_function
import sys
import os
import logging
import unittest
import numpy
sys.path.insert(1, "..")
from ..test_data import getdatafile
from cclib.method import CDA
from cclib.parser import Gaussian
def main(log=True):
data1, logfile1 = getdatafile(Gaussian, "CDA", ["BH3CO-sp.log"])
data2, logfile2 = getdatafile(Gaussian, "CDA", ["BH3.log"])
data3, logfile3 = getdatafile(Gaussian, "CDA", ["CO.log"])
fa = CDA(data1)
if not log:
fa.logger.setLevel(logging.ERROR)
fa.calculate([data2, data3])
return fa
def printResults():
fa = main()
print(" d b r")
print("---------------------------")
spin = 0
for i in range(len(fa.donations[0])):
print("%2i: %7.3f %7.3f %7.3f" % (i,
fa.donations[spin][i],
fa.bdonations[spin][i],
fa.repulsions[spin][i]))
print("---------------------------")
print("T: %7.3f %7.3f %7.3f" % (fa.donations[0].sum(),
fa.bdonations[0].sum(),
fa.repulsions[0].sum()))
print("\n\n")
class CDATest(unittest.TestCase):
def runTest(self):
"""Testing CDA results against Frenking's code"""
fa = main(log=False)
donation = fa.donations[0].sum()
bdonation = fa.bdonations[0].sum()
repulsion = fa.repulsions[0].sum()
self.assertAlmostEqual(donation, 0.181, 3)
self.assertAlmostEqual(bdonation, 0.471, 3)
self.assertAlmostEqual(repulsion, -0.334, 3)
if __name__ == "__main__":
printResults()
unittest.TextTestRunner(verbosity=2).run(unittest.makeSuite(CDATest))
|