Gene Ontology (GO)¶
Pathways represent interconnected molecular networks of signaling cascades that govern critical cellular processes. They provide understandings cellular behavior mechanisms, insights of disease progression and treatment responses. In an R&D organization, managing pathways across different datasets are crucial for gaining insights of potential therapeutic targets and intervention strategies.
In this notebook we manage a pathway registry based on “2023 GO Biological Process” ontology. We’ll walk you through the steps of registering pathways and link them to genes.
In the following Standardize metadata on-the-fly notebook, we’ll demonstrate how to perform a pathway enrichment analysis and track the dataset with LaminDB.
# !pip install 'lamindb[jupyter,bionty]'
!lamin init --storage ./use-cases-registries --schema bionty
import lamindb as ln
import bionty as bt
import gseapy as gp
bt.settings.organism = "human" # globally set organism
→ connected lamindb: testuser1/use-cases-registries
Fetch GO pathways annotated with human genes using Enrichr¶
First we fetch the “GO_Biological_Process_2023” pathways for humans using GSEApy which wraps GSEA and Enrichr.
go_bp = gp.get_library(name="GO_Biological_Process_2023", organism="Human")
print(f"Number of pathways {len(go_bp)}")
Number of pathways 5406
go_bp["ATF6-mediated Unfolded Protein Response (GO:0036500)"]
['MBTPS1', 'MBTPS2', 'XBP1', 'ATF6B', 'DDIT3', 'CREBZF']
Parse out the ontology_id from keys, convert into the format of {ontology_id: (name, genes)}
def parse_ontology_id_from_keys(key):
"""Parse out the ontology id.
"ATF6-mediated Unfolded Protein Response (GO:0036500)" -> ("GO:0036500", "ATF6-mediated Unfolded Protein Response")
"""
name, id = key.rsplit(" (", 1)
id = id.rstrip(")")
return id, name
go_bp_parsed = {}
for key, genes in go_bp.items():
id, name = parse_ontology_id_from_keys(key)
go_bp_parsed[id] = (name, genes)
go_bp_parsed["GO:0036500"]
('ATF6-mediated Unfolded Protein Response',
['MBTPS1', 'MBTPS2', 'XBP1', 'ATF6B', 'DDIT3', 'CREBZF'])
Register pathway ontology in LaminDB¶
bionty = bt.Pathway.public()
bionty
Show code cell output
PublicOntology
Entity: Pathway
Organism: all
Source: go, 2024-06-17
#terms: 47856
Next, we register all the pathways and genes in LaminDB to finally link pathways to genes.
Register pathway terms¶
To register the pathways we make use of .from_values
to directly parse the annotated GO pathway ontology IDs into LaminDB.
pathway_records = bt.Pathway.from_values(go_bp_parsed.keys(), bt.Pathway.ontology_id)
ln.save(pathway_records)
Register gene symbols¶
Similarly, we use .from_values
for all Pathway associated genes to register them with LaminDB.
all_genes = bt.Gene.standardize(list({g for genes in go_bp.values() for g in genes}))
gene_records = bt.Gene.from_values(all_genes, bt.Gene.symbol)
ln.save(gene_records);
! found 56 synonyms in Bionty: ['C12ORF4', 'PIFO', 'C12ORF50', 'C18ORF32', 'C10ORF71', 'THEG', 'C12ORF57', 'ANP32C', 'SLC9A3R1', 'TTC30A', 'C1ORF68', 'FAM172BP', 'C2ORF49', 'SLC9A3R2', 'C1ORF112', 'TTC26', 'SPATA5L1', 'C9ORF72', 'C3ORF70', 'C11ORF80', 'C17ORF75', 'C12ORF29', 'USP41', 'C6ORF89', 'DUSP13', 'C11ORF65', 'C15ORF62', 'C19ORF12', 'C8ORF17', 'TRB', 'C10ORF90', 'C1ORF146', 'C1ORF109', 'FAM172A', 'C1ORF56', 'C21ORF91', 'C17ORF99', 'C3ORF33', 'C8ORF88', 'C18ORF25', 'C1ORF131', 'C2ORF69', 'C9ORF78', 'TDGF1', 'RNF165', 'SPATA5', 'GBAP1', 'C17ORF97', 'SOGA1', 'C20ORF173', 'C3ORF38', 'ADGRF2', 'C1ORF43', 'PDZD3', 'C6ORF15', 'HSPB11']
please add corresponding Gene records via `.from_values(['CRIPTO', 'ADGRF2P', 'C3orf33', 'C1orf131', 'C21orf91', 'RLIG1', 'C10orf90', 'ANP32CP', 'C2orf69', 'C8orf88', 'C17orf75', 'C10orf71', 'C6orf15', 'ARB2BP', 'IFT70A', 'C3orf38', 'C2orf49', 'C9orf78', 'GBA1LP', 'C15orf62', 'SPMAP2', 'THRB', 'KPLCE', 'C12orf57', 'FIRRM', 'C3orf70', 'MTCL2', 'C1orf43', 'AFG2B', 'C6orf89', 'C20orf173', 'C1orf146', 'C1orf56', 'NHERF1', 'C12orf50', 'CIMAP3', 'TOP6BL', 'C11orf65', 'C17orf99', 'NHERF4', 'AFG2A', 'AIRIM', 'ARB2A', 'C9orf72', 'USP41P', 'C19orf12', 'C18orf32', 'C12orf4', 'ARK2N', 'DUSP13B', 'IFT25', 'ARK2C', 'LIAT1', 'C8orf17', 'IFT56', 'NHERF2'])`
! ambiguous validation in Bionty for 1104 records: 'ZNF100', 'PSMB3', 'BCL2L14', 'DUX4L9', 'MYO19', 'OR5T1', 'TRMT9B', 'HLA-DRB3', 'TFE3', 'IFNL2', 'MEF2D', 'OR2T7', 'TRIM31', 'CWC25', 'NDUFS1', 'USP17L7', 'RABGGTA', 'KRT12', 'TAPBP', 'HHAT', ...
! did not create Gene records for 38 non-validated symbols: 'AFD1', 'AZF1', 'CCL3L1', 'CCL4L1', 'DGS2', 'DUX3', 'DUX5', 'FOXL3-OT1', 'IGL', 'LOC100653049', 'LOC102723475', 'LOC102723996', 'LOC102724159', 'LOC107984156', 'LOC112268384', 'LOC122319436', 'LOC122513141', 'LOC122539214', 'LOC344967', 'MDRV', ...
Manually register the 37 non-validated symbols:
inspect_result = bt.Gene.inspect(all_genes, bt.Gene.symbol)
nonval_genes = []
for g in inspect_result.non_validated:
nonval_genes.append(bt.Gene(symbol=g))
ln.save(nonval_genes)
! received 14696 unique terms, 1 empty/duplicated term is ignored
! 38 terms (0.30%) are not validated for symbol: MTRNR2L8, CCL3L1, LOC102723475, IGL, LOC122513141, DUX5, MTRNR2L2, MTRNR2L13, FOXL3-OT1, MTRNR2L11, LOC102724159, LOC107984156, TRL-AAG2-3, DGS2, LOC102723996, AFD1, TRA, AZF1, MTRNR2L7, LOC344967, ...
couldn't validate 38 terms: 'MTRNR2L5', 'TAS2R36', 'MTRNR2L2', 'DGS2', 'DUX3', 'LOC102723996', 'MTRNR2L10', 'MTRNR2L1', 'DUX5', 'LOC102724159', 'MTRNR2L7', 'TAS2R33', 'FOXL3-OT1', 'MTRNR2L3', 'MTRNR2L13', 'TRL-AAG2-3', 'MTRNR2L11', 'CCL3L1', 'AFD1', 'LOC107984156', ...
→ if you are sure, create new records via Gene() and save to your registry
Link pathway to genes¶
Now that we are tracking all pathways and genes records, we can link both of them to make the pathways even more queryable.
symbols_gene_records = {record.symbol: record for record in gene_records}
for pathway_record in pathway_records:
pathway_genes = go_bp_parsed.get(pathway_record.ontology_id)[1]
pathway_genes_records = [symbols_gene_records.get(gene) for gene in pathway_genes]
pathway_record.genes.set(pathway_genes_records)
Now genes are linked to pathways:
pathway_record.genes.list("symbol")
['CARD18', 'XIAP', 'CAST', 'CARD8', 'CST7']
pathway_record.genes.list("ensembl_gene_id")
['ENSG00000255501',
'ENSG00000101966',
'ENSG00000153113',
'ENSG00000105483',
'ENSG00000077984']
Move on to the next analysis: Standardize metadata on-the-fly