Skip to content

Commit

Permalink
tests: Add OIF smoke test
Browse files Browse the repository at this point in the history
  • Loading branch information
jngrad committed Oct 20, 2023
1 parent fb817ad commit 4774947
Showing 1 changed file with 41 additions and 18 deletions.
59 changes: 41 additions & 18 deletions testsuite/python/oif_volume_conservation.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,40 +27,37 @@


@utx.skipIfMissingFeatures("MASS")
class OifVolumeConservation(ut.TestCase):

"""Loads a soft elastic sphere via object_in_fluid, stretches it and checks
restoration of original volume due to elastic forces."""
class Test(ut.TestCase):

system = espressomd.System(box_l=(50., 50., 50.))
system.time_step = 0.4
system.cell_system.skin = 0.5

def check_relaxation(self, **kwargs):
self.system.part.clear()
def tearDown(self):
self.system.thermostat.turn_off()
half_box_l = np.copy(self.system.box_l) / 2.
self.system.part.clear()

# creating the template for OIF object
cell_type = oif.OifCellType(
def make_cell_type(self, **kwargs):
return oif.OifCellType(
nodes_file=str(tests_common.data_path("sphere393nodes.dat")),
triangles_file=str(
tests_common.data_path("sphere393triangles.dat")),
system=self.system, **kwargs, kb=1.0, kal=1.0, kag=0.1, kv=0.1,
check_orientation=False, resize=(3.0, 3.0, 3.0))

# creating the OIF object
cell0 = oif.OifCell(
cell_type=cell_type, particle_type=0, origin=half_box_l)
def check_relaxation(self, **kwargs):
half_box_l = np.copy(self.system.box_l) / 2.
cell = oif.OifCell(cell_type=self.make_cell_type(**kwargs),
particle_type=0, origin=half_box_l)
partcls = self.system.part.all()

diameter_init = cell0.diameter()
diameter_init = cell.diameter()
self.assertAlmostEqual(diameter_init, 24., delta=1e-3)

# OIF object is being stretched by factor 1.5
partcls.pos = (partcls.pos - half_box_l) * 1.5 + half_box_l

diameter_stretched = cell0.diameter()
diameter_stretched = cell.diameter()
self.assertAlmostEqual(diameter_stretched, 36., delta=1e-3)

# Apply non-isotropic deformation
Expand All @@ -85,7 +82,7 @@ def check_relaxation(self, **kwargs):
for _ in range(20):
self.system.integrator.run(steps=20)
xdata.append(self.system.time)
ydata.append(cell0.diameter())
ydata.append(cell.diameter())
# check exponential decay
(prefactor, lam, _, diameter_final), _ = scipy.optimize.curve_fit(
lambda x, a, b, c, d: a * np.exp(-b * x + c) + d, xdata, ydata,
Expand All @@ -94,16 +91,42 @@ def check_relaxation(self, **kwargs):
self.assertGreater(prefactor, 0.)
self.assertAlmostEqual(diameter_final, diameter_init, delta=0.005)
self.assertAlmostEqual(lam, 0.0325, delta=0.0001)
self.system.thermostat.turn_off()
self.system.part.clear()

def test(self):
def test_00_volume_relaxation(self):
"""
Load a soft elastic sphere via ``object_in_fluid``, stretch it and
check restoration of original volume due to elastic forces.
"""
self.assertEqual(self.system.max_oif_objects, 0)
with self.subTest(msg='linear stretching'):
with self.subTest(msg="linear stretching"):
self.check_relaxation(kslin=1.)
self.assertEqual(self.system.max_oif_objects, 1)
with self.subTest(msg='neo-Hookean stretching'):
with self.subTest(msg="neo-Hookean stretching"):
self.check_relaxation(ks=1.)
self.assertEqual(self.system.max_oif_objects, 2)

def test_01_elastic_forces(self):
half_box_l = np.copy(self.system.box_l) / 2.
cell = oif.OifCell(cell_type=self.make_cell_type(),
particle_type=0, origin=half_box_l)
# stretch cell
partcls = self.system.part.all()
partcls.pos = (partcls.pos - half_box_l) * 1.5 + half_box_l
# reduce number of triangles to speed up calculation
cell.mesh.triangles = cell.mesh.triangles[:20]
# smoke test
results = cell.elastic_forces(el_forces=6 * [0], f_metric=6 * [1])
ref = [0., 1.36730815e-12, 22.4985704, 6838.5749, 7.3767594, 6816.6342]
np.testing.assert_allclose(results, ref, atol=0., rtol=1E-7)
self.assertEqual(cell.elastic_forces(), 0)
# check exceptions
with self.assertRaises(Exception):
cell.elastic_forces(el_forces=6 * [0], vtk_file="test")
with self.assertRaises(Exception):
cell.elastic_forces(el_forces=6 * [0], raw_data_file="test")


if __name__ == "__main__":
ut.main()

0 comments on commit 4774947

Please sign in to comment.