The objective of this project is to identify gene expression patterns associated with different conditions or diseases, leveraging advanced data processing and model training techniques. RNA sequencing (RNA-Seq) is a teachnique used to quantify and analyze gene expression levels across different conditions or samples. The classification of RNA-Seq data can be used to identify which genes are differently expressed between healthy and diseased samples, or between different diseased states, thus aiding in the diagnosis, treatment, and understanding of various diseases and conditions.
- Overview
- Table of Contents
- Dataset
- Project Structure
- Running the Project
- Models Used
- Results
- Contributing
- References
The dataset used in this project:
-
Source: https://archive.ics.uci.edu/dataset/401/gene+expression+cancer+rna+seq
-
Description: This dataset is part of the RNA-Seq (HiSeq) PANCAN data set. It is a random extraction of gene expressions of patients having different types of tumor: BRCA (Breast invasive carcinoma), KIRC (Kidney renal clear cell carcinoma), COAD (Colon adenocarcinoma), LUAD (Lung adenocarcinoma) and PRAD (Prostate adenocarcinoma).
The downloaded dataset file TCGA-PANCAN-HiSeq-801x20531.tar.gz contains two CSV files.
- data.csv: Contains the feature set (X) representing gene expression data.
- labels.csv: Contains the target labels (y) corresponding to the samples in the feature set.
The outline of the project repository:
RNASeq-GeneExpression-ML/
├── data/
│ ├── raw/
│ ├── processed/
│ │ ├── split_data
│ │ ├── transformed
├── notebooks/
│ ├── data_preprocessing.ipynb
│ ├── model_training.ipynb
│ ├── model_evaluation.ipynb
├── src/
│ ├── load_data.py
│ ├── split.py
│ ├── smote.py
│ ├── pca.py
│ ├── models/
│ │ ├── logistic_regression.py
│ │ ├── decision_tree.py
│ │ ├── random_forest.py
│ │ ├── svm.py
│ │ ├── naive_bayes.py
│ │ ├── knn.py
│ │ ├── mlp.py
│ │ ├── gradient_boosting.py
│ │ ├── ada_boost.py
│ │ ├── xgboost.py
│ │ ├── lightgbm.py
│ │ ├── catboost.py
│ ├── evaluate_models.py
├── results/
│ ├── logistic_regression.txt
│ ├── decision_tree.txt
│ ├── random_forest.txt/
│ ├── svm.txt/
│ ├── naive_bayes.txt/
│ ├── knn.txt/
│ ├── mlp.txt/
│ ├── gradient_boosting.txt/
│ ├── ada_boost.txt/
│ ├── xgboost.txt/
│ ├── lightgbm.txt/
│ ├── catboost.txt/
├── README.md
├── requirements.txt
- Clone the repository:
git clone git@github.com:shalinis602/RNASeq-GeneExpression-ML.git
cd RNASeq-GeneExpression-ML
- Create and activate a virtual environment:
python3 -m venv venv
source venv/bin/activate # On Windows use `venv\Scripts\activate`
- Install the dependencies:
pip install -r requirements.txt
- Fast load the dataset and verify its contents:
python src/load_data.py
- Split the data into training, testing and validation sets:
python src/split.py
- Preprocess the dataset:
python src/smote.py
python src/pca.py
- Train the models:
python src/models/random_forest.py
- Evaluate the models:
python src/model_evaluation.py
Alternatively, you can run the Jupyter notebooks located in the notebooks/
directory to interactively execute the code.
- Logistic Regression
- Decision Tree
- Random Forest
- Support Vector Machine (SVM)
- Naive Bayes
- k-Nearest Neighbors (KNN)
- Multilayer Perceptron (MLP)
- Gradient Boosting
- AdaBoost
- XGBoost
- LightGBM
- CatBoost
- Accuracy
- Precision
- Recall
- F1-Score
- Confusion Matrix
If you find any issues or have suggestions for improvements or expanding the project, feel free to open an issue or submit a pull request.
- Fork the repository.
- Create a new branch (
git checkout -b feature-branch
). - Commit your changes (
git commit -am 'Add new feature'
). - Push to the branch (
git push origin feature-branch
). - Create a new Pull Request.