Как устроен арбитражный трейдинг?
В интернете множество способов спекулятивного трейдинга, который может заключаться на скальпинге, высокочастотном алгоритме или арбитраже. Именно с последней методикой мало кто знаком и недавно мне задали вопрос по этой теме на последнем вебинаре. Ответом на вопрос «как устроен арбитражный трейдинг» я бы хотел поделиться в этой статье.
Спекулятивный трейдинг с каждым годом завлекает все больше и больше новых игроков, ведь в краткосрочной перспективе спекуляции способны продемонстрировать больше потенциал доходности, нежели инвестиционные сделки. Все хотят легких или быстрых денег и забывают о простой логике: каждый вид спекулятивного трейдинга заключается в правильном распределении рисков и грамотном управлении капиталом. Однако такая комбинация получается далеко не у каждого трейдера. Именно из-за таких хаотичных решений и слепой веры формируется статистика, при которой практически 90% игроков рынка теряют свои средства.
Если же выбирать спекуляции как источник заработка с финансового рынка, то я настоятельно рекомендую использовать вспомогательные алгоритмы, системы, сигналы, консультации и так далее. Благо мы живём с вами в эпоху информационных технологий, в которой можно автоматизировать каждый процесс и трейдинг в том числе. Если рассматривать алгоритмические стратегии для спекулятивного трейдинга, то самым сложным и полностью неизведанным является именно арбитражный трейдинг.
Арбитраж — это вид спекулятивного трейдинга, который основан на парном анализе одного и того же финансового актива, но на разных брокерских или биржевых площадках. Проще говоря, арбитраж позволяет анализировать один и тот же актив на наличие курсовых расхождений или задержек, с целью открытия краткосрочной сделки. Сама логика работы уже давно не нова, однако на валютном рынке начала использоваться совсем недавно.
Чтобы более подробно понять логику работы, предлагаю рассмотреть конкретный пример:
Стоимость валютной пары EURUSD в одного брокера составляет 1.1230, а во второго 1.1220. То есть существует курсовое расхождение в моменте размера 10 пунктов, при том факте, что нормативное значение равняется 5 пунктам. Торговый робот или вспомогательный алгоритм видит это расхождение и совершает две сделки: на покупку по цене 1.1220 (на торговом счету в первого брокера) и продажу по цене 1.1230 (на торговом счету второго брокера). Когда же цена достигнет нормативного расхождения (5 пунктов), то робот одновременно закроет две сделки. Пускай цена составила 1.1267 и 1.1262 соответственно. Таким образом, трейдер получит убыток на первом счету размером 37 пунктов, а также прибыль размера 42 пункта на счету второго брокера. Общий финансовый результат равняется 5 пунктов чистой прибыли.
Идентично это может работать и на рынке криптовалют.
Такой вид спекулятивного трейдинга имеет ряд преимуществ:
На рынке форекс существует множество спекулятивных краткосрочных алгоритмов. Однако далеко не каждая подобная торговая система способна демонстрировать стабильный положительный результат. Множество «кухонных» брокеров попросту запрещают данный вид торговли и прописывают это в своих договорах. Поэтому будьте бдительны!
Я хочу отметить тот факт, что считаю спекуляции основой движения рынка и что на них делаются огромные деньги. Но те трейдеры, которые только знакомятся с рынком, не способны правильно проанализировать ситуацию и войти в рынок. И если вы только знакомитесь с рынком и не понимаете базовых принципов его движения, то с вероятностью 90% у вас будет убыток (на что опять-таки указывает статистика).
Надеюсь этот сложный процесс и алгоритм мне удалось пояснить просто и понятно. Но если у вас возник все же вопрос – пишите мне в комментарии!
Арбитражные сделки
Арбитражные сделки
Арбитражные сделки — вид трейдинга, при котором трейдер пытается извлекать прибыль без рыночных рисков (угадал-не угадал).
Ключевая идея арбитража заключается в неэффективном ценообразовании того или иного инструмента или группы инструментов — то есть, рынок неправильно оценивает стоимость актива, что создает арбитражную возможность.
Распространено заблуждение, что арбитраж подразумевает безрисковые сделки. На самом деле, арбитражная сделка — это всего лишь направленная позиция по спрэду (разнице цен между двумя активами), которая избавлена от рыночного риска, но не исключает остальных рисков[1].
В совершенном мире арбитражные сделки были бы невозможны. В мире реальном арбитражные возможности быстро исчезают из-за действий участников рынка, если таким действиям не препятствуют большие транзакционные издержки.
Арбитражные сделки — вид трейдинга, при котором трейдер пытается извлекать прибыль без рыночных рисков (угадал-не угадал).
Ключевая идея арбитража заключается в неэффективном ценообразовании того или иного инструмента или группы инструментов — то есть, рынок неправильно оценивает стоимость актива, что создает арбитражную возможность.
Распространено заблуждение, что арбитраж подразумевает безрисковые сделки. На самом деле, арбитражная сделка — это всего лишь направленная позиция по спрэду (разнице цен между двумя активами), которая избавлена от рыночного риска, но не исключает остальных рисков[1].
В совершенном мире арбитражные сделки были бы невозможны. В мире реальном арбитражные возможности быстро исчезают из-за действий участников рынка, если таким действиям не препятствуют большие транзакционные издержки.
Риски арбитражных сделок
Арбитражеры часто имеют дело с «риском асфальтоукладчика» — они пытаются подобрать несколько монет с земли прямо перед надвигающимся асфальтоукладчиком.
Изменения в законодательстве, регулировании и налогообложении могут заставить арбитражера закрыть позицию с потерей денег. Например, внезапный запрет на короткие позиции может вынудить закрыть шорт.
Транзакционные издержки могут составлять существенную долю арбитражной прибыли. В этом случае, большое конкурентное преимущество получают те фонды, которые работают с меньшими комиссиями:
Арбитражеры часто имеют дело с «риском асфальтоукладчика» — они пытаются подобрать несколько монет с земли прямо перед надвигающимся асфальтоукладчиком.
Изменения в законодательстве, регулировании и налогообложении могут заставить арбитражера закрыть позицию с потерей денег. Например, внезапный запрет на короткие позиции может вынудить закрыть шорт.
Транзакционные издержки могут составлять существенную долю арбитражной прибыли. В этом случае, большое конкурентное преимущество получают те фонды, которые работают с меньшими комиссиями.
Обычно, транзакционные издержки меньше у наиболее крупных и активных игроков, которым брокеры снижают комиссию.
Виды арбитражных сделок:
Парный арбитраж — попытка торговать парой похожих инструментов одного сектора — например, акции Лукойла и Роснефти. Основная идея — акции ходят вместе. Если разница между ценами акции слишком большая, разницу можно продавать.
Географический арбитраж — игра на разнице цен на разных рынках. Например, разница между ценами на Московской бирже и ADR в Лондоне. Риском такого арбитража являются транзакционные издержки и скорость исполнения приказов на родном рынке и американской бирже.
Арбитраж спот-фьючерс (эквивалентный арбитраж) — игра на расхождении между ценами инструмента на спот-рынке и ценой фьючерса на этот инструмент. Например, торговля казначейскими облигациями США и фьючерсами на них.
Арбитраж между фьючерсом на фондовый индекс и корзиной акций. Например, если цена фьючерса на индекс существенно превышает значение самого фондового индекса, имеет смысл продать фьючерсы и купить на эту же сумму корзину акций, составляющих фондовый индекс.
Арбитраж нефти разных сортов. Основная идея заключается в том, что если один сорт нефти слишком сильно подорожал относительно второго, то эта ситуация будет временной, и можно продавать дорогой сорт нефти и покупать дешевый.
Опционный арбитраж — принцип паритета стоимости опционов Пут и Колл.
Рисковый арбитраж — покупка перепроданных дефолтных облигаций или акций компаний с высоким риском банкротства.
Арбитраж между новыми и устаревающими 30-летними облигациями Treasuries. 30-летние облигации, выпущенные Минфином вчера всегда будут ликвиднее и чуть дороже, чем выпущенные несколько месяцев назад такие же облигации, рынок которых стал неликвидным. Неликвидность создает арбитражную возможность
Арбитражная торговля (Алгоритм Беллмана — Форда)
Торговля на бирже обычно ассоциируется с рисками. Это совершенно верно для большинства торговых стратегий. Успешность торговли в этих случаях определяется исключительно способностью верно оценивать риски и управлять ими. Но не все торговые стратегии таковы. Существуют безрисковые стратегии, к которым относится, в частности, арбитраж. В этой статье будет рассказано, что такое арбитраж, и как реализовать его с использованием такого классического алгоритма на графе, как алгоритм Беллмана — Форда.
Что такое арбитраж
Арбитраж — это несколько логически связанных сделок, направленных на извлечение прибыли из разницы в ценах на одинаковые или связанные активы в одно и то же время на разных рынках (пространственный арбитраж), либо на одном и том же рынке в разные моменты времени (временной арбитраж).
В качестве простого примера рассмотрим пространственный арбитраж. В Нью-Йорке и Лондоне можно заключить сделки по покупке долларов за евро и евро за доллары. В Нью-Йорке это можно делать по курсу 4 доллара за 3 евро, а в Лондоне — по курсу 5 долларов за 3 евро. Такая разница курсов открывает возможность для пространственного арбитража.
Имея 4 доллара, в Нью-Йорке на них можно купить 3 евро. После этого в Лондоне купить за эти 3 евро 5 долларов. Как можно заметить, такая несложная последовательность сделок приносит 1 доллар прибыли на каждые вложенные 4 доллара. Соответственно, если изначально имеется 4 миллиона долларов, то и прибыль будет уже в миллион.
Когда обменные курсы (спред не рассматриваем) для одной и той же валютной пары отличаются, то последовательность сделок, необходимых для реализации арбитражной стратегии, очень простая. В случае, если курс для одной валютной пары фиксирован, но торгуются несколько валютных пар параллельно, арбитраж также возможен, но последовательность сделок уже будет нетривиальной. К примеру, можно купить 4 евро за 5 долларов, 3 фунта за 4 евро, а потом 6 долларов за 3 фунта. Прибыль от такой последовательности сделок составит 1 доллар на каждые 5 вложенных долларов.
На бирже могут торговаться сотни валютных пар, а обменные курсы постоянно меняются. Понять, какая последовательность сделок принесёт прибыль, без алгоритмического решения в этом случае уже невозможно.
Переход к алгоритмической задаче
Представим потенциальные сделки обмена валюты в алгоритмическом виде, а именно в виде графа. Вершины в этом графе представляют валюты, а ребра являются возможными сделками. Длина же ребра соответствует обменному курсу, по которому данную сделку можно заключить.
Далее встает вопрос, как в таком графе найти последовательность сделок, которая принесет прибыль. Очевидно, что так как в начале последовательности и в её конце должна быть одна и та же валюта, то последовательность должна соответствовать циклу в заданном графе. Далее необходимо определиться с тем, как вычисляется обменный курс между двумя валютами, если они обмениваются не напрямую, а через некую третью валюту (или произвольное количество промежуточных операций). Тут всё тоже достаточно просто. Такой обменный курс будет вычисляться как произведение обменных курсов промежуточных сделок. Прибыльной последовательность сделок становится, если это произведение принимает значение меньше единицы. Другими словами, если единицу валюты можно купить меньше, чем за единицу этой же самой валюты.
Классические алгоритмы на графах плохо подходят для работы с произведением длин ребер. Такие алгоритмы, в основном, заточены на нахождение пути, который определяется как сумма этих длин. Однако для обхода этого ограничения существует математический способ перейти от произведения к сумме. Таким способом является логарифмирование. Если под логарифмом оказывается произведение, то такой логарифм может быть преобразован в сумму логарифмов. В правой же части этого уравнения желаемым является число меньшее единицы, а значит, логарифм этого числа должен быть меньше нуля.
Такой простой математический трюк позволяет перейти от поиска цикла, произведение длин ребер которого меньше единицы, к поиску цикла, сумма длин ребер которого меньше нуля. Такая задача уже выглядит более решаемой классическими графовыми алгоритмами, а точнее алгоритмом Беллмана — Форда.
Алгоритм Беллмана — Форда
Алгоритм Беллмана — Форда обычно используется для нахождения расстояния от заданной вершины до всех остальных вершин некоторого графа, однако его модификация позволяет найти и циклы отрицательной длины.
Базовой операцией этого алгоритма является релаксация ребер. Суть данной операции следующая. Допустим, что имеется ребро , а еще известны вычисленные ранее предварительные значения расстояний до вершин
и
. Для выполнения релаксации ребра требуется вычислить, какое получилось бы расстояние до вершины
, если бы путь проходил через вершину
и ребро
. Это расстояние вычисляется как сумма расстояния до вершины
и длины ребра
. Далее, если это расстояние оказывается меньше текущего предварительного расстояния до
, то это самое расстоние до
переписывается и принимает новое, только что вычисленное, значение.
Остальной алгоритм тоже несложен. Необходимо раз (
— это количество вершин графа) обойти список ребер, при каждом обходе применяя операцию релаксации. Сложность алгоритма при этом получается
(где
— количество вершин, а
— количество ребер). Для графа без отрицательных циклов дальнейшие релаксации ребер не приведут к изменению расстояний до вершин. В то же время, для графа, содержащего отрицательный цикл, релаксации будут уменьшать расстояние до вершин и после
обходов. Это свойство может быть использовано использовано для нахождения искомого цикла.
Тем, кому привычнее разбираться с кодом, должна помочь следующая небольшая реализация описанного выше алгоритма на Kotlin’е.
Разберем пример с небольшим графом, в состав которого входит цикл отрицательной длины. Для работы алгоритма необходимо для каждой вершины поддерживать текущее известное расстояние до неё, а так же ссылку на её предыдущую вершину. Ссылка на предыдущая вершина в данном случае определяется успешной релаксацией ребра. Если операция релаксации прошла успешно, и дистанция до вершины была обновлена, то ссылка на предыдущую вершина этой вершины также обновляется и принимает значение вершины-источника заданного ребра.
Итак, для начала необходимо инициализировать вершины, установив дистанцию до всех вершин кроме начальной равной бесконечности. Для начальной вершины устанавливается дистанция равная нулю.
Далее следует первый обход всех ребер и выполняются их релаксации. Практически все релаксации не дают никакого результата, кроме релаксации ребра . Релаксация данного ребра позволяет обновить расстояние до
.
Далее следует второй обход всех рёбер графа и соответствующие релаксации. На этот раз результат дают релаксации ребер , а также
. Обновляются расстояния до вершин
и
. Тут следует заметить, что результат зависит от того, в каком порядке происходит обход ребер.
При третьем обходе ребер удается успешно релаксировать уже три ребра, а именно ребра ,
,
. При этом, при релаксации ребер
и
обновляются уже записанные ранее расстояния до
и
, а так же соответствующие ссылки на предыдущие вершины.
При четвертом обходе успешно заканчиваются операции релаксации ребер и
. При этом опять обновляются уже записанные значения расстояний до вершин
и
, как и соответствующие ссылки на предыдущие вершины.
Пятый обход является последним. При этом обходе релаксируются ребра ,
,
. Тут можно заметить, что наличие цикла отрицательной длины уже вносит определенные корректировки в значения расстояний до вершин.
После этого обхода, если бы граф не содержал цикла отрицательной длины, алгоритм был бы закончен, так как релаксация любого ребра уже не внесла бы никаких изменений. Однако для данного графа из-за наличия цикла отрицательной длины, все еще можно найти ребро, релаксация которого обновит значения расстояния до одной из вершин.
Ребро, релаксация которого обновляет расстояние до вершины, найдено. Это подтверждает наличие цикла отрицательной длины. Теперь необходимо найти сам этот цикл. Важно, что вершина, расстояние до которой сейчас обновилось, может быть как внутри цикла, так и вне него. В примере это вершина и она вне цикла. Далее необходимо обратиться к ссылкам на предыдущие вершины, которые аккуратно обновлялись на всех шагах алгоритма. Чтобы гарантированно попасть в цикл, необходимо отступить назад на
вершин, пользуясь этими ссылками.
В данном примере переходы будут следующие: . Таким образом находится вершина
, которая гарантированно лежит в цикле отрицательной длины.
Далее дело техники. Чтобы вернуть искомый цикл, нужно опять итерироваться по ссылкам на предыдущие вершины, пока опять не встретится вершина . Это будет значить, что цикл замкнулся. Остается только изменить порядок на обратный, так как при итерациях по ссылкам на предыдущие вершины порядок был инвертирован.
В приведенном алгоритме предполагается наличие некоторой изначальной вершины, от которой рассчитываются расстояния. Наличие такой вершины не является обязательным для работы алгоритма, а введена она в большей степени для соответствия изначальному алгоритму Беллмана — Форда. Если же предметом интереса является цикл отрицательной длины, то можно считать, что все вершины заданного графа являются начальными. Другими словами, что дистанция до всех вершин изначально равна нулю.







