|
--- |
|
pipeline_tag: text-generation |
|
tags: |
|
- biology |
|
- single-cell |
|
- single-cell analysis |
|
- text-generation-inference |
|
--- |
|
|
|
|
|
|
|
|
|
<div align="center"> |
|
|
|
<img src="./figures/logo.png" alt="image" width=8%> |
|
|
|
<h2 align="center"> ChatCell: Facilitating Single-Cell Analysis with Natural Language </h2> |
|
|
|
<p align="center"> |
|
<a href="https://chat.openai.com/g/g-vUwj222gQ-chatcell">💻Demo</a> • |
|
<a href="https://huggingface.co/datasets/zjunlp/ChatCell-Instructions">🤗 Dataset</a> • |
|
<a href="#1">🏖️ Overview</a> • |
|
<a href="#2">🧬 Single-cell Analysis Tasks</a> • |
|
<a href="#3">🛠️ Quickstart</a> • |
|
<a href="#4">📝 Cite</a> |
|
</p> |
|
|
|
|
|
</div> |
|
The project <b>ChatCell</b> |
|
aims to facilitate single-cell analysis with natural language, which derives from the <a href="https://github.com/vandijklab/cell2sentence-ft">Cell2Sentence</a> |
|
technique to obtain cell language tokens and utilizes cell vocabulary adaptation for T5-based pre-training. Have a try with the demo at |
|
<a href="https://chat.openai.com/g/g-vUwj222gQ-chatcell">💻GPTStore App</a>. |
|
|
|
## 📌 Table of Contents |
|
|
|
- [🛠️ Quickstart](#2) |
|
- [🧬 Single-cell Analysis Tasks](#3) |
|
- [✨ Acknowledgements](#4) |
|
- [📝 Cite](#5) |
|
|
|
--- |
|
|
|
|
|
<h2 id="2">🛠️ Quickstart</h2> |
|
|
|
```python |
|
from transformers import AutoTokenizer, AutoModelForSeq2SeqLM |
|
|
|
tokenizer = AutoTokenizer.from_pretrained("zjunlp/chatcell-small") |
|
model = AutoModelForSeq2SeqLM.from_pretrained("zjunlp/chatcell-small") |
|
input_text="Detail the 100 starting genes for a Mix, ranked by expression level: " |
|
|
|
# Encode the input text and generate a response with specified generation parameters |
|
input_ids = tokenizer(input_text,return_tensors="pt").input_ids |
|
output_ids = model.generate(input_ids, max_length=512, num_return_sequences=1, no_repeat_ngram_size=2, top_k=50, top_p=0.95, do_sample=True) |
|
|
|
# Decode and print the generated output text |
|
output_text = tokenizer.decode(output_ids[0],skip_special_tokens=True) |
|
print(output_text) |
|
``` |
|
|
|
|
|
|
|
<h2 id="3">🧬 Single-cell Analysis Tasks</h2> |
|
|
|
ChatCell can handle the following single-cell tasks: |
|
|
|
- <b>Random Cell Sentence Generation.</b> |
|
Random cell sentence generation challenges the model to create cell sentences devoid of predefined biological conditions or constraints. This task aims to evaluate the model's ability to generate valid and contextually appropriate cell sentences, potentially simulating natural variations in cellular behavior. |
|
|
|
<p align="center"> |
|
<img src="./figures/example1.jpg" alt="image" width=80%> |
|
</p> |
|
|
|
|
|
- <b>Pseudo-cell Generation.</b> |
|
Pseudo-cell generation focuses on generating gene sequences tailored to specific cell type labels. This task is vital for unraveling gene expression and regulation across different cell types, offering insights for medical research and disease studies, particularly in the context of diseased cell types. |
|
|
|
|
|
<p align="center"> |
|
<img src="./figures/example2.jpg" alt="image" width=80%> |
|
</p> |
|
|
|
- <b>Cell Type Annotation.</b> |
|
For cell type annotation, the model is tasked with precisely classifying cells into their respective types based on gene expression patterns encapsulated in cell sentences. This task is fundamental for understanding cellular functions and interactions within tissues and organs, playing a crucial role in developmental biology and regenerative medicine. |
|
|
|
<p align="center"> |
|
<img src="./figures/example3.jpg" alt="image" width=80%> |
|
</p> |
|
|
|
- <b>Drug Sensitivity Prediction.</b> |
|
The drug sensitivity prediction task aims to predict the response of different cells to various drugs. It is pivotal in designing effective, personalized treatment plans and contributes significantly to drug development, especially in optimizing drug efficacy and safety. |
|
|
|
|
|
<p align="center"> |
|
<img src="./figures/example4.jpg" alt="image" width=80%> |
|
</p> |
|
|
|
<h2 id="4">📝 ✨ Acknowledgements</h2> |
|
|
|
Special thanks to the authors of [Cell2Sentence: Teaching Large Language Models the Language of Biology](https://github.com/vandijklab/cell2sentence-ft) and [Representing cells as sentences enables natural-language processing for single-cell transcriptomics |
|
](https://github.com/rahuldhodapkar/cell2sentence) for their inspiring work. |
|
|
|
|
|
<h2 id="5">📝 Cite</h2> |
|
|
|
``` |
|
@article{fang2024chatcell, |
|
title={ChatCell: Facilitating Single-Cell Analysis with Natural Language}, |
|
author={Fang, Yin and Liu, Kangwei and Zhang, Ningyu and Deng, Xinle and Yang, Penghui and Chen, Zhuo and Tang, Xiangru and Gerstein, Mark and Fan, Xiaohui and Chen, Huajun}, |
|
year={2024}, |
|
} |
|
``` |