|
--- |
|
pipeline_tag: text-generation |
|
license: apache-2.0 |
|
tags: |
|
- text generation |
|
- Deci AI |
|
- DeciCoder |
|
programming_language: |
|
- Java |
|
- JavaScript |
|
- Python |
|
metrics: |
|
- code_eval |
|
inference: true |
|
widget: |
|
- text: 'def print_hello_world():' |
|
example_title: Hello world |
|
group: Python |
|
model-index: |
|
- name: DeciCoder-1b |
|
results: |
|
- task: |
|
type: text-generation |
|
dataset: |
|
type: nuprl/MultiPL-E |
|
name: MultiPL-HumanEval (Python) |
|
metrics: |
|
- name: pass@1 |
|
type: pass@1 |
|
value: 0.191 |
|
verified: false |
|
- task: |
|
type: text-generation |
|
dataset: |
|
type: nuprl/MultiPL-E |
|
name: MultiPL-HumanEval (JavaScript) |
|
metrics: |
|
- name: pass@1 |
|
type: pass@1 |
|
value: 0.184 |
|
verified: false |
|
- task: |
|
type: text-generation |
|
dataset: |
|
type: nuprl/MultiPL-E |
|
name: MultiPL-HumanEval (Java) |
|
metrics: |
|
- name: pass@1 |
|
type: pass@1 |
|
value: 0.166 |
|
verified: false |
|
datasets: |
|
- bigcode/starcoderdata |
|
--- |
|
|
|
# Model Card for DeciCoder 1B |
|
|
|
DeciCoder 1B is a 1 billion parameter decoder-only code completion model |
|
trained on the Python, Java, and Javascript subsets of [Starcoder Training Dataset](https://huggingface.co/datasets/bigcode/starcoderdata). |
|
The model uses Grouped Query Attention and has a context window of 2048 |
|
tokens. It was trained using a Fill-in-the-Middle training objective. The model's |
|
architecture was generated by Deci's proprietary Neural Architecture |
|
Search-based technology, AutoNAC. |
|
|
|
## Model Details |
|
|
|
- **Developed by:** Deci |
|
- **Model type:** DeciCoder is an auto-regressive language model based on the transformer decoder architecture, using Grouped Query Attention. |
|
- **Language(s):** Python, Java, JavaScript |
|
- **License:** Model checkpoints are licensed under the [Apache 2.0](https://www.apache.org/licenses/LICENSE-2.0) |
|
|
|
## Model Architecture |
|
|
|
| Parameters | Layers | Heads | Sequence Length | GQA num_key_value_heads | Hidden Size | |
|
|:----------|:----------|:----------|:----------|:----------|:----------| |
|
| 1.1B | 20 | 32 | 2048 | 4 | 2048 | | |
|
|
|
|
|
- **Decoder layer:** Grouped Query Attention [Ainslie et al., 2023](https://arxiv.org/abs/2305.13245) |
|
- **Position Embeddings:** Rotary Position Embeddings [Su et al., 2021](https://arxiv.org/abs/2104.09864) |
|
|
|
## Uses |
|
|
|
The model is intended to do single/multiline code completion from a |
|
context window of up to 2048k tokens. It is *not* an instruction model |
|
and commands like \"Write a function that computes the absolute value of |
|
an integer,\" won't yield the desired results. A more effective approach |
|
is to frame instructions in the style of source code comments (e.g. \# |
|
this function calculates the absolute value of an integer) or to present |
|
a function signature and docstring, enabling the model to complete the |
|
function's body. |
|
|
|
### How to Use |
|
|
|
```bibtex |
|
# pip install -q transformers |
|
from transformers import AutoModelForCausalLM, AutoTokenizer |
|
|
|
checkpoint = "Deci/DeciCoder-1b" |
|
device = "cuda" # for GPU usage or "cpu" for CPU usage |
|
|
|
tokenizer = AutoTokenizer.from_pretrained(checkpoint) |
|
model = AutoModelForCausalLM.from_pretrained(checkpoint, trust_remote_code=True).to(device) |
|
|
|
inputs = tokenizer.encode("def print_hello_world():", return_tensors="pt").to(device) |
|
outputs = model.generate(inputs, max_new_tokens=100) |
|
print(tokenizer.decode(outputs[0])) |
|
``` |
|
|
|
### Attribution |
|
|
|
DeciCoder was trained on StarCoder Training Dataset, filtered for |
|
Python, Java, and Javascript code. For additional information, please |
|
refer to [https://huggingface.co/datasets/bigcode/starcoderdata](https://huggingface.co/datasets/bigcode/starcoderdata). |
|
|
|
### Limitations |
|
|
|
The model has undergone training with source code from Python, Java, and |
|
JavaScript. While the primary language in the source is English, it does |
|
contain other languages. Therefore, the model can produce code snippets |
|
given some context. However, there\'s no assurance that the resulting |
|
code will function as expected. It might be suboptimal, contain bugs, or |
|
even exploits. |
|
|
|
## Training Details |
|
|
|
### Training Data |
|
|
|
DeciCoder was trained on the Python, Java, and Javascript subsets of [Starcoder Training Dataset](https://huggingface.co/datasets/bigcode/starcoderdata) |
|
|
|
|
|
### Training Procedure |
|
|
|
- **Warm-Up Steps**: 9000 |
|
- **Total Training Steps**: 284k |
|
- **Total Tokens**: 446B |
|
- **Global Batch Size**: 768 |
|
- **Optimizer**: AdamW |
|
- **Optimizer Parameters**: beta1=0.9, beta2=0.95 |
|
- **Weight Decay**: 0.1 |
|
- **Learning Rate**: 4e-4 |
|
- **Learning Rate Schedule**: cosine |
|
|
|
## Evaluation |
|
|
|
Below are DeciCoder's pass@1 on MultiPL HumanEval scores |
|
|
|
| Python | JavaScript | Java | |
|
|:----------|:----------|:----------| |
|
| 19.1% | 18.4% | 16.6% | |
|
|
|
|
|
### Runtime Benchmarks |
|
|
|
|Inference Tool/Hardware | A10 (tokens/sec) |A100 (tokens/sec) | |
|
|:----------|:----------|:----------| |
|
| PyTorch | 1,364.2 | 3,244.4 | |
|
| Infery LLM | 3,889.3 | 11,676.8 | |
|
|
|
- Throughput (tokens/sec) - Measured with optimal batch size per hardware - A10 on BS 128, A100 on BS 512 |
|
|
|
## Documentation |
|
|
|
- [Notebook](https://colab.research.google.com/drive/1JCxvBsWCZKHfIcHSMVf7GZCs3ClMQPjs) |
|
- Blog post: [Introducing DeciCoder: The New Gold Standard in Efficient and Accurate Code Generation](https://deci.ai/blog/decicoder-efficient-and-accurate-code-generation-llm/) |
|
- Questions:Feel free to contact us via our [Discord Community!](https://discord.com/invite/p9ecgRhDR8/) |
|
|
|
## How to Cite |
|
|
|
Please cite this model using this format. |
|
|
|
```bibtex |
|
@misc{DeciFoundationModels, |
|
title = {DeciCoder}, |
|
author = {DeciAI Research Team}, |
|
year = {2023} |
|
url={[https://huggingface.co/deci/decicoder-1b](https://huggingface.co/deci/decicoder-1b)}, |
|
} |
|
``` |