Ошибка при переходе с 4.0.22 на 4.0.23

Ошибка при переходе с 4.0.22 на 4.0.23
Atom
4/13/2012
Lester


Всем доброго дня!

Настроен экспорт таблицы "Инструменты" с дополнительными колонками:

// Создание подключения к QUIK
_trader = new QuikTrader(path);

// Экпорт дополнительных колонок инструментов
var columns = _trader.SecuritiesTable.Columns;

columns.Add(DdeSecurityColumns.Strike);
columns.Add(DdeSecurityColumns.Volatility);
columns.Add(DdeSecurityColumns.UnderlyingSecurity);
columns.Add(DdeSecurityColumns.TheorPrice);
columns.Add(DdeSecurityColumns.OptionType);
columns.Add(DdeSecurityColumns.ExpiryDate);
columns.Add(DdeSecurityColumns.LastTradePrice);
columns.Add(DdeSecurityColumns.LastTradeVolume);
columns.Add(DdeSecurityColumns.LastTradeTime);
columns.Add(DdeSecurityColumns.BestAskPrice);
columns.Add(DdeSecurityColumns.BestBidPrice);
columns.Add(DdeSecurityColumns.IndexCurrentPrice);

В версии 4.0.22. изменения инструментов в QUIK корректно отражаются в состоянии объектов Security в S#. А в версии 4.0.23. параметры Security заполняются при старте и дальше не изменяются, хотя событие OnTraderSecurutiesChanged появляется правильно.


Tags:


Thanks:


1 2  >
Alexander

Avatar
Date: 4/13/2012
Reply


покажите распечатку полей по событию

Thanks:

Lester

Avatar
Date: 4/16/2012
Reply


Таблица инструментов:

Газпром

При приходе события OnTraderSecurutiesChanged на 4.0.22:

4.0.22

4.0.23:

4.0.23

Похоже, что проблема касается только LastTrade, лучшие оффер и бид приходят корректно.

Thanks:

Alexander

Avatar
Date: 4/16/2012
Reply


Так LastTrade у вас меняется по SecurutiesChanged? По скриншотам непонятно что не так.

Подпишитесь на событие и сделайте вывод LastTrade

Thanks:

Lester

Avatar
Date: 4/16/2012
Reply


Распечатка полей сделана как раз из обработки события. В 4.0.22 LastTrade меняется, в 4.0.23 - нет, имеет значение, какое было при запуске.

Thanks:

Alexander

Avatar
Date: 4/16/2012
Reply


Lester: Распечатка полей сделана как раз из обработки события. В 4.0.22 LastTrade меняется, в 4.0.23 - нет, имеет значение, какое было при запуске.

Запустил Sample из 4.0.23, открыл вкладку Инструменты. Последняя цена постоянно меняется. Т.е. Sample работает как надо.

Проверяйте у себя.

Thanks:

Lester

Avatar
Date: 4/16/2012
Reply


Мистика: перезакачал дистрибутив, распаковал и запустил своего робота - работает. Возможно, проблема была в том, что версию 23 я накатил поверх 22.

Вопрос закрыт, Александру спасибо!

Вопрос открыт заново.

Thanks:

Lester

Avatar
Date: 4/16/2012
Reply


Рано я радовался :) зато наконец удалось локализовать проблему.

Начну, пожалуй с самого начала: робот использует последнюю сделку инструмента, получая ее <u>не</u> из таблицы Все сделки (и соответственно, остлеживая событие OnTrades), а из таблицы Инструменты, в которой настроены дополнительно 3 столбца:

  • LastTradePrice
  • LastTradeVolume
  • LastTradeTime

В версии 4.0.22 все работало прекрасно, мне не требовалось вообще использовать таблицу Все сделки, т.к. достаточную мне информацию я получал с помощью дополнительных 3 столбцов из Инструменты, отлавливая события SecurutiesChanged. В версии 4.0.23 такая штука больше не катит, последняя сделка не обновляется, об этом как раз раньше и писал.

Work-around: распаковка свежескачанного архива 4.0.23, запуск Sample из папки QUIK. Видим, что в окне Инструменты последняя сделка обновляется.

Теперь открываем MainWindow.xaml.cs и после строки 117 добавляем:

var columns = Trader.SecuritiesTable.Columns;
columns.Add(DdeSecurityColumns.LastTradePrice);
columns.Add(DdeSecurityColumns.LastTradeVolume);
columns.Add(DdeSecurityColumns.LastTradeTime);

Запускаем и видим, что с включенным экспортом всех сделок поле последняя сделка не обновляется.

Если скачать релиз 4.0.22 и собрать программу с References от 22, то экспорт всех сделок работает правильно и инструмент обновляется, а также если выключить экспорт всех сделок, все равно все верно обновляется, но уже из таблицы Инструменты.

Я готов выложить как исходники, так и все что угодно. Сейчас прикладываю собранную версию Sample с 22 и 23 релизами + настройки QUIK

Может я что-то делаю не так? Комментарий к 4.0.23 не указывает на какие-либо изменения в экспорте из QUIK.

Thanks:

Alexander

Avatar
Date: 4/16/2012
Reply


Скриншот квика приложите к этим своим строчкам.

var columns = Trader.SecuritiesTable.Columns; columns.Add(DdeSecurityColumns.LastTradePrice); columns.Add(DdeSecurityColumns.LastTradeVolume); columns.Add(DdeSecurityColumns.LastTradeTime);

Thanks:

Lester

Avatar
Date: 4/16/2012
Reply


Прикладываю.

з.ы. замена LastTradeTime на LastChangeTime ничего не меняет.

Thanks:

Alexander

Avatar
Date: 4/17/2012
Reply


Спасибо, будет фикс. Либо в 4.1, либо в 4.0.24 (если он будет).

Thanks:
1 2  >

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

loading
clippy