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

Ошибка при переходе с 4.0.22 на 4.0.23
Atom
13.04.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 появляется правильно.


Теги:


Спасибо:


1 2  >
Alexander

Фотография
Дата: 13.04.2012
Ответить


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

Lester

Фотография
Дата: 16.04.2012
Ответить


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

Газпром

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

4.0.22

4.0.23:

4.0.23


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

Alexander

Фотография
Дата: 16.04.2012
Ответить


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

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

Lester

Фотография
Дата: 16.04.2012
Ответить


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

Alexander

Фотография
Дата: 16.04.2012
Ответить


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


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

Проверяйте у себя.
Спасибо:

Lester

Фотография
Дата: 16.04.2012
Ответить




Вопрос открыт заново.
Спасибо:

Lester

Фотография
Дата: 16.04.2012
Ответить


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

Начну, пожалуй с самого начала: робот использует последнюю сделку инструмента, получая ее не из таблицы Все сделки (и соответственно, остлеживая событие 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.
Спасибо:

Alexander

Фотография
Дата: 16.04.2012
Ответить


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

Цитата:
var columns = Trader.SecuritiesTable.Columns;
columns.Add(DdeSecurityColumns.LastTradePrice);
columns.Add(DdeSecurityColumns.LastTradeVolume);
columns.Add(DdeSecurityColumns.LastTradeTime);
Спасибо:

Lester

Фотография
Дата: 16.04.2012
Ответить


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

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

Спасибо:

Alexander

Фотография
Дата: 17.04.2012
Ответить


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

Добавить файлы через драг-н-дроп, , или вставить из буфера обмена.

loading
clippy