Избранное трейдера Петр Петров

по

Моя система маней-менеджмента

    • 16 мая 2016, 11:34
    • |
    • SciFi
  • Еще

Решил поделиться своей системой маней-менеджмента.

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

Как я к ней пришел:
1. Играл и изучал покер, он во многом похож на трейдинг. Так же не гарантируется профит несмотря ни на какие карты. Нужен маней-менеджмент, чтобы не слиться в ноль слишком рано и дать статистике работать. 
2. Читал Нассима Талеба, он рекомендует на 10% ловить Черного Лебедя, 90% держать в облигациях.
3. Изучал ребалансировку и пробовал ее на деле — она работает.
4. Читал про оптимальную f, критерий Келли, послушал рекомендации уменьшить плечи разных людей.  

У меня есть два субсчета:
1. Безрисковый. (не менее 75% от общего счета, риск около 0%, либо сильно диверсифицированный портфель, покупаемый на лоях РТС, либо ОФЗ, либо валюта во время валютного тренда)
2. Рисковый. (не более 25% от общего счета, используется для смелой спекулятивной торговли)

Почему именно 25%? Это оптимальная f (доля) счета, которой следует рисковать при игре с подбрасыванием монетки, где профит в 2 раза больше потери. Если рисковать большей долей, возникает убыток пересчета и счет начинает расти медленнее, хотя и используются, казалось бы, большие объемы в системе с положительным мат. ожиданием. Я считаю приближенно, что моя торговля примерно такая же как при таком подбрасывании монетки. Иногда хуже, иногда лучше. Но стремиться нужно, чтобы она была лучше.

Кроме этого, после просадки 25% восстановиться реально. Такую просадку получают многие торговые системы и даже инвесторы во время кризисов. Нужно сделать около 30% к оставшемуся счету.Н апример, пусть было 100 рублей. 25 рублей от оставшихся 75 — это 30%. И есть еще как минимум 3 шанса поторговать. А вот после просадки общего счета на 80-90% восстановиться нереально сложно. Нужно сделать тысячи процентов, чтобы восстановиться с 10%. Я уже один раз так слился и очень долго после этого восстанавливался. 



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

Отчет от СМЕ по нефти на 10.05.

По отчетам сот видим что набирают своп-дилеры и производственники больше лонгов.
Отчет от СМЕ по нефти на 10.05.

Хеджирование портфеля акций от падения опционами.

У инвесторов во время падений рынка часто возникает  проблема «бумажных» убытков.Пересиживать просадку бывает некомфортно, а сдавать портфель в рынок убыточно.Это спреды в низколиквидных акциях, потеря налоговых льгот(при удержании акций более 3-х лет не платится НДФЛ), возможно даже потеря доли в акциях недопустима по каким либо причинам.В этом случае можно прибегнуть к хеджированию.Причём хедж в традиционном понимании -это опционы.Если будет падение и мы купили путы мы не чего не теряет, если будет рост(с падением мы не угадали) мы берём рост акциями и платим только временную стоимость пута.Проблема вобщем то в том что если мы берём путы около денег то соотношение риск-доход у нас получается плохим даже при «армагеддоне».Путы около денег стоят дорого.В то же время для инвестора  неприятно именно сильное падение стоимости портфеля акций, а легкие падения некритичны.Исходя из этого обстоятельства, более интересно выглядит хедж дальними опционами  вне денег с применением проданных опционов т.е. мы покупаем дальние дешёвые путы вне денег и в этом же количестве продаём ещё более дальние путы вне денег и компенсируем часть временного распада купленных опционов.Соотношение риск-прибыль получается гараздо более интересное, но рынку нужно пролететь большее расстояние что бы хедж сработал.Но на то он и «чёрный лебедь» что бы пролетать большие расстояния.Хедж этот имеет место только при серьёзных опасениях обвала рынка, а лучше когда рынок уже полетел вниз.

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

Про бросить работу и уйти в трейдинг.

Некоторые Великие Компании Ресурса Смарт-Лаб, призывают бросить работу и торговать внутри дня.

Они пишут, через 6 мес — вы начнете стабильно зарабатывать. Нужно лишь посвятить несколько часов в день для торговли и обучения.

Они — ЛГУТ.

1. Обучение от года до трех, по 10 часов в день, если ваш учитель — Супер Профи.
2. Потом, если у вас несколько Высших образований и Вы ГЕНИЙ, Вам еще пару лет, на то, чтобы познать рынок.

Итого, период обучения лет 5, если у вас есть миллионов пять деревянных.

3. Далее, только начнется Ваш ТЕСТ.

Вам нужна фикс комиссия и счет от 5-7 млн., чтобы у Вас просто появился ШАНС.

Я 20 лет в рынке, не слушайте вы сопляков, которые сами торговать не умеют и не научатся. Вместо того, чтобы самим что-то узнать, пытаются выманить последние деньги у наивных лохов.

Я поставлю правильные тэги к моему опусу.

Собственные впечатления от торговли на Америке и на России.

Работаю на американском рынке через брокера Interactivebrokers (IB) чуть меньше года, впечатления только положительные. На российском рынке на FORTS около четырех месяцев, работаю через Промсвязьбанк, за это время связь с биржей прерывалась раза четыре, от десяти минут до часа, через IB ничего подобного не было. Причина естественно не в брокере, надежность российского рынка просто никакая, нет никакой гарантии, что войдя в краткосрочную позицию работа биржи тут же не оборвется. Но с другой стороны комиссия FOTRS на фьючерсах за одну сделку 0.6руб против 1$-2.5$ на америке дает волю фантазиям для оттачивания торговых стратегий. С IB торговать фьючерсами можно практически круглосуточно, т.к. торговля поддерживается практически на всех финансовых рынках мира. Но с небольшим депо на америке фьчерсами торговать очень рисковано, например, ГО на нефть BRENT составляет 5000$ при цене шага 10$. С одной стороны при успешной стратегии и прибыль получается достаточно большая, но с другой стороны, если брать контракт на среднесрок, то даже небольшая просадка с легкостью может поглотить ваше депо.

R. Считаем корреляцию.

Вчера на СмартЛабе  был размещен пост Как построить корреляционную матрицу (для парной торговли) в Excel, собравший аж 150 "+".
Решил тоже попрактиковаться и написать под эту задачу код в R. Важным преимуществом R является наличие пакета rusquant, который позволяет автоматически получать котировки с Финам в любом таймфрейме (в т.ч. в тиках), что существенно экономит время по сравнению с ручной обработкой в Excel.

Код на R приведен ниже:

R. Считаем корреляцию.

  • Файл c кодом можно скачать тут.
  • Файл с названиями тикеров: для примера 1 тут, для примера 2 тутЭти файлы используется для ввода тикеров в программу, т.к. прописывать тикеры вручную непосредственно в коде при их большом количестве не удобно. 
  • Время загрузки данных с Финам по 79 тикерам составило 84 секунды, т.е. примерно по 1 сек. на тикер. А сколько бы ушло на ручную загрузку для Excel сложно представать.

 

Результаты:



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

Как выйти на американский рынок?

Как выйти на американский рынок?

Суть в том, что скажем часть денег необходимо вложить в акции компаний США. Варианты:

— СПБ биржа, через нашего крупного брокера и нашего депозитария. Список доступных акций будет в районе 60 шт. самых ликвидных. Но хотелось бы иметь доступ ко всем торгуемым акциям скажем Nyse и Nasdaq. Для этого у рос. брокера необходимо получить статус квалифицированного инвестора. Чтобы его получить, нужно иметь капитал или ДС на счете от 6 лямов, либо иметь сделок с бумагами за последние 4 квартала на такую же сумму, либо же иметь экономическую вышку по специальности рынок ЦБ. (Кстати у меня есть высшее эконом. образование по специальности «Фин. и кредит», со специализацией РЦБ, гос. ВУЗа) Но вопрос какие вузы относятся к данным критериям не понятно и список таких ВУЗов я не нашел. Либо любой из следующих аттестатов и сертификатов: квалификационный аттестат специалиста финансового рынка, квалификационный аттестат аудитора, квалификационный аттестат страхового актуария. В общем положим и такой статус я получить не могу, то остается при таком варианте инвестировать в акции из перечня 60 которые предлагает СПБ биржа.



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

Изучаю 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 протокол с нуля. Рисуем и программируем дальше.

О прогнозировании временных рядов

    • 27 января 2016, 10:32
    • |
    • cerenc
  • Еще

Как учат классики, рациональной основой прогнозирования, является – априорная вероятность, например цены.

Стратегия « регрессия к среднему » в качестве такого априорного значения определяет среднее значение временного ряда, однако, его продолжительность не устанавливает.

 В одной из статей по этому вопросу Тайлер Чессман http://www.osp.ru/win2000/2013/10/13037710/ отмечает

 « Работая с временным рядом, история которого уходит далеко в прошлое, вы можете захотеть включить в модель все исторические данные. Однако подчас дополнительная история не повышает точность прогнозирования.  Давние данные могут даже исказить прогноз, если условия в прошлом существенно отличаются от условий в настоящем...

 Мне не попадалась какая-то особая формула или практический метод, которые подсказали бы, какое количество исторических данных необходимо включить...».

 Учитывая, что Чессман, не математик, какова практика решения этого вопроса более обоснованным образом...?!  


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