Подсчет 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#:
Код

NEW long: price: 141010, position: 0, totalvolume: 247, PnL: 0
Actual execution: 140940
TP: price: 140700, position: 1, PnL: 70.000000000
Actual execution: 140790

Где price - это цена заявки, actual execution - то как заявка исполнилась в реальности, TP - означает, что робот решил взять прибыль, ПОТОМУ ЧТО он посчитал, что PnL > 0.

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

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

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

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

Инструмент настроен так:
Код

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,
            };

Теги:


Спасибо:


< 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
Ответить


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


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

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

loop

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


devruss

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

Это рекурсия))

А так 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
Ответить


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


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

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

Спасибо:

Bond

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


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


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

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



Полностью с Вами согласен!
Спасибо:
< 1 2 

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

loading
clippy