Инициализация стратегии в тестировании на истории
Atom Ответить
09.11.2012


Я бы инициализацию стратегии перенес сюда. А то ошибка происходит, про состояние объекта что-то.

Код
_trader.StateChanged += (oldState, newState) =>
{
	if (_trader.State == EmulationStates.Stopped)
	{
		this.GuiAsync(() =>
		{
			StartBtn.IsEnabled = true;

			if (_trader.IsFinished)
			{
				TestingProcess.Value = TestingProcess.Maximum;
				MessageBox.Show(this, "Закончено за " + (DateTime.Now - _startEmulationTime));
			}
			else
				MessageBox.Show(this, "Отменено");
		});
	}
	else if (_trader.State == EmulationStates.Started)
	{
        //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
        // создаем торговую стратегию, скользящие средние на 80 5-минуток и 10 5-минуток
        _strategy = new SmaStrategy(series, new SimpleMovingAverage { Length = 80 }, new SimpleMovingAverage { Length = 10 })
        {
            Volume = 1,
            Portfolio = portfolio,
            Security = security,
            Trader = _trader
        };
        //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
		// запускаем стратегию когда эмулятор запустился
		_strategy.Start();
	}
};



Спасибо:




10 Ответов
pyhta4og

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


vk37 Перейти
Я бы инициализацию стратегии перенес сюда. А то ошибка происходит, про состояние объекта что-то.

Код
_trader.StateChanged += (oldState, newState) =>
{
	if (_trader.State == EmulationStates.Stopped)
	{
		this.GuiAsync(() =>
		{
			StartBtn.IsEnabled = true;

			if (_trader.IsFinished)
			{
				TestingProcess.Value = TestingProcess.Maximum;
				MessageBox.Show(this, "Закончено за " + (DateTime.Now - _startEmulationTime));
			}
			else
				MessageBox.Show(this, "Отменено");
		});
	}
	else if (_trader.State == EmulationStates.Started)
	{
        //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
        // создаем торговую стратегию, скользящие средние на 80 5-минуток и 10 5-минуток
        _strategy = new SmaStrategy(series, new SimpleMovingAverage { Length = 80 }, new SimpleMovingAverage { Length = 10 })
        {
            Volume = 1,
            Portfolio = portfolio,
            Security = security,
            Trader = _trader
        };
        //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
		// запускаем стратегию когда эмулятор запустился
		_strategy.Start();
	}
};


тогда у вас стратегия не факт что запустится с начала данных - эмулятор уедет вперед
Спасибо:

vk37

Фотография
Курсы
Дата: 09.11.2012
Ответить


Ошибка, в общем, возникает при инициализации старетгии. Вне зависимости в каком месте ее инициализировать. Возникает не при каждом запуске. Одна и та же сборка иногда нормально сработает, а иногда с ошибкой. Может кто сталкивался?
Автор топика
Спасибо:

pyhta4og

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


судя по колстаку у вас Parallel.For или что-то в этом духе. Там точно нет ситуации что EmulationTrader дергается из двух разных потоков? Он вполне может быть не потокобезопасным.

если вам надо сделать оптимизацию гораздо быстрее будет сделать кучу экземпляров стратегии с разными параметрами и всю кучу прогнать в одном эмуляйшн-трейдере.
Спасибо:

vk37

Фотография
Курсы
Дата: 12.11.2012
Ответить


В упрощенном виде код оптимизации такой:
Вроде EmulationTrader на правильном месте. Не знаю как правильно )
Автор топика
Спасибо:

Mikhail Sukhov

Фотография
Автор статей Программист Трейдер
Дата: 12.11.2012
Ответить


Цитата:
System.InvalidOperationException: Operation is not valid due to the current state of the object.
at StockSharp.Algo.BaseTrader.ProcessEvents(Action handler)
at AlgoTrading.HistoryTesting.Optimizer.<>c__DisplayClassb.<Optimize>b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83


По стек трейсу видно, что напрямую вызывается BaseTrader.ProcessEvents. Зачем?
Спасибо:

vk37

Фотография
Курсы
Дата: 12.11.2012
Ответить


Mikhail Sukhov Перейти
Цитата:
System.InvalidOperationException: Operation is not valid due to the current state of the object.
at StockSharp.Algo.BaseTrader.ProcessEvents(Action handler)
at AlgoTrading.HistoryTesting.Optimizer.<>c__DisplayClassb.<Optimize>b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83


По стек трейсу видно, что напрямую вызывается BaseTrader.ProcessEvents. Зачем?

Даже не знаю что это такое. Строка 83 - инициализация стратегии.
Упрощенный код моей стратегии:
Может неявно как-то вызывается. Могу выслать код стратегии котирования. Для ревью )


Автор топика
Спасибо:

Mikhail Sukhov

Фотография
Автор статей Программист Трейдер
Дата: 12.11.2012
Ответить


vk37 Перейти
Может неявно как-то вызывается. Могу выслать код стратегии котирования. Для ревью )


Если только Михаил заинтересуетсяBigGrin Мне и своего кода для ревьирования хватает, спасибо. Надо поднтянуть матчасть связанную с отладкой ошибок. Дебаггер, рефлектор.
Спасибо:

vk37

Фотография
Курсы
Дата: 12.11.2012
Ответить


Mikhail Sukhov Перейти
Дебаггер, рефлектор.
деобфускатор? )

Автор топика
Спасибо:

Mikhail Sukhov

Фотография
Автор статей Программист Трейдер
Дата: 12.11.2012
Ответить


vk37 Перейти
Mikhail Sukhov Перейти
Дебаггер, рефлектор.
деобфускатор? )



Да я про ваш код имел ввиду. Хотя конечно я бы начал с основ - что такое исключение и что такое стектрейс. Но я так понял вы не из тех, кто любит на всякие разности отвлекаться.RollEyes
Спасибо:

komaranton

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


Получилось разобраться?
Спасибо:


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

loading
clippy