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


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


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

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

Code
// Создание подключения к 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 Go to
Распечатка полей сделана как раз из обработки события.
В 4.0.22 LastTrade меняется, в 4.0.23 - нет, имеет значение, какое было при запуске.


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

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

Lester

Avatar
Date: 4/16/2012
Reply




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

Lester

Avatar
Date: 4/16/2012
Reply


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

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

  • LastTradePrice
  • LastTradeVolume
  • LastTradeTime


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

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

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

Code
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


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

Quote:
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