Разработка системы ценообразования опционов (Black-Scholes для крипто)

Проектируем и разрабатываем блокчейн-решения полного цикла: от архитектуры смарт-контрактов до запуска DeFi-протоколов, NFT-маркетплейсов и криптобирж. Аудит безопасности, токеномика, интеграция с существующей инфраструктурой.
Показано 1 из 1 услугВсе 1306 услуг
Разработка системы ценообразования опционов (Black-Scholes для крипто)
Сложная
~3-5 рабочих дней
Часто задаваемые вопросы
Направления блокчейн-разработки
Этапы блокчейн-разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1258
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1170
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    873
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1092
  • image_logo-advance_0.png
    Разработка логотипа компании B2B Advance
    563
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    830

Разработка системы ценообразования опционов (Black-Scholes для крипто)

On-chain опционный протокол сталкивается с проблемой, которой нет у традиционных деривативов: модель Блэка-Шоулза требует вычислений с плавающей точкой — логарифмов, квадратных корней, нормального распределения — а EVM оперирует только целыми числами. Deribit считает цены опционов off-chain и централизованно. Lyra, Hegic, Dopex решают это по-разному. Разработка собственной системы ценообразования — это, прежде всего, выбор компромисса между точностью и gas cost.

Математика Black-Scholes в целых числах

Формула BSM для европейского колл-опциона:

C = S * N(d1) - K * e^(-rT) * N(d2)

где d1 = (ln(S/K) + (r + σ²/2) * T) / (σ * √T)

Каждый элемент — источник ошибки при целочисленной арифметике.

Логарифм и экспонента через таблицы или approximation

Классический подход — аппроксимация ln(x) через разложение Тейлора с фиксированной точкой (fixed-point arithmetic, 18 знаков). Solidity не имеет нативного ln, но библиотека PRBMath (Paul Razvan Berg) реализует ln, exp, sqrt с точностью до 1e-9 используя 59.18-decimal fixed-point. Это production-ready: Uniswap v3 использует аналогичные техники для sqrtPriceX96.

Альтернатива — lookup tables для стандартного нормального распределения N(d). Таблица из 1000 точек с интерполяцией даёт достаточную точность для опционов и обходится дешевле по газу, чем аналитическая аппроксимация. Lyra v1 использовала именно этот подход.

Implied Volatility — обратная задача

Самое сложное — не вычислить цену по известной волатильности, а найти implied volatility (IV) из рыночной цены. Это уравнение BSM_price(σ) = market_price не решается аналитически. Методы: Newton-Raphson итерации или bisection search.

On-chain Newton-Raphson за 5-7 итераций сходится к IV с точностью 0.1% — стоит около 80-150k gas на Ethereum mainnet. Для L2 приемлемо, для mainnet — дорого. Решение: IV вычисляется off-chain, подаётся on-chain с подписью оракула, контракт только верифицирует подпись и использует значение.

Проблема stale volatility

Крипто-волатильность меняется быстро. IV биткоина за 24 часа может вырасти с 60% до 120% при резком движении рынка. Если on-chain хранится устаревшая IV — опционы оцениваются неверно. Покупатель опциона с занижённой IV получает несправедливую цену за счёт LPs.

Lyra v2 решает это через offchain oracle (сначала SNX keeper, потом Lyra-специфичный) с обновлением IV каждые 15 минут. Hegic использует Chainlink volatility oracle (экспериментальный feed). Для кастомной системы — обновление через keeper (Gelato или Chainlink Automation) с bounded update: IV не может измениться более чем на X% за одно обновление.

Архитектура системы ценообразования

Off-chain pricing engine + on-chain verification

Оптимальная архитектура для production: ценообразование на TypeScript/Python сервере с полной точностью float64, результат подписывается оператором или multi-party committee, контракт верифицирует подпись и использует цену.

Это не «централизованно» в негативном смысле — есть явный trust assumption, который документируется. Для сравнения: Deribit полностью централизован, Lyra v1 использовал аналогичную схему с оракулом.

On-chain контракт хранит: spotPrice (от Chainlink), impliedVolatility (от keeper), lastUpdateTimestamp. При устаревших данных (> maxStaleness) — новые позиции не открываются.

Расчёт Greeks для управления риском

Для LP-пула, который выступает counterparty для всех опционов, critical — агрегированный delta-hedging. Delta каждого опциона суммируется в net delta пула, keeper исполняет hedging свапы для удержания delta-нейтральности.

Greek Значение для пула Метод расчёта
Delta Exposure к spot цене N(d1) для колл, N(d1)-1 для пут
Gamma Скорость изменения delta φ(d1) / (S * σ * √T)
Vega Exposure к волатильности S * φ(d1) * √T
Theta Временной распад Аналитически

Pnl пула от греков суммируется в netDelta, netVega. Если |netDelta| > hedgeThreshold — keeper инициирует swap на Uniswap v3 для выравнивания.

Типы опционов и settlement

Cash-settled vs physical delivery. Cash-settled проще: при экспирации контракт запрашивает spot цену у Chainlink, вычисляет payoff, переводит USDC. Physical delivery требует хранения underlying asset в контракте.

American vs European. Американские опционы (исполнение в любой момент) требуют binomial tree или Monte Carlo для корректной оценки — on-chain нецелесообразно. Все on-chain опционные протоколы используют европейский стиль.

Early exercise через flash loan. Теоретически атакующий мог бы попытаться исполнить опцион в момент манипуляции оракулом. Защита: settlement цена вычисляется как TWAP за последний час перед экспирацией, а не spot.

Процесс работы

Математическая спецификация (2-3 дня). Формализуем: тип опционов, settlement механика, источники данных для S и σ, модель комиссий, механизм hedging.

Pricing library (2-3 дня). Solidity библиотека для BSM с PRBMath. Unit-тесты сравнивают результаты с Python scipy.stats reference implementation.

Оракул и keeper (2-3 дня). Off-chain pricing engine, подписание данных, Gelato автоматизация обновления IV.

Core контракты (3-5 дней). OptionPool (LP), OptionToken (ERC-1155), settlement логика.

Тестирование (2-3 дня). Fork-тесты на mainnet с реальными Chainlink feeds, сценарии экспирации.

Ориентиры по срокам

Система ценообразования как библиотека + оракульная инфраструктура — 3-5 дней. Полноценный опционный протокол с LP пулом, hedging и frontend — 6-10 недель.