Серьезный трабл с ассинхронным режимом

Серьезный трабл с ассинхронным режимом
Atom
7/7/2010
Tauler


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

Это преамбула. (бага на версии 2.0.1, т.к. с 2.1 у меня известные вам траблы)

Амбула - т.к. режим асинхронный, когда уходит сигнал, успевает пройти запрос на снятие раз 15, прежде чем заявка снимется и поменяет статус на Canceled, у меня как только заявка становится Canceled или Matched срабатывает ветка в коде, кторая проверяет Volume-Blance и на эту разницу выкидывает вторую заявку (если Canceled), либо (если Matched) выкидывают вторую заявку на Volume первой.И у меня складывается ощущения, что в какой то момент сбивается или нарушается (не знаю как скзаать) процесс обновления полей в экземпляре заявки. Как эт овыглядит (в прилагаемом скрине, я далее для удобства буду давать только послдение 4 цифры номера заявки)

Сработал сигнал, выставилась заявка 6984, сигнал ушел, я отправляю trader.CancelOrder(order) до тех пор пока order.State != Canceled. как только Canceled, делаю order = null и дальше слушать сигнал.В логах так и написано - заявка стала Canceled, Balance = 2

Сигнал срабатывает второй раз, выставялю снвоа заявку order = new Order () .... (перменная та же самая), trader.RegisterOrder(order). Высталяется заявка (номер у нее 8248) Что происходит далее - на бирже заявка исполняется, но сигнал уходит. Робот честно пытается ее отменить до тех пор, пока статус у нее Active. как только статус заявки меняется на Исполнена(в квике), робот видит изменение статуса, но! в логах пишет мне что заявка Canceled, и Balance у нее 2. (то есть данные из заявки 6984). ну и соответсвенно не выкидаывает правую часть. и другая бага (наверно изза тгого, что уходит 10-15 запросов на снятие заявки до тех пора пока она станет Canceled - были случаи ,когда аявки часто тсавилис снимались, что например идут заявки 1,2,3,4,5,6 , они выставляются- снимают, но по логам заявка под номером например 4 вообще не снималась.То есть робот ее не снимал.Может быть это изза тго, что между первым запросом на снятие и реальным изменением ее статуса на Canceled на сервер уходит штук 15 транзакций на снятие?

скрин списка заявок - файл 07.07.png


Tags:


Thanks:


< 1 2 3 4  >
Mikhail Sukhov

Avatar
Date: 7/7/2010
Reply


... если этот поможет.

Thanks:

Tauler

Avatar
Date: 7/7/2010
Reply


Блин опять то же самое :( не помогла генерация транзакций.

Thanks:

Mikhail Sukhov

Avatar
Date: 7/7/2010
Reply


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

Thanks:

Tauler

Avatar
Date: 7/7/2010
Reply


в сделке кторая пришла по событию баланс - 0, а в переменной - 4.

вот лог из консоли

Done branch, Order Id = 1882934524, Balance = 4 - эт ов основном цикле, ветка Status = Done

а это лог из OrderChanged 15:27:03,968 - OrderId = 1882934524 State = Done Bal = 0 TrId = 55471 Time = 15:27:03 15:27:03,968 - OrderId = 1882934524 State = Done Bal = 0 TrId = 55471 Time = 15:27:03 15:27:03,968 - OrderId = 1882934524 State = Done Bal = 0 TrId = 55471 Time = 15:27:03

Thanks:

Tauler

Avatar
Date: 7/7/2010
Reply


Переменная эта используется в Workflow, а воркфолоу работает в своем потоке. может изза этого?

Thanks:

Tauler

Avatar
Date: 7/7/2010
Reply


смотрите как интересно - как будто заявка сразу считается снята. это может быть отго, что бросается масса заявок на снятие?

он выполняет ветку кторая if (State == Done), а потом еще приходит 3 события OrderChaged.

15:47:52,656 - OrderId = 1883161388 State = Active Bal = 4 TrId = 56280 Time = 15:47:51 15:47:52,656 - OrderId = 1883161388 State = Active Bal = 4 TrId = 56280 Time = 15:47:51 15:47:52,765 - OrderId = 1883161388 State = Done Bal = 4 TrId = 56280 Time = 15:47:51

Thanks:

Tauler

Avatar
Date: 7/7/2010
Reply


в общем щас еще раз поймаю - напишу сюда последовательность.

Thanks:

Tauler

Avatar
Date: 7/7/2010
Reply


Забрела ко мне в голову идея - может вы сперва в заявке статус обновляете, а потом баланс?

Thanks:

Tauler

Avatar
Date: 7/7/2010
Reply


Поймал. вот что мы имеем

16:59:23,578 - Buy left part spread start. SRU0 BA = 7567, SBER03 BB = 75,4 16:59:23,578 - Buy left part spread end. SRU0 BA = 7567, SBER03 BB = 75,4 Это вставил заявку в результате срабатывания сигнала

16:59:24,093 - Check open long spread order. A = 35,125000, ? = 39,0, (A-?*?) = 41,125000, signal is 0 < 39,0 - 41,125000 <= 2, alpha = 6, sigma = 1 16:59:24,093 - Prices: SRU0 BA = 7570, SBER03 BB = 75,3 16:59:24,093 - Try cancel order 1883929777, State = Active, Status = Done 16:59:24,093 - Canceling succesful это проверка сигнала. в данном случае сигнал ушел, поэтому мы отменяем заявку.Проверяем и отменяем в цикле до тех пор, пока статус не станет Done. Canceling succesful - т.к. режим ассинхронный, и CancelOrder не вызывает исключений

16:59:24,109 - Check open long spread order. A = 35,125000, ? = 39,0, (A-??) = 41,125000, signal is 0 < 39,0 - 41,125000 <= 2, alpha = 6, sigma = 1 16:59:24,109 - Prices: SRU0 BA = 7570, SBER03 BB = 75,3 16:59:24,109 - Try cancel order 1883929777, State = Active, Status = Done 16:59:24,109 - Canceling succesful 16:59:24,125 - Check open long spread order. A = 35,125000, ? = 39,0, (A-??) = 41,125000, signal is 0 < 39,0 - 41,125000 <= 2, alpha = 6, sigma = 1 16:59:24,125 - Prices: SRU0 BA = 7570, SBER03 BB = 75,3 16:59:24,125 - Try cancel order 1883929777, State = Active, Status = Done 16:59:24,125 - Canceling succesful 16:59:24,140 - Check open long spread order. A = 35,125000, ? = 39,0, (A-??) = 41,125000, signal is 0 < 39,0 - 41,125000 <= 2, alpha = 6, sigma = 1 16:59:24,140 - Prices: SRU0 BA = 7570, SBER03 BB = 75,3 16:59:24,140 - Try cancel order 1883929777, State = Active, Status = Done 16:59:24,140 - Canceling succesful 16:59:24,156 - Check open long spread order. A = 35,125000, ? = 39,0, (A-??) = 41,125000, signal is 0 < 39,0 - 41,125000 <= 2, alpha = 6, sigma = 1 16:59:24,156 - Prices: SRU0 BA = 7570, SBER03 BB = 75,3 16:59:24,156 - Try cancel order 1883929777, State = Active, Status = Done 16:59:24,156 - Canceling succesful 16:59:24,171 - Check open long spread order. A = 35,125000, ? = 39,0, (A-??) = 41,125000, signal is 0 < 39,0 - 41,125000 <= 2, alpha = 6, sigma = 1 16:59:24,171 - Prices: SRU0 BA = 7570, SBER03 BB = 75,3 16:59:24,171 - Try cancel order 1883929777, State = Active, Status = Done 16:59:24,171 - Canceling succesful 16:59:24,187 - Check open long spread order. A = 35,125000, ? = 39,0, (A-??) = 41,125000, signal is 0 < 39,0 - 41,125000 <= 2, alpha = 6, sigma = 1 16:59:24,187 - Prices: SRU0 BA = 7570, SBER03 BB = 75,3 16:59:24,187 - Try cancel order 1883929777, State = Active, Status = Done 16:59:24,187 - Canceling succesful 16:59:24,203 - Check open long spread order. A = 35,125000, ? = 39,0, (A-??) = 41,125000, signal is 0 < 39,0 - 41,125000 <= 2, alpha = 6, sigma = 1 16:59:24,203 - Prices: SRU0 BA = 7570, SBER03 BB = 75,3 16:59:24,203 - Try cancel order 1883929777, State = Active, Status = Done 16:59:24,203 - Canceling succesful 16:59:24,218 - Check open long spread order. A = 35,125000, ? = 39,0, (A-??) = 41,125000, signal is 0 < 39,0 - 41,125000 <= 2, alpha = 6, sigma = 1 16:59:24,218 - Prices: SRU0 BA = 7570, SBER03 BB = 75,3 16:59:24,218 - Try cancel order 1883929777, State = Active, Status = Done 16:59:24,218 - Canceling succesful

и вот на этом месте статус меняется, но баланс все равно 4, и робот уходит в ветку, где статус = Done и IsFilledEmpty = true. Хотя на деле баланс = 0.

А дальше идет лог из OrderChaged:

16:59:24,546 - OrderId = 1883929777 State = Done Bal = 0 TrId = 60554 Time = 16:59:23 Now = 16:59:24.5468750 16:59:24,546 - OrderId = 1883929777 State = Done Bal = 0 TrId = 60554 Time = 16:59:23 Now = 16:59:24.5468750 16:59:24,546 - OrderId = 1883929777 State = Done Bal = 0 TrId = 60554 Time = 16:59:23 Now = 16:59:24.5468750

Thanks:

Mikhail Sukhov

Avatar
Date: 7/7/2010
Reply


Кажется я начинаю понимать. У Вас случаем не такой код?

while (order.Type != Done) { WriteLog(); }

if (order.Balance > 0) {

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

А почему Вы не работаете стандартным путем - через события. У Вас везде вечные циклы. Зачем все так сложно?

Thanks:
< 1 2 3 4  >

Attach files by dragging & dropping, , or pasting from the clipboard.

loading
clippy