PyMOL KVFinder-web Tools
The PyMOL KVFinder-web Tools, written in Python and Qt, is a user-friendly PyMOL v2.x plugin for detecting and characterizing biomolecular cavities at a KVFinder-web service with functionalities similar to PyMOL parKVFinder Tools, which is natively configured to our publicly available web service (http://kvfinder-web.cnpem.br).
Our PyMOL plugin enables customization of parKVFinder parameters for a target structure and submits jobs via HTTP POST request to a configured KVFinder-web service. After submission, jobs are routinely requested via HTTP GET request to the KVFinder-web service by a worker thread. When a job is finished, the worker thread automatically processes the incoming data to files.
Installation
PyMOL v2 is required if you wish to use PyMOL KVFinder-web Tools.
To install the Python dependencies from requirements.txt, run:
pip3 install -r requirements.txt
To install PyMOL KVFinder-web Tools, download the latest version of PyMOL KVFinder-web Tools from here. Now, follow these steps:
Open PyMOL;
Go to Plugin menu and select Plugin Manager option;
The Plugin Manager window will open, go to the Install New Plugin tab;
Under Install from local file group, click on Choose file…;
The Install Plugin window will open, select the PyMOL-KVFinder-web-Tools.zip;
The Select plugin directory window will open, select /home/user/.pymol/startup and click OK;
The Confirm window will open, click on OK;
The Sucess window will open, confirming that the plugin has been installed;
Restart PyMOL;
PyMOL KVFinder-web Tools is ready to use under Plugin menu.
Or, if you clone this repository, instead of selecting PyMOL-KVFinder-web-Tools.zip (Step 5), user must select __init__.py of PyMOL-KVFinder-web-Tools directory.
To use the PyMOL KVFinder-web Tools in a locally configured KVFinder-web service, users must change the server url and path hardcoded on the __init__.py file and reinstall the client plugin on PyMOL.
From:
# Server #
server = "http://kvfinder-web.cnpem.br" #
# Path #
path = "/api" #
to:
# Server #
server = "http://localhost:8081" #
# Path #
path = "" #
Note
If the KVFinder-web service is on another computer on your network, you must provide the IP Address instead of localhost.
Tutorial
On this tutorial, we are going to demonstrate how to use PyMOL KVFinder-web Tools with our publicly available KVFinder-web at https://kvfinder-web.cnpem.br.
All files used on this tutorial can be found under examples directory, on the PyMOL KVFinder-web Tools repository.
Whole protein detection
First, load examples/1FMO.pdb into PyMOL. The 1FMO is the catalytic subunit of a cAMP-dependent protein kinase (cAPK).
After, open PyMOL KVFinder-web Tools under Plugin tab. The objects on the scene will be listed on the Input PDB box, on the Main tab. If not, click on the Refresh button.
The Input PDB selection sets which object will be analyzed by KVFinder-web service. Then, select 1FMO.
The default parameters are designed to make a simple and fast whole protein detection. To submit a job with the default parameters to KVFinder-web service, just click on Run KVFinder-web button.
After successfully submitting the job to KVFinder-web service, a window will appear with the Job ID. For instace, the Job ID of our submission is 4990580026958948489.
The job informations are stored on ~/.KVFinder-web directory in TOML-formatted files and can be visualized on Results tab under Jobs tab. The status of our submission (4990580026958948489) is displayed on the Status field.
After completion, the Status field will change to Completed and the Show button will be enabled. Then, click on Show button load cavities into PyMOL viewer and the results on the Visualization tab. In addition, the focus will be automatically shifted to the Visualization tab.
We can select cavities in the Volume or Surface Area lists to highlight them on a new object called cavities, identifying each cavity. Additionally, we can select cavity tags in the Interface Residues list to highlight residues around the cavities on a new object named residues.
Note
The interface residues surrounding the cavity KAH are colored in green (sticks), the surface points are colored in red (nb_spheres) and the remaining cavity points are colored in blue (non_bounded).
We can visualize depth of the cavity points by clicking on Depth option on Show descriptors. We can select cavities in the Average Depth or Maximum Depth lists to highlight them on a new object called depths, identifying each cavity.
Note
The cavity points are colored using a gradient from blue to red to represent the depth of each point. The blue points correspond to the shallowest points on the cavity-bulk boundary, while the red points correspond to the deepest points. The depth scale ranges from 0.0 to the maximum depth of all cavities
We can visualize hydropathy of the surface points by clicking on Hydropathy options on Show descriptors. We can select cavities in the Average Hydropathy list to highlight them on a new object called hydropathy, identifying each cavity.
Note
The surface points are colored based on the closest amino acid to it. The Eisenberg & Weiss hydrophobicity scale [2] ranges from -1.42 (highly hydrophobic) to 2.6 (highly hydrophilic).
Changing cavity boundary
KVFinder-web service is all about parameters customization of parKVFinder software. One of parKVFinder’s most powerful assets is the ability to manually set the cavity boundary.
parKVFinder works with a double probe system to detect cavities. A smaller probe, called Probe In, and a bigger one, called Probe Out, that defined two molecular surfaces with different accessibility. The space left between these surfaces is considered cavities.
Let’s show the effect of varying Probe Out and Removal Distance on the cavity boundary.
First, we should copy the cavity KAH to a new object to compare cavity boundary from the previous execution.
# Copy KAH
select resn KAH and output.KVFinder.output
create KAH, sele
delete sele
# Color KAH
color magenta, KAH
Adjusting Probe Out
As mentioned above, adjusting the Probe Out size changes the level of the cavity boundary. So let’s go back on the Main tab and change the Probe Out size to 8.0 Å. Submit the job to KVFinder-web service again.
After completion, load the job results by clicking on Show button on Results tab under Jobs tab.
Again, copy the cavity KAF to a new object (KAF_PO).
# Copy KAF
select resn KAF and output.KVFinder.output
create KAF_PO, sele
delete sele
The cavity KAF detected with the 4 Å Probe Out (magenta) has a lower boundary than that detected with the 8 Å probe (white). Therefore, by increasing the size of the Probe Out, the cavity boundary is also raised.
Adjusting Removal Distance
Besides adjusting the Probe Out size, we can also adjust the Removal Distance to change the cavity boundary. So let’s go back to the Main tab and change the Removal Distance to 1.2 Å and the size of Probe Out back to 4.0 Å. Submit the job to KVFinder-web service again.
After completion, load the job results by clicking on Show button on Results tab under Jobs tab.
Again, copy the cavity KAG (same region of the previous detections) to a new object (KAG_RD).
# Copy KAG
select resn KAG and output.KVFinder.output
create KAG_RD, sele
delete sele
The cavity KAH detected with the 2.4 Å Removal Distance (magenta) has a lower boundary than that detected with the 1.2 Å (KAG; white). Therefore, by decreasing the Removal Distance, the cavity boundary is also raised.
Furthermore, changing the cavity boundary by varying Probe Out and Removal Distance also affects cavity segregation.
Note
Usually the Removal Distance adjustment is less time consuming than the Probe Out adjustment for similar effects.
Steered detection
An important feature of parKVFinder is the steered detection of cavities. We continue our tutorial illustrating two distinct methods of cavity segmentation.
First, load examples/ligs_1FMO.pdb into PyMOL viewer. The ligs_1FMO is an adenosine (ADN) and a peptide kinase inhibitor (PKI).
Box adjustment mode
Box adjustment mode explores closed regions with a custom box, which can be drawn via the GUI.
On the Search Space tab, select Box Adjustment check box. This will enable a Box Adjustment frame, which handles the custom box in PyMOL viewer
Then, select the adenosine ligand on ligs_1FMO object. This can be made on the PyMOL viewer by clicking on the ligand structure or using select resn ADN
PyMOL command.
Click on Draw Box Button. This will create a custom box that limits the search space. It is fully customizable, but we will not change it for now.
On the Main tab, change Removal Distance back to 2.4 Å and submit the job to KVFinder-web service.
After completion, load the job results by clicking on Show button on Results tab under Jobs tab.
Now, let’s customize the box parameters to segment the binding site of our target protein.
Each axis is associated with one color (red with X, green with Y and blue with Z). The adjustment is made by the arrows or directly setting the value in the entry on the Search Space tab in the Box Adjustment group. We can also adjust the box angles by the same procedure. After altering the values, just click on Redraw button to redraw the box object using the new values.
Then, on the Search Space tab, reduce Maximum X to 1.0 Å and click Redraw Box. Submit the job to KVFinder-web service.
After completion, load the job results by clicking on Show button on Results tab under Jobs tab.
Lastly, click on Delete Box button to delete the custom box.
Ligand adjustment mode
A last feature is to limit the search around a structure. In this last example, let’s do a whole protein prospection again, but limiting the search space around ligands.
First, on the Search Space tab, deselect Box Adjustment check box, which will disable the previous enabled Box Adjustment frame.
Still on the Search Space tab, click on the check button Ligand Adjustment, which will enable the Refresh button, the Ligand PDB combo box and the Ligand Cutoff entry.
Afterwards, copy the adenosine (ADN) from ligs_1FMO to a new object.
# Copy adenosine
select resn ADN
create adenosine, sele
delete sele
Click the Refresh button to display all objects in the scene in the Ligand PDB combo box. Select the ADN on the combo box and reduce Ligand Cutoff to 3.0 Å. Submit the job to KVFinder-web service.
After completion, load the job results by clicking on Show button on Results tab under Jobs tab.
Now, let’s shift focus to the two ligands (ADN and PKI) in the ligs_1FMO object.
On the Search Space tab, select the ligs_1FMO on the Ligand PDB combo box and increase Ligand Cutoff back to 5.0 Å. Back on the Main tab, increase Probe Out to 10.0 Å and reduce Removal Distance to 0.0 Å. Submit the job to KVFinder-web service.
After completion, load the job results by clicking on Show button on Results tab under Jobs tab.
Submitting an already sent job
Users may submit a job that have already been submitted to the KVFinder-web service and the job is still available on the web service.
In this scenario, when you submit the job, the Job Submission window will display the job status. If the job is completed, the GUI automatically loads the job into the GUI and PyMOL viewer.
For instance, resubmit your last job.
Retrieving a Job by its ID
Users may share their jobs with colleagues by the Job ID that they receive when submitting a job.
On the Results tab, under Jobs tab, click on the Add ID button. A new window (Job ID Form) will appear.
In this window, fill the fields and click on Add button.
If the job was not available on the KVFinder-web service or does not exist. A window will apper stating that the Job ID (XXXXX) was not found in KVFinder-web server!.
Otherwise, a window will apper stating that the Job successfully added! together with the job status. Additionally, this Job ID will appear on the Available Jobs combo box.