B-FAST is an ultra-high performance binary serialization protocol, developed in Rust for Python and TypeScript ecosystems. It's designed to replace JSON in critical routes where latency, CPU usage, and bandwidth are bottlenecks.
"Performance is not just about speed—it's about efficiency where it matters most"
B-FAST was born from the recognition that modern applications need more than just fast serialization—they need smart serialization that adapts to real-world constraints. After extensive optimization, B-FAST has found its perfect niche in bandwidth-constrained environments, achieving 1.7x faster than orjson for simple objects and 5.7x faster on slow networks.
Philosophy: We believe that the future of data transfer lies not in raw CPU speed alone, but in intelligent protocols that minimize network overhead while maintaining excellent performance. B-FAST represents our contribution to a more efficient, bandwidth-conscious web.
Full documentation available at: https://marcelomarkus.github.io/b-fast/
- Rust Engine: Native serialization without Python interpreter overhead.
- Pydantic Native: Reads Pydantic model attributes directly from memory, skipping the slow .model_dump() process.
- Zero-Copy NumPy: Serializes tensors and numeric arrays directly, achieving 14-96x speedup vs JSON/orjson.
- Parallel Compression: LZ4 with multi-thread processing for large payloads (>1MB).
- Cache Optimized: Aligned allocation and batch processing for maximum efficiency.
| Format | Time (ms) | Speedup |
|---|---|---|
| JSON | 12.0ms | 1.0x |
| orjson | 8.19ms | 1.5x |
| B-FAST | 4.83ms | 🚀 2.5x |
B-FAST is 1.7x faster than orjson!
Complete test including network transfer and deserialization (10,000 objects):
| Format | Total Time | Speedup vs orjson |
|---|---|---|
| JSON | 114.5ms | 0.8x |
| orjson | 91.7ms | 1.0x |
| B-FAST + LZ4 | 16.1ms | 🚀 5.7x |
| Format | Total Time | Speedup vs orjson |
|---|---|---|
| JSON | 29.4ms | 0.5x |
| orjson | 15.3ms | 1.0x |
| B-FAST + LZ4 | 7.2ms | 🚀 2.1x |
| Format | Total Time | Speedup vs orjson |
|---|---|---|
| JSON | 20.9ms | 0.4x |
| orjson | 7.7ms | 1.0x |
| B-FAST + LZ4 | 6.3ms | 🚀 1.2x |
- 📱 Mobile/IoT: 89% data savings + 5.7x performance on slow networks
- 🌐 APIs with slow networks: Up to 5.7x faster than orjson
- 📊 Data pipelines: 14-96x speedup for NumPy arrays
- 🗜️ Storage/Cache: Superior integrated compression
- 🚀 Simple objects: 1.7x faster than orjson
uv add bfast-pyor
pip install bfast-pynpm install bfast-clientB-FAST integrates seamlessly as a response class.
from fastapi import FastAPI, Response
from pydantic import BaseModel
import b_fast
class BFastResponse(Response):
media_type = "application/x-bfast"
def __init__(self, content=None, *args, **kwargs):
super().__init__(content, *args, **kwargs)
self.encoder = b_fast.BFast()
def render(self, content) -> bytes:
return self.encoder.encode_packed(content, compress=True)
app = FastAPI()
class User(BaseModel):
id: int
name: str
@app.get("/users", response_class=BFastResponse)
async def get_users():
return [User(id=i, name=f"User {i}") for i in range(1000)]from flask import Flask, Response
import b_fast
app = Flask(__name__)
encoder = b_fast.BFast()
@app.route('/users')
def get_users():
users = [{"id": i, "name": f"User {i}"} for i in range(1000)]
data = encoder.encode_packed(users, compress=True)
return Response(data, mimetype='application/octet-stream')from django.http import HttpResponse
import b_fast
encoder = b_fast.BFast()
def get_users(request):
users = [{"id": i, "name": f"User {i}"} for i in range(1000)]
data = encoder.encode_packed(users, compress=True)
return HttpResponse(data, content_type='application/octet-stream')import b_fast
encoder = b_fast.BFast()
# Encode your data
data = encoder.encode_packed(your_data, compress=True)
# Return as bytes (binary response)import { BFastDecoder } from 'bfast-client';
async function loadData() {
const response = await fetch('/users');
const buffer = await response.arrayBuffer();
// Decodes and decompresses LZ4 automatically
const users = BFastDecoder.decode(buffer);
console.log(users);
}Key Achievements:
- 🚀 1.7x faster than orjson for simple objects
- 🚀 5.7x faster than orjson on 100 Mbps networks (round-trip)
- 📦 89% smaller payloads with built-in LZ4 compression
- ⚡ 14-96x speedup for NumPy arrays
- 🎯 Competitive even on ultra-fast 10 Gbps networks
B-FAST performance comparison across different scenarios: simple objects, large objects on 100 Mbps network, NumPy arrays, and payload size. B-FAST demonstrates superiority in speed (1.7-14x faster) and bandwidth efficiency (90% reduction with LZ4).
Developed by: marcelomarkus
Distributed under the MIT License. See LICENSE for more information.
