Skip to content

srampal/semantic-router

Β 
Β 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

vLLM Semantic Router

Documentation Hugging Face License Crates.io Test And Build

πŸ“š Complete Documentation | πŸš€ Quick Start | πŸ“£ Blog | πŸ“– Publications

code

Innovations ✨

architecture

Intelligent Routing 🧠

Auto-Reasoning and Auto-Selection of Models

An Mixture-of-Models (MoM) router that intelligently directs OpenAI API requests to the most suitable models from a defined pool based on Semantic Understanding of the request's intent (Complexity, Task, Tools).

This is achieved using BERT classification. Conceptually similar to Mixture-of-Experts (MoE) which lives within a model, this system selects the best entire model for the nature of the task.

As such, the overall inference accuracy is improved by using a pool of models that are better suited for different types of tasks:

Model Accuracy

The screenshot below shows the LLM Router dashboard in Grafana.

LLM Router Dashboard

The router is implemented in two ways:

  • Golang (with Rust FFI based on the candle rust ML framework)
  • Python Benchmarking will be conducted to determine the best implementation.

Auto-Selection of Tools

Select the tools to use based on the prompt, avoiding the use of tools that are not relevant to the prompt so as to reduce the number of prompt tokens and improve tool selection accuracy by the LLM.

Category-Specific System Prompts

Automatically inject specialized system prompts based on query classification, ensuring optimal model behavior for different domains (math, coding, business, etc.) without manual prompt engineering.

Enterprise Security πŸ”’

PII detection

Detect PII in the prompt, avoiding sending PII to the LLM so as to protect the privacy of the user.

Prompt guard

Detect if the prompt is a jailbreak prompt, avoiding sending jailbreak prompts to the LLM so as to prevent the LLM from misbehaving.

Similarity Caching ⚑️

Cache the semantic representation of the prompt so as to reduce the number of prompt tokens and improve the overall inference latency.

Distributed Tracing πŸ”

Comprehensive observability with OpenTelemetry distributed tracing provides fine-grained visibility into the request processing pipeline.

Open WebUI Integration πŸ’¬

To view the Chain-Of-Thought of the vLLM-SR's decision-making process, we have integrated with Open WebUI.

code

Quick Start πŸš€

Get up and running in seconds with our interactive setup script:

bash ./scripts/quickstart.sh

This command will:

  • πŸ” Check all prerequisites automatically
  • πŸ“¦ Install HuggingFace CLI if needed
  • πŸ“₯ Download all required AI models (~1.5GB)
  • 🐳 Start all Docker services
  • ⏳ Wait for services to become healthy
  • 🌐 Show you all the endpoints and next steps

For detailed installation and configuration instructions, see the Complete Documentation.

What This Starts By Default

make docker-compose-up now launches the full stack including a lightweight local OpenAI-compatible model server powered by llm-katan (serving the small model Qwen/Qwen3-0.6B under the alias qwen3). The semantic router is configured to route classification & default generations to this local endpoint out-of-the-box. This gives you an entirely self-contained experience (no external API keys required) while still letting you add remote / larger models later.

Core Mode (Without Local Model)

If you only want the core semantic-router + Envoy + observability stack (and will point to external OpenAI-compatible endpoints yourself):

make docker-compose-up-core

Prerequisite Model Download (Speeds Up First Run)

The existing model bootstrap targets now also pre-download the small llm-katan model so the first docker-compose-up avoids an on-demand Hugging Face fetch.

Minimal set (fast):

make models-download-minimal

Full set:

make models-download

Both create a stamp file once Qwen/Qwen3-0.6B is present to keep subsequent runs idempotent.

Documentation πŸ“–

For comprehensive documentation including detailed setup instructions, architecture guides, and API references, visit:

πŸ‘‰ Complete Documentation at Read the Docs

The documentation includes:

Community πŸ‘‹

For questions, feedback, or to contribute, please join #semantic-router channel in vLLM Slack.

Community Meetings πŸ“…

We host bi-weekly community meetings to sync up with contributors across different time zones:

Join us to discuss the latest developments, share ideas, and collaborate on the project!

Citation

If you find Semantic Router helpful in your research or projects, please consider citing it:

@misc{semanticrouter2025,
  title={vLLM Semantic Router},
  author={vLLM Semantic Router Team},
  year={2025},
  howpublished={\url{https://github.com/vllm-project/semantic-router}},
}

Star History πŸ”₯

We opened the project at Aug 31, 2025. We love open source and collaboration ❀️

Star History Chart

About

Intelligent Mixture-of-Models Router for Efficient LLM Inference

Resources

License

Code of conduct

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Languages

  • Go 34.6%
  • Python 33.1%
  • TypeScript 9.8%
  • CSS 6.7%
  • Rust 6.6%
  • Shell 5.9%
  • Other 3.3%