Разработка алгоритма 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.







