Разработка алгоритма маркет-мейкинга

Проектируем и разрабатываем блокчейн-решения полного цикла: от архитектуры смарт-контрактов до запуска DeFi-протоколов, NFT-маркетплейсов и криптобирж. Аудит безопасности, токеномика, интеграция с существующей инфраструктурой.
Показано 1 из 1Все 1306 услуг
Разработка алгоритма маркет-мейкинга
Сложный
от 2 недель до 3 месяцев
Часто задаваемые вопросы

Направления блокчейн-разработки

Этапы блокчейн-разработки

Последние работы

  • image_website-b2b-advance_0.webp
    Разработка сайта компании B2B ADVANCE
    1288
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1198
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    902
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1122
  • image_logo-advance_0.webp
    Разработка логотипа компании B2B Advance
    589
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    859

Разработка алгоритма маркет-мейкинга

Маркет-мейкер — это участник рынка, который постоянно выставляет котировки на покупку и продажу. Его прибыль — разница между bid и ask (спред). Маркет-мейкинг обеспечивает ликвидность рынка, за что биржи платят rebates (скидки на fees или отрицательные комиссии). В крипте маркет-мейкинг превратился в высококонкурентную нишу, но для нишевых активов (mid-cap altcoins, perpetual futures с невысокой ликвидностью) по-прежнему очень прибылен.

Базовая модель маркет-мейкинга

Naive market making — выставить bid на X% ниже mid-price и ask на X% выше. Проблема: inventory risk. Если цена резко движется в одну сторону, маркет-мейкер накапливает невыгодную позицию.

Avellaneda-Stoikov модель — математически оптимальная стратегия маркет-мейкинга. Учитывает inventory risk и time horizon:

bid_price = mid - δ/2 - γσ²(T-t)q
ask_price = mid + δ/2 - γσ²(T-t)q

где:
δ  = spread (оптимальный)
γ  = risk aversion coefficient
σ  = волатильность актива
q  = текущий inventory (в единицах актива)
T  = конец торгового периода
t  = текущее время

Ключевое: при положительном inventory (накоплено много актива) алгоритм сдвигает котировки вниз, чтобы быстрее продать излишки. При отрицательном — поднимает, чтобы купить.

Inventory management

Inventory risk — главный враг маркет-мейкера. Если позиция вышла за пределы допустимого диапазона:

Hard limit: при inventory > MAX_INVENTORY — останавливаем выставление ордеров на соответствующей стороне. Ждём исполнения.

Soft limit с skewing: постепенно смещаем котировки против направления накопленного inventory. Чем больше inventory — тем сильнее сдвиг.

Hedging: открываем хедж-позицию на другой бирже или в perpetual futures. Если накопили много BTC spot, продаём BTC-PERP.

Управление спредом

Спред не должен быть фиксированным — он адаптируется к условиям рынка:

Volatility-based spread: spread = base_spread × (current_volatility / mean_volatility). При высокой волатильности спред расширяется — inventory risk выше.

Order book depth: если ликвидность в стакане низкая — риск adverse selection выше, спред шире.

Time of day: в периоды низкой активности спред расширяется.

Токсичный flow: если последние N сделок были преимущественно на одной стороне — возможно informed trading. Алгоритм расширяет спред или временно снимает котировки.

Multi-level quotes

Вместо одной пары ордеров (1 bid + 1 ask) выставляем несколько уровней:

Bid 3: mid - 0.5% × 1000 USDT
Bid 2: mid - 0.3% × 500 USDT
Bid 1: mid - 0.15% × 200 USDT
--- MID PRICE ---
Ask 1: mid + 0.15% × 200 USDT
Ask 2: mid + 0.3% × 500 USDT
Ask 3: mid + 0.5% × 1000 USDT

Ближние к mid ордера исполняются чаще и дают rebate от биржи. Дальние — страхуют от резких движений.

Order cancellation и re-quoting

Ордера нужно регулярно обновлять при изменении mid-price:

Threshold-based re-quoting: если mid сдвинулся более чем на N% — отменяем старые ордера и выставляем новые.

Time-based re-quoting: принудительное обновление каждые T секунд.

Event-based: при любом изменении лучшего bid/ask в стакане.

Частая отмена ордеров стоит API request quota. Биржи имеют rate limits. Для Binance: 1200 requests/min HTTP, отдельные лимиты для WebSocket. Важно оптимизировать частоту обновлений.

Биржевые программы маркет-мейкинга

Крупные биржи платят за предоставление ликвидности:

Биржа Программа Условия
Binance Liquidity Provider Rebate до -0.005%
Bybit Market Maker Нулевая или отрицательная maker fee
OKX Market Maker Специальные условия fee
Kraken Market Maker Maker rebate по заявке

Для получения этих условий нужно обеспечивать минимальный uptime котировок (>80% времени bid/ask в определённом диапазоне от mid) и минимальный объём.

Мониторинг и метрики

P&L breakdown: spread income - inventory risk losses - fees.

Fill rate: процент ордеров, которые исполнились. Слишком низкий → слишком широкий спред. Слишком высокий → слишком узкий, много adverse selection.

Inventory exposure: текущая позиция в USD, максимальная за сессию, среднее.

Uptime: процент времени, когда котировки выставлены.

Latency: время от получения обновления рынка до выставления/обновления ордеров.

Технический стек

Язык: Python (asyncio + aiohttp/websockets) для стратегий с latency > 50ms. C++ или Rust для latency-critical компонентов.

Биржевые коннекторы: CCXT Pro (Python) обеспечивает унифицированный API для WebSocket. Для production — собственные коннекторы для каждой биржи.

Хранение: PostgreSQL для trades, orders, positions. InfluxDB или TimescaleDB для метрик производительности.

Мониторинг: Grafana дашборды для realtime P&L, inventory, latency. Алерты в Telegram при превышении risk limits.

Разрабатываем маркет-мейкинговый алгоритм с Avellaneda-Stoikov моделью, динамическим спредом, multi-level quotes, inventory management, hedging через фьючерсы и полным мониторингом производительности.