diff --git a/README.md b/README.md index 7b1aa3e..f8dc757 100644 --- a/README.md +++ b/README.md @@ -40,8 +40,8 @@ conda activate biobb_VS_tutorial #### EBI REST API tutorial -[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2Febi_api%2Fwf_vs_ebi_api.ipynb) [![](https://readthedocs.org/projects/biobb-wf-virtual-screening/badge/?version=latest)](https://biobb-wf-virtual-screening.readthedocs.io/en/latest/ebi_api_tutorial.html) +[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2Febi_api%2Fwf_vs_ebi_api.ipynb) [![](https://img.shields.io/badge/Google%20Colab-Open-orange?logo=google-colab)](https://colab.research.google.com/github/bioexcel/biobb_wf_virtual-screening/blob/main/biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipynb) ```console @@ -50,8 +50,8 @@ jupyter-notebook biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipyn #### Cluster Binding Site tutorial -[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2FclusterBindingSite%2Fwf_vs_clusterBindingSite.ipynb) [![](https://readthedocs.org/projects/biobb-wf-virtual-screening/badge/?version=latest)](https://biobb-wf-virtual-screening.readthedocs.io/en/latest/cluster_bs_tutorial.html) +[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2FclusterBindingSite%2Fwf_vs_clusterBindingSite.ipynb) [![](https://img.shields.io/badge/Google%20Colab-Open-orange?logo=google-colab)](https://colab.research.google.com/github/bioexcel/biobb_wf_virtual-screening/blob/main/biobb_wf_virtual-screening/notebooks/clusterBindingSite/wf_vs_clusterBindingSite.ipynb) ```console @@ -60,8 +60,8 @@ jupyter-notebook biobb_wf_virtual-screening/notebooks/clusterBindingSite/wf_vs_c #### fpocket tutorial -[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2Ffpocket%2Fwf_vs_fpocket.ipynb) [![](https://readthedocs.org/projects/biobb-wf-virtual-screening/badge/?version=latest)](https://biobb-wf-virtual-screening.readthedocs.io/en/latest/fpocket_tutorial.html) +[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2Ffpocket%2Fwf_vs_fpocket.ipynb) [![](https://img.shields.io/badge/Google%20Colab-Open-orange?logo=google-colab)](https://colab.research.google.com/github/bioexcel/biobb_wf_virtual-screening/blob/main/biobb_wf_virtual-screening/notebooks/fpocket/wf_vs_fpocket.ipynb) ```console diff --git a/biobb_wf_virtual-screening/docs/source/cluster_bs_tutorial.md b/biobb_wf_virtual-screening/docs/source/cluster_bs_tutorial.md index 0032f3b..866b3ee 100644 --- a/biobb_wf_virtual-screening/docs/source/cluster_bs_tutorial.md +++ b/biobb_wf_virtual-screening/docs/source/cluster_bs_tutorial.md @@ -1,5 +1,5 @@ # Protein-ligand Docking tutorial using BioExcel Building Blocks (biobb) -**-- *PDB Cluster90 Binding Site Version* --** +### -- *PDB Cluster90 Binding Site Version* -- *** This tutorial aims to illustrate the process of **protein-ligand docking**, step by step, using the **BioExcel Building Blocks library (biobb)**. The particular example used is the **Mitogen-activated protein kinase 14** (p38-α) protein (PDB code [3HEC](https://www.rcsb.org/structure/3HEC), [https://doi.org/10.2210/pdb3HEC/pdb](https://doi.org/10.2210/pdb3HEC/pdb)), a well-known **Protein Kinase enzyme**, @@ -20,21 +20,21 @@ Please note that **docking algorithms**, and in particular, **AutoDock Vina** pr - [biobb_structure_utils](https://github.com/bioexcel/biobb_structure_utils): Tools to modify or extract information from a PDB structure file. - [biobb_chemistry](https://github.com/bioexcel/biobb_chemistry): Tools to perform chemoinformatics processes. - [biobb_vs](https://github.com/bioexcel/biobb_vs): Tools to perform virtual screening studies. - + ### Auxiliary libraries used * [jupyter](https://jupyter.org/): Free software, open standards, and web services for interactive computing across all programming languages. * [nglview](http://nglviewer.org/#nglview): Jupyter/IPython widget to interactively view molecular structures and trajectories in notebooks. -### Conda Installation and Launch +### Conda Installation ```console git clone https://github.com/bioexcel/biobb_wf_virtual-screening.git cd biobb_wf_virtual-screening conda env create -f conda_env/environment.yml conda activate biobb_VS_tutorial -jupyter-notebook biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipynb -``` +jupyter-notebook biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_clusterBindingSite.ipynb +``` *** ## Pipeline steps @@ -62,6 +62,50 @@ jupyter-notebook biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipyn *** +## Initializing colab +The two cells below are used only in case this notebook is executed via **Google Colab**. Take into account that, for running conda on **Google Colab**, the **condacolab** library must be installed. As [explained here](https://pypi.org/project/condacolab/), the installation requires a **kernel restart**, so when running this notebook in **Google Colab**, don't run all cells until this **installation** is properly **finished** and the **kernel** has **restarted**. + + +```python +# Only executed when using google colab +import sys +if 'google.colab' in sys.modules: + import subprocess + from pathlib import Path + try: + subprocess.run(["conda", "-V"], check=True) + except FileNotFoundError: + subprocess.run([sys.executable, "-m", "pip", "install", "condacolab"], check=True) + import condacolab + condacolab.install() + # Clone repository + repo_URL = "https://github.com/bioexcel/biobb_wf_virtual-screening.git" + repo_name = Path(repo_URL).name.split('.')[0] + if not Path(repo_name).exists(): + subprocess.run(["mamba", "install", "-y", "git"], check=True) + subprocess.run(["git", "clone", repo_URL], check=True) + print("⏬ Repository properly cloned.") + # Install environment + print("⏳ Creating environment...") + env_file_path = f"{repo_name}/conda_env/environment.yml" + subprocess.run(["mamba", "env", "update", "-n", "base", "-f", env_file_path], check=True) + print("🎨 Install NGLView dependencies...") + subprocess.run(["mamba", "install", "-y", "-c", "conda-forge", "nglview==3.0.8", "ipywidgets=7.7.2"], check=True) + print("👍 Conda environment successfully created and updated.") +``` + + +```python +# Enable widgets for colab +if 'google.colab' in sys.modules: + from google.colab import output + output.enable_custom_widget_manager() + # Change working dir + import os + os.chdir("biobb_wf_virtual-screening/biobb_wf_virtual-screening/notebooks/clusterBindingSite") + print(f"📂 New working directory: {os.getcwd()}") +``` + ## Input parameters **Input parameters** needed: @@ -69,7 +113,7 @@ jupyter-notebook biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipyn - **pdb_code**: PDB code of the experimental complex structure (if exists).
In this particular example, the **p38α** structure in complex with the **Imatinib drug** was experimentally solved and deposited in the **PDB database** under the **3HEC** PDB code ([https://doi.org/10.2210/pdb3HEC/pdb](https://doi.org/10.2210/pdb3HEC/pdb)). The protein structure from this PDB file will be used as a **target protein** for the **docking process**, after stripping the **small molecule**. An **APO structure**, or any other structure from the **p38α** [cluster 100](https://www.rcsb.org/search?request=%7B%22query%22%3A%7B%22type%22%3A%22terminal%22%2C%22service%22%3A%22sequence%22%2C%22parameters%22%3A%7B%22target%22%3A%22pdb_protein_sequence%22%2C%22value%22%3A%22RPTFYRQELNKTIWEVPERYQNLSPVGSGAYGSVCAAFDTKTGLRVAVKKLSRPFQSIIHAKRTYRELRLLKHMKHENVIGLLDVFTPARSLEEFNDVYLVTHLMGADLNNIVKCQKLTDDHVQFLIYQILRGLKYIHSADIIHRDLKPSNLAVNEDCELKILDFGLARHTDDEMTGYVATRWYRAPEIMLNWMHYNQTVDIWSVGCIMAELLTGRTLFPGTDHIDQLKLILRLVGTPGAELLKKISSESARNYIQSLTQMPKMNFANVFIGANPLAVDLLEKMLVLDSDKRITAAQALAHAYFAQYHDPDDEPVADPYDQSFESRDLLIDEWKSLTYDEVISFVPPP%22%2C%22identity_cutoff%22%3A1%2C%22evalue_cutoff%22%3A0.1%7D%2C%22node_id%22%3A0%7D%2C%22return_type%22%3A%22polymer_entity%22%2C%22request_options%22%3A%7B%22pager%22%3A%7B%22start%22%3A0%2C%22rows%22%3A25%7D%2C%22scoring_strategy%22%3A%22combined%22%2C%22sort%22%3A%5B%7B%22sort_by%22%3A%22score%22%2C%22direction%22%3A%22desc%22%7D%5D%7D%2C%22request_info%22%3A%7B%22src%22%3A%22ui%22%2C%22query_id%22%3A%22bea5861f8b38a9e25a3e626b39d6bcbf%22%7D%7D) (sharing a 100% of sequence similarity with the **p38α** structure) could also be used as a **target protein**. This structure of the **protein-ligand complex** will be also used in the last step of the tutorial to check **how close** the resulting **docking pose** is from the known **experimental structure**. ----- - - **ligandCode**: Ligand PDB code (3-letter code) for the small molecule (e.g. STI), DrugBank Ligand Code [DB00619](https://go.drugbank.com/drugs/DB00619).
+ - **ligandCode**: Ligand PDB code (3-letter code) for the small molecule (e.g. STI, DrugBank Ligand Code [DB00619](https://go.drugbank.com/drugs/DB00619)).
In this particular example, the small molecule chosen for the tutorial is the FDA-approved drug **Imatinib** (PDB Code STI, DrugBank Ligand Code [DB00619](https://go.drugbank.com/drugs/DB00619)), a type of cancer growth blocker, used in [diferent types of leukemia](https://go.drugbank.com/drugs/DB00619). @@ -245,7 +289,7 @@ view[0].add_representation(repr_type='cartoon', opacity=.2, color='#cccccc') -view.add_component(output_bindingsite, default=False) +view.add_component(nglview.FileStructure(output_bindingsite), default=False) view[1].add_representation(repr_type='surface', selection='*', opacity = .3, @@ -253,7 +297,7 @@ view[1].add_representation(repr_type='surface', lowResolution= True, # 0: low resolution smooth=1, - useWorker= True, + #useWorker= True, wrap= True) view[1].add_representation(repr_type='licorice', selection='*') @@ -301,9 +345,9 @@ Visualizing the **protein structure**, the **selected cavity**, and the **genera #view = nglview.show_structure_file(box, default=False) view = nglview.NGLWidget() #s = view.add_component(pdb_single_chain) -s = view.add_component(download_pdb) -b = view.add_component(output_box) -s = view.add_component(output_bindingsite) +s = view.add_component(nglview.FileStructure(download_pdb)) +b = view.add_component(nglview.FileStructure(output_box)) +s = view.add_component(nglview.FileStructure(output_bindingsite)) atomPair = [ [ "9999:Z.ZN1", "9999:Z.ZN2" ], @@ -350,7 +394,7 @@ s.add_representation(repr_type='surface', surfaceType= 'av', contour=True, opacity=0.4, - useWorker= True, + #useWorker= True, wrap= True) @@ -665,7 +709,7 @@ Note that outputs from **AutoDock Vina** don't contain all the atoms, as the pro view = nglview.NGLWidget() # v1 = Experimental Structure -v1 = view.add_component(download_pdb) +v1 = view.add_component(nglview.FileStructure(download_pdb)) v1.clear() v1.add_representation(repr_type='licorice', @@ -673,7 +717,7 @@ v1.add_representation(repr_type='licorice', radius=0.5) # v2 = Docking result -v2 = view.add_component(output_structure) +v2 = view.add_component(nglview.FileStructure(output_structure)) v2.clear() v2.add_representation(repr_type='cartoon', colorScheme = 'sstruc') v2.add_representation(repr_type='licorice', radius=0.5, color= 'green', selection='UNL') diff --git a/biobb_wf_virtual-screening/docs/source/ebi_api_tutorial.md b/biobb_wf_virtual-screening/docs/source/ebi_api_tutorial.md index f612884..970a364 100644 --- a/biobb_wf_virtual-screening/docs/source/ebi_api_tutorial.md +++ b/biobb_wf_virtual-screening/docs/source/ebi_api_tutorial.md @@ -1,5 +1,5 @@ # Protein-ligand Docking tutorial using BioExcel Building Blocks (biobb) -**-- *PDBe REST-API Version* --** +### -- *PDBe REST-API Version* -- *** This tutorial aims to illustrate the process of **protein-ligand docking**, step by step, using the **BioExcel Building Blocks library (biobb)**. The particular example used is the **Mitogen-activated protein kinase 14** (p38-α) protein (PDB code [3LFA](https://www.rcsb.org/structure/3LFA), [https://doi.org/10.2210/pdb3LFA/pdb](https://doi.org/10.2210/pdb3LFA/pdb)), a well-known **Protein Kinase enzyme**, @@ -20,13 +20,13 @@ Please note that **docking algorithms**, and in particular, **AutoDock Vina** pr - [biobb_structure_utils](https://github.com/bioexcel/biobb_structure_utils): Tools to modify or extract information from a PDB structure file. - [biobb_chemistry](https://github.com/bioexcel/biobb_chemistry): Tools to perform chemoinformatics processes. - [biobb_vs](https://github.com/bioexcel/biobb_vs): Tools to perform virtual screening studies. - + ### Auxiliary libraries used * [jupyter](https://jupyter.org/): Free software, open standards, and web services for interactive computing across all programming languages. * [nglview](http://nglviewer.org/#nglview): Jupyter/IPython widget to interactively view molecular structures and trajectories in notebooks. -### Conda Installation and Launch +### Conda Installation ```console git clone https://github.com/bioexcel/biobb_wf_virtual-screening.git @@ -34,7 +34,7 @@ cd biobb_wf_virtual-screening conda env create -f conda_env/environment.yml conda activate biobb_VS_tutorial jupyter-notebook biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipynb -``` +``` *** ## Pipeline steps @@ -61,12 +61,56 @@ jupyter-notebook biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipyn *** +## Initializing colab +The two cells below are used only in case this notebook is executed via **Google Colab**. Take into account that, for running conda on **Google Colab**, the **condacolab** library must be installed. As [explained here](https://pypi.org/project/condacolab/), the installation requires a **kernel restart**, so when running this notebook in **Google Colab**, don't run all cells until this **installation** is properly **finished** and the **kernel** has **restarted**. + + +```python +# Only executed when using google colab +import sys +if 'google.colab' in sys.modules: + import subprocess + from pathlib import Path + try: + subprocess.run(["conda", "-V"], check=True) + except FileNotFoundError: + subprocess.run([sys.executable, "-m", "pip", "install", "condacolab"], check=True) + import condacolab + condacolab.install() + # Clone repository + repo_URL = "https://github.com/bioexcel/biobb_wf_virtual-screening.git" + repo_name = Path(repo_URL).name.split('.')[0] + if not Path(repo_name).exists(): + subprocess.run(["mamba", "install", "-y", "git"], check=True) + subprocess.run(["git", "clone", repo_URL], check=True) + print("⏬ Repository properly cloned.") + # Install environment + print("⏳ Creating environment...") + env_file_path = f"{repo_name}/conda_env/environment.yml" + subprocess.run(["mamba", "env", "update", "-n", "base", "-f", env_file_path], check=True) + print("🎨 Install NGLView dependencies...") + subprocess.run(["mamba", "install", "-y", "-c", "conda-forge", "nglview==3.0.8", "ipywidgets=7.7.2"], check=True) + print("👍 Conda environment successfully created and updated.") +``` + + +```python +# Enable widgets for colab +if 'google.colab' in sys.modules: + from google.colab import output + output.enable_custom_widget_manager() + # Change working dir + import os + os.chdir("biobb_wf_virtual-screening/biobb_wf_virtual-screening/notebooks/ebi_api") + print(f"📂 New working directory: {os.getcwd()}") +``` + ## Input parameters **Input parameters** needed: - **pdb_code**: PDB code of the experimental complex structure (if exists).
-In this particular example, the **p38α** structure in complex with the **Dasatinib drug** was experimentally solved and deposited in the **PDB database** under the **3LFA** PDB code, [https://doi.org/10.2210/pdb3LFA/pdb](https://doi.org/10.2210/pdb3LFA/pdb). The protein structure from this PDB file will be used as a **target protein** for the **docking process**, after stripping the **small molecule**. An **APO structure**, or any other structure from the **p38α** [cluster 100](https://www.rcsb.org/search?request=%7B%22query%22%3A%7B%22type%22%3A%22terminal%22%2C%22service%22%3A%22sequence%22%2C%22parameters%22%3A%7B%22target%22%3A%22pdb_protein_sequence%22%2C%22value%22%3A%22RPTFYRQELNKTIWEVPERYQNLSPVGSGAYGSVCAAFDTKTGLRVAVKKLSRPFQSIIHAKRTYRELRLLKHMKHENVIGLLDVFTPARSLEEFNDVYLVTHLMGADLNNIVKCQKLTDDHVQFLIYQILRGLKYIHSADIIHRDLKPSNLAVNEDCELKILDFGLARHTDDEMTGYVATRWYRAPEIMLNWMHYNQTVDIWSVGCIMAELLTGRTLFPGTDHIDQLKLILRLVGTPGAELLKKISSESARNYIQSLTQMPKMNFANVFIGANPLAVDLLEKMLVLDSDKRITAAQALAHAYFAQYHDPDDEPVADPYDQSFESRDLLIDEWKSLTYDEVISFVPPP%22%2C%22identity_cutoff%22%3A1%2C%22evalue_cutoff%22%3A0.1%7D%2C%22node_id%22%3A0%7D%2C%22return_type%22%3A%22polymer_entity%22%2C%22request_options%22%3A%7B%22pager%22%3A%7B%22start%22%3A0%2C%22rows%22%3A25%7D%2C%22scoring_strategy%22%3A%22combined%22%2C%22sort%22%3A%5B%7B%22sort_by%22%3A%22score%22%2C%22direction%22%3A%22desc%22%7D%5D%7D%2C%22request_info%22%3A%7B%22src%22%3A%22ui%22%2C%22query_id%22%3A%22bea5861f8b38a9e25a3e626b39d6bcbf%22%7D%7D) (sharing a 100% of sequence similarity with the **p38α** structure) could also be used as a **target protein**. This structure of the **protein-ligand complex** will be also used in the last step of the tutorial to check **how close** the resulting **docking pose** is from the known **experimental structure**. +In this particular example, the **p38α** structure in complex with the **Dasatinib drug** was experimentally solved and deposited in the **PDB database** under the **3LFA** PDB code, , [https://doi.org/10.2210/pdb3LFA/pdb](https://doi.org/10.2210/pdb3LFA/pdb). The protein structure from this PDB file will be used as a **target protein** for the **docking process**, after stripping the **small molecule**. An **APO structure**, or any other structure from the **p38α** [cluster 100](https://www.rcsb.org/search?request=%7B%22query%22%3A%7B%22type%22%3A%22terminal%22%2C%22service%22%3A%22sequence%22%2C%22parameters%22%3A%7B%22target%22%3A%22pdb_protein_sequence%22%2C%22value%22%3A%22RPTFYRQELNKTIWEVPERYQNLSPVGSGAYGSVCAAFDTKTGLRVAVKKLSRPFQSIIHAKRTYRELRLLKHMKHENVIGLLDVFTPARSLEEFNDVYLVTHLMGADLNNIVKCQKLTDDHVQFLIYQILRGLKYIHSADIIHRDLKPSNLAVNEDCELKILDFGLARHTDDEMTGYVATRWYRAPEIMLNWMHYNQTVDIWSVGCIMAELLTGRTLFPGTDHIDQLKLILRLVGTPGAELLKKISSESARNYIQSLTQMPKMNFANVFIGANPLAVDLLEKMLVLDSDKRITAAQALAHAYFAQYHDPDDEPVADPYDQSFESRDLLIDEWKSLTYDEVISFVPPP%22%2C%22identity_cutoff%22%3A1%2C%22evalue_cutoff%22%3A0.1%7D%2C%22node_id%22%3A0%7D%2C%22return_type%22%3A%22polymer_entity%22%2C%22request_options%22%3A%7B%22pager%22%3A%7B%22start%22%3A0%2C%22rows%22%3A25%7D%2C%22scoring_strategy%22%3A%22combined%22%2C%22sort%22%3A%5B%7B%22sort_by%22%3A%22score%22%2C%22direction%22%3A%22desc%22%7D%5D%7D%2C%22request_info%22%3A%7B%22src%22%3A%22ui%22%2C%22query_id%22%3A%22bea5861f8b38a9e25a3e626b39d6bcbf%22%7D%7D) (sharing a 100% of sequence similarity with the **p38α** structure) could also be used as a **target protein**. This structure of the **protein-ligand complex** will be also used in the last step of the tutorial to check **how close** the resulting **docking pose** is from the known **experimental structure**. ----- - **ligandCode**: Ligand PDB code (3-letter code) for the small molecule (e.g. 1N1, DrugBank Ligand Code [DB01254](https://go.drugbank.com/drugs/DB01254)).
In this particular example, the small molecule chosen for the tutorial is the FDA-approved drug **Dasatinib** (PDB Code 1N1, DrugBank Ligand Code [DB01254](https://go.drugbank.com/drugs/DB01254)), a **tyrosine kinase inhibitor**, used in [lymphoblastic or chronic myeloid leukemia](https://go.drugbank.com/drugs/DB01254). @@ -116,7 +160,6 @@ Note (and try to identify) the **Dasatinib small molecule (1N1)** and the **dete view = nglview.show_structure_file(download_pdb, default=True) view.center() view._remote_call('setSize', target='Widget', args=['','600px']) - view ``` @@ -155,7 +198,6 @@ view.add_representation(repr_type='cartoon', colorScheme = 'atomindex') view.center() view._remote_call('setSize', target='Widget', args=['','600px']) - view ``` @@ -252,7 +294,6 @@ view.add_representation(repr_type='surface', view.center() view._remote_call('setSize', target='Widget', args=['','600px']) - view ``` @@ -294,8 +335,8 @@ Visualizing the **protein structure**, the **selected cavity**, and the **genera ```python view = nglview.NGLWidget() -s = view.add_component(download_pdb) -b = view.add_component(output_box) +s = view.add_component(nglview.FileStructure(download_pdb)) +b = view.add_component(nglview.FileStructure(output_box)) atomPair = [ [ "9999:Z.ZN1", "9999:Z.ZN2" ], @@ -340,13 +381,12 @@ s.add_representation(repr_type='surface', surfaceType= 'av', contour=True, opacity=0.4, - useWorker= True, + #useWorker= True, wrap= True) view.center() view._remote_call('setSize', target='Widget', args=['','600px']) - view ``` @@ -480,7 +520,7 @@ prop = { str_check_add_hydrogens( input_structure_path = pdb_protein, output_structure_path = prep_receptor, - properties=prop) + properties = prop) ``` @@ -656,7 +696,7 @@ Note that outputs from **AutoDock Vina** don't contain all the atoms, as the pro view = nglview.NGLWidget() # v1 = Experimental Structure -v1 = view.add_component(download_pdb) +v1 = view.add_component(nglview.FileStructure(download_pdb)) v1.clear() v1.add_representation(repr_type='licorice', @@ -664,7 +704,7 @@ v1.add_representation(repr_type='licorice', radius=0.5) # v2 = Docking result -v2 = view.add_component(output_structure) +v2 = view.add_component(nglview.FileStructure(output_structure)) v2.clear() v2.add_representation(repr_type='cartoon', colorScheme = 'sstruc') v2.add_representation(repr_type='licorice', radius=0.5, color= 'green', selection='UNL') @@ -689,7 +729,6 @@ s[ 0 ].autoView() """ view._execute_js_code(code) - view ``` diff --git a/biobb_wf_virtual-screening/docs/source/fpocket_tutorial.md b/biobb_wf_virtual-screening/docs/source/fpocket_tutorial.md index f1c40b5..43c9fbe 100644 --- a/biobb_wf_virtual-screening/docs/source/fpocket_tutorial.md +++ b/biobb_wf_virtual-screening/docs/source/fpocket_tutorial.md @@ -1,5 +1,5 @@ # Protein-ligand Docking tutorial using BioExcel Building Blocks (biobb) -**-- *Fpocket Version* --** +### -- *Fpocket Version* -- *** This tutorial aims to illustrate the process of **protein-ligand docking**, step by step, using the **BioExcel Building Blocks library (biobb)**. The particular example used is the **Mitogen-activated protein kinase 14** (p38-α) protein (PDB code [3HEC](https://www.rcsb.org/structure/3HEC), [https://doi.org/10.2210/pdb3HEC/pdb](https://doi.org/10.2210/pdb3HEC/pdb)), a well-known **Protein Kinase enzyme**, @@ -63,6 +63,50 @@ jupyter-notebook biobb_wf_virtual-screening/notebooks/fpocket/wf_vs_fpocket.ipyn *** +## Initializing colab +The two cells below are used only in case this notebook is executed via **Google Colab**. Take into account that, for running conda on **Google Colab**, the **condacolab** library must be installed. As [explained here](https://pypi.org/project/condacolab/), the installation requires a **kernel restart**, so when running this notebook in **Google Colab**, don't run all cells until this **installation** is properly **finished** and the **kernel** has **restarted**. + + +```python +# Only executed when using google colab +import sys +if 'google.colab' in sys.modules: + import subprocess + from pathlib import Path + try: + subprocess.run(["conda", "-V"], check=True) + except FileNotFoundError: + subprocess.run([sys.executable, "-m", "pip", "install", "condacolab"], check=True) + import condacolab + condacolab.install() + # Clone repository + repo_URL = "https://github.com/bioexcel/biobb_wf_virtual-screening.git" + repo_name = Path(repo_URL).name.split('.')[0] + if not Path(repo_name).exists(): + subprocess.run(["mamba", "install", "-y", "git"], check=True) + subprocess.run(["git", "clone", repo_URL], check=True) + print("⏬ Repository properly cloned.") + # Install environment + print("⏳ Creating environment...") + env_file_path = f"{repo_name}/conda_env/environment.yml" + subprocess.run(["mamba", "env", "update", "-n", "base", "-f", env_file_path], check=True) + print("🎨 Install NGLView dependencies...") + subprocess.run(["mamba", "install", "-y", "-c", "conda-forge", "nglview==3.0.8", "ipywidgets=7.7.2"], check=True) + print("👍 Conda environment successfully created and updated.") +``` + + +```python +# Enable widgets for colab +if 'google.colab' in sys.modules: + from google.colab import output + output.enable_custom_widget_manager() + # Change working dir + import os + os.chdir("biobb_wf_virtual-screening/biobb_wf_virtual-screening/notebooks/fpocket") + print(f"📂 New working directory: {os.getcwd()}") +``` + ## Input parameters **Input parameters** needed: @@ -177,7 +221,7 @@ Although in this particular example we already know the **binding site** region,
*** **Building Blocks** used: - - [fpocket](https://biobb-vs.readthedocs.io/en/latest/fpocket.html#module-fpocket.fpocket_run) from **biobb_vs.fpocket.fpocket_run** + - [fpocket_run](https://biobb-vs.readthedocs.io/en/latest/fpocket.html#module-fpocket.fpocket_run) from **biobb_vs.fpocket.fpocket_run** *** @@ -193,9 +237,9 @@ prop = { } fpocket_run(input_pdb_path=pdb_protein, - output_pockets_zip = fpocket_all_pockets, - output_summary=fpocket_summary, - properties=prop) + output_pockets_zip = fpocket_all_pockets, + output_summary=fpocket_summary, + properties=prop) ``` @@ -278,7 +322,7 @@ r = lambda: random.randint(0,255) # load structure view = nglview.NGLWidget() -c = view.add_component(pdb_protein) +c = view.add_component(nglview.FileStructure(pdb_protein)) # load cavities (d) and pockets (p) and create pocketNames list c = {} @@ -291,10 +335,10 @@ for pock in path_pockets: if not [item for item in pocketNames if ('pocket' + i) in item]: pocketNames.append(('pocket' + i, int(i))) if suff == 'pdb': - c[i] = view.add_component(pock) + c[i] = view.add_component(filename=nglview.FileStructure(pock), **{'name': 'pocket' + i}) c[i].clear() else: - p[i] = view.add_component(pock) + p[i] = view.add_component(filename=nglview.FileStructure(pock), **{'name': 'pocket' + i}) p[i].clear() # sort pocket names @@ -304,13 +348,14 @@ pocketNames.sort(key=lambda tup: tup[1]) for pock in path_pockets_pdb: g = re.findall('(?:pocket)(\d+)(?:_\w+)\.(\w+)', pock) i = g[0][0] - c[i].add_surface(color='#{}'.format((r(),r(),r())), + c[i].add_surface(color='#cc0000', radius='1.5', lowResolution= True, # 0: low resolution smooth=1, - useWorker= True, - wrap= True) + #useWorker= True, + wrap= True + ) # representation for pockets for pock in path_pockets_pqr: @@ -329,7 +374,7 @@ var view = this.stage.viewer; var clist_len = stage.compList.length; var i = 0; for(i = 0; i <= clist_len; i++){ - if(stage.compList[i] != undefined && stage.compList[i].structure != undefined && stage.compList[i].object.name.indexOf('pqr') != -1) { + if(stage.compList[i] != undefined && stage.compList[i].structure != undefined && stage.compList[i].parameters.ext === 'pqr') { var elm = document.createElement("div"); elm.innerText = 'pocket' + stage.compList[i].object.name.match(/\d+/g) @@ -428,9 +473,9 @@ Visualizing the **protein structure**, the **selected cavity**, and the **genera ```python view = nglview.NGLWidget() -s = view.add_component(download_pdb) -b = view.add_component(output_box) -p = view.add_component(fpocket_pocket) +s = view.add_component(nglview.FileStructure(download_pdb)) +b = view.add_component(nglview.FileStructure(output_box)) +p = view.add_component(nglview.FileStructure(fpocket_pocket)) p.clear() atomPair = [ @@ -475,7 +520,7 @@ p.add_surface(component=mdsel.value, smooth=1, contour=True, opacity=0.4, - useWorker= True, + #useWorker= True, wrap= True ) @@ -792,7 +837,8 @@ Note that outputs from **AutoDock Vina** don't contain all the atoms, as the pro view = nglview.NGLWidget() # v1 = Experimental Structure -v1 = view.add_component(download_pdb) +#v1 = view.add_component(download_pdb) +v1 = view.add_component(nglview.FileStructure(download_pdb)) v1.clear() v1.add_representation(repr_type='licorice', @@ -800,7 +846,8 @@ v1.add_representation(repr_type='licorice', radius=0.5) # v2 = Docking result -v2 = view.add_component(output_structure) +#v2 = view.add_component(output_structure) +v2 = view.add_component(nglview.FileStructure(output_structure)) v2.clear() v2.add_representation(repr_type='cartoon', colorScheme = 'sstruc') v2.add_representation(repr_type='licorice', radius=0.5, color= 'green', selection='UNL') diff --git a/biobb_wf_virtual-screening/docs/source/readme.md b/biobb_wf_virtual-screening/docs/source/readme.md index 7b1aa3e..f8dc757 100644 --- a/biobb_wf_virtual-screening/docs/source/readme.md +++ b/biobb_wf_virtual-screening/docs/source/readme.md @@ -40,8 +40,8 @@ conda activate biobb_VS_tutorial #### EBI REST API tutorial -[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2Febi_api%2Fwf_vs_ebi_api.ipynb) [![](https://readthedocs.org/projects/biobb-wf-virtual-screening/badge/?version=latest)](https://biobb-wf-virtual-screening.readthedocs.io/en/latest/ebi_api_tutorial.html) +[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2Febi_api%2Fwf_vs_ebi_api.ipynb) [![](https://img.shields.io/badge/Google%20Colab-Open-orange?logo=google-colab)](https://colab.research.google.com/github/bioexcel/biobb_wf_virtual-screening/blob/main/biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipynb) ```console @@ -50,8 +50,8 @@ jupyter-notebook biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipyn #### Cluster Binding Site tutorial -[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2FclusterBindingSite%2Fwf_vs_clusterBindingSite.ipynb) [![](https://readthedocs.org/projects/biobb-wf-virtual-screening/badge/?version=latest)](https://biobb-wf-virtual-screening.readthedocs.io/en/latest/cluster_bs_tutorial.html) +[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2FclusterBindingSite%2Fwf_vs_clusterBindingSite.ipynb) [![](https://img.shields.io/badge/Google%20Colab-Open-orange?logo=google-colab)](https://colab.research.google.com/github/bioexcel/biobb_wf_virtual-screening/blob/main/biobb_wf_virtual-screening/notebooks/clusterBindingSite/wf_vs_clusterBindingSite.ipynb) ```console @@ -60,8 +60,8 @@ jupyter-notebook biobb_wf_virtual-screening/notebooks/clusterBindingSite/wf_vs_c #### fpocket tutorial -[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2Ffpocket%2Fwf_vs_fpocket.ipynb) [![](https://readthedocs.org/projects/biobb-wf-virtual-screening/badge/?version=latest)](https://biobb-wf-virtual-screening.readthedocs.io/en/latest/fpocket_tutorial.html) +[![](https://img.shields.io/badge/launch-myBinder-579ACA.svg?logo=)](https://mybinder.org/v2/gh/bioexcel/biobb_wf_virtual-screening/HEAD?labpath=biobb_wf_virtual-screening%2Fnotebooks%2Ffpocket%2Fwf_vs_fpocket.ipynb) [![](https://img.shields.io/badge/Google%20Colab-Open-orange?logo=google-colab)](https://colab.research.google.com/github/bioexcel/biobb_wf_virtual-screening/blob/main/biobb_wf_virtual-screening/notebooks/fpocket/wf_vs_fpocket.ipynb) ```console diff --git a/biobb_wf_virtual-screening/html/cluster_bs/wf_vs_clusterBindingSite.web.html b/biobb_wf_virtual-screening/html/cluster_bs/wf_vs_clusterBindingSite.web.html index 62e13f8..6788770 100644 --- a/biobb_wf_virtual-screening/html/cluster_bs/wf_vs_clusterBindingSite.web.html +++ b/biobb_wf_virtual-screening/html/cluster_bs/wf_vs_clusterBindingSite.web.html @@ -1,13 +1,9 @@ - - - - -wf_vs_clusterBindingSite.web2 - - - + + + +wf_vs_clusterBindingSite.web - - - +.jp-Cell-Placeholder { + padding-left: 55px; +} + +.jp-Cell-Placeholder-wrapper { + background: #fff; + border: 1px solid; + border-color: #e5e6e9 #dfe0e4 #d0d1d5; + border-radius: 4px; + -webkit-border-radius: 4px; + margin: 10px 15px; +} + +.jp-Cell-Placeholder-wrapper-inner { + padding: 15px; + position: relative; +} + +.jp-Cell-Placeholder-wrapper-body { + background-repeat: repeat; + background-size: 50% auto; +} + +.jp-Cell-Placeholder-wrapper-body div { + background: #f6f7f8; + background-image: -webkit-linear-gradient( + left, + #f6f7f8 0%, + #edeef1 20%, + #f6f7f8 40%, + #f6f7f8 100% + ); + background-repeat: no-repeat; + background-size: 800px 104px; + height: 104px; + position: absolute; + right: 15px; + left: 15px; + top: 15px; +} + +div.jp-Cell-Placeholder-h1 { + top: 20px; + height: 20px; + left: 15px; + width: 150px; +} + +div.jp-Cell-Placeholder-h2 { + left: 15px; + top: 50px; + height: 10px; + width: 100px; +} + +div.jp-Cell-Placeholder-content-1, +div.jp-Cell-Placeholder-content-2, +div.jp-Cell-Placeholder-content-3 { + left: 15px; + right: 15px; + height: 10px; +} + +div.jp-Cell-Placeholder-content-1 { + top: 100px; +} + +div.jp-Cell-Placeholder-content-2 { + top: 120px; +} + +div.jp-Cell-Placeholder-content-3 { + top: 140px; +} - + - +/* Hiding the collapser by default */ +.jp-Collapser { + display: none; +} +@page { + margin: 0.5in; /* Margin for each printed piece of paper */ +} +@media print { + .jp-Cell-inputWrapper, + .jp-Cell-outputWrapper { + display: block; + } +} + - - - + + - - + + + + +
+
+ +
- - - - - - - diff --git a/biobb_wf_virtual-screening/html/ebi_api/wf_vs_ebi_api.web.html b/biobb_wf_virtual-screening/html/ebi_api/wf_vs_ebi_api.web.html index 89c3b4d..4bd9fd7 100644 --- a/biobb_wf_virtual-screening/html/ebi_api/wf_vs_ebi_api.web.html +++ b/biobb_wf_virtual-screening/html/ebi_api/wf_vs_ebi_api.web.html @@ -1,13 +1,9 @@ - - - - -wf_vs_ebi_api.web2 - - - + + + +wf_vs_ebi_api.web - - - +.jp-Cell-Placeholder { + padding-left: 55px; +} + +.jp-Cell-Placeholder-wrapper { + background: #fff; + border: 1px solid; + border-color: #e5e6e9 #dfe0e4 #d0d1d5; + border-radius: 4px; + -webkit-border-radius: 4px; + margin: 10px 15px; +} + +.jp-Cell-Placeholder-wrapper-inner { + padding: 15px; + position: relative; +} + +.jp-Cell-Placeholder-wrapper-body { + background-repeat: repeat; + background-size: 50% auto; +} + +.jp-Cell-Placeholder-wrapper-body div { + background: #f6f7f8; + background-image: -webkit-linear-gradient( + left, + #f6f7f8 0%, + #edeef1 20%, + #f6f7f8 40%, + #f6f7f8 100% + ); + background-repeat: no-repeat; + background-size: 800px 104px; + height: 104px; + position: absolute; + right: 15px; + left: 15px; + top: 15px; +} + +div.jp-Cell-Placeholder-h1 { + top: 20px; + height: 20px; + left: 15px; + width: 150px; +} + +div.jp-Cell-Placeholder-h2 { + left: 15px; + top: 50px; + height: 10px; + width: 100px; +} + +div.jp-Cell-Placeholder-content-1, +div.jp-Cell-Placeholder-content-2, +div.jp-Cell-Placeholder-content-3 { + left: 15px; + right: 15px; + height: 10px; +} + +div.jp-Cell-Placeholder-content-1 { + top: 100px; +} + +div.jp-Cell-Placeholder-content-2 { + top: 120px; +} - + - +/* Hiding the collapser by default */ +.jp-Collapser { + display: none; +} +@page { + margin: 0.5in; /* Margin for each printed piece of paper */ +} +@media print { + .jp-Cell-inputWrapper, + .jp-Cell-outputWrapper { + display: block; + } +} + - - - + + - - + + + + +
+
+ +
- - - - - - - diff --git a/biobb_wf_virtual-screening/html/fpocket/ngl5.png b/biobb_wf_virtual-screening/html/fpocket/ngl5.png index bffca46..e245904 100644 Binary files a/biobb_wf_virtual-screening/html/fpocket/ngl5.png and b/biobb_wf_virtual-screening/html/fpocket/ngl5.png differ diff --git a/biobb_wf_virtual-screening/html/fpocket/ngl6.png b/biobb_wf_virtual-screening/html/fpocket/ngl6.png index e425b05..47817d1 100644 Binary files a/biobb_wf_virtual-screening/html/fpocket/ngl6.png and b/biobb_wf_virtual-screening/html/fpocket/ngl6.png differ diff --git a/biobb_wf_virtual-screening/html/fpocket/ngl7.png b/biobb_wf_virtual-screening/html/fpocket/ngl7.png index 617d413..c99e7cc 100644 Binary files a/biobb_wf_virtual-screening/html/fpocket/ngl7.png and b/biobb_wf_virtual-screening/html/fpocket/ngl7.png differ diff --git a/biobb_wf_virtual-screening/html/fpocket/ngl8.png b/biobb_wf_virtual-screening/html/fpocket/ngl8.png deleted file mode 100644 index 3605007..0000000 Binary files a/biobb_wf_virtual-screening/html/fpocket/ngl8.png and /dev/null differ diff --git a/biobb_wf_virtual-screening/html/fpocket/ngl9.png b/biobb_wf_virtual-screening/html/fpocket/ngl9.png deleted file mode 100644 index c99e7cc..0000000 Binary files a/biobb_wf_virtual-screening/html/fpocket/ngl9.png and /dev/null differ diff --git a/biobb_wf_virtual-screening/html/fpocket/wf_vs_fpocket.web.html b/biobb_wf_virtual-screening/html/fpocket/wf_vs_fpocket.web.html index 89bff29..2e0f177 100644 --- a/biobb_wf_virtual-screening/html/fpocket/wf_vs_fpocket.web.html +++ b/biobb_wf_virtual-screening/html/fpocket/wf_vs_fpocket.web.html @@ -1,13 +1,9 @@ - - - - -wf_vs_fpocket.web2 - - - + + + +wf_vs_fpocket.web - - - +.jp-Cell-Placeholder { + padding-left: 55px; +} + +.jp-Cell-Placeholder-wrapper { + background: #fff; + border: 1px solid; + border-color: #e5e6e9 #dfe0e4 #d0d1d5; + border-radius: 4px; + -webkit-border-radius: 4px; + margin: 10px 15px; +} + +.jp-Cell-Placeholder-wrapper-inner { + padding: 15px; + position: relative; +} + +.jp-Cell-Placeholder-wrapper-body { + background-repeat: repeat; + background-size: 50% auto; +} + +.jp-Cell-Placeholder-wrapper-body div { + background: #f6f7f8; + background-image: -webkit-linear-gradient( + left, + #f6f7f8 0%, + #edeef1 20%, + #f6f7f8 40%, + #f6f7f8 100% + ); + background-repeat: no-repeat; + background-size: 800px 104px; + height: 104px; + position: absolute; + right: 15px; + left: 15px; + top: 15px; +} + +div.jp-Cell-Placeholder-h1 { + top: 20px; + height: 20px; + left: 15px; + width: 150px; +} + +div.jp-Cell-Placeholder-h2 { + left: 15px; + top: 50px; + height: 10px; + width: 100px; +} + +div.jp-Cell-Placeholder-content-1, +div.jp-Cell-Placeholder-content-2, +div.jp-Cell-Placeholder-content-3 { + left: 15px; + right: 15px; + height: 10px; +} + +div.jp-Cell-Placeholder-content-1 { + top: 100px; +} + +div.jp-Cell-Placeholder-content-2 { + top: 120px; +} + +div.jp-Cell-Placeholder-content-3 { + top: 140px; +} - + - +.jp-RenderedText pre { + color: var(--jp-content-font-color1); + font-size: var(--jp-code-font-size); +} + +/* Hiding the collapser by default */ +.jp-Collapser { + display: none; +} +@page { + margin: 0.5in; /* Margin for each printed piece of paper */ +} +@media print { + .jp-Cell-inputWrapper, + .jp-Cell-outputWrapper { + display: block; + } +} + - - - + + - - + + + + +
+
+ +
- - - - - - - diff --git a/biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipynb b/biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipynb index a13d1e6..cdecc3e 100644 --- a/biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipynb +++ b/biobb_wf_virtual-screening/notebooks/ebi_api/wf_vs_ebi_api.ipynb @@ -987,7 +987,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.8.9" + "version": "3.11.9" } }, "nbformat": 4,