Instructions to use Data-Selection/PDS-160M with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Transformers
How to use Data-Selection/PDS-160M with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("text-generation", model="Data-Selection/PDS-160M")# Load model directly from transformers import AutoTokenizer, AutoModelForCausalLM tokenizer = AutoTokenizer.from_pretrained("Data-Selection/PDS-160M") model = AutoModelForCausalLM.from_pretrained("Data-Selection/PDS-160M") - Notebooks
- Google Colab
- Kaggle
- Local Apps
- vLLM
How to use Data-Selection/PDS-160M with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "Data-Selection/PDS-160M" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "Data-Selection/PDS-160M", "prompt": "Once upon a time,", "max_tokens": 512, "temperature": 0.5 }'Use Docker
docker model run hf.co/Data-Selection/PDS-160M
- SGLang
How to use Data-Selection/PDS-160M 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 "Data-Selection/PDS-160M" \ --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": "Data-Selection/PDS-160M", "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 "Data-Selection/PDS-160M" \ --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": "Data-Selection/PDS-160M", "prompt": "Once upon a time,", "max_tokens": 512, "temperature": 0.5 }' - Docker Model Runner
How to use Data-Selection/PDS-160M with Docker Model Runner:
docker model run hf.co/Data-Selection/PDS-160M
Update README.md
Browse files
README.md
CHANGED
|
@@ -8,4 +8,47 @@ pipeline_tag: text-generation
|
|
| 8 |
library_name: transformers
|
| 9 |
---
|
| 10 |
|
| 11 |
-
## PDS-160M
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 8 |
library_name: transformers
|
| 9 |
---
|
| 10 |
|
| 11 |
+
## PDS-160M
|
| 12 |
+
|
| 13 |
+
[paper](https://arxiv.org/abs/2410.07064) | [code](https://github.com/microsoft/LMOps/tree/main/data_selection)
|
| 14 |
+
|
| 15 |
+
**PDS-160M** is a 160M model with [Mistral](https://arxiv.org/abs/2310.06825) achitecture pre-trained from scratch on the data selected from the CC split of [Redpajama](https://github.com/togethercomputer/RedPajama-Data), using the PDS framework.
|
| 16 |
+
|
| 17 |
+
The PDS framework is based on the [Pontryagin's maximum principle](https://en.wikipedia.org/wiki/Pontryagin%27s_maximum_principle#:~:text=Pontryagin's%20maximum%20principle%20is%20used,the%20state%20or%20input%20controls.) for optimal pre-training data selection, which not only enjoy strong theoretical support but is also scalable for training large language models.
|
| 18 |
+
|
| 19 |
+
Please refer to our [paper](https://arxiv.org/abs/2410.07064) for more details.
|
| 20 |
+
|
| 21 |
+
### Overview of the theory:
|
| 22 |
+
|
| 23 |
+
<p align='left'>
|
| 24 |
+
<img src="https://cdn-uploads.huggingface.co/production/uploads/624ac662102fcdff87be51b9/Hdw83Vsb305GRlsqB7c34.png" width="700">
|
| 25 |
+
</p>
|
| 26 |
+
|
| 27 |
+
### Overview of the PDS framework:
|
| 28 |
+
|
| 29 |
+
<p align='left'>
|
| 30 |
+
<img src="https://cdn-uploads.huggingface.co/production/uploads/624ac662102fcdff87be51b9/YPwluLyZGK7DACH1WqDUN.png" width="700">
|
| 31 |
+
</p>
|
| 32 |
+
|
| 33 |
+
### Evaluation
|
| 34 |
+
|
| 35 |
+
PDS-selected data improves the performance of language models pre-trained from scratch and saves pre-training comptation. The improvement scales up to large model sizes.
|
| 36 |
+
|
| 37 |
+
<p align='left'>
|
| 38 |
+
<img src="https://cdn-uploads.huggingface.co/production/uploads/624ac662102fcdff87be51b9/6undIr37d10qD73TDiPDK.png" width="600">
|
| 39 |
+
</p>
|
| 40 |
+
|
| 41 |
+
### Baseline
|
| 42 |
+
|
| 43 |
+
[Conventional Pre-training](https://huggingface.co/Data-Selection/BSL-160M)
|
| 44 |
+
|
| 45 |
+
### Citation
|
| 46 |
+
|
| 47 |
+
```bibtex
|
| 48 |
+
@article{gu2024data,
|
| 49 |
+
title={Data Selection via Optimal Control for Language Models},
|
| 50 |
+
author={Gu, Yuxian and Dong, Li and Wang, Hongning and Hao, Yaru and Dong, Qingxiu and Wei, Furu and Huang, Minlie},
|
| 51 |
+
journal={arXiv preprint arXiv:2410.07064},
|
| 52 |
+
year={2024}
|
| 53 |
+
}
|
| 54 |
+
```
|