Подсчет PnL трейда
Atom
21.02.2014
devruss


Что-то никак не могу разобраться как правильно считать PnL в S#.

Обычно, PnL = size * (buy price - sell price) * direction sign , где direction sign = 1 if long, = -1 if short.

Теперь как считает S#: [code=csharp] NEW long: price: 141010, position: 0, totalvolume: 247, PnL: 0 Actual execution: 140940 TP: price: 140700, position: 1, PnL: 70.000000000 Actual execution: 140790 [/code] Где price - это цена заявки, actual execution - то как заявка исполнилась в реальности, TP - означает, что робот решил взять прибыль, ПОТОМУ ЧТО он посчитал, что PnL > 0.

PnL посчитан из стратегии методом MyTrades.Last().GetPnL()

Я всегда считал, что если купил по 140940, а рынок на 140750, то я в минусе, а именно -190.

Далее, в чем считается PnL? В рублях или пунктах индекса?

Если в рублях, то должно быть (-141010+140790) * 7 рублей MinStepPrice / 10 MinStepSize = -154 рубля (без учета комиссии)

Инструмент настроен так: [code=csharp] security = new Security { Id = "RIH4@FORTS", // по идентификатору инструмента будет искаться папка с историческими маркет данными Code = "RIH4", Name = "RTS-3.14", MinStepSize = 10, MinStepPrice = 7, //MinPrice = 10, //MaxPrice = 1000000, MarginBuy = 10000, // задаем ГО MarginSell = 10000, ExchangeBoard = ExchangeBoard.Forts, }; [/code]


Теги:


Спасибо:


< 1 2 
devruss

Фотография
Дата: 26.02.2014
Ответить


Есть 2 типа PnL - realized и mark-to-market (unrealized). Realized PnL - это PnL уже полностью закрытой позиции, т.е. реализованный PnL. Realized PnL = (position close price - position open price) * direction sign , где direction sign = 1 if long, = -1 if short. Пример - купили RIH4 по 140000, продали по 140100, заработали 100 = (140100 - 140000) * 1

Теперь с mark-to-market. Каждый шаг (раз в секунду, минуту, на каждом тике и т.д.) вы считаете PnL как если бы вы закрыли позицию сейчас. Т.е. MtM PnL = (Current price - position open price) * direction sign. Пример - купили RIH4 по 140000 минуту назад, RIH4 сейчас стоит 1405000, значит наш MtM PnL = (140500 - 140000) * 1 = 500 - но это нереализованная прибыль, так как мы еще в позиции.

MtM PnL можно управлять, так как от него можно выставлять take profit, stop loss, всяческие risk-off стратегии и т.д. Пока из того, что я вижу - MtM PnL позиции не реализован. Это не сложно написать самому, но было бы проще пользоваться уже готовым функционалом, чтобы не встраивать свои модули каждый раз.

P.S. понятно, что объяснение упрощенное. Я не учитывал комиссии, bid/ask спред, что long должны маркироваться по биду, а shorts по офферу и т.д.

Спасибо: loop

loop

Фотография
Дата: 26.02.2014
Ответить


Понятно, благодарю. Но в S# есть и стоплос и тейкпрофит ,а их никак по другому детектить нельзя кроме как анализируя MtM, значит где то «внутри» есть такие данные. К тому же это информация важна для вычисления некоторых важных статистик например MFE\MAE и тп. Палюбому эти данные есть.

Спасибо:

devruss

Фотография
Дата: 26.02.2014
Ответить


[quote=loop;29822]Понятно, благодарю. Но в S# есть и стоплос и тейкпрофит ,а их никак по другому детектить нельзя кроме как анализируя MtM, значит где то «внутри» есть такие данные. К тому же это информация важна для вычисления некоторых важных статистик например MFE\MAE и тп. Палюбому эти данные есть. [/quote]

Stoploss, takeprofit можно и по другому делать - например вход в трейд, и мгновенное выставление 2х заявок на takeprofit & stoploss, что-то типа котирования. При срабатывании одной из этих заявок, вторая снимается

Как S# реализует stoploss/takeprofit мне пока неизвестно

Спасибо:

loop

Фотография
Дата: 27.02.2014
Ответить


[quote=devruss;29830] Stoploss, takeprofit можно и по другому делать - например вход в трейд, и мгновенное выставление 2х заявок на takeprofit & stoploss, [/quote] Это рекурсия))

А так SL и TP могут быть устроены? Вариантов не много.

По логике SL и TP, устроены следующим образом:

  1. От текущего ценовой ряда отнимается величина по которой зафиксирован ордер. То есть тот самый MtM = p(t) – p(open)
  2. Для ТР сигнал это MtM*dir > TPvalue
  3. Для SL сигнал это MtM*dir < SLvalue

Как реализовать SL и TP без внутреннего вычисления MtM? Врядле это возможно. MtM = (p(t) – p(open))*dir обязан быть в потрохах S#

Спасибо:

Bond

Фотография
Дата: 27.02.2014
Ответить


Вы о чем? [biggrin] Тейк-профит и стоп-лосс стандартные заявки и они в S# не высчитываюися. Все срабатывания и выставления происходят в терминале и на бирже.

Спасибо:

devruss

Фотография
Дата: 27.02.2014
Ответить


[quote=Bond;29843]Вы о чем? [biggrin] Тейк-профит и стоп-лосс стандартные заявки и они в S# не высчитываюися. Все срабатывания и выставления происходят в терминале и на бирже.[/quote]

Ну строго говоря, take profit ордеров нет - http://en.wikipedia.org/wiki/Order_(exchange)

Я не понимаю смысла использовать в алготрейдинге любые биржевые заявки кроме лимитных и по-рынку. Алго дает возможность все реализовать самому и не светить свои позиции и стратегии + следить за рынком с большой эффективностью. Так что под stop-loss/take-profit я понимаю скорее стратегию, нежели тип ордера

Спасибо:

Bond

Фотография
Дата: 27.02.2014
Ответить


[quote=devruss;29847][quote=Bond;29843]Вы о чем? [biggrin] Тейк-профит и стоп-лосс стандартные заявки и они в S# не высчитываюися. Все срабатывания и выставления происходят в терминале и на бирже.[/quote]

Ну строго говоря, take profit ордеров нет - http://en.wikipedia.org/wiki/Order_(exchange)

Я не понимаю смысла использовать в алготрейдинге любые биржевые заявки кроме лимитных и по-рынку. Алго дает возможность все реализовать самому и не светить свои позиции и стратегии + следить за рынком с большой эффективностью. Так что под stop-loss/take-profit я понимаю скорее стратегию, нежели тип ордера

[/quote]

Полностью с Вами согласен!

Спасибо:
< 1 2 

Добавить файлы через драг-н-дроп, , или вставить из буфера обмена.

loading
clippy