Избранное трейдера EAGor

по

Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#

Вступление

     Никогда не увлекался скоростным трейдингом. Всегда хватало терминала. Изучать этот протокол меня побудил набор вакансий. Надо отметить, что я неспешно перебираю хорошие вакансии на рынке. Частному трейдеру очень сложно развиваться в одиночку — психологически, эмоционально, физически. Создавать и развиваться постоянно хочется, поэтому принял решение вливаться в коллектив. За несколько месяцев, мне удалось провести несколько собеседований. На втором этапе я проваливался именно из за не знаний протокола.  Предметную область я примерно представлял. Ну что там сложного? Соединился с биржей по сокетам и начинай обмен сообщениями. Надо отметить, что в этой области есть уже готовые разработки в виде quickfix или готового API от StockSharp (правда платные). Но я принял решение разбираться с нуля, чтобы вникнуть в детали.

Технические аспекты протокола


     Итак. Любой протокол, какой бы он сложный не был, работает примерно одинаково. Мы создаем у себя соединение с сервером, устанавливаем некий туннель между нами и сервером, посредством которого будем обмениваться сообщениями. Протокол — это как раз и есть набор правил, по которым строятся сообщения нужного формата. Если говорить технически, то мы должны создать сокет соединение с сервером на указанный порт.
Сообщение в FIX, как и в любом другом протоколе, состоит из нескольких блоков:
  • <Заголовок сообщения>
  • <Сообщение>
  • <Концовка сообщения>
     Наша задача, правильно заполнить эти блоки и отправить на сервер. Заголовок сообщения в свою очередь состоит из следующих данных:
  • <Начало сообщения, версия протокола>
  • <Длина (размер) сообщения>
  • <Тип сообщения>
  • <Идентификатор отправителя>
  • <Идентификатор получателя>
  • <Номер сообщения>
  • <Время отправки>
     Обращу ваше внимание, что я перечисляю обязательные поля. Есть еще и дополнительные. Концовка сообщения должна выглядеть так:
  • <Контрольная сумма сообщения>
     Сами данные заполняются достаточно легко. В виде: <тип поля> = <значение>. Например, <длина сообщения> = 78, то есть мы серверу говорим, что размер передаваемого нами сообщения составляет 78 байт. Стоит обратить внимание, что в протоколе FIX, типы полей кодируются в виде числовых значений. Например,  <длина сообщения> в протоколе передается как цифра 9. Исходя из выше сказанного, наш заголовок сообщения, выглядел бы следующим образом:
  • 8=FIX.4.4 _____ начало сообщения, протокол версии 4.4
  • 9=78 _____ размер сообщения 78 байт
  • 35=A _____ тип сообщения А, что означает попытка на соединение с сервером
  • 49=<ваш идентификатор выдается биржей>
  • 56=FG _____ идентификатор получателя, раздел Forts на бирже
  • 34=1 _____ первое сообщение
  • 52=20160212-11:42:51.812 _____ время отправки сообщения

Организационные вопросы

  1. Наша биржа дает тестовый контур для отработки своих алгоритмов по данному протоколу. Надо всего лишь написать запрос на доступ. Надо признать, тех служба работает отменно. Очень все быстро было организовано. Подробности http://moex.com/s442
  2. Обязательно понадобится описание протокола для нашей биржи ftp://ftp.moex.com/pub/FIX/Spectra/test/docs/spectra_fixgate_ru.pdf
  3. Чтобы вникнуть в тонкости передачи, мне очень помогла эта программа от биржи (позже я покажу как помогла) ftp://ftp.moex.com/pub/FIX/Spectra/Utils/fix_client.zip
  4. Описание самого протокола от создателей (на английском). Мне помог сильно wiki. http://fixwiki.org/fixwiki/FIXwiki
  5. Чтобы найти свои ошибки, мне приходилось перехватывать сообщения рабочего клиента биржи и сверять со своими. Для этого мне понадобился tcp/ip сниффер — программа перехвата сетевого трафика.
  6. Разработку я веду на c#.

К бою. Немного теоретической практики

     На момент изучения протокола, я уверен, многие столкнуться со следующими вопросами:
  • как именно считать длину сообщения
  • как разделять между собой данные
  • как считать контрольную сумму

     Если говорить образно. То, чтобы отправить сообщение на сервер, нам просто нужно сформировать нужную строку со всеми данными и отправить ее на биржу. Ну например:

8=FIX.4.4
;9=78;35=A;49=FG;56=tgFhcfx901U05;34=1;52=20160212-11:42:51.812
;98=0;108=3000;141=Y;10=047;

Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#

     Если быть внимательным, то мы увидим, что кол-во символов в строке у нас 100, а в заголовке сообщения мы передаем, что 78 (9 = 78). По правилам протокола FIX, длину сообщения нужно считать без учета концовки и первых двух полей заголовка. А именно:

Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#     С длиной сообщения разобрались. Теперь про разделитель. Пока в моем скрине это ";". В документациях западных написано что это символ SOH. Чтобы однозначно ответить на этот вопрос, я запустил прилагаемого клиента биржи и сниффером стал перехватывать сообщения между клиентом и биржей. Кстати, программа ведет логи, и их общение выглядит так (зеленое — передача запроса на биржу, красное — ответ от биржи):
Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#
     Зачеркнул свой идентификатор, прошу понять правильно. Ну а перехват сообщения выглядит так:
Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#     Зеленым я отметил именно разделители. Как вы уже видите, это просто в шестнадцатеричном виде код 01. То есть, в нашу строку в виде разделителей, нужно вставлять код 01. Также я отметил для себя последовательность полей в сообщении. Почему то в другом порядке у меня вызывало ошибки (возможно тут я не прав)
Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#     Ну и контрольная сумма. Контрольная сумма считается над всем сообщением, за исключением концовки. То есть в расчет берется только заголовок и само сообщение. Для этого, мы переводим каждый символ в его Ascii код и вычисляем их сумму. Полученную сумму делим по модулю 256. Это и будет контрольной суммой сообщения. При этом, значение должно быть трехзначным. Если мы получаем 2 знака, то подставляем 0 слева (например, если контрольная сумма = 68, то должны передать значении 068).

К бою. Начало программирования

     В законченном виде, разработка будет составлять готовый класс, для работы с протоколом. Теперь начинаю строить его по кирпичикам. Для начала, я создал несколько классов:
  • класс для работы с заголовками
  • класс для работы с сообщением подключения к серверу (onLogon)
  • класс для работы с концовкой
    Каждый класс включает в себя поля, которые передаются и некоторые методы для их обработки.
    Класс для работы с заголовками. Пока просто выглядит так: 
Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#

Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#     Как видим, первый метод строит нужную строку из полей. Обратите внимание, там присутствует наш разделитель в виде спец символа \u0001. Второй метод вычисляет размер заголовка (чтобы потом высчитывать размер сообщения). Надо обратить внимание, что при передачи времени, миллисекунды должны указываться в трехзначном формате (даже если миллисекунды = 52, то передаем 052). Следующие классы строятся по аналогии.
Класс создания сообщения на подключение (инициализация сессии)
Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#
Класс создания концовки сообщения
Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#

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

//Получаем ip сервера
IPAddress ipAddr = IPAddress.Parse(server);
IPEndPoint ipEndPoint = new IPEndPoint(ipAddr, port);
//Создаем заголовк
HeaderMessage msHeader = new HeaderMessage
{
BeginString = «FIX.4.4»,
MsgType = «A», //Тип сообщения на установку сессии
SenderCompID = "",
TargetCompID = «FG»,
MsgSeqNum = 1
};
//Создаем сообщение на подключение onLogon
LogonMessage msLogon = new LogonMessage
{
EncryptMethod = 0,
HeartBtInt = 3000,
ResetSeqNumFlag = true
};

//Вычисляем длину сообщения
msHeader.BodyLength = msHeader.GetHeaderSize() + msLogon.GetMessageSize();
//Создаем концовку сообщения
TrailerMessage msTrailer = new TrailerMessage(msHeader.ToString() + msLogon.ToString());

//Формируем полное готовое сообщение
string fullMessage = msHeader.ToString() + msLogon.ToString() + msTrailer.ToString();
Console.WriteLine(«Сообщение для отправки {0}»,fullMessage);

//Создаем сокет для подключения
sSender = new Socket(ipAddr.AddressFamily, SocketType.Stream, ProtocolType.Tcp);
//Подключаемся
sSender.Connect(ipEndPoint);
Console.WriteLine(«Сокет соединился с {0} », sSender.RemoteEndPoint.ToString());


byte[] msg = Encoding.UTF8.GetBytes(fullMessage);
//Отправляем сообщение
int bytesSent = sSender.Send(msg);
Console.WriteLine(«Отправил {0} байт», bytesSent.ToString());


//Получаем ответ от сервера
byte[] bytes = new byte[1024];
int bytesRec = 0;
bytesRec = sSender.Receive(bytes);
Console.WriteLine(«Ответ от сервера: {0}», Encoding.UTF8.GetString(bytes, 0, bytesRec));


Все таки приложу и в виде картинок. Так наглядней. Кликабельно.
Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#
Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#
В результате мы запросили у сервера подключение с нашим логином. И получили от него ответ.
Изучаю FIX протокол с нуля. Разбор протокола, первый код на c#
По мере развития, буду продолжать с теоретической частью. Если модераторы перенесут в раздел «Алго», я не против.

Продолжение Изучаю FIX протокол с нуля. Рисуем и программируем дальше.

Опционы - конструкция дикий кошак :)

В прошлом посте http://smart-lab.ru/blog/308980.php я достаточно жёстко получил от ребят, которые не принимают мысль о вохможности продажи непокрытых опционов.

Поэтому, в честь выходного дня, я решил выложить простую и очень надёжную конструкцию — дикий кошак)

Опционы - конструкция дикий кошак :)

Суть очень простая — это комбо из колл и пут опционных ловушек.

Опционы - конструкция дикий кошак :)

На экспире поза прибыльна от 72620 до 84130. Более двенадцати (12 !!!!!!) рублей прибыльный купол. Дельта нулевая, тетта за нас. При уходе за край нужен всего 1 фьюч, чтобы выровнять дельту.

Думаю вскоре опробовать такую конструкцию на практике. Особенно, когда до экспиры остаётся совсем чуть-чуть времени. Жду очередного критического пинка от профи опционов.

Есть эксперты по Qiuk ?? need help...

подскажите плз можно ли в квике встроенныеми средствами создать график BRX5*SIZ5 тиковый ??

Как торговать популярную арбитражную стратегию.

Здравствуйте,
Я арбитражный трейдер. Торгую с 2007 года. Начинал, как и многие с простой направленной торговли, какие проблемы тогда были, купи в лонг на всё и стриги купоны.
В 2008, пришло осознание, что биржа это не халява, а место где нужно думать. Думать стал в сторону снижения рисков, узнал про арбитраж и с тех самых пор только им и занимаюсь.
Пару лет назад, после выноса нескольких арбитражных пар, решил изучит опционы. Так же прошёл путь от простой покупки или продажи, и в конце концов вернулся к арбитражу, но только теперь уже более сложному с фьючерсами и опционами.  С мая месяца торгую стратегию Call Put паритет. Так как ручной арбитраж это из области не очевидного и мало вероятного, то написал специальную программу для автоматизации управления заявками. О чём и решил поделиться с сообществом.

 Торговая стратегия Call Put паритет обладает одним уникальным свойством, после того как вы зашли в сделку, прибыль в позиции не изменяется, это всегда одно и тоже значение при любой цене базового актива. Т.е. абсолютная рыночная нейтральность.

( Читать дальше )

Мутим робота на коленке. Часть "очередная"

На этот раз для фьючерса Si.

Проверим закономерность: Если в час Х цена выше (ниже) чем закрытие прошлой вечерней сессии то покупаем (продаем) и что-нибудь делаем с позицией для достижения успеха.
Получаем: (с 2009 года по сейчас)
Мутим робота на коленке. Часть "очередная"

Мутим робота на коленке. Часть "очередная"

( Читать дальше )

Сделай робота САМ 4

Собрал еще один алгоритм, в программе TSLab по просьбе одного из участников Смарт-Лаба, цель была в следующем: обьяснить роботу, чтобы на дневном таймфрейме создать фильтр и применить его на меньшем таймфрейме в частности часового графика. 
 
 
Новый видеоурок будет или по запросу участников, если же не поступит предложений, то сделаю очередную импровизацию.

Мой самый первый робот

Когда начинал свой путь в алготрейдинге, мозги взрывались от того, что было непонимание, как делать систему, на основе чего, и что должно получиться в итоге!
Помог мне в этом человек как писал уже раньше, Алексей (777), дал замечательный толчок в развитии, и тут понеслось… Сделал не мало роботов за третий уже год, но пост о моем самом первом роботе, которого запустил в торговлю и собрал своей логикой.
Мой самый первый робот
 
Как видно на графике система трендовая. то есть поймала тренд и давай тянуть, но если на рынке флет то раздавать будет пока не поймает новый тренд.
Далее хочу пояснить, на форуме тслаб уже была практика мною одного мини-конкурса! я выкладывал скрины сделок и предлагал ребятам разобраться на основе чего и как торгует робот! Предлагаю тоже самое смарт-лабу! forum.tslab.ru/ubb/ubbthreads.php?ubb=showflat&Number=46803#Post46803 читать можно сначала а можно со страницы 5-10 там конкретно разбирается алгоритм по горизонтальному объему.  


( Читать дальше )

принципы Рэя Далио.

Это самое лучшее, что я читал в своей жизни. Почему? Потому что это выглядит так, как будто это я сам написал в 60 лет письмо в прошлое себе 30-летнему, по большому секрету.

Написанное Рэем Далио очень живо пересекается с рядом моих философских выводов, которые я успел сделать по жизни.

о реальности: dr-mart.livejournal.com/10136.html
развитие идей реальности: smart-lab.ru/blog/notes/43.php
концепция равновесия: http://smart-lab.ru/blog/mytrading/16591.php
формула счастья: smart-lab.ru/blog/notes/31.php
работа над ошибками (пример): smart-lab.ru/blog/mtrading/7499.php
о роли цели: smart-lab.ru/blog/48396.php
о дисциплине: smart-lab.ru/blog/92360.php
о независимости мышления: smart-lab.ru/blog/94275.php
 
Многие мои из описанных выше идей вызывали насмешки у публики.
Это видно по комментариям к каждой из записей.
Я всегда их читал, но мне честно говоря было наплевать на насмешки, потому что я формировал свое представление об устройстве мира.

И вот я встречаю вот это:
http://www.bwater.com/Uploads/FileManager/Principles/Bridgewater-Associates-Ray-Dalio-Principles.pdf

Это чтиво, которое полностью пересекается с тем, что я вывел до этого. Более того, чтиво более систематизировано и имеет вполне завешенный вид. В отличие от меня, Далио, применяя эти концепции, добился большого успеха в жизни, доказав работу этих принципов.

Я немного законспектировал эти принципы и хочу предложить их наиболее думающим из вас. Конспектировал для себя, поэтому местами выглядит сумбурно.

***


( Читать дальше )

Как работает поддержка у брокера openecry?

Вот решил поделиться перепиской с поддержкой брокера OEC openecry.
Получить демо-доступ вы сможете только после разговора по телефону. 


Как работает поддержка у брокера openecry?


( Читать дальше )

....все тэги
UPDONW
Новый дизайн