Text Generation
Transformers
Safetensors
English
llama
small
tiny
story
tinystories
roneneldan
cpu
free
open-source
text-generation-inference
Instructions to use SupraLabs/StorySupra-10M with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Transformers
How to use SupraLabs/StorySupra-10M with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("text-generation", model="SupraLabs/StorySupra-10M")# Load model directly from transformers import AutoTokenizer, AutoModelForCausalLM tokenizer = AutoTokenizer.from_pretrained("SupraLabs/StorySupra-10M") model = AutoModelForCausalLM.from_pretrained("SupraLabs/StorySupra-10M") - Notebooks
- Google Colab
- Kaggle
- Local Apps
- vLLM
How to use SupraLabs/StorySupra-10M with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "SupraLabs/StorySupra-10M" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "SupraLabs/StorySupra-10M", "prompt": "Once upon a time,", "max_tokens": 512, "temperature": 0.5 }'Use Docker
docker model run hf.co/SupraLabs/StorySupra-10M
- SGLang
How to use SupraLabs/StorySupra-10M 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 "SupraLabs/StorySupra-10M" \ --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": "SupraLabs/StorySupra-10M", "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 "SupraLabs/StorySupra-10M" \ --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": "SupraLabs/StorySupra-10M", "prompt": "Once upon a time,", "max_tokens": 512, "temperature": 0.5 }' - Docker Model Runner
How to use SupraLabs/StorySupra-10M with Docker Model Runner:
docker model run hf.co/SupraLabs/StorySupra-10M
| import torch | |
| from datasets import load_dataset | |
| from tokenizers import Tokenizer, models, trainers, pre_tokenizers | |
| from transformers import LlamaConfig, LlamaForCausalLM, Trainer, TrainingArguments, DataCollatorForLanguageModeling | |
| dataset = load_dataset("roneneldan/TinyStories", split="train[:200000]") | |
| def train_tokenizer(dataset): | |
| tokenizer = Tokenizer(models.BPE(unk_token="<unk>")) | |
| tokenizer.pre_tokenizer = pre_tokenizers.Whitespace() | |
| trainer = trainers.BpeTrainer( | |
| vocab_size=8192, | |
| special_tokens=["<s>", "<pad>", "</s>", "<unk>", "<mask>"] | |
| ) | |
| def batch_iterator(): | |
| for i in range(0, len(dataset), 1000): | |
| yield dataset[i : i + 1000]["text"] | |
| tokenizer.train_from_iterator(batch_iterator(), trainer=trainer) | |
| from transformers import PreTrainedTokenizerFast | |
| return PreTrainedTokenizerFast( | |
| tokenizer_object=tokenizer, | |
| bos_token="<s>", | |
| eos_token="</s>", | |
| unk_token="<unk>", | |
| pad_token="<pad>" | |
| ) | |
| tokenizer = train_tokenizer(dataset) | |
| def tokenize_function(examples): | |
| return tokenizer(examples["text"], truncation=True, max_length=256) | |
| tokenized_dataset = dataset.map(tokenize_function, batched=True, remove_columns=["text"]) | |
| config = LlamaConfig( | |
| vocab_size=8192, | |
| hidden_size=256, | |
| intermediate_size=1024, | |
| num_hidden_layers=8, | |
| num_attention_heads=8, | |
| max_position_embeddings=256, | |
| pad_token_id=tokenizer.pad_token_id, | |
| bos_token_id=tokenizer.bos_token_id, | |
| eos_token_id=tokenizer.eos_token_id, | |
| ) | |
| model = LlamaForCausalLM(config) | |
| print(f"Model parameters: {model.num_parameters():,}") | |
| training_args = TrainingArguments( | |
| output_dir="./StorySupra-10M", | |
| per_device_train_batch_size=32, | |
| num_train_epochs=3, | |
| save_steps=500, | |
| logging_steps=100, | |
| learning_rate=5e-4, | |
| weight_decay=0.01, | |
| fp16=True, | |
| push_to_hub=False, | |
| report_to="none", | |
| lr_scheduler_type="cosine" | |
| ) | |
| data_collator = DataCollatorForLanguageModeling(tokenizer=tokenizer, mlm=False) | |
| trainer = Trainer( | |
| model=model, | |
| args=training_args, | |
| train_dataset=tokenized_dataset, | |
| data_collator=data_collator, | |
| ) | |
| trainer.train() | |
| def generate_story(prompt): | |
| inputs = tokenizer(prompt, return_tensors="pt").to("cuda") | |
| model.to("cuda") | |
| outputs = model.generate(**inputs, max_length=100, do_sample=True, temperature=0.55, top_k=25, top_p=0.85, repetition_penalty=1.1) | |
| print(tokenizer.decode(outputs[0], skip_special_tokens=True)) | |
| generate_story("Once upon a time, a small bird") | |
| trainer.save_model("./StorySupra-10M") | |
| tokenizer.save_pretrained("./StorySupra-10M") |