Instructions to use bytecodehr/qwen3-coder-30b-rails with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Transformers
How to use bytecodehr/qwen3-coder-30b-rails with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("text-generation", model="bytecodehr/qwen3-coder-30b-rails") messages = [ {"role": "user", "content": "Who are you?"}, ] pipe(messages)# Load model directly from transformers import AutoModel model = AutoModel.from_pretrained("bytecodehr/qwen3-coder-30b-rails", dtype="auto") - llama-cpp-python
How to use bytecodehr/qwen3-coder-30b-rails with llama-cpp-python:
# !pip install llama-cpp-python from llama_cpp import Llama llm = Llama.from_pretrained( repo_id="bytecodehr/qwen3-coder-30b-rails", filename="qwen3-coder-30b-rails-Q4_K_M.gguf", )
llm.create_chat_completion( messages = [ { "role": "user", "content": "What is the capital of France?" } ] ) - Notebooks
- Google Colab
- Kaggle
- Local Apps
- llama.cpp
How to use bytecodehr/qwen3-coder-30b-rails with llama.cpp:
Install from brew
brew install llama.cpp # Start a local OpenAI-compatible server with a web UI: llama-server -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M # Run inference directly in the terminal: llama-cli -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M
Install from WinGet (Windows)
winget install llama.cpp # Start a local OpenAI-compatible server with a web UI: llama-server -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M # Run inference directly in the terminal: llama-cli -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M
Use pre-built binary
# Download pre-built binary from: # https://github.com/ggerganov/llama.cpp/releases # Start a local OpenAI-compatible server with a web UI: ./llama-server -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M # Run inference directly in the terminal: ./llama-cli -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M
Build from source code
git clone https://github.com/ggerganov/llama.cpp.git cd llama.cpp cmake -B build cmake --build build -j --target llama-server llama-cli # Start a local OpenAI-compatible server with a web UI: ./build/bin/llama-server -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M # Run inference directly in the terminal: ./build/bin/llama-cli -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M
Use Docker
docker model run hf.co/bytecodehr/qwen3-coder-30b-rails:Q4_K_M
- LM Studio
- Jan
- vLLM
How to use bytecodehr/qwen3-coder-30b-rails with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "bytecodehr/qwen3-coder-30b-rails" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "bytecodehr/qwen3-coder-30b-rails", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'Use Docker
docker model run hf.co/bytecodehr/qwen3-coder-30b-rails:Q4_K_M
- SGLang
How to use bytecodehr/qwen3-coder-30b-rails 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 "bytecodehr/qwen3-coder-30b-rails" \ --host 0.0.0.0 \ --port 30000 # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:30000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "bytecodehr/qwen3-coder-30b-rails", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'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 "bytecodehr/qwen3-coder-30b-rails" \ --host 0.0.0.0 \ --port 30000 # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:30000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "bytecodehr/qwen3-coder-30b-rails", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }' - Ollama
How to use bytecodehr/qwen3-coder-30b-rails with Ollama:
ollama run hf.co/bytecodehr/qwen3-coder-30b-rails:Q4_K_M
- Unsloth Studio new
How to use bytecodehr/qwen3-coder-30b-rails with Unsloth Studio:
Install Unsloth Studio (macOS, Linux, WSL)
curl -fsSL https://unsloth.ai/install.sh | sh # Run unsloth studio unsloth studio -H 0.0.0.0 -p 8888 # Then open http://localhost:8888 in your browser # Search for bytecodehr/qwen3-coder-30b-rails to start chatting
Install Unsloth Studio (Windows)
irm https://unsloth.ai/install.ps1 | iex # Run unsloth studio unsloth studio -H 0.0.0.0 -p 8888 # Then open http://localhost:8888 in your browser # Search for bytecodehr/qwen3-coder-30b-rails to start chatting
Using HuggingFace Spaces for Unsloth
# No setup required # Open https://huggingface.co/spaces/unsloth/studio in your browser # Search for bytecodehr/qwen3-coder-30b-rails to start chatting
- Pi new
How to use bytecodehr/qwen3-coder-30b-rails with Pi:
Start the llama.cpp server
# Install llama.cpp: brew install llama.cpp # Start a local OpenAI-compatible server: llama-server -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M
Configure the model in Pi
# Install Pi: npm install -g @mariozechner/pi-coding-agent # Add to ~/.pi/agent/models.json: { "providers": { "llama-cpp": { "baseUrl": "http://localhost:8080/v1", "api": "openai-completions", "apiKey": "none", "models": [ { "id": "bytecodehr/qwen3-coder-30b-rails:Q4_K_M" } ] } } }Run Pi
# Start Pi in your project directory: pi
- Hermes Agent new
How to use bytecodehr/qwen3-coder-30b-rails with Hermes Agent:
Start the llama.cpp server
# Install llama.cpp: brew install llama.cpp # Start a local OpenAI-compatible server: llama-server -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M
Configure Hermes
# Install Hermes: curl -fsSL https://hermes-agent.nousresearch.com/install.sh | bash hermes setup # Point Hermes at the local server: hermes config set model.provider custom hermes config set model.base_url http://127.0.0.1:8080/v1 hermes config set model.default bytecodehr/qwen3-coder-30b-rails:Q4_K_M
Run Hermes
hermes
- Docker Model Runner
How to use bytecodehr/qwen3-coder-30b-rails with Docker Model Runner:
docker model run hf.co/bytecodehr/qwen3-coder-30b-rails:Q4_K_M
- Lemonade
How to use bytecodehr/qwen3-coder-30b-rails with Lemonade:
Pull the model
# Download Lemonade from https://lemonade-server.ai/ lemonade pull bytecodehr/qwen3-coder-30b-rails:Q4_K_M
Run and chat with the model
lemonade run user.qwen3-coder-30b-rails-Q4_K_M
List all available models
lemonade list
Install from WinGet (Windows)
winget install llama.cpp
# Start a local OpenAI-compatible server with a web UI:
llama-server -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M# Run inference directly in the terminal:
llama-cli -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_MUse pre-built binary
# Download pre-built binary from:
# https://github.com/ggerganov/llama.cpp/releases# Start a local OpenAI-compatible server with a web UI:
./llama-server -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M# Run inference directly in the terminal:
./llama-cli -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_MBuild from source code
git clone https://github.com/ggerganov/llama.cpp.git
cd llama.cpp
cmake -B build
cmake --build build -j --target llama-server llama-cli# Start a local OpenAI-compatible server with a web UI:
./build/bin/llama-server -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M# Run inference directly in the terminal:
./build/bin/llama-cli -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_MUse Docker
docker model run hf.co/bytecodehr/qwen3-coder-30b-rails:Q4_K_Mqwen3-coder-30b-rails
A 31B parameter Mixture-of-Experts model fine-tuned for Ruby on Rails code generation. Trained on 111,000 samples extracted from our own internal Rails projects.
Built by Bytecode.
Model Details
| Property | Value |
|---|---|
| Base model | Qwen3-Coder-30B-A3B-Instruct |
| Architecture | Qwen3 MoE (31B total, 3B active) |
| Training method | QLoRA (rank 16) via Unsloth |
| Training data | 111K samples from internal Rails projects |
| Training cost | ~$32 (A100 80GB, ~26 hours) |
| Quantization | GGUF Q4_K_M (18.6 GB), Q5_K_M (21.7 GB) |
What it does
This model writes idiomatic Ruby on Rails code following specific conventions:
- Devise authentication
- Namespaced concerns instead of service objects
- Sidekiq instead of Solid Queue
- State-as-records instead of boolean flags
- DaisyUI drawer layouts instead of ActiveAdmin
It generates code that follows these patterns without prompt engineering โ the conventions are baked into the weights.
Usage with Ollama
# Download and run
ollama run bytecodehr/qwen3-coder-30b-rails
# Example prompt
ollama run bytecodehr/qwen3-coder-30b-rails "Write a Rails controller for managing user subscriptions with state transitions"
Memory requirements
| Format | GGUF Size | Min RAM | Recommended |
|---|---|---|---|
| Q5_K_M | 21.7 GB | 24 GB | 32 GB |
| Q4_K_M | 18.6 GB | 20 GB | 24 GB |
Rule of thumb: GGUF file size + 2โ4 GB for KV cache and overhead.
Training
Trained with LoRA (rank 16, alpha 16) on attention projection layers (q_proj, k_proj, v_proj, o_proj, gate_proj, up_proj, down_proj). Only 0.78% of parameters were trained.
The dataset pipeline:
- Extracted code from our internal Rails projects
- 15-step cleaning and deduplication pipeline
- 111K final training samples
- Includes 29 contrastive pairs (wrong way vs right way)
- Source diversity cap at 20% per repository
Full details in our blog posts:
Why Ruby for LLMs?
Ruby uses 42โ45% fewer tokens than TypeScript across every major LLM tokenizer. That means more code fits in the context window, generations are faster, and costs are lower. Read our analysis: Why Ruby Is the Better Language for LLM-Powered Development.
Other models
- bytecodehr/qwen3-8b-rails โ 8B dense model, runs on laptops (5 GB)
- bytecodehr/qwen2.5-coder-7b-rails โ 7B LoRA adapter
- bytecodehr/qwen2.5-coder-3b-rails โ 3B LoRA adapter
- Downloads last month
- 29
4-bit
5-bit
Model tree for bytecodehr/qwen3-coder-30b-rails
Base model
Qwen/Qwen3-Coder-30B-A3B-Instruct
Install from brew
# Start a local OpenAI-compatible server with a web UI: llama-server -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M# Run inference directly in the terminal: llama-cli -hf bytecodehr/qwen3-coder-30b-rails:Q4_K_M