Skip to content

Commit

Permalink
Merge branch 'write_charge_in_elementary' of https://github.com/daico…
Browse files Browse the repository at this point in the history
…007/gmso into write_charge_in_elementary
  • Loading branch information
daico007 committed Jan 15, 2024
2 parents 4302517 + 2b03f19 commit 57aa96f
Show file tree
Hide file tree
Showing 3 changed files with 68 additions and 2 deletions.
32 changes: 32 additions & 0 deletions gmso/tests/test_dihedral.py
Original file line number Diff line number Diff line change
Expand Up @@ -153,3 +153,35 @@ def test_equivalent_members_set(self):
tuple(dihedral.connection_members)
in dihedral_not_eq.equivalent_members()
)

def test_sort_dihedral_types(self):
from gmso.utils.sorting import sort_by_classes, sort_by_types

atom1 = Atom(
name="atom1", position=[0, 0, 0], atom_type=AtomType(name="A")
)
atom2 = Atom(
name="atom2", position=[1, 0, 0], atom_type=AtomType(name="B")
)
atom3 = Atom(
name="atom3", position=[1, 1, 0], atom_type=AtomType(name="C")
)
atom4 = Atom(
name="atom4", position=[1, 1, 4], atom_type=AtomType(name="D")
)

consituentList = [
atom2.atom_type.name,
atom4.atom_type.name,
atom3.atom_type.name,
atom1.atom_type.name,
]
dihtype = DihedralType(
member_types=consituentList, member_classes=consituentList
)

expected_sortingList = tuple(
[atom.atom_type.name for atom in [atom1, atom3, atom4, atom2]]
)
assert sort_by_classes(dihtype) == expected_sortingList
assert sort_by_types(dihtype) == expected_sortingList
32 changes: 32 additions & 0 deletions gmso/tests/test_improper.py
Original file line number Diff line number Diff line change
Expand Up @@ -152,3 +152,35 @@ def test_equivalent_members_set(self):
tuple(improper.connection_members)
in improper_not_eq.equivalent_members()
)

def test_sort_improper_types(self):
from gmso.utils.sorting import sort_by_classes, sort_by_types

atom1 = Atom(
name="atom1", position=[0, 0, 0], atom_type=AtomType(name="A")
)
atom2 = Atom(
name="atom2", position=[1, 0, 0], atom_type=AtomType(name="B")
)
atom3 = Atom(
name="atom3", position=[1, 1, 0], atom_type=AtomType(name="C")
)
atom4 = Atom(
name="atom4", position=[1, 1, 4], atom_type=AtomType(name="D")
)

consituentList = [
atom2.atom_type.name,
atom4.atom_type.name,
atom3.atom_type.name,
atom1.atom_type.name,
]
imptype = ImproperType(
member_types=consituentList, member_classes=consituentList
)

expected_sortingList = tuple(
[atom.atom_type.name for atom in [atom2, atom3, atom4, atom1]]
)
assert sort_by_classes(imptype) == expected_sortingList
assert sort_by_types(imptype) == expected_sortingList
6 changes: 4 additions & 2 deletions gmso/utils/sorting.py
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,8 @@ def sort_by_classes(potential):
elif isinstance(potential, ImproperType):
return (
potential.member_classes[0],
*sorted(potential.member_classes[1:]),
*sorted(potential.member_classes[1:3]),
potential.member_classes[3],
)
return ValueError(
f"Potential {potential} not one of {potential_attribute_map.values()}"
Expand Down Expand Up @@ -174,7 +175,8 @@ def sort_by_types(potential):
elif isinstance(potential, ImproperType):
return (
potential.member_types[0],
*sorted(potential.member_types[1:]),
*sorted(potential.member_types[1:3]),
potential.member_types[3],
)
return ValueError(
f"Potential {potential} not one of {potential_attribute_map.values()}"
Expand Down

0 comments on commit 57aa96f

Please sign in to comment.