002 化合物的筛选:ADME和类药性
🏃🏻 快速开始
您可以直接在 Bohrium Notebook 上执行此文档。首先,请点击位于界面顶部的 开始连接 按钮,然后选择 bohrium-notebook:05-31 镜像并选择合适的的机器配置,稍等片刻即可开始运行。
📖 来源
本 Notebook 来自 https://github.com/volkamerlab/teachopencadd,由杨合 📨 修改搬运至 Bohrium Notebook。
Talktorial T002: This talktorial is part of the TeachOpenCADD pipeline described in the first TeachOpenCADD paper, comprising of talktorials T001-T010.
Aim of this talktorial
In the context of drug design, it is important to filter candidate molecules by e.g. their physicochemical properties. In this talktorial, the compounds acquired from ChEMBL (Talktorial T001) will be filtered by Lipinsik's rule of five to keep only orally bioavailable compounds.
Contents in Theory
- ADME - absorption, distribution, metabolism, and excretion
- Lead-likeness and Lipinski's rule of five (Ro5)
- Radar charts in the context of lead-likeness
Contents in Practical
- Define and visualize example molecules
- Calculate and plot molecular properties for Ro5
- Investigate compliance with Ro5
- Apply Ro5 to the EGFR dataset
- Visualize Ro5 properties (radar plot)
References
- ADME criteria (Wikipedia and Mol Pharm. (2010), 7(5), 1388-1405)
- SwissADME webserver
- What are lead compounds? (Wikipedia)
- What is the LogP value? (Wikipedia)
- Lipinski et al. "Experimental and computational approaches to estimate solubility and permeability in drug discovery and development settings." (Adv. Drug Deliv. Rev. (1997), 23, 3-25)
- Ritchie et al. "Graphical representation of ADME-related molecule properties for medicinal chemists" (Drug. Discov. Today (2011), 16, 65-72)
Theory
In a virtual screening, we aim to predict whether a compound might bind to and interact with a specific target. However, if we want to identify a new drug, it is also important that this compound reaches the target and is eventually removed from the body in a favorable way. Therefore, we should also consider whether a compound is actually taken up into the body and whether it is able to cross certain barriers in order to reach its target. Is it metabolically stable and how will it be excreted once it is not acting at the target anymore? These processes are investigated in the field of pharmacokinetics. In contrast to pharmacodynamics ("What does the drug do to our body?"), pharmacokinetics deals with the question "What happens to the drug in our body?".
ADME - absorption, distribution, metabolism, and excretion
Pharmacokinetics are mainly divided into four steps: Absorption, Distribution, Metabolism, and Excretion. These are summarized as ADME. Often, ADME also includes Toxicology and is thus referred to as ADMET or ADMETox. Below, the ADME steps are discussed in more detail (Wikipedia and Mol Pharm. (2010), 7(5), 1388-1405).
Absorption: The amount and the time of drug-uptake into the body depends on multiple factors which can vary between individuals and their conditions as well as on the properties of the substance. Factors such as (poor) compound solubility, gastric emptying time, intestinal transit time, chemical (in-)stability in the stomach, and (in-)ability to permeate the intestinal wall can all influence the extent to which a drug is absorbed after e.g. oral administration, inhalation, or contact to skin.
Distribution: The distribution of an absorbed substance, i.e. within the body, between blood and different tissues, and crossing the blood-brain barrier are affected by regional blood flow rates, molecular size and polarity of the compound, and binding to serum proteins and transporter enzymes. Critical effects in toxicology can be the accumulation of highly apolar substances in fatty tissue, or crossing of the blood-brain barrier.
Metabolism: After entering the body, the compound will be metabolized. This means that only part of this compound will actually reach its target. Mainly liver and kidney enzymes are responsible for the break-down of xenobiotics (substances that are extrinsic to the body).
Excretion: Compounds and their metabolites need to be removed from the body via excretion, usually through the kidneys (urine) or in the feces. Incomplete excretion can result in accumulation of foreign substances or adverse interference with normal metabolism.
Figure 1: ADME processes in the human body (figure taken from Openclipart and adapted).
Lead-likeness and Lipinski's rule of five (Ro5)
Lead compounds are developmental drug candidates with promising properties. They are used as starting structures and modified with the aim to develop effective drugs. Besides bioactivity (compound binds to the target of interest), also favorable ADME properties are important criteria for the design of efficient drugs.
The bioavailability of a compound is an important ADME property. Lipinski's rule of five (Ro5, Adv. Drug Deliv. Rev. (1997), 23, 3-25) was introduced to estimate the bioavailability of a compound solely based on its chemical structure. The Ro5 states that poor absorption or permeation of a compound is more probable if the chemical structure violates more than one of the following rules:
- Molecular weight (MWT) <= 500 Da
- Number of hydrogen bond acceptors (HBAs) <= 10
- Number of hydrogen bond donors (HBD) <= 5
- Calculated LogP (octanol-water coefficient) <= 5
Note: All numbers in the Ro5 are multiples of five; this is the origin of the rule's name.
Additional remarks:
- LogP is also called partition coefficient or octanol-water coefficient. It measures the distribution of a compound, usually between a hydrophobic (e.g. 1-octanol) and a hydrophilic (e.g. water) phase.
- Hydrophobic molecules might have a reduced solubility in water, while more hydrophilic molecules (e.g. high number of hydrogen bond acceptors and donors) or large molecules (high molecular weight) might have more difficulties in passing phospholipid membranes.
Radar charts in the context of lead-likeness
Molecular properties, such as the Ro5 properties, can be visualized in multiple ways (e.g. craig plots, flower plots, or golden triangle) to support the interpretation by medicinal chemists (Drug. Discov. Today (2011), 16(1-2), 65-72).
Due to their appearance, radar charts are sometimes also called "spider" or "cobweb" plots. They are arranged circularly in 360 degrees and have one axis, starting in the center, for each condition. The values for each parameter are plotted on the axis and connected with a line. A shaded area can indicate the region where the parameters meet the conditions.
Figure 2: Radar plot displaying physico-chemical properties of a compound dataset
Practical
Define and visualize example molecules
Before working with the whole dataset retrieved from ChEMBL, we pick four example compounds to investigate their chemical properties. We draw four example molecules from their SMILES.
First, we combine the names and SMILES of the molecules, together with their structure, in a DataFrame.
name | smiles | ROMol | |
---|---|---|---|
0 | cyclosporine | CCC1C(=O)N(CC(=O)N(C(C(=O)NC(C(=O)N(C(C(=O)NC(... | |
1 | clozapine | CN1CCN(CC1)C2=C3C=CC=CC3=NC4=C(N2)C=C(C=C4)C | |
2 | beta-carotene | CC1=C(C(CCC1)(C)C)C=CC(=CC=CC(=CC=CC=C(C)C=CC=... | |
3 | cannabidiol | CCCCCC1=CC(=C(C(=C1)O)C2C=C(CCC2C(=C)C)C)O |
Calculate and plot molecular properties for Ro5
- Calculate molecular weight, number of hydrogen bond acceptors and donors, and logP using some of the descriptors available in
rdkit
.
molecular_weight | n_hba | n_hbd | logp | |
---|---|---|---|---|
0 | 1201.841368 | 12 | 5 | 3.26900 |
1 | 306.184447 | 4 | 1 | 1.68492 |
2 | 536.438202 | 0 | 0 | 12.60580 |
3 | 314.224580 | 2 | 2 | 5.84650 |
name | smiles | ROMol | molecular_weight | n_hba | n_hbd | logp | color | |
---|---|---|---|---|---|---|---|---|
0 | cyclosporine | CCC1C(=O)N(CC(=O)N(C(C(=O)NC(C(=O)N(C(C(=O)NC(... | <img data-content="rdkit/molecule" src="" alt="Mol"/> | 1201.841368 | 12 | 5 | 3.26900 | red |
1 | clozapine | CN1CCN(CC1)C2=C3C=CC=CC3=NC4=C(N2)C=C(C=C4)C | <img data-content="rdkit/molecule" src="" alt="Mol"/> | 306.184447 | 4 | 1 | 1.68492 | green |
2 | beta-carotene | CC1=C(C(CCC1)(C)C)C=CC(=CC=CC(=CC=CC=C(C)C=CC=... | <img data-content="rdkit/molecule" src="" alt="Mol"/> | 536.438202 | 0 | 0 | 12.60580 | blue |
3 | cannabidiol | CCCCCC1=CC(=C(C(=C1)O)C2C=C(CCC2C(=C)C)C)O | <img data-content="rdkit/molecule" src="" alt="Mol"/> | 314.224580 | 2 | 2 | 5.84650 | cyan |
- Plot the molecule properties as bar plots.
In the bar chart, we compared the Ro5 properties for four example molecules with different properties. In the next steps, we will investigate for each compound whether it violates the Ro5.
Investigate compliance with Ro5
Ro5 fulfilled for cyclosporine: False Ro5 fulfilled for clozapine: True Ro5 fulfilled for beta-carotene: False Ro5 fulfilled for cannabidiol: True
According to the Ro5, cyclosporin and betacarotene are estimated to have poor bioavailability. However, since all of them are approved drugs, they are good examples of how the Ro5 can be used as an alert but should not necessarily be used as a filter.
Apply Ro5 to the EGFR dataset
The calculate_ro5_properties
function can be applied to the EGFR dataset for Ro5-compliant compounds.
(5568, 5)
molecule_chembl_id | IC50 | units | smiles | pIC50 | |
---|---|---|---|---|---|
0 | CHEMBL63786 | 0.003 | nM | Brc1cccc(Nc2ncnc3cc4ccccc4cc23)c1 | 11.522879 |
1 | CHEMBL35820 | 0.006 | nM | CCOc1cc2ncnc(Nc3cccc(Br)c3)c2cc1OCC | 11.221849 |
2 | CHEMBL53711 | 0.006 | nM | CN(C)c1cc2c(Nc3cccc(Br)c3)ncnc2cn1 | 11.221849 |
3 | CHEMBL66031 | 0.008 | nM | Brc1cccc(Nc2ncnc3cc4[nH]cnc4cc23)c1 | 11.096910 |
4 | CHEMBL53753 | 0.008 | nM | CNc1cc2c(Nc3cccc(Br)c3)ncnc2cn1 | 11.096910 |
Apply the Ro5 to all molecules.
molecular_weight | n_hba | n_hbd | logp | ro5_fulfilled | |
---|---|---|---|---|---|
0 | 349.021459 | 3 | 1 | 5.2891 | True |
1 | 387.058239 | 5 | 1 | 4.9333 | True |
2 | 343.043258 | 5 | 1 | 3.5969 | True |
3 | 339.011957 | 4 | 2 | 4.0122 | True |
4 | 329.027607 | 5 | 2 | 3.5726 | True |
Concatenate molecules with Ro5 data.
molecule_chembl_id | IC50 | units | smiles | pIC50 | molecular_weight | n_hba | n_hbd | logp | ro5_fulfilled | |
---|---|---|---|---|---|---|---|---|---|---|
0 | CHEMBL63786 | 0.003 | nM | Brc1cccc(Nc2ncnc3cc4ccccc4cc23)c1 | 11.522879 | 349.021459 | 3 | 1 | 5.2891 | True |
1 | CHEMBL35820 | 0.006 | nM | CCOc1cc2ncnc(Nc3cccc(Br)c3)c2cc1OCC | 11.221849 | 387.058239 | 5 | 1 | 4.9333 | True |
2 | CHEMBL53711 | 0.006 | nM | CN(C)c1cc2c(Nc3cccc(Br)c3)ncnc2cn1 | 11.221849 | 343.043258 | 5 | 1 | 3.5969 | True |
3 | CHEMBL66031 | 0.008 | nM | Brc1cccc(Nc2ncnc3cc4[nH]cnc4cc23)c1 | 11.096910 | 339.011957 | 4 | 2 | 4.0122 | True |
4 | CHEMBL53753 | 0.008 | nM | CNc1cc2c(Nc3cccc(Br)c3)ncnc2cn1 | 11.096910 | 329.027607 | 5 | 2 | 3.5726 | True |
# compounds in unfiltered data set: 5568 # compounds in filtered data set: 4635 # compounds not compliant with the Ro5: 933
molecule_chembl_id | IC50 | units | smiles | pIC50 | molecular_weight | n_hba | n_hbd | logp | ro5_fulfilled | |
---|---|---|---|---|---|---|---|---|---|---|
0 | CHEMBL63786 | 0.003 | nM | Brc1cccc(Nc2ncnc3cc4ccccc4cc23)c1 | 11.522879 | 349.021459 | 3 | 1 | 5.2891 | True |
1 | CHEMBL35820 | 0.006 | nM | CCOc1cc2ncnc(Nc3cccc(Br)c3)c2cc1OCC | 11.221849 | 387.058239 | 5 | 1 | 4.9333 | True |
2 | CHEMBL53711 | 0.006 | nM | CN(C)c1cc2c(Nc3cccc(Br)c3)ncnc2cn1 | 11.221849 | 343.043258 | 5 | 1 | 3.5969 | True |
3 | CHEMBL66031 | 0.008 | nM | Brc1cccc(Nc2ncnc3cc4[nH]cnc4cc23)c1 | 11.096910 | 339.011957 | 4 | 2 | 4.0122 | True |
4 | CHEMBL53753 | 0.008 | nM | CNc1cc2c(Nc3cccc(Br)c3)ncnc2cn1 | 11.096910 | 329.027607 | 5 | 2 | 3.5726 | True |
Visualize Ro5 properties (radar plot)
Calculate statistics on Ro5 properties
Define a helper function to calculate the mean and standard deviation for an input DataFrame.
We calculate the statistic for the dataset of compounds that are fulfilling the Ro5.
mean | std | |
---|---|---|
molecular_weight | 414.439011 | 87.985100 |
n_hba | 5.996548 | 1.875491 |
n_hbd | 1.889968 | 1.008368 |
logp | 4.070568 | 1.193034 |
We calculate the statistic for the dataset of compounds that are violating the Ro5.
mean | std | |
---|---|---|
molecular_weight | 587.961963 | 101.999229 |
n_hba | 7.963558 | 2.373576 |
n_hbd | 2.301179 | 1.719732 |
logp | 5.973461 | 1.430636 |
Define helper functions to prepare data for radar plotting
In the following, we will define a few helper functions that are only used for radar plotting.
Prepare y values: The properties used for the Ro5 criteria are of different magnitudes. The MWT has a threshold of 500, whereas the number of HBAs and HBDs and the LogP have thresholds of only 10, 5, and 5, respectively. In order to visualize these different scales most simplistically, we will scale all property values to a scaled threshold of 5:
scaled property value
= property value
/ property threshold
* scaled property threshold
- scaled MWT = MWT / 500 * 5 = MWT / 100
- scaled HBA = HBA / 10 * 5 = HBA / 2
- scaled HBD = HBD / 5 * 5 = HBD
- scaled LogP = LogP / 5 * 5 = LogP
This results in a downscaling of the MWT by 100, HBA by 2, while HBD and LogP stay unchanged.
The following helper function performs such a scaling and will be used later during radar plotting.
Prepare x values: The following helper function returns the angles of the physicochemical property axes for the radar chart. For example, if we want to generate a radar plot for 4 properties, we want to set the axes at 0°, 90°, 180°, and 270°. The helper function returns such angles as radians.
Both functions will be used as helper functions in the radar plotting function, which is defined next.
Generate radar plots, finally!
Now, we define a function that visualizes the compounds' chemical properties in the form of a radar chart. We followed these instructions on stackoverflow.
In the following, we want to plot the radar chart for our two datasets:
- Compounds that fulfill the Ro5
- Compounds that violate the Ro5
Define input parameters that should stay the same for both radar charts:
- We plot the radarplot for the dataset of compounds that fulfill the Ro5.
The blue square shows the area where a molecule's physicochemical properties are compliant with the Ro5. The blue line highlights the mean values, while the orange dashed lines show the standard deviations. We can see that the mean values never violate any of Lipinski's rules. However, according to the standard deviation, some properties have larger values then the Ro5 thresholds. This is acceptable because, according to the Ro5, one of the four rules can be violated.
- We plot the radarplot for the dataset of compounds that violate the Ro5.
We see that compounds mostly violate the Ro5 because of their logP values and their molecular weight.
Discussion
In this talktorial, we have learned about Lipinski's Ro5 as a measure to estimate a compound's oral bioavailability and we have applied the rule on a dataset using rdkit
.
Note that drugs can also be administered via alternative routes, i.e. inhalation, skin penetration and injection.
In this talktorial, we have looked at only one of many more ADME properties. Webservers such as SwissADME give a more comprehensive view on compound properties.