Skip to main content

Python package for calculating TME scores

Project description

TMEImmune

TMEImmune is a Python package that implements the ESTIMATE algorithm, ISTMEscore method, NetBio method, and SIA method. The ESTIMATE and ISTMEscore methods were originally available only in R, and we've ported them to Python for broader accessibility. Additionally, the NetBio and SIA methods, which did not have existing packages, has been manually implemented in Python following the original publications and codes.

Features

  • Implementation of the ESTIMATE algorithm for estimating stromal, immune and estimate scores in tumor samples. Estimate tumor purity for Affymetrix platform data.
  • Implementation of the ISTMEscore method for improved tumor microenvironment (TME) immune and stromal scoring. The ISTME TME subtypes are also provided.
  • Novel implementation of the NetBio and SIA method for comprehensive TME analysis.
  • Data pre-processing including normalization and batch correction for both unnormalized read counts and normalized data.
  • Performance evaluation for immune checkpoint inhibitor response prediction and survival prognosis.

Requirement

The installation of TMEImmune requires python version 3.10 and above.

Installation

You can install the package via the following two commands:

pip install TMEImmune
pip install git+https://github.com/ShahriyariLab/TMEImmune

Usage

Here are some basic usage examples:

Example 1:

import pandas as pd
from TMEImmune import data_processing, TME_score, optimal

# Step 1: Data Normalization
clin = pd.read_csv("example_clin.csv", index_col = 0)
df = data_processing.normalization(path = "example_gene.csv", method = 'TMM', batch = clin, batch_col = "CANCER")

# Step 2: Compute TME score
score = TME_score.get_score(df, method = ['ESTIMATE','ISTME', 'NetBio', 'SIA'], clin = clin, test_clinid = "response")

# Step 3: Performance comparison
outcome = optimal.get_performance(score, metric = ['ICI', 'survival'], 
                                  score_name = ['EST_stromal','EST_immune','IS_immune', 'IS_stromal','NetBio','SIA'], 
                                  ICI_col = 'response', surv_col = ['time', 'delta'], df_clin = clin)

Example 2:

gene = pd.read_excel("riaz.xlsx", sheet_name=0, index_col=0)
clin = pd.read_excel("riaz.xlsx", sheet_name=1, index_col = 1)
clin = clin.loc[clin.index.str.contains("Pre", na=False)]
clin['delta'] = clin['Dead/Alive\n(Dead = True)'].apply(lambda x: 1 if x == True else 0)
clin['OS'] = clin['Time to Death\n(weeks)']
df_norm = data_processing.normalization(gene, batch = clin, batch_col = "Cohort")

score = TME_score.get_score(df_norm, method = ['ESTIMATE','ISTME', 'NetBio', 'SIA'], clin = clin, test_clinid = "response")

outcome = optimal.get_performance(score, metric = ['ICI', 'survival'], 
                                  score_name = ['EST_stromal','EST_immune','IS_immune', 'IS_stromal','NetBio','SIA'], 
                                  ICI_col = 'response', surv_col = ['delta', 'OS'], df_clin = clin, name = "Riaz et al.")

Docker Container

For users who prefer a ready-to-use, stable runtime environment, we provide a pre-built Docker container tmeimmune that includes all necessary dependencies and configurations for running our package. Below shows an example to pull the image from docker and run it, which returns the same output as Example 1 in previous section.

Pull the Docker image:

docker pull qiluzhou/tmeimmune:v1.0

Or build the Docker image from local Dockerfile after downloading the docker/ folder:

docker build -t tmeimmune .

Run the container using Example 1. The two required example datasets are in the data/ folder.

docker run --rm -v $(pwd):/app tmeimmune python /app/docker_test.py

Troubleshooting

Bug 1: `GLIBCXX_version' not found

Some users may encounter errors similar to:

ImportError: /path/to/libstdc++.so.6: version `GLIBCXX_3.4.32` not found

This usually indicates that the system’s C++ standard library (libstdc++) is too old for one of our package’s dependencies. The following two solutions work for Ubuntu 24.04 with conda version 24.11.3:

1. Update libstdc++ via Conda

Install or upgrade the libstdcxx-ng package from the conda-forge channel to get the latest version.

conda install -c conda-forge libstdcxx-ng

This will install the most recent version of libstdcxx-ng available, ensuring that the required GLIBCXX version is present.

2. Create a Preconfigured Environment

We provide an env.yml file in our repository that sets up a Conda environment with all the recommended dependencies (including a compatible version of libstdcxx-ng). To create this environment, run:

conda env create -f env.yml

After the environment is created, activate it with:

conda activate tme_env

Bug 2: command 'g++' failed

This error indicates that no C++ compiler (g++) is installed in the current environment. To fix this, you need to install the build tools.

apt-get update && apt-get install -y build-essential

If you continue to have issues, please ensure that your system’s packages are up-to-date, or contact us for further support.

License

This project is licensed under the MIT License. See the LICENSE file for more details.

Contact and contribution

If you have any questions or feedback, feel free to open an issue on GitHub Issues. We also welcome contributions for integrating new TME scores into our package. If you'd like to propose a method, please attach a link to its introduction in the Github issue using the feature_request template, and we will evaluate it accordingly. If you encounter any bugs, open an issue on bug_report. All the changes we've made can be tracked through the GitHub project TMEImmune_project.

Acknowledgements

The ESTIMATE algorithm from Yoshihara et al. The ISTMEscore method from Zeng et al. The NetBio method from Kong et al. The SIA method from Mezheyeuski et al.

Citations

If you use TMEImmune in your research, please cite the following papers:

Yoshihara, K., Shahmoradgoli, M., Martínez, E. et al. Inferring tumour purity and stromal and immune cell admixture from expression data. Nat Commun 4, 2612 (2013). https://doi.org/10.1038/ncomms3612

Zeng, Z., Li, J., Zhang, J. et al. Immune and stromal scoring system associated with tumor microenvironment and prognosis: a gene-based multi-cancer analysis. J Transl Med 19, 330 (2021). https://doi.org/10.1186/s12967-021-03002-1

Kong, J., Ha, D., Lee, J., Kim, I., Park, M., Im, S. H., ... & Kim, S. (2022). Network-based machine learning approach to predict immunotherapy response in cancer patients. Nature communications, 13(1), 3703. https://doi.org/10.1038/s41467-022-31535-6

Mezheyeuski, A., Backman, M., Mattsson, J., Martín-Bernabé, A., Larsson, C., Hrynchyk, I., Hammarström, K., Ström, S., Ekström, J., Mauchanski, S., Khelashvili, S., Lindberg, A., Agnarsdóttir, M., Edqvist, P. H., Huvila, J., Segersten, U., Malmström, P. U., Botling, J., Nodin, B., Hedner, C., … Sjöblom, T. (2023). An immune score reflecting pro- and anti-tumoural balance of tumour microenvironment has major prognostic impact and predicts immunotherapy response in solid cancers. EBioMedicine, 88, 104452. https://doi.org/10.1016/j.ebiom.2023.104452

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tmeimmune-1.3.3.tar.gz (11.3 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tmeimmune-1.3.3-py3-none-any.whl (11.4 MB view details)

Uploaded Python 3

File details

Details for the file tmeimmune-1.3.3.tar.gz.

File metadata

  • Download URL: tmeimmune-1.3.3.tar.gz
  • Upload date:
  • Size: 11.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for tmeimmune-1.3.3.tar.gz
Algorithm Hash digest
SHA256 99dfdc047753ebf64e9e34ca04b3eb0909f4d792f8b02c6970bb761a32e8a65d
MD5 7d2064f69a07d04de09cacea22fe9a98
BLAKE2b-256 746a4b22f66a3aa2e3238a5cc49332697d2d94b770bfd370ba099f804becc1f2

See more details on using hashes here.

File details

Details for the file tmeimmune-1.3.3-py3-none-any.whl.

File metadata

  • Download URL: tmeimmune-1.3.3-py3-none-any.whl
  • Upload date:
  • Size: 11.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for tmeimmune-1.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 766d6dd2fb461d829e26da668d109251be4395be2713037ed8f298eb63788e40
MD5 62fd6b7022a8cb9a176f68134f5662cb
BLAKE2b-256 886eaabf35485c693cc8e55243fb5ae6c1213e36ce4b85c1c295359fb91204f9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page