Text Generation
Transformers
PyTorch
English
gpt_bigcode
HumanEval
StarCoder
Eval Results (legacy)
text-generation-inference
Instructions to use jinaai/starcoder-1b-textbook with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Transformers
How to use jinaai/starcoder-1b-textbook with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("text-generation", model="jinaai/starcoder-1b-textbook")# Load model directly from transformers import AutoTokenizer, AutoModelForCausalLM tokenizer = AutoTokenizer.from_pretrained("jinaai/starcoder-1b-textbook") model = AutoModelForCausalLM.from_pretrained("jinaai/starcoder-1b-textbook") - Notebooks
- Google Colab
- Kaggle
- Local Apps
- vLLM
How to use jinaai/starcoder-1b-textbook with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "jinaai/starcoder-1b-textbook" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "jinaai/starcoder-1b-textbook", "prompt": "Once upon a time,", "max_tokens": 512, "temperature": 0.5 }'Use Docker
docker model run hf.co/jinaai/starcoder-1b-textbook
- SGLang
How to use jinaai/starcoder-1b-textbook with SGLang:
Install from pip and serve model
# Install SGLang from pip: pip install sglang # Start the SGLang server: python3 -m sglang.launch_server \ --model-path "jinaai/starcoder-1b-textbook" \ --host 0.0.0.0 \ --port 30000 # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:30000/v1/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "jinaai/starcoder-1b-textbook", "prompt": "Once upon a time,", "max_tokens": 512, "temperature": 0.5 }'Use Docker images
docker run --gpus all \ --shm-size 32g \ -p 30000:30000 \ -v ~/.cache/huggingface:/root/.cache/huggingface \ --env "HF_TOKEN=<secret>" \ --ipc=host \ lmsysorg/sglang:latest \ python3 -m sglang.launch_server \ --model-path "jinaai/starcoder-1b-textbook" \ --host 0.0.0.0 \ --port 30000 # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:30000/v1/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "jinaai/starcoder-1b-textbook", "prompt": "Once upon a time,", "max_tokens": 512, "temperature": 0.5 }' - Docker Model Runner
How to use jinaai/starcoder-1b-textbook with Docker Model Runner:
docker model run hf.co/jinaai/starcoder-1b-textbook
Commit ·
400c001
1
Parent(s): a7b6c41
add usage example
Browse files
README.md
CHANGED
|
@@ -35,6 +35,40 @@ The results (on the human eval benchmark) are on par with other open-source mode
|
|
| 35 |
|
| 36 |
It still underperforms compared to other models like CodeLLama (53%) chat gpt 4 (82) or wizard coder (73.2), but these model are more than 30 times bigger.
|
| 37 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 38 |
## Finetuning details
|
| 39 |
|
| 40 |
We did full parameter fine-tuning and used a Nvidia a40 for 12 hours using a batch size of 128 and a micro-batch size of 8.
|
|
|
|
| 35 |
|
| 36 |
It still underperforms compared to other models like CodeLLama (53%) chat gpt 4 (82) or wizard coder (73.2), but these model are more than 30 times bigger.
|
| 37 |
|
| 38 |
+
## Usage
|
| 39 |
+
You can download and use the model like so:
|
| 40 |
+
```python
|
| 41 |
+
from transformers import AutoModelForCausalLM, AutoTokenizer
|
| 42 |
+
|
| 43 |
+
model = AutoModelForCausalLM.from_pretrained(
|
| 44 |
+
"jinaai/starcoder-1b-textbook", device_map='auto'
|
| 45 |
+
)
|
| 46 |
+
|
| 47 |
+
tokenizer = AutoTokenizer.from_pretrained("jinaai/starcoder-1b-textbook")
|
| 48 |
+
|
| 49 |
+
prompt = '''
|
| 50 |
+
def unique(l: list):
|
| 51 |
+
"""Return sorted unique elements in a list
|
| 52 |
+
>>> unique([5, 3, 5, 2, 3, 3, 9, 0, 123])
|
| 53 |
+
[0, 2, 3, 5, 9, 123]
|
| 54 |
+
"""
|
| 55 |
+
'''
|
| 56 |
+
|
| 57 |
+
inputs = tokenizer(prompt.rstrip(), return_tensors="pt").to("cuda")
|
| 58 |
+
|
| 59 |
+
generation_output = model.generate(
|
| 60 |
+
**inputs,
|
| 61 |
+
max_new_tokens=128,
|
| 62 |
+
eos_token_id=tokenizer.eos_token_id,
|
| 63 |
+
return_dict_in_generate=True,
|
| 64 |
+
)
|
| 65 |
+
|
| 66 |
+
s = generation_output.sequences[0]
|
| 67 |
+
output = tokenizer.decode(s, skip_special_tokens=True)
|
| 68 |
+
|
| 69 |
+
print(output)
|
| 70 |
+
```
|
| 71 |
+
|
| 72 |
## Finetuning details
|
| 73 |
|
| 74 |
We did full parameter fine-tuning and used a Nvidia a40 for 12 hours using a batch size of 128 and a micro-batch size of 8.
|