Update README.md
Browse files
    	
        README.md
    CHANGED
    
    | @@ -26,4 +26,233 @@ tags: | |
| 26 | 
             
            <p><b>License:</b>
         | 
| 27 | 
             
            <p>The original model is licensed under the Creative Commons Attribution 4.0 International License (CC-BY-4.0). Please refer to the original license file for full terms. All modifications and redistributions of this quantized version must also adhere to the terms of this license.
         | 
| 28 |  | 
| 29 | 
            -
            <p><b>Author: van Dijk Lab (Yale), Google Research, Google DeepMind</b>
         | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | 
|  | |
| 26 | 
             
            <p><b>License:</b>
         | 
| 27 | 
             
            <p>The original model is licensed under the Creative Commons Attribution 4.0 International License (CC-BY-4.0). Please refer to the original license file for full terms. All modifications and redistributions of this quantized version must also adhere to the terms of this license.
         | 
| 28 |  | 
| 29 | 
            +
            <p><b>Author: van Dijk Lab (Yale), Google Research, Google DeepMind</b>
         | 
| 30 | 
            +
             | 
| 31 | 
            +
            # C2S-Scale-Gemma-27B model card
         | 
| 32 | 
            +
             | 
| 33 | 
            +
            **GitHub homepage:** [Cell2Sentence GitHub](https://github.com/vandijklab/cell2sentence)
         | 
| 34 | 
            +
             | 
| 35 | 
            +
            **Model documentation:** [Cell2Sentence Documentation](https://vandijklab-cell2sentence.readthedocs.io/en/latest/)
         | 
| 36 | 
            +
             | 
| 37 | 
            +
            **Resources:**
         | 
| 38 | 
            +
             | 
| 39 | 
            +
            *   C2S-Scale Paper: [Scaling Large Language Models for Next-Generation Single-Cell Analysis](https://www.biorxiv.org/content/10.1101/2025.04.14.648850v1)
         | 
| 40 | 
            +
            *   HuggingFace C2S Collection: [C2S-Scale Models](https://huggingface.co/collections/vandijklab/c2s-scale-gemma-models-68ed5e4d3b55c8c29682d842)
         | 
| 41 | 
            +
            *   GitHub Repository: [vandijklab/cell2sentence](https://github.com/vandijklab/cell2sentence) (for code, tutorials, and discussions)
         | 
| 42 | 
            +
            *   Google Research Blog Post: [Teaching machines the language of biology](https://research.google/blog/teaching-machines-the-language-of-biology-scaling-large-language-models-for-next-generation-single-cell-analysis/)
         | 
| 43 | 
            +
             | 
| 44 | 
            +
            **Author:** van Dijk Lab (Yale), Google Research, Google DeepMind
         | 
| 45 | 
            +
             | 
| 46 | 
            +
             | 
| 47 | 
            +
            ## Model information
         | 
| 48 | 
            +
             | 
| 49 | 
            +
            This section describes the C2S-Scale model and how to use it.
         | 
| 50 | 
            +
             | 
| 51 | 
            +
            ### Description
         | 
| 52 | 
            +
             | 
| 53 | 
            +
            C2S-Scale-Gemma-27B is a state-of-the-art, open language model built upon the Gemma-2 27B 
         | 
| 54 | 
            +
            architecture and fine-tuned for single-cell biology. Developed through the Cell2Sentence 
         | 
| 55 | 
            +
            (C2S) framework, the model processes and understands single-cell RNA sequencing 
         | 
| 56 | 
            +
            (scRNA-seq) data by treating it as a language. It converts high-dimensional scRNA-seq 
         | 
| 57 | 
            +
            expression data into "cell sentences" - ordered sequences of gene names - enabling a 
         | 
| 58 | 
            +
            wide range of biological analyses.
         | 
| 59 | 
            +
             | 
| 60 | 
            +
            This work is the result of a collaboration between Yale University, Google Research, 
         | 
| 61 | 
            +
            and Google DeepMind to scale up C2S models. The C2S-Scale models were trained on 
         | 
| 62 | 
            +
            Google's TPU v5s, which allowed for a significant increase in model size and 
         | 
| 63 | 
            +
            capability. These models excel at tasks such as cell type prediction, tissue 
         | 
| 64 | 
            +
            classification, and generating biologically meaningful cell representations.
         | 
| 65 | 
            +
             | 
| 66 | 
            +
            **Key Features**
         | 
| 67 | 
            +
             | 
| 68 | 
            +
            *   Versatility: Demonstrates strong performance across a diverse set of single-cell and multi-cell tasks.
         | 
| 69 | 
            +
            *   Scalability: Trained on a massive dataset of over 57 million cells, showcasing the power of scaling LLMs for biological data.
         | 
| 70 | 
            +
            *   Generative Power: Capable of generating realistic single-cell gene expression profiles.
         | 
| 71 | 
            +
            *   Foundation for Fine-tuning: Can serve as a powerful pretrained foundation for specialized, domain-specific single-cell analysis tasks.
         | 
| 72 | 
            +
             | 
| 73 | 
            +
            **Potential Applications**
         | 
| 74 | 
            +
             | 
| 75 | 
            +
            C2S-Scale can be a valuable tool for researchers in the following areas:
         | 
| 76 | 
            +
             | 
| 77 | 
            +
            *   In Silico Experiments: Generate cells under specific conditions or predict perturbational changes to form and test new biological hypotheses.
         | 
| 78 | 
            +
            *   Cell Atlas Annotation: Streamline the process of annotating large-scale single-cell datasets by predicting cell types and tissues.
         | 
| 79 | 
            +
            *   Biomarker Discovery: Analyze gene patterns within cell sentences to identify potential markers for specific cell states or diseases.
         | 
| 80 | 
            +
             | 
| 81 | 
            +
            ### How to use
         | 
| 82 | 
            +
             | 
| 83 | 
            +
            Below are code snippets to help you get started running the model locally on a GPU. 
         | 
| 84 | 
            +
            The model can be used for various tasks, further described in the C2S-Scale paper.
         | 
| 85 | 
            +
             | 
| 86 | 
            +
            #### Formatting prompts for cell type prediction
         | 
| 87 | 
            +
             | 
| 88 | 
            +
            To perform cell type prediction, the model expects a prompt containing the cell sentence followed by a query.
         | 
| 89 | 
            +
             | 
| 90 | 
            +
            ```python
         | 
| 91 | 
            +
            # A "cell sentence" is a space-separated string of gene names
         | 
| 92 | 
            +
            # ordered by expression level, from highest to lowest.
         | 
| 93 | 
            +
            cell_sentence = "MALAT1 TMSB4X B2M EEF1A1 H3F3B ACTB FTL RPL13 ..." # Truncated for example purposes
         | 
| 94 | 
            +
            num_genes = 1000
         | 
| 95 | 
            +
            organism = "Homo sapiens"
         | 
| 96 | 
            +
             | 
| 97 | 
            +
            # Construct the prompt for cell type prediction
         | 
| 98 | 
            +
            prompt = f"""The following is a list of {num_genes} gene names ordered by descending expression level in a {organism} cell. Your task is to give the cell type which this cell belongs to based on its gene expression.
         | 
| 99 | 
            +
            Cell sentence: {cell_sentence}.
         | 
| 100 | 
            +
            The cell type corresponding to these genes is:"""
         | 
| 101 | 
            +
             | 
| 102 | 
            +
            print(prompt)
         | 
| 103 | 
            +
            ```
         | 
| 104 | 
            +
             | 
| 105 | 
            +
            The resulting prompt is in the format expected by the model for this task:
         | 
| 106 | 
            +
            ```none
         | 
| 107 | 
            +
            The following is a list of 1000 gene names ordered by descending expression level in a Homo sapiens cell. Your task is to give the cell type which this cell belongs to based on its gene expression.
         | 
| 108 | 
            +
            Cell sentence: MALAT1 TMSB4X B2M EEF1A1 H3F3B ACTB FTL RPL13 ... .
         | 
| 109 | 
            +
            The cell type corresponding to these genes is:
         | 
| 110 | 
            +
            ```
         | 
| 111 | 
            +
             | 
| 112 | 
            +
            #### Running the model on predictive tasks
         | 
| 113 | 
            +
             | 
| 114 | 
            +
            ```python
         | 
| 115 | 
            +
            # pip install accelerate transformers sentencepiece
         | 
| 116 | 
            +
            from transformers import AutoTokenizer, AutoModelForCausalLM
         | 
| 117 | 
            +
            import torch
         | 
| 118 | 
            +
             | 
| 119 | 
            +
            device = "cuda" if torch.cuda.is_available() else "cpu"
         | 
| 120 | 
            +
             | 
| 121 | 
            +
            # Load model directly from Hugging Face Hub
         | 
| 122 | 
            +
            model_id = "vandijklab/C2S-Scale-Gemma-2-27B"
         | 
| 123 | 
            +
             | 
| 124 | 
            +
            # Load tokenizer; requires sentencepiece to be installed
         | 
| 125 | 
            +
            tokenizer = AutoTokenizer.from_pretrained(model_id)
         | 
| 126 | 
            +
            model = AutoModelForCausalLM.from_pretrained(
         | 
| 127 | 
            +
                model_id,
         | 
| 128 | 
            +
            ).to(device)
         | 
| 129 | 
            +
             | 
| 130 | 
            +
            # Format prompt (see previous section)
         | 
| 131 | 
            +
            cell_sentence = "MALAT1 TMSB4X B2M EEF1A1 H3F3B ACTB FTL RPL13 ..." # Truncated for example, use at least 200 genes for inference
         | 
| 132 | 
            +
            num_genes = 1000
         | 
| 133 | 
            +
            organism = "Homo sapiens"
         | 
| 134 | 
            +
             | 
| 135 | 
            +
            prompt = f"""The following is a list of {num_genes} gene names ordered by descending expression level in a {organism} cell. Your task is to give the cell type which this cell belongs to based on its gene expression.
         | 
| 136 | 
            +
            Cell sentence: {cell_sentence}.
         | 
| 137 | 
            +
            The cell type corresponding to these genes is:"""
         | 
| 138 | 
            +
             | 
| 139 | 
            +
            # Prepare tokenized inputs
         | 
| 140 | 
            +
            input_ids = tokenizer(prompt, return_tensors="pt").to(device)
         | 
| 141 | 
            +
             | 
| 142 | 
            +
            # Generate response
         | 
| 143 | 
            +
            outputs = model.generate(**input_ids, max_new_tokens=20)
         | 
| 144 | 
            +
            response = tokenizer.decode(outputs[0], skip_special_tokens=True)
         | 
| 145 | 
            +
             | 
| 146 | 
            +
            # The predicted cell type will be the text immediately following the prompt
         | 
| 147 | 
            +
            predicted_cell_type = response.split("The cell type corresponding to these genes is:")[1].strip()
         | 
| 148 | 
            +
            print(f"Predicted Cell Type: {predicted_cell_type}")
         | 
| 149 | 
            +
            ```
         | 
| 150 | 
            +
             | 
| 151 | 
            +
            ### Examples
         | 
| 152 | 
            +
             | 
| 153 | 
            +
            See the following Colab notebooks in our GitHub repository for examples of how to use C2S-Scale models:
         | 
| 154 | 
            +
             | 
| 155 | 
            +
            *   To quickly get started with the model for tasks like cell type prediction and generation: [C2S Tutorials](https://github.com/vandijklab/cell2sentence/tree/master/tutorials)
         | 
| 156 | 
            +
             | 
| 157 | 
            +
            ### Model architecture overview
         | 
| 158 | 
            +
             | 
| 159 | 
            +
            *   C2S-Scale is based on the Gemma 2 family of lightweight, state-of-the-art open LLMs, which utilizes a decoder-only transformer architecture.
         | 
| 160 | 
            +
            *   Base Model: Gemma-2 27B.
         | 
| 161 | 
            +
            *   Fine-tuning Data: A comprehensive collection of over 800 datasets from CellxGene and the Human Cell Atlas, totaling over 57 million human and mouse cells.
         | 
| 162 | 
            +
            *   Training Approach: Instruction fine-tuning using the Cell2Sentence framework, which converts scRNA-seq expression data into sequences of gene tokens.
         | 
| 163 | 
            +
             | 
| 164 | 
            +
             | 
| 165 | 
            +
            ### Technical Specifications
         | 
| 166 | 
            +
             | 
| 167 | 
            +
            *   Model type: Decoder-only Transformer (based on Gemma-2)
         | 
| 168 | 
            +
            *   Key publication: [Scaling Large Language Models for Next-Generation Single-Cell Analysis](https://www.biorxiv.org/content/10.1101/2025.04.14.648850v1)
         | 
| 169 | 
            +
             | 
| 170 | 
            +
             | 
| 171 | 
            +
            ### Performance & Validation
         | 
| 172 | 
            +
             | 
| 173 | 
            +
            The performance of C2S-Scale models was validated on a wide range of single-cell and multi-cell 
         | 
| 174 | 
            +
            tasks, including advanced downstream tasks such as cluster captioning, question answering, 
         | 
| 175 | 
            +
            and perturbation prediction. C2S-Scale models demonstrated significant improvements over 
         | 
| 176 | 
            +
            other open and closed-source models, establishing new state-of-the-art benchmarks for LLMs 
         | 
| 177 | 
            +
            in single-cell biology. Please see our preprint for a full breakdown of performance metrics.
         | 
| 178 | 
            +
             | 
| 179 | 
            +
            ### Inputs and outputs
         | 
| 180 | 
            +
             | 
| 181 | 
            +
            *   Input: Text. For best performance, prompts should be structured according to the specific task (e.g., cell type prediction, conditioned generation). Inputs are "cell sentences"—ordered, space-separated lists of gene names.
         | 
| 182 | 
            +
            *   Output: Text. The model generates text as a response, which can be a predicted label (like a cell type or tissue), a full cell sentence, or a natural language abstract.
         | 
| 183 | 
            +
             | 
| 184 | 
            +
            ## Dataset details
         | 
| 185 | 
            +
             | 
| 186 | 
            +
            ### Training dataset
         | 
| 187 | 
            +
             | 
| 188 | 
            +
            **CellxGene and Human Cell Atlas:** The model was trained on a curated collection of over 800 
         | 
| 189 | 
            +
            public scRNA-seq datasets, encompassing more than 57 million cells. This data covers a broad 
         | 
| 190 | 
            +
            range of tissues, cell types, and experimental conditions from both human and mouse, ensuring 
         | 
| 191 | 
            +
            the model learns a robust and generalizable representation of cellular states.
         | 
| 192 | 
            +
             | 
| 193 | 
            +
            ### Evaluation dataset
         | 
| 194 | 
            +
             | 
| 195 | 
            +
            Evaluation was performed using held-out datasets and standardized benchmarks designed to 
         | 
| 196 | 
            +
            test the model's capabilities on the tasks listed above. All evaluation methodologies followed 
         | 
| 197 | 
            +
            established best practices for splitting data to ensure robust and unbiased assessment.
         | 
| 198 | 
            +
             | 
| 199 | 
            +
            ## License
         | 
| 200 | 
            +
             | 
| 201 | 
            +
            The model weights shared on Huggingface are CC-by-4.0.
         | 
| 202 | 
            +
             | 
| 203 | 
            +
            ## Implementation information
         | 
| 204 | 
            +
             | 
| 205 | 
            +
            ### Software
         | 
| 206 | 
            +
             | 
| 207 | 
            +
            The model was trained using [JAX](https://github.com/jax-ml/jax), leveraging Google's TPU v5 
         | 
| 208 | 
            +
            hardware for efficient and large-scale training.
         | 
| 209 | 
            +
             | 
| 210 | 
            +
            ## Use and limitations
         | 
| 211 | 
            +
             | 
| 212 | 
            +
            ### Intended use
         | 
| 213 | 
            +
             | 
| 214 | 
            +
            *   Research in single-cell genomics and computational biology.
         | 
| 215 | 
            +
            *   As a foundational model for fine-tuning on specific biological domains or datasets.
         | 
| 216 | 
            +
            *   To aid in the annotation and interpretation of large-scale scRNA-seq experiments.
         | 
| 217 | 
            +
             | 
| 218 | 
            +
            ### Benefits
         | 
| 219 | 
            +
             | 
| 220 | 
            +
            C2S-Scale provides a powerful, versatile, and scalable tool for single-cell analysis. It offers:
         | 
| 221 | 
            +
            *   State-of-the-art performance on a wide range of scRNA-seq tasks.
         | 
| 222 | 
            +
            *   A unified framework for handling diverse single-cell analysis challenges.
         | 
| 223 | 
            +
            *   A foundation for building more specialized models from private or proprietary data.
         | 
| 224 | 
            +
            *   The ability to perform in silico generation of cellular data to explore biological hypotheses.
         | 
| 225 | 
            +
             | 
| 226 | 
            +
            ### Limitations
         | 
| 227 | 
            +
             | 
| 228 | 
            +
            *   The model is trained on public data and its knowledge is limited to the genes, cell types, and conditions present in that data.
         | 
| 229 | 
            +
            *   Performance on out-of-distribution data (e.g., completely novel cell types or technologies) is not guaranteed and requires validation.
         | 
| 230 | 
            +
            *   Performance of the models on input prompt formats that greatly deviate from training prompt formatting is not guaranteed.
         | 
| 231 | 
            +
             | 
| 232 | 
            +
            ## Citation
         | 
| 233 | 
            +
             | 
| 234 | 
            +
            ```bibtex
         | 
| 235 | 
            +
            @article{Rizvi2025.04.14.648850,
         | 
| 236 | 
            +
            	abstract = {Single-cell RNA sequencing has transformed our understanding of cellular diversity, yet current single-cell foundation models (scFMs) remain limited in their scalability, flexibility across diverse tasks, and ability to natively integrate textual information. In this work, we build upon the Cell2Sentence (C2S) framework, which represents scRNA-seq profiles as textual {\textquotedblleft}cell sentences,{\textquotedblright} to train Large Language Models (LLMs) on a corpus comprising over one billion tokens of transcriptomic data, biological text, and metadata. By scaling model size to 27 billion parameters, we observe consistent improvements in predictive and generative capabilities, as well as the capacity for advanced downstream tasks requiring synthesis of information across multicellular contexts. Through targeted fine-tuning supported by modern reinforcement learning techniques, our approach excels in tasks such as perturbation response prediction, natural language interpretation, and complex biological reasoning. By unifying transcriptomic and textual data at unprecedented scales, this approach not only surpasses both specialized single-cell models and general-purpose LLMs, but also establishes a powerful platform for next-generation single-cell analysis, paving the way for the development of {\textquotedblleft}virtual cells.{\textquotedblright}Competing Interest StatementThe authors have declared no competing interest.},
         | 
| 237 | 
            +
            	author = {Rizvi, Syed Asad and Levine, Daniel and Patel, Aakash and Zhang, Shiyang and Wang, Eric and He, Sizhuang and Zhang, David and Tang, Cerise and Lyu, Zhuoyang and Darji, Rayyan and Li, Chang and Sun, Emily and Jeong, David and Zhao, Lawrence and Kwan, Jennifer and Braun, David and Hafler, Brian and Ishizuka, Jeffrey and Dhodapkar, Rahul M. and Chung, Hattie and Azizi, Shekoofeh and Perozzi, Bryan and van Dijk, David},
         | 
| 238 | 
            +
            	doi = {10.1101/2025.04.14.648850},
         | 
| 239 | 
            +
            	elocation-id = {2025.04.14.648850},
         | 
| 240 | 
            +
            	eprint = {https://www.biorxiv.org/content/early/2025/04/17/2025.04.14.648850.full.pdf},
         | 
| 241 | 
            +
            	journal = {bioRxiv},
         | 
| 242 | 
            +
            	publisher = {Cold Spring Harbor Laboratory},
         | 
| 243 | 
            +
            	title = {Scaling Large Language Models for Next-Generation Single-Cell Analysis},
         | 
| 244 | 
            +
            	url = {https://www.biorxiv.org/content/early/2025/04/17/2025.04.14.648850},
         | 
| 245 | 
            +
            	year = {2025},
         | 
| 246 | 
            +
            	Bdsk-Url-1 = {https://www.biorxiv.org/content/early/2025/04/17/2025.04.14.648850},
         | 
| 247 | 
            +
            	Bdsk-Url-2 = {https://doi.org/10.1101/2025.04.14.648850}}
         | 
| 248 | 
            +
            ```
         | 
| 249 | 
            +
             | 
| 250 | 
            +
            # C2S-Scale Links
         | 
| 251 | 
            +
            - Paper: [Scaling Large Language Models for Next-Generation Single-Cell Analysis](https://www.biorxiv.org/content/10.1101/2025.04.14.648850v1)
         | 
| 252 | 
            +
            - Google Research Blog Post: [Teaching machines the language of biology: Scaling large language models for next-generation single-cell analysis](https://research.google/blog/teaching-machines-the-language-of-biology-scaling-large-language-models-for-next-generation-single-cell-analysis/)
         | 
| 253 | 
            +
            - GitHub: https://github.com/vandijklab/cell2sentence (Note: Codebase has CC BY-NC-ND 4.0 license. Only weights shared on Hugging Face are CC-by-4.0)
         | 
| 254 | 
            +
             | 
| 255 | 
            +
            # Gemma-2 Links
         | 
| 256 | 
            +
            - HuggingFace: https://huggingface.co/google/gemma-2-27b
         | 
| 257 | 
            +
            - Gemma-2 Blog Post: [Gemma explained: What's new in Gemma 2](https://developers.googleblog.com/en/gemma-explained-new-in-gemma-2/)
         | 
| 258 | 
            +
            - Technical report: https://storage.googleapis.com/deepmind-media/gemma/gemma-2-report.pdf
         | 
