Разработка алгоритма grid trading с динамическими уровнями

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

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

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

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

  • 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

Разработка алгоритма grid trading с динамическими уровнями

Grid trading — стратегия выставления сетки ордеров выше и ниже текущей цены. При движении цены вниз — покупаем, при движении вверх — продаём. Прибыль накапливается на каждом «шаге» сетки. Динамическая сетка отличается от статической тем, что адаптируется к изменяющейся волатильности и тренду.

Базовая механика grid trading

Статическая сетка (для понимания): задаём диапазон $40,000–$50,000, 10 уровней. Шаг: $1,000. Выставляем:

  • Buy orders: 40k, 41k, 42k, 43k, 44k
  • Sell orders: 46k, 47k, 48k, 49k, 50k
  • Текущая цена: ~$45k (middle)

При падении до $44k → исполняется buy order → автоматически выставляем sell $45k. При росте до $45k → исполняется sell → profit $1,000 за шаг.

Profit per grid = шаг / цена. Шаг 1% → ~1% profit на каждом полном цикле (без учёта fees).

Динамическая сетка: адаптация к волатильности

Статическая сетка работает в диапазоне. Если цена уходит за границу — сетка «застывает» и не торгует. Динамическая сетка решает это:

ATR-based grid spacing: шаг между уровнями = кратное ATR. При высокой волатильности шаги шире (меньше ложных сигналов, выше profit per step). При низкой — уже (больше сделок).

def calculate_grid_levels(current_price, atr, n_levels=10, atr_multiplier=0.5):
    step = atr * atr_multiplier
    levels = []
    for i in range(-n_levels//2, n_levels//2 + 1):
        level_price = current_price + i * step
        levels.append(level_price)
    return sorted(levels)

Recentering: если цена ушла за пределы сетки на N шагов — пересчитываем сетку вокруг текущей цены. Все незаполненные ордера отменяются, новые выставляются.

Trend-aware grid: в восходящем тренде (EMA положительная) сетка смещается вверх. Больше sell уровней выше, меньше buy уровней ниже. В нисходящем — наоборот.

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

Равномерное распределение: одинаковое количество капитала на каждый уровень.

Pyramid allocation: больше капитала на уровни ближе к текущей цене (более вероятное исполнение), меньше на крайние уровни.

Максимальный inventory: ограничение на максимальный накопленный актив. Если сетка продолжает покупать при падении — рискуем перегрузиться позицией.

def check_inventory_limit(current_qty, max_qty_pct, capital, price):
    max_qty = (capital * max_qty_pct) / price
    if current_qty >= max_qty:
        # Останавливаем buy orders, только sell
        return False
    return True

Profit и метрики

Grid profit: суммарная прибыль от исполненных пар buy/sell ордеров. Unrealized P&L: если накоплен inventory при падении цены. Total P&L: grid profit + unrealized P&L. Grid occupancy: процент уровней, которые торговались (сколько раз каждый уровень исполнился).

Когда grid trading работает

Идеальные условия: боковой рынок с регулярными колебаниями. BTC в диапазоне $40k–$50k в течение нескольких месяцев — отличная ситуация для grid.

Плохие условия: сильный тренд. При направленном движении вниз накапливаем убыточную позицию без продаж.

Защита от тренда: Stop-loss на весь grid при падении ниже нижней границы на X%. Или использование только spot (без плеча) — тогда убыток только unrealized, не margin call.

Стек: Python (asyncio + CCXT), PostgreSQL для хранения уровней и ордеров, простой web UI для настройки и мониторинга сетки, Telegram алерты при recentering и stop-loss.