TUPÃ (pronounced as tu-pan) is a python algorithm that employs MDAnalysis engine to calculate electric fields at any point inside the simulation box throughout MD trajectories. TUPÃ also includes a PyMOL plugin to visualize electric field vectors together with molecules.
Required packages:
- MDAnalysis >= 2.2.0
- Python >= 3.x
- Numpy >= 1.2.x
- Clone this repository into a folder of your choice:
git clone https://github.com/mdpoleto/tupa.git
-
Inside the cloned folder, use conda and the
tupa.yml
file to create a conda environment containing the necessary dependencies. -
To easily use TUPÃ, make a symlink of the executable TUPA.py:
sudo ln -s $PWD/TUPA.py /usr/local/bin/
- To test TUPÃ installation, activate the conda environment (
conda activate tupa
) and run:
python check_install.py
This will trigger 4 tests and all should pass with a final message "OK".
TUPÃ calculations are based on parameters that are provided via a configuration file, which can be obtained via the command:
TUPA.py -template config.conf
The configuration file usually contains:
[Environment Selection]
sele_environment = (string) [default: None]
[Probe Selection]
mode = (string) [default: None]
selatom = (string) [default: None]
selbond1 = (string) [default: None]
selbond2 = (string) [default: None]
probecoordinate = [float,float,float] [default: None]
file_of_coordinates = (pathway to file) [default: None]
remove_self = (True/False) [default: False]
remove_cutoff = (float) [default: 1 A ]
[Solvent]
include_solvent = (True/False) [default: False]
solvent_cutoff = (float) [default: 10 A]
solvent_selection = (string) [default: None]
[Time]
dt = (integer) [default: 1]
[Box Info]
redefine_box = Whether or not provide explicit box dimension information.
boxdimensions = Box dimension information [A,B,C,Alpha,Beta,Gamma]. A,B
and C are the edge lengths (in Angstrom). Alpha, Beta
and Gamma are the box internal angles (in degrees)
A complete explanation of each option in the configuration file is available via the command:
TUPA.py -h
TUPÃ has 4 calculations MODES:
-
In
ATOM
mode, the coordinate of one atom will be tracked throughout the trajectory to serve as probe point. If more than 1 atom is provided in the selection, the center of geometry (COG) is used as probe position. An example is provided HERE. -
In
BOND
mode, the midpoint between 2 atoms will be tracked throughout the trajectory to serve as probe point. In this mode, the bond axis is used to calculate electric field alignment. By default, the bond axis is define asselbond1 ---> selbond2
. An example is provided HERE. -
In
COORDINATE
mode, a [X,Y,Z] coordinate will serve as probe point in all trajectory frames. An example is provided HERE. -
In
LIST
mode, a list of [X,Y,Z] coordinates will serve as probe points, one for each trajectory frame.
IMPORTANT:
- All selections must be compatible with MDAnalysis syntax.
- TUPÃ was designed to work with
ORTHORHOMBIC
box types. We are working to support for rhombic dodecahedron and truncated octahedron boxes. - Trajectories MUST be re-imaged before running TUPÃ. Make sure your probe is well centered in the box.
- Molecules in
solvent_selection
beyond the PBC are re-imaged. This is achieved by applying thearound
selection feature in MDAnalysis and properly shifting the coordinates. - If using COORDINATE mode, be mindful that our code does not account for rotations and translations of coordinates. Be mindful of the coordinate selection.
pyTUPÃmol is a PyMOL plugin to plot electric field vectors alongside other molecules. By definition, an arrow CGO object is created starting at a given coordinate [X,Y,Z] and has the size of the magnitude of the provided electric field.
DESCRIPTION
Allows the user to create arrows representing:
1) vector between 2 selected atoms (atom1 -> atom2)
2) Electric field vectors midway between 2 picked atoms ([atom1+atom2]/2)
3) Electric field vector at a given atom or coordinate
ARGUMENTS
bond_atom1 = string: single atom selection or list of 3 floats {default: pk1}
bond_atom2 = string: single atom selection or list of 3 floats {default: pk2}
point = string: single atom selection or list of 3 floats {default: pk1}
efield = list of 3 floats containing the XYZ electric field components {default: [1.0. 1.0, 1.0]}
radius = float: arrow radius {default: 0.1}
scale = float: scale factor to change arrow size {default: 0.0}
hlength = float: length of arrow head in percentage of efield magnitude {default: 30%}
hradius = float: radius of arrow head in percentage of radius {default: 2*radius}
color = string: one or two color names {default: blue red}
stdev = angle to define the spatial standard deviation of the efield
efield_name = string: name of CGO object for the efield vector
stdev_name = string: name of CGO object for the 3D standard deviation
Our plugin has 3 functions that can be called via command line within PyMOL:
- efield_point: create a vector at a given atom or set of coordinates.
efield_point segid LIG and name O1, efield=[-117.9143, 150.3252, 86.5553], scale=0.01, color="red", name="efield_OG"
- efield_bond: create a vector midway between 2 selected atoms.
efield_bond resname LIG and name O1, resname LIG and name C1, efield=[-94.2675, -9.6722, 58.2067], scale=0.01, color="blue", name="efield_OG-C1"
- draw_bond_axis: create a vector representing the axis between 2 atoms.
draw_bond_axis resname LIG and name O1, resname LIG and name C1, gap=0.5, color="gray60", name="axis_OG-C1"
To install pyTUPÃmol
plugin in PyMOL, click on Plugin > Plugin Manager and then "Install New Plugin" tab. Choose the pyTUPÃmol.py
file and click Install.
If you use TUPÃ in a scientific publication, we would appreciate citations to the following paper:
Marcelo D. Polêto, Justin A. Lemkul. TUPÃ: Electric field analysis for molecular simulations, 2022.
Bibtex entry:
@article{TUPÃ2022,
author = {Pol\^{e}to, M D and Lemkul, J A},
title = {TUPÃ: Electric field analyses for molecular simulations},
journal = {Journal of Computational Chemistry},
volume = {43},
number = {16},
pages = {1113-1119},
keywords = {electric field, electrostatics, force fields, molecular dynamics, molecular mechanics},
doi = {https://doi.org/10.1002/jcc.26873},
url = {https://onlinelibrary.wiley.com/doi/abs/10.1002/jcc.26873},
eprint = {https://onlinelibrary.wiley.com/doi/pdf/10.1002/jcc.26873},
abstract = {Abstract We introduce TUPÃ, a Python-based algorithm to calculate and analyze electric fields in molecular simulations. To demonstrate the features in TUPÃ, we present three test cases in which the orientation and magnitude of the electric field exerted by biomolecules help explain biological phenomena or observed kinetics. As part of TUPÃ, we also provide a PyMOL plugin to help researchers visualize how electric fields are organized within the simulation system. The code is freely available and can be obtained at https://mdpoleto.github.io/tupa/.}
}
In Brazilian folklore, Tupã is considered a "manifestation of God in the form of thunder". To know more, refer to this.
E-mail: mdpoleto@vt.edu / jalemkul@vt.edu