S# 4.0 MQS не перестает работать при превышении лимита счета

S# 4.0 MQS не перестает работать при превышении лимита счета
Atom
9/29/2011
dart


Если стратегия задает MQS котировать ордер с количеством контрактов, превышающим лимит счета, начинают очень быстро сыпаться месседжи, что размера счета не хватает и в конечном итоге робот просто вылетает.
В ранних версиях помню просто выскакивало всего одно сообщение и котирование просто останавливалось (это в окне мониторинга было видно), и робот не вылетал.
Можно сделать как раньше было?

Tags:


Thanks:


1 2  >
Mikhail Sukhov

Avatar
Date: 9/29/2011
Reply


dart
Если стратегия задает MQS котировать ордер с количеством контрактов, превышающим лимит счета, начинают очень быстро сыпаться месседжи, что размера счета не хватает и в конечном итоге робот просто вылетает.
В ранних версиях помню просто выскакивало всего одно сообщение и котирование просто останавливалось (это в окне мониторинга было видно), и робот не вылетал.
Можно сделать как раньше было?


Как стабильного робота в данном случае зависит от MQS?
Thanks:

dart

Avatar
Date: 9/29/2011
Reply


Mikhail Sukhov

Как стабильного робота в данном случае зависит от MQS?

Как стабильность робота зависит?
Он просто вылетает весь, со всеми стратегиями, когда кол-во сообщений становится очень большим (подсчитать не представляется возможным). То есть заново приходится его запускать.
Кроме того процессор грузится на 100 %
Thanks:

Mikhail Sukhov

Avatar
Date: 9/29/2011
Reply


А чему равно Strategy.MaxErrorCount?
Thanks:

dart

Avatar
Date: 9/29/2011
Reply


Mikhail Sukhov
А чему равно Strategy.MaxErrorCount?

Сорри, не знаю. Надо заново промоделировать ситуацию. В данный момент пока S#4.0 не могу запустить (почему то инструменты не находит). Сейчас опять S#3.1.8 запустил.
Thanks:

Mikhail Sukhov

Avatar
Date: 9/29/2011
Reply


dart
В данный момент пока S#4.0 не могу запустить (почему то инструменты не находит).


ITrader.ProcessDataError
Thanks:

dart

Avatar
Date: 10/4/2011
Reply


dart

В данный момент пока S#4.0 не могу запустить (почему то инструменты не находит). Сейчас опять S#3.1.8 запустил.

Опять не могу подключить S# 4.0. Та же самая ситуация. Робот вылетел, второй раз подключиться не могу.
_trader.ProcessDataError += ex => this.GuiAsync(() => MessageBox.Show(this, ex.ToString())) ничего не выдает.
В MainWindow выполняется TryCreateStrategy. Внутри неё перед проверкой
if (_lkoh != null && _frts != null && _fgazp != null && _micex != null)
вывожу в файл:
outStream.WriteLine("Time = {0} test TryCrStr, _lkoh = {1}, _frts = {2}, _fgazp = {3}, _micex = {4}", _trader.MarketTime, _lkoh.ToString(), _frts.ToString(), _fgazp.ToString(), _micex.ToString());
Все бумаги и портфель выводит правильно, но вылетает ошибка, что на этой строке в экземпляре объекта не задана ссылка на объект.
Как так может быть, если правильно выводит, то все должно быть задано по идее.
3.1.8 подключается без проблем, да и 4.0 в первый раз подключается без проблем.
Thanks:

Alexander

Avatar
Date: 10/4/2011
Reply


dart
dart

В данный момент пока S#4.0 не могу запустить (почему то инструменты не находит). Сейчас опять S#3.1.8 запустил.

Опять не могу подключить S# 4.0. Та же самая ситуация. Робот вылетел, второй раз подключиться не могу.
_trader.ProcessDataError += ex => this.GuiAsync(() => MessageBox.Show(this, ex.ToString())) ничего не выдает.
В MainWindow выполняется TryCreateStrategy. Внутри неё перед проверкой
if (_lkoh != null && _frts != null && _fgazp != null && _micex != null)
вывожу в файл:
outStream.WriteLine("Time = {0} test TryCrStr, _lkoh = {1}, _frts = {2}, _fgazp = {3}, _micex = {4}", _trader.MarketTime, _lkoh.ToString(), _frts.ToString(), _fgazp.ToString(), _micex.ToString());
Все бумаги и портфель выводит правильно, но вылетает ошибка, что на этой строке в экземпляре объекта не задана ссылка на объект.
Как так может быть, если правильно выводит, то все должно быть задано по идее.
3.1.8 подключается без проблем, да и 4.0 в первый раз подключается без проблем.


посмотрите на LastTrade у инструмента, BestBid, BestAsk у стакана.
в новостях писал, что они теперь null по умолчанию.
Thanks:

dart

Avatar
Date: 10/4/2011
Reply


Alexander Mukhanchikov

посмотрите на LastTrade у инструмента, BestBid, BestAsk у стакана.
в новостях писал, что они теперь null по умолчанию.

Вывожу так:
outStream199.WriteLine("Time = {0} test tryCrstr inside _lkoh = {1}, _frts = {2}, _fgazp = {3}, _micex = {4}", _trader.MarketTime, _lkoh.LastTrade.Price, _frts.LastTrade.Price, _fgazp.LastTrade.Price, 0);
Все цены выводятся. Старые цены, правда, сейчас другие, но это наверно из-за того что все сделки ещё не прокачались. Стакан не выводил - я его позже начинаю экспортировать.
Ну а как это может повлиять, если инструменты правильно выводятся, значит они есть, нашлись. Значит всё должно работать
Thanks:

Alexander

Avatar
Date: 10/4/2011
Reply


dart
Alexander Mukhanchikov

посмотрите на LastTrade у инструмента, BestBid, BestAsk у стакана.
в новостях писал, что они теперь null по умолчанию.

Вывожу так:
outStream199.WriteLine("Time = {0} test tryCrstr inside _lkoh = {1}, _frts = {2}, _fgazp = {3}, _micex = {4}", _trader.MarketTime, _lkoh.LastTrade.Price, _frts.LastTrade.Price, _fgazp.LastTrade.Price, 0);
Все цены выводятся. Старые цены, правда, сейчас другие, но это наверно из-за того что все сделки ещё не прокачались. Стакан не выводил - я его позже начинаю экспортировать.
Ну а как это может повлиять, если инструменты правильно выводятся, значит они есть, нашлись. Значит всё должно работать


У вас "вылетел робот". стэк трэйса нет. у вас возник nre - нулевая ссылка на объект.
раз раньше работало - я высказал предположения с какими изменениями в S# это могло быть связано. других изменений больших не было.

без стэк трэйса никак.
Thanks:

dart

Avatar
Date: 10/4/2011
Reply


а как сделать стэк трэйс? Это он?
Mistake4_0.jpg 139 KB (218)
Thanks:
1 2  >

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

loading
clippy