A comprehensive toolkit for processing and analyzing metabolomics data.
Project description
Rodin: Metabolomics Data Analysis Toolkit
Rodin is a Python library specifically designed for the comprehensive processing and analysis of metabolomics data and other omics data. It is a class-methods based toolkit, facilitating a range of tasks from basic data manipulation to advanced statistical evaluations, visualization, and metabolic pathway analysis.
📘 Documentation: https://minasenko.com/rodin
Now, most of its functionality is available in the Web App at https://rodin-meta.com.
Features
- Efficient Data Handling: Streamlined manipulation and transformation of metabolomics data and other omics.
- Robust Statistical Analysis: Includes ANOVA, t-tests, and more.
- Machine Learning Methods: Random Forest, Logistic and Linear regressions.
- Advanced Dimensionality Reduction: Techniques like PCA, t-SNE, UMAP.
- Interactive Data Visualization: Tools for effective data visualization.
- Pathway Analysis: Features for metabolic pathway analysis.
Installation
We recommend installing Rodin in a separate environment for effective dependency management.
Prerequisites
- Python (3.10 or higher)
Install Rodin
pip install rodin
or install Rodin directly from GitHub:
pip install git+https://github.com/BM-Boris/rodin.git
Basic Example
Here's a basic example demonstrating the usage of Rodin for data analysis. Comprehensive Jupyter notebook guides can be found in the 'guides' folder
import rodin
# Assume 'features.csv' and 'class_labels.csv' are your datasets
features_path = 'path/to/features.csv'
classes_path = 'path/to/class_labels.csv'
# Creating an instance of Rodin_Class
rodin_instance = rodin.create(features_path, classes_path)
# Transform the data (imputation, normalization, and log-transformation steps)
rodin_instance.transform()
# Run t-test comparing two groups based on 'age'
rodin_instance.ttest('age')
# Run two-way anova test comparing groups based on 'age' and 'region'
rodin_instance.twoway_anova(['age','region'])
# Run multiple logistic regressions and linear regressions to get pvalues for each feature
rodin_instance.sf_lg('sex')
rodin_instance.sf_lr('age')
#Run a random forest classifier and regressor to obtain the metrics of the trained model using k-fold validation, with assigned feature importance scores to each variable
rodin_instance.rf_class('region')
rodin_instance.rf_regress('age')
#Slice the whole object using the pattern from pandas
rodin_instance = rodin_instance[rodin_instance.features[rodin_instance.features['imp(rf) age']>0]]
# Perform PCA with 2 principal components (UMAP and t-SNE are available as well)
rodin_instance.run_pca(n_components=2)
# Plotting the PCA results
# 'region' column in the 'samples' DataFrame is used for coloring the points
rodin_instance.plot(dr_name='pca', hue='region', title='PCA Plot')
# Volcano Plot
rodin_instance.volcano(p='p_adj(owa) region', effect_size='lfc (New York vs Georgia)', sign_line=0.01)
# Box Plot
rodin_instance.boxplot(rows=[9999,4561], hue='region')
# Clustergram
rodin_instance.clustergram(hue='sex',standardize='row')
# Pathway analysis
rodin_instance.analyze_pathways(pvals='p_value', stats='statistic',mode='positive')
# Replace 'p_value' and 'statistic' with the actual column names in your 'features' DataFrame(rodin_instance.features) and provide Mass spectrometry analysis mode.
The updated guide can be accessed here: https://bm-boris.github.io/rodin_guide/basics.html. Test data from the guide can be found at https://github.com/BM-Boris/rodin_guide/tree/main/data.
Contact
For questions, suggestions, or feedback, please contact boris.minasenko@emory.edu
Citation
If you use Rodin in your research, please cite the following paper:
Minasenko B, Wang D, Cirillo P, Krigbaum N, Cohn B, Jones DP, Collins JM, Hu X.
Rodin: a streamlined metabolomics data analysis and visualization tool. Bioinformatics Advances. 2025; 5(1): vbaf088.
https://doi.org/10.1093/bioadv/vbaf088
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file rodin-1.9.27.tar.gz.
File metadata
- Download URL: rodin-1.9.27.tar.gz
- Upload date:
- Size: 2.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
be4fd427b7d5abba695eb5f8ddd19553b6e5408006b5477a13dea778b8560d1e
|
|
| MD5 |
c13cf318b256eb3b1a7c11a835238558
|
|
| BLAKE2b-256 |
dee13904fa1af939e51a763bab47f70b0ffc88eeee3018ff41a5dccb9d211803
|
File details
Details for the file rodin-1.9.27-py3-none-any.whl.
File metadata
- Download URL: rodin-1.9.27-py3-none-any.whl
- Upload date:
- Size: 2.2 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1f9363bf1adb973947e9c55705d51acd0f7ab436050d0a4ac1ec7166776eb95b
|
|
| MD5 |
4259906ee7acb4f3de437b16e7f5d538
|
|
| BLAKE2b-256 |
c01d05db2cdf614bad7e22398c27659e0d82c47374389ad3aa15b39052410353
|