Disease¶
lamindb provides access to the following public Disease ontologies through bionty:
Here we show how to access and search Disease ontologies to standardize new data.
import bionty as bt
import pandas as pd
→ connected lamindb: testuser1/test-public-ontologies
PublicOntology objects¶
Let us create a public ontology accessor with .public method, which chooses a default public ontology source from Source.
It’s a PublicOntology object, which you can think about as a public registry:
diseases = bt.Disease.public(organism="all")
diseases
PublicOntology
Entity: Disease
Organism: all
Source: mondo, 2025-06-03
#terms: 30128
As for registries, you can export the ontology as a DataFrame:
df = diseases.to_dataframe()
df.head()
| name | definition | synonyms | parents | |
|---|---|---|---|---|
| ontology_id | ||||
| MONDO:0000001 | disease | A Disease Is A Disposition To Undergo Patholog... | disease or disorder|diseases|other disease|dis... | [] |
| MONDO:0000002 | obsolete 46,XX sex reversal | None | None | [] |
| MONDO:0000003 | obsolete 17-hydroxysteroid dehydrogenase defic... | None | None | [] |
| MONDO:0000004 | adrenocortical insufficiency | An Endocrine Or Hormonal Disorder That Occurs ... | adrenal gland insufficiency|hypocortisolemia|a... | [MONDO:0002816] |
| MONDO:0000005 | alopecia, isolated | None | None | [MONDO:0004907, MONDO:0100118] |
Unlike registries, you can also export it as a Pronto object via public.ontology.
Look up terms¶
As for registries, terms can be looked up with auto-complete:
lookup = diseases.lookup()
The . accessor provides normalized terms (lower case, only contains alphanumeric characters and underscores):
lookup.alzheimer_disease
Disease(ontology_id='MONDO:0004975', name='Alzheimer disease', definition='A Progressive, Neurodegenerative Disease Characterized By Loss Of Function And Death Of Nerve Cells In Several Areas Of The Brain Leading To Loss Of Cognitive Function Such As Memory And Language.', synonyms="Alzheimer dementia|Alzheimers disease|Alzheimer disease|Alzheimer's disease|AD|Alzheimers dementia|presenile and senile dementia|Alzheimer's dementia", parents=array(['MONDO:0001627', 'MONDO:0005574'], dtype=object))
To look up the exact original strings, convert the lookup object to dict and use the [] accessor:
lookup_dict = lookup.dict()
lookup_dict["Alzheimer disease"]
Disease(ontology_id='MONDO:0004975', name='Alzheimer disease', definition='A Progressive, Neurodegenerative Disease Characterized By Loss Of Function And Death Of Nerve Cells In Several Areas Of The Brain Leading To Loss Of Cognitive Function Such As Memory And Language.', synonyms="Alzheimer dementia|Alzheimers disease|Alzheimer disease|Alzheimer's disease|AD|Alzheimers dementia|presenile and senile dementia|Alzheimer's dementia", parents=array(['MONDO:0001627', 'MONDO:0005574'], dtype=object))
By default, the name field is used to generate lookup keys. You can specify another field to look up:
lookup = diseases.lookup(diseases.ontology_id)
lookup.mondo_0004975
Disease(ontology_id='MONDO:0004975', name='Alzheimer disease', definition='A Progressive, Neurodegenerative Disease Characterized By Loss Of Function And Death Of Nerve Cells In Several Areas Of The Brain Leading To Loss Of Cognitive Function Such As Memory And Language.', synonyms="Alzheimer dementia|Alzheimers disease|Alzheimer disease|Alzheimer's disease|AD|Alzheimers dementia|presenile and senile dementia|Alzheimer's dementia", parents=array(['MONDO:0001627', 'MONDO:0005574'], dtype=object))
Search terms¶
Search behaves in the same way as it does for registries:
diseases.search("parkinson disease").head(3)
| name | definition | synonyms | parents | |
|---|---|---|---|---|
| ontology_id | ||||
| MONDO:0005180 | Parkinson disease | A Progressive Degenerative Disorder Of The Cen... | paralysis agitans|Parkinson disease|PD|Parkins... | [MONDO:0021095, MONDO:0100545] |
| MONDO:0008199 | late-onset Parkinson disease | A Parkinson Disease That Begins After Around T... | LOPD|Parkinson disease, susceptibility to, Mul... | [MONDO:0005180] |
| MONDO:0011613 | autosomal recessive early-onset Parkinson dise... | Any Parkinson Disease In Which The Cause Of Th... | PINK1 Parkinson disease|Parkinson disease caus... | [MONDO:0017279] |
By default, search also covers synonyms and all other fileds containing strings:
diseases.search("paralysis agitans").head(3)
| name | definition | synonyms | parents | |
|---|---|---|---|---|
| ontology_id | ||||
| MONDO:0005180 | Parkinson disease | A Progressive Degenerative Disorder Of The Cen... | paralysis agitans|Parkinson disease|PD|Parkins... | [MONDO:0021095, MONDO:0100545] |
| MONDO:0008193 | paralysis agitans, juvenile, of Hunt | None | paralysis agitans, juvenile, of Hunt | [MONDO:0009830] |
Search specific field (by default, search is done on all fields containing strings):
diseases.search(
"progressive degenerative disorder of the central nervous system",
field=diseases.definition,
).head()
| name | definition | synonyms | parents | |
|---|---|---|---|---|
| ontology_id | ||||
| MONDO:0005180 | Parkinson disease | A Progressive Degenerative Disorder Of The Cen... | paralysis agitans|Parkinson disease|PD|Parkins... | [MONDO:0021095, MONDO:0100545] |
Standardize Disease identifiers¶
Let us generate a DataFrame that stores a number of Disease identifiers, some of which corrupted:
df_orig = pd.DataFrame(
index=[
"supraglottis cancer",
"alexia",
"trigonitis",
"paranasal sinus disorder",
"This disease does not exist",
]
)
df_orig
| supraglottis cancer |
|---|
| alexia |
| trigonitis |
| paranasal sinus disorder |
| This disease does not exist |
We can check whether any of our values are validated against the ontology reference:
validated = diseases.validate(df_orig.index, diseases.name)
df_orig.index[~validated]
! 1 unique term (20.00%) is not validated: 'This disease does not exist'
Index(['This disease does not exist'], dtype='object')
Ontology source versions¶
For any given entity, we can choose from a number of versions:
bt.Source.filter(entity="bionty.Disease").to_dataframe()
Show code cell output
| uid | entity | organism | name | in_db | currently_used | description | url | md5 | source_website | version | is_locked | created_at | branch_id | space_id | created_by_id | run_id | dataframe_artifact_id | |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| id | ||||||||||||||||||
| 20 | 25rhq3yV | bionty.Disease | human | icd | False | False | International Classification of Diseases (ICD) | s3://bionty-assets/df_human__icd__icd-11-2023_... | None | https://www.who.int/standards/classifications/... | icd-11-2023 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 19 | 4kswnHVF | bionty.Disease | human | doid | False | True | Human Disease Ontology | http://purl.obolibrary.org/obo/doid/releases/2... | None | https://disease-ontology.org | 2024-05-29 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 18 | IGIkseWQ | bionty.Disease | all | mondo | False | True | Mondo Disease Ontology | http://purl.obolibrary.org/obo/mondo/releases/... | None | https://mondo.monarchinitiative.org | 2025-06-03 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
# only lists the sources that are currently used
bt.Source.filter(entity="bionty.Disease", currently_used=True).to_dataframe()
| uid | entity | organism | name | in_db | currently_used | description | url | md5 | source_website | version | is_locked | created_at | branch_id | space_id | created_by_id | run_id | dataframe_artifact_id | |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| id | ||||||||||||||||||
| 19 | 4kswnHVF | bionty.Disease | human | doid | False | True | Human Disease Ontology | http://purl.obolibrary.org/obo/doid/releases/2... | None | https://disease-ontology.org | 2024-05-29 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 18 | IGIkseWQ | bionty.Disease | all | mondo | False | True | Mondo Disease Ontology | http://purl.obolibrary.org/obo/mondo/releases/... | None | https://mondo.monarchinitiative.org | 2025-06-03 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
When instantiating a Bionty object, we can choose a source or version:
source = bt.Source.filter(
name="mondo", organism="all"
).first()
diseases= bt.Disease.public(source=source)
diseases
PublicOntology
Entity: Disease
Organism: all
Source: mondo, 2025-06-03
#terms: 30128
The currently used ontologies can be displayed using:
bt.Source.filter(currently_used=True).to_dataframe()
Show code cell output
| uid | entity | organism | name | in_db | currently_used | description | url | md5 | source_website | version | is_locked | created_at | branch_id | space_id | created_by_id | run_id | dataframe_artifact_id | |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| id | ||||||||||||||||||
| 33 | 5JnVODh4 | BioSample | all | ncbi | False | True | NCBI BioSample attributes | s3://bionty-assets/df_all__ncbi__2023-09__BioS... | None | https://www.ncbi.nlm.nih.gov/biosample/docs/at... | 2023-09 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 32 | MJRqduf9 | bionty.Ethnicity | human | hancestro | False | True | Human Ancestry Ontology | http://purl.obolibrary.org/obo/hancestro/relea... | None | https://github.com/EBISPOT/hancestro | 3.0 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 31 | 10va5JSt | bionty.DevelopmentalStage | mouse | mmusdv | False | True | Mouse Developmental Stages | https://github.com/obophenotype/developmental-... | None | https://github.com/obophenotype/developmental-... | 2024-05-28 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 30 | 1GbFkOdz | bionty.DevelopmentalStage | human | hsapdv | False | True | Human Developmental Stages | https://github.com/obophenotype/developmental-... | None | https://github.com/obophenotype/developmental-... | 2024-05-28 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 28 | ugaIoIlj | Drug | all | dron | False | True | Drug Ontology | http://purl.obolibrary.org/obo/dron/releases/2... | None | https://bioportal.bioontology.org/ontologies/DRON | 2024-08-05 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 27 | 3rm9aOzL | BFXPipeline | all | lamin | False | True | Bioinformatics Pipeline | s3://bionty-assets/df_all__lamin__1.0.0__BFXpi... | None | https://lamin.ai | 1.0.0 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 25 | 7Ent3V2y | bionty.Pathway | all | go | False | True | Gene Ontology | http://purl.obolibrary.org/obo/go/releases/202... | None | http://geneontology.org | 2024-06-17 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 23 | 48fBFLmn | bionty.Phenotype | human | hp | False | True | Human Phenotype Ontology | https://github.com/obophenotype/human-phenotyp... | None | https://hpo.jax.org | 2024-04-26 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 22 | 6S4qkDx1 | bionty.Phenotype | all | pato | False | True | Phenotype And Trait Ontology | http://purl.obolibrary.org/obo/pato/releases/2... | None | https://github.com/pato-ontology/pato | 2024-03-28 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 21 | 2a1HvjdB | bionty.ExperimentalFactor | all | efo | False | True | The Experimental Factor Ontology | http://www.ebi.ac.uk/efo/releases/v3.70.0/efo.owl | None | https://bioportal.bioontology.org/ontologies/EFO | 3.70.0 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 19 | 4kswnHVF | bionty.Disease | human | doid | False | True | Human Disease Ontology | http://purl.obolibrary.org/obo/doid/releases/2... | None | https://disease-ontology.org | 2024-05-29 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 18 | IGIkseWQ | bionty.Disease | all | mondo | False | True | Mondo Disease Ontology | http://purl.obolibrary.org/obo/mondo/releases/... | None | https://mondo.monarchinitiative.org | 2025-06-03 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 17 | 4U5uYTlc | bionty.Tissue | all | uberon | False | True | Uberon multi-species anatomy ontology | http://purl.obolibrary.org/obo/uberon/releases... | None | http://obophenotype.github.io/uberon | 2025-05-28 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 16 | 3T9KZcjQ | bionty.CellType | all | cl | False | True | Cell Ontology | http://purl.obolibrary.org/obo/cl/releases/202... | None | https://obophenotype.github.io/cell-ontology | 2025-04-10 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 14 | 6LyRtvz8 | bionty.CellLine | all | clo | False | True | Cell Line Ontology | s3://bionty-assets/df_all__clo__2022-03-21__Ce... | None | https://bioportal.bioontology.org/ontologies/CLO | 2022-03-21 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 13 | 7bV5uJo3 | bionty.CellMarker | mouse | cellmarker | False | True | CellMarker | s3://bionty-assets/mouse_cellmarker_2.0_CellMa... | None | http://bio-bigdata.hrbmu.edu.cn/CellMarker | 2.0 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 12 | 3kDh8qAX | bionty.CellMarker | human | cellmarker | False | True | CellMarker | s3://bionty-assets/human_cellmarker_2.0_CellMa... | None | http://bio-bigdata.hrbmu.edu.cn/CellMarker | 2.0 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 11 | 01RWXN2V | bionty.Protein | mouse | uniprot | False | True | Uniprot | s3://bionty-assets/df_mouse__uniprot__2024-03_... | None | https://www.uniprot.org | 2024-03 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 10 | 3EYyGRYN | bionty.Protein | human | uniprot | False | True | Uniprot | s3://bionty-assets/df_human__uniprot__2024-03_... | None | https://www.uniprot.org | 2024-03 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 9 | 4RPA3Re0 | bionty.Gene | saccharomyces cerevisiae | ensembl | False | True | Ensembl | s3://bionty-assets/df_saccharomyces cerevisiae... | None | https://www.ensembl.org | release-112 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 8 | 4r4fvV0S | bionty.Gene | mouse | ensembl | False | True | Ensembl | s3://bionty-assets/df_mouse__ensembl__release-... | None | https://www.ensembl.org | release-112 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 7 | 4UGNz3fr | bionty.Gene | human | ensembl | False | True | Ensembl | s3://bionty-assets/df_human__ensembl__release-... | None | https://www.ensembl.org | release-112 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 6 | 4tsksCMX | bionty.Organism | all | ncbitaxon | False | True | NCBItaxon Ontology | http://purl.obolibrary.org/obo/ncbitaxon/2023-... | None | https://github.com/obophenotype/ncbitaxon | 2023-06-20 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 5 | 7GPHh16S | bionty.Organism | plants | ensembl | False | True | Ensembl | https://ftp.ensemblgenomes.ebi.ac.uk/pub/plant... | None | https://www.ensembl.org | release-57 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 4 | 2PmTrc8x | bionty.Organism | metazoa | ensembl | False | True | Ensembl | https://ftp.ensemblgenomes.ebi.ac.uk/pub/metaz... | None | https://www.ensembl.org | release-57 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 3 | 6s9nV6xh | bionty.Organism | fungi | ensembl | False | True | Ensembl | https://ftp.ensemblgenomes.ebi.ac.uk/pub/fungi... | None | https://www.ensembl.org | release-57 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 2 | 6bbVUTCS | bionty.Organism | bacteria | ensembl | False | True | Ensembl | https://ftp.ensemblgenomes.ebi.ac.uk/pub/bacte... | None | https://www.ensembl.org | release-57 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |
| 1 | 33TUF039 | bionty.Organism | vertebrates | ensembl | False | True | Ensembl | https://ftp.ensembl.org/pub/release-112/specie... | None | https://www.ensembl.org | release-112 | False | 2025-10-27 08:27:09.109000+00:00 | 1 | 1 | 1 | None | None |