Skip to content

Latest commit

 

History

History
73 lines (59 loc) · 3.15 KB

README.md

File metadata and controls

73 lines (59 loc) · 3.15 KB

VoronoiSelection

see demo_voronoiSelection.py for information on how to select the first and second hydration shells and how to partition the air-water interface into layers, as done in the paper

Libraries required

NumPy Numba MDAnalysis freud

Basics

The VoronoiSelection class allows you to find concentric regions starting from any group of points/atoms. To initialize an object, run

vor = VoronoiSelection(startingPointsIdx=startingGroup.ix,  # indices of the starting group of points/atoms
                       points=system.atoms.positions,  # MDAnalysis Universe atom positions or just positions
                       atomInfo=system.atoms,  # optional, required for MDAnalysis-based work
                       dim=system.dimensions,  # required, periodic box information
                       rememberInner=True)  # remember neighbors already found to avoid repeated neighbors (see demo)

to find neighbors, run

myNeighbors = vor.getNeighbors(neighborIdx=waters.ix,  # among which atoms/points to search for neighbors?
                               byResidue=True) # if one atom is a neighbor, should the whole residue be? (requires atomInfo above)
neighborsOfNeighbors = myNeighbors.getNeighbors(neighborIdx=waters.ix, byResidue=True)  # get next layer without repeats

Note that to use the byResidue=True option, each residue and/or water molecule and/or ion must have its own unique residue number in the topology. If residue numbers repeat, extra atoms will be pulled into the selection.

Advanced example

if you need to make many starting atom group objects, recalculating the Voronoi tessellation every time is wasteful. Avoid this by grabbing the neighborList after the first getNeighbors() run and setting it in future VoronoiSelection objects using setNeighborList() as in the below example

# say you need a bigNumber of hydration shells for different parts of the system
# you can do the following for efficiency:

# get the first of the hydration shells
startIdx = 0
endIdx = startIdx + nAtomsPerGroup
startingGroup = system.atoms[startIdx:endIdx]

vor = VoronoiSelection(startingPointsIdx=startingGroup.ix,
                       points=system.atoms.positions,
                       atomInfo=system.atoms,
                       dim=system.dimensions,
                       rememberInner=True)  # remember neighbors already found (see demo)
hydrationShell[0] = vor.getNeighbors(neighborIdx=waters.ix, byResidue=True)  # tessellation calculated here
neighborList = vor.getNeighborList()  # grab it for later

# never calculate Voronoi tessellation again, just set it
for i in range(1, bigNumber):
    startIdx = i * nAtomsPerGroup
    endIdx = startIdx + nAtomsPerGroup
    startingGroup = system.atoms[startIdx:endIdx]

    vor = VoronoiSelection(startingPointsIdx=startingGroup.ix,
                       points=system.atoms.positions,
                       atomInfo=system.atoms,
                       dim=system.dimensions,
                       rememberInner=True)
    vor.setNeighborList(neighborList)  # <-----------
    hydrationShell[i] = vor.getNeighbors(neighborIdx=waters.ix, byResidue=True)