"vscode:/vscode.git/clone" did not exist on "607f2b6a2587575754c1b38dd286685ed9317325"
TestNumpyCompatibility.py 4.29 KB
Newer Older
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
import unittest
import numpy as np

from simtk.openmm import app
import simtk.openmm as mm
from simtk import unit

class TestNumpyCompatibility(unittest.TestCase):
    
    def setUp(self):
        prmtop = app.AmberPrmtopFile('systems/water-box-216.prmtop')
    
        system = prmtop.createSystem(nonbondedMethod=app.PME, 
                                         nonbondedCutoff=0.9*unit.nanometers,
                                         constraints=app.HBonds, rigidWater=True, 
                                         ewaldErrorTolerance=0.0005)
        integrator = mm.LangevinIntegrator(300*unit.kelvin, 1.0/unit.picoseconds, 
                                           2.0*unit.femtoseconds)
        self.simulation = app.Simulation(prmtop.topology, system, integrator,
                                    mm.Platform.getPlatformByName('Reference'))
    
    
    def test_setPositions(self):
        n_particles = self.simulation.context.getSystem().getNumParticles()
        input = np.random.randn(n_particles, 3)
        self.simulation.context.setPositions(input)
        output = self.simulation.context.getState(getPositions=True).getPositions(asNumpy=True)
    
        np.testing.assert_array_almost_equal(input, output)
    
    def test_setPositions_units(self):
        n_particles = self.simulation.context.getSystem().getNumParticles()
        input = unit.Quantity(np.random.randn(n_particles, 3), unit.angstroms)
        self.simulation.context.setPositions(input)
        output = self.simulation.context.getState(getPositions=True).getPositions(asNumpy=True)
    
        np.testing.assert_array_almost_equal(input.value_in_unit(unit.nanometers), output.value_in_unit(unit.nanometers))
    
    
    def test_setVelocities(self):
        n_particles = self.simulation.context.getSystem().getNumParticles()
        input = np.random.randn(n_particles, 3)
        self.simulation.context.setVelocities(input)
        output = self.simulation.context.getState(getVelocities=True).getVelocities(asNumpy=True)
    
        np.testing.assert_array_almost_equal(input, output)
    
    def test_setVelocities_units(self):
        n_particles = self.simulation.context.getSystem().getNumParticles()
        input = unit.Quantity(np.random.randn(n_particles, 3), unit.angstroms / unit.femtoseconds)
        self.simulation.context.setVelocities(input)
        output = self.simulation.context.getState(getVelocities=True).getVelocities(asNumpy=True)
    
        np.testing.assert_array_almost_equal(input.value_in_unit(unit.angstroms / unit.femtoseconds),
                                             output.value_in_unit(unit.angstroms / unit.femtoseconds))
    
    
    def test_tabulatedFunction(self):
        f = mm.CustomNonbondedForce('g(r)')
    
        r = np.linspace(0,10)
        g_of_r = np.sin(r)
    
        indx = f.addFunction('g', g_of_r, np.min(r), np.max(r)) 
    
        name, g_of_r_out, min_r_out, max_r_out = f.getFunctionParameters(indx)
    
        np.testing.assert_array_almost_equal(g_of_r, np.asarray(g_of_r_out))
        assert min_r_out == np.min(r)
        assert max_r_out == np.max(r)
    
    def test_CMAP(self):
        f = mm.CMAPTorsionForce()
        energy = np.random.randn(10*10)
        f.addMap(10, energy)
        size, energy_out = f.getMapParameters(0)
77
78
        energy_out = energy_out.value_in_unit_system(unit.md_unit_system)

79
    
80
        self.assertEqual(size, 10)
81
82
        np.testing.assert_array_almost_equal(energy, np.asarray(energy_out))

83
84
85
86
87
88
89
class TestNumpyUnits(unittest.TestCase):

    def setUp(self):
        self.data = unit.Quantity(np.arange(300), unit.nanometers)

    def testNumpyAttributes(self):
        d = self.data.reshape((100, 3))
90
        self.assertTrue(unit.is_quantity(d) and d.unit is unit.nanometers)
91
92
93
94
95
96
97
98
99
100
101
        self.assertTrue(unit.is_quantity(d.sum()))
        self.assertTrue(unit.is_quantity(d.sum(axis=0)))
        self.assertTrue(unit.is_quantity(d.std()))
        self.assertTrue(unit.is_quantity(d.std(axis=0)))
        self.assertTrue(unit.is_quantity(d.max()))
        self.assertTrue(unit.is_quantity(d.max(axis=1)))
        self.assertTrue(unit.is_quantity(d.min()))
        self.assertTrue(unit.is_quantity(d.min(axis=0)))
        self.assertTrue(unit.is_quantity(d.mean()))
        self.assertTrue(unit.is_quantity(d.mean(axis=1)))

102
103
if __name__ == '__main__':
    unittest.main()