Позиции роботов. Класс Position.

Позиции роботов. Класс Position.

Большинство роботов в OsEngine видят и управляют только своими личными позициями. Теми, которые хранятся только в журнале конкретного робота. Роботы открывают и закрывают позиции, управляют ими и видят их только у себя в журнале.

На картинке выше изображена разница между позицией на бирже (PositionOnBoard) и позициями (Positioin) у роботов. Из этой картинки Вы должны понять, что у роботов по одному инструменту может быть много позиций (и даже в разные стороны), а в портфеле на бирже она всегда одна.

 

1. Что такое позиция у робота?

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

Когда робот хочет выйти из какого-то актива, то робот должен закрыть позицию.

Для тех, кто торговал много лет только в Quik, данная концепция болезненна. Однако, это пришло в OsEngine из WealthLab, а это является мировым стандартом написания роботов уже много лет. Придётся очень плотно работать с этим классом и привыкать к такой абстракции.

В журнале робота позиции выглядят как таблица:

1. Открываем общий журнал у терминала.

2. Переходим во вкладку «Открытые позиции».

3. Перед нами соответствующая таблица.

 

2. Класс Position в OsEngine.

Посмотреть на него на ГитХаб можно здесь.

В самом проекте он находится тут:

Рассмотрим члены класса Position.

OpenOrders – публичное свойство типа List<Order>. Возвращает список всех ордеров, участвовавших в открытии данной позиции.

AddNewOpenOrder – публичный метод, добавляет входящий ордер, участвовавший в открытии позиции.

CloseOrders – публичное свойство типа List<Order>. Возвращает список всех ордеров, участвовавших в закрытии данной позиции.

MyTrades – публичное свойство типа List<MyTrade>. Возвращает список всех сделок, принадлежащих позиции.

AddNewCloseOrder – публичный метод. Добавляет входящий ордер, участвовавший в закрытии позиции.

OpenActiv – публичное свойство типа bool. Проверяет, есть ли в позиции активные ордера на открытие.

CloseActiv – публичное свойство типа bool. Проверяет, есть ли в позиции активные ордера на закрытие.

StopOrderIsActiv – публичное поле типа bool. Флаг активности стоп-лосса для позиции.

StopOrderPrice – публичное поле типа decimal. Содержит цену уровня стоп-лосса.

StopOrderRedLine – публичное поле типа decimal. Содержит цену, при достижении которой в торговую систему будет выслан реальный ордер по цене StopOrderPrice.

ProfitOrderIsActiv – публичное поле типа bool. Флаг активности стоп-профита для позиции.

ProfitOrderPrice – публичное поле типа decimal. Содержит цену уровня стоп-профита.

ProfitOrderRedLine – публичное поле типа decimal. Содержит цену, при достижении которой в торговую систему будет выслан реальный ордер по цене ProfitOrderPrice.

Direction – публичное поле типа Side. Указывает направление позиции. Используемые значения перечисления Side:

None - используется при создании объектов, когда направление не определено.

Buy - покупка, длинная позиция, лонг.

Sell - продажа, короткая позиция, шорт.

State - публичное поле типа PositionStateType. Отображает текущее состояние позиции. Рассмотрим подробнее все варианты перечисления:

None - объект только что был создан программой, и его состояние еще не было определено.

Opening - позиция находится в состоянии открытия. Данное состояние указывает на наличие активного ордера, участвующего в открытии позиции.

Done - закрыта. Указывает на успешное исполнение операции.

OpeningFail - ошибка открытия позиции. Устанавливается, если открывающий ордер был отменен или отвергнут торговой системой.

Open - успешное открытие позиции. Следует заметить, если открывающий ордер исполнился частично, позиция все равно будет считаться открытой.

Closing - находится в процессе закрытия. Данное состояние указывает на наличие активного или частично исполнившегося ордера.

ClosingFail - была неудачная попытка закрытия. Необходимо принять меры для закрытия.

ClosingSurplus - позиция была закрыта с переполнением, то есть исполненный объем в ордерах, закрывающих позицию, превышает аналогичный показатель в открывающих ордерах.

Deleted - был запрос на удаление позиции.

Number – публичное поле типа int. Хранит уникальный в рамках программы номер.

SecurityName – публичное строковое свойство. Предоставляет доступ к полю, хранящему наименование торгового инструмента, сделки по которому совершаются в рамках этой позиции.

NameBot – публичное строковое поле. Хранит название робота, которому данная позиция принадлежит.

ProfitOperationPersent – публичное поле типа decimal. Используется для хранения результата торговли в процентном отношении к цене открытия позиции.

ProfitOperationPunkt – публичное поле типа decimal. Используется для хранения результата торговли, выражаемое в шагах цены инструмента.

Comment – публичное строковое поле. Используется для хранения дополнительной информации, задаваемой пользователем.

SignalTypeOpen – общедоступное поле типа string. Содержит описание сигнала на открытие позиции. 

SignalTypeClose – общедоступное поле типа string. Содержит описание сигнала на закрытие позиции. 

MaxVolume – публичное свойство типа decimal, доступно только для чтения. Возвращает максимальный объем, исполненный в позиции.

OpenVolume – публичное свойство типа decimal. Доступно только для чтения. Возвращает открытый объем.

WaitVolume – публичное свойство типа decimal. Доступно только для чтения. Возвращает объем, выставленный на биржу и ожидающий открытия.

EntryPrice – публичное свойство типа decimal. Рассчитывает и возвращает средневзвешенную цену всех сделок, участвовавших в открытии позиции.

ClosePrice – публичное свойство типа decimal. Рассчитывает и возвращает средневзвешенную цену всех сделок, участвовавших в закрытии позиции.

MultToJournal – мультипликатор для анализа позиции. Используется для нужд платформы. ВАЖНО. Не изменять значение.

SetOrder – публичный метод. Вычисляет необходимое состояние позиции, используя для этого входящий ордер.

CalculateProfitToPosition – закрытый метод. Вычисляет значения полей ProfitOperationPersent и ProfitOperationPunkt.

SetTrade - публичный метод. Вычисляет необходимое состояние позиции, используя для этого входящую сделку.

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

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

SetDealFromString - общедоступный метод. Принимает строку, содержащую данные по всем полям, парсит ее и инициализирует состояние объекта.

TimeCreate – публичное свойство типа DateTime. Возвращает время создания позиции.

TimeClose - публичное свойство типа DateTime. Возвращает время закрытия позиции.

TimeOpen - публичное свойство типа DateTime. Возвращает время открытия позиции.

ProfitPortfolioPersent – публичное свойство типа decimal. Возвращает размер прибыли/убытка позиции относительно портфеля в процентах.

ComissionType – публичное поле типа ComissionType. Определяет способ расчета комиссии. Перечисление ComissionType содержит следующие значения:

None - способ не задан.

Percent - в процентном соотношении.

OneLotFix - фиксированный размер на один лот.

ComissionValue – публичное поле типа decimal. Содержит значение, используемое для расчёта комиссии.

ProfitPortfolioPunkt – публичное свойство типа decimal. Возвращает количество прибыли/убытка относительно портфеля в абсолютном выражении, рассчитанное с учетом комиссии.

IsLotServer – приватный метод. Определяет, поддерживает ли биржа множественное количество бумаг в одном лоте.

CommissionTotal – публичный метод. Рассчитывает количество суммарной комиссии по позиции.

Lots – публичное поле типа decimal. Содержит количество бумаг инструмента в одном лоте.

PriceStepCost – публичное поле типа decimal. Содержит стоимость минимального движения цены по инструменту.

PriceStep – публичное поле типа decimal. Содержит размер минимально возможного движения цены.

PortfolioValueOnOpenPosition – публичное поле типа decimal. Содержит размер портфеля на момент создания позиции.

Поддержка OsEngine: https://t.me/osengine_official_support

 

18:38
557
FAQ

Комментарии

Нет комментариев. Ваш будет первым!