Text Generation
Transformers
PyTorch
English
experimental
research
bit-level
transformer
reversible
safety
telemetry
language-modeling
Instructions to use WCNegentropy/BitTransformerLM with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Transformers
How to use WCNegentropy/BitTransformerLM with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("text-generation", model="WCNegentropy/BitTransformerLM")# Load model directly from transformers import AutoModel model = AutoModel.from_pretrained("WCNegentropy/BitTransformerLM", dtype="auto") - Notebooks
- Google Colab
- Kaggle
- Local Apps
- vLLM
How to use WCNegentropy/BitTransformerLM with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "WCNegentropy/BitTransformerLM" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "WCNegentropy/BitTransformerLM", "prompt": "Once upon a time,", "max_tokens": 512, "temperature": 0.5 }'Use Docker
docker model run hf.co/WCNegentropy/BitTransformerLM
- SGLang
How to use WCNegentropy/BitTransformerLM 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 "WCNegentropy/BitTransformerLM" \ --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": "WCNegentropy/BitTransformerLM", "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 "WCNegentropy/BitTransformerLM" \ --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": "WCNegentropy/BitTransformerLM", "prompt": "Once upon a time,", "max_tokens": 512, "temperature": 0.5 }' - Docker Model Runner
How to use WCNegentropy/BitTransformerLM with Docker Model Runner:
docker model run hf.co/WCNegentropy/BitTransformerLM
| import pathlib | |
| import torch | |
| from bit_transformer import BitTransformerLM | |
| DATA_PATH = pathlib.Path('full_bits.pt') | |
| class BitSeq(torch.utils.data.IterableDataset): | |
| def __init__(self, path: str | pathlib.Path = DATA_PATH, seq: int = 2048) -> None: | |
| self.bits = torch.load(path, mmap=True) | |
| self.seq = seq | |
| def __len__(self) -> int: | |
| return (self.bits.numel() // self.seq) - 1 | |
| def __iter__(self): | |
| N = (self.bits.numel() // self.seq) - 1 | |
| for i in range(N): | |
| s = i * self.seq | |
| yield ( | |
| self.bits[s:s+self.seq].long(), | |
| self.bits[s+1:s+self.seq+1].long(), | |
| ) | |
| def main() -> None: | |
| dl = torch.utils.data.DataLoader( | |
| BitSeq(DATA_PATH, seq=2048), | |
| batch_size=8, | |
| num_workers=0, | |
| pin_memory=False, | |
| ) | |
| model = BitTransformerLM( | |
| d_model=64, | |
| nhead=4, | |
| num_layers=2, | |
| dim_feedforward=256, | |
| max_seq_len=2048, | |
| reversible=True, | |
| use_autocast=True, | |
| ) | |
| loss_fn = torch.nn.CrossEntropyLoss() | |
| xb, yb = next(iter(dl)) | |
| logits, _ = model(xb) | |
| pred = logits.reshape(-1, 2) | |
| target = yb.reshape(-1) | |
| loss = loss_fn(pred, target) | |
| print('Batch loss:', float(loss)) | |
| if __name__ == '__main__': | |
| main() | |