Перестает вызываться OnProcess стратегии


Перестает вызываться OnProcess стратегии
Atom Reply
4/5/2011


Заметил, что робот проворонил сигнал, в логах ничего не нашел, задебажил и увидел, что не вызывается OnProcess. В последнем вызове PropertyChanged у стратегии состояние Runned. Стратегия унаследована от TimeFrameStrategy, S# последний.

Tags:


Thanks:




15 Answers
Alter

Avatar
Date: 4/19/2011
Reply


Ситуация воспроизвелась. OnProcess запускается раз в секунду. Утром он в последний раз запустился в 9:55:07 и стал вызываться снова только после того, как специально обученный костыль перезапустил стратегию в 10:00:18.
Topic starter
Thanks:

Mikhail Sukhov

Avatar
Date: 4/19/2011
Reply


Alter Go to
Ситуация воспроизвелась. OnProcess запускается раз в секунду. Утром он в последний раз запустился в 9:55:07 и стал вызываться снова только после того, как специально обученный костыль перезапустил стратегию в 10:00:18.


Ситуация повторяется только в не торговое время?
Thanks:

Alter

Avatar
Date: 4/19/2011
Reply


Да, пока что отлавливал сабж только перед началом утренней сессии.
Topic starter
Thanks:

Mikhail Sukhov

Avatar
Date: 4/19/2011
Reply


Alter Go to
Да, пока что отлавливал сабж только перед началом утренней сессии.


Может у вас в стратегии какая проверка стоит? Еще не плохо было бы проверить состояние QuikTrader.IsConnected.
Thanks:

Alter

Avatar
Date: 4/19/2011
Reply


QuikTrader.IsConnected был true. Точнее я проверял Terminal.IsConnected, но как я понимаю это будет одно и то же. В стратегии в OnProcess в самом начале метода запоминается время его вызова и периодически проверяется.
Topic starter
Thanks:

Mikhail Sukhov

Avatar
Date: 4/19/2011
Reply


Alter Go to
QuikTrader.IsConnected был true. Точнее я проверял Terminal.IsConnected, но как я понимаю это будет одно и то же.


Разное. Terminal проверяет подключение по косвенным признакам, а QuikTrader.IsConnected через АПИ. С точки зрения логики это одно и то же, но могут быть и различия в особых ситуациях. То, что у вас не стартует до торгов явно не является обычной практикой (хотя бы взять тот факт, что это до торгов).

Alter Go to
В стратегии в OnProcess в самом начале метода запоминается время его вызова и периодически проверяется.


Вы пробовали отладчиком поставить точку останова в начало метода?
Thanks:

Alter

Avatar
Date: 4/19/2011
Reply


Отладчиком проверял, метод не вызывается. Так вместо Terminal.IsConnected лучше проверять QuikTrader.IsConnected? Просто я посмотрел в документацию и выбрал из двух то свойство, про которое было понятно написано =)
Topic starter
Thanks:

Alter

Avatar
Date: 4/22/2011
Reply


Сегодня вывел в лог оба IsConnected, получилось вот так:

Market time = 22.04.2011 10:00:24
Terminal.IsConnected = False
QuikTrader.IsConnected = True
Last OnProcess launch time = 22.04.2011 9:55:44

Может Terminal.IsConnected = False виновато?
Topic starter
Thanks:

Mikhail Sukhov

Avatar
Date: 4/22/2011
Reply


Alter Go to
Может Terminal.IsConnected = False виновато?


Нет, не виновато.
Thanks:

Alter

Avatar
Date: 5/24/2011
Reply


Понаблюдал тут на досуге за ходом развития событий, происходит следующее:
9:55 - MarketTime показывает глубокую ночь, 2:00-4:00, в квике в статусбаре времени сервера нет, OnProcess у стратегии почему-то вызывается.
9:56-9:57 - в квике появляется время сервера, в MarketTime соответственно оно тоже перескакивает с ночи на текущее, OnProcess вызываться перестает.
10:00 и далее - MarketTime показывает корректное время, но OnProcess не вызывается, через энндцать секунд я перезапускаю стратегию, после этого все ок.

Интересно, почему OnProcess вызывается ночью, но не вызывается сразу после 10 утра, пока не перезапустишь стратегию.
Topic starter
Thanks:

Mikhail Sukhov

Avatar
Date: 5/24/2011
Reply


Alter Go to
Понаблюдал тут на досуге за ходом развития событий, происходит следующее:
9:55 - MarketTime показывает глубокую ночь, 2:00-4:00, в квике в статусбаре времени сервера нет, OnProcess у стратегии почему-то вызывается.
9:56-9:57 - в квике появляется время сервера, в MarketTime соответственно оно тоже перескакивает с ночи на текущее, OnProcess вызываться перестает.
10:00 и далее - MarketTime показывает корректное время, но OnProcess не вызывается, через энндцать секунд я перезапускаю стратегию, после этого все ок.

Интересно, почему OnProcess вызывается ночью, но не вызывается сразу после 10 утра, пока не перезапустишь стратегию.


А интервал у стратегии какой? Какие образом перезапустили стратегию?
Thanks:

Alter

Avatar
Date: 5/24/2011
Reply


Интервал 1 секунда, перезапустил через strategy.Stop(); strategy.Start();
Topic starter
Thanks:

Greene-nsk

Avatar
Date: 5/24/2011
Reply


У меня практически такая же проблема (http://stocksharp.com/forum/1602/vypolnieniie-TimeFrameStrategy/)
Версия S# 3.0.19.0.

Единственное отличие, которое вижу - OnProcess в начале дня выполняется, но ломается после вечернего клиринга. Помогает стоп/старт стратегии (как воркэраунд).
Thanks:

Greene-nsk

Avatar
Date: 5/24/2011
Reply


еще наблюдения:
интервал - 2 секунды
таймфрейм - 10 минут
несколько стратегий

OnProcess перестает вызываться через интервал равный таймфрейму, для ВСЕХ стратегий одновременно.
Например, я запускаю одну стратегию в 19:04, вторую в 19:07. В 19:14 у обоих стратегий перестает вызываться OnProcess. Для 3х и больше стратегий аналогично. Локаются все. Дочерние в том числе.
Thanks:

Alter

Avatar
Date: 6/1/2011
Reply


А сегодня еще и в квике время сервера встало колом до начала сессии, да так и осталось. Михаил, может в свете всего описанного в этой теме невызов OnProcess в неторговое время сделать отключаемым?
Topic starter
Thanks:


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

loading
clippy