Preparation: Remove Solvent
Briefs
This science API, named enzy_htp.preparation.remove_solvent,
removes solvent from the supplied enzy_htp.structure.Structure class instance
(hereafter referred to as Structure instance).
All enzy_htp.structure.Solvent class instances (hereafter referred to as
Solvent instances) will be removed.
Input/Output
input: A Structure instance (no matter it’s a protein, polypeptite, or ligand).
Getting a Structure
A Structure instance can be obtained using these APIs
output: A Structure instance with solvents removed (in-place modification, not as return value).
Arguments
struThe input
Structureinstance (no matter it’s a protein, polypeptite, or ligand).(See Input/Output section)
Examples
Prepare the Input: Load Structure
In order to make use of the API, we should have structure loaded.
import enzy_htp.structure as struct
sp = struct.PDBParser()
pdb_filepath = "/path/to/your/structure.pdb"
stru = sp.get_structure(pdb_filepath)
Execute API
Use preparation.remove_solvent to remove solvent from your structure.
The way to use remove_solvent is pretty simple.
from enzy_htp.preparation import remove_solvent
stru = remove_solvent(stru=stru)
Note
This API modifies the Structure instance (what we passed as argument stru) itself but also returns a reference value.
Thus, even if you write remove_solvent(stru=stru) (you don’t use any variables to receive the return value),
the structure referred by stru will still be changed.
Check the Output
Let’s try executing the API here and check if there’s any changes taking place.
We choose the crystal structure of small protein crambin at 0.48 Angstrom resolution for example.
Now, we can go through the procedure.
import enzy_htp.structure as struct
from enzy_htp.preparation import remove_solvent
sp = struct.PDBParser()
# Read PDB file here.
pdb_filepath = "3NIR.pdb"
stru = sp.get_structure(pdb_filepath)
# Remove solvents here.
print(stru.num_atoms) # 742.
remove_solvent(stru=stru) # <enzy_htp.structure.structure.Structure object at 0x7fa383c4aa30>
print(stru.num_atoms) # 644.
We may notice that, after executing the API, the number of atoms (num_atoms) in the structure decreased,
representing that the solvent have been removed from the structure.
Author: Zhong, Yinjie <yinjie.zhong@vanderbilt.edu>