pyhta4og
|
Date: 11/9/2012
|
|
|
|
|
[quote=vk37;22371]Я бы инициализацию стратегии перенес сюда. А то ошибка происходит, про состояние объекта что-то.
[code=csharp]_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();
}
};[/code][/quote]
тогда у вас стратегия не факт что запустится с начала данных - эмулятор уедет вперед
|
|
|
|
Thanks:
|
|
|
|
|
|
vk37
|
Date: 11/10/2012
|
|
|
|
|
Ошибка, в общем, возникает при инициализации старетгии. Вне зависимости в каком месте ее инициализировать. Возникает не при каждом запуске. Одна и та же сборка иногда нормально сработает, а иногда с ошибкой. Может кто сталкивался?
[SPOILER][code=plain]System.AggregateException: One or more errors occurred. ---> 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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83
at System.Threading.Tasks.Parallel.<>c__DisplayClassf1.<ForWorker>b__c() at System.Threading.Tasks.Task.InnerInvokeWithArg(Task childTask) at System.Threading.Tasks.Task.<>c__DisplayClass10.<ExecuteSelfReplicating>b__f(Object param0) --- End of inner exception stack trace --- at System.Threading.Tasks.Task.Wait(Int32 millisecondsTimeout, CancellationToken cancellationToken) at System.Threading.Tasks.Task.Wait() at System.Threading.Tasks.Parallel.ForWorker[TLocal](Int32 fromInclusive, Int32 toExclusive, ParallelOptions parallelOptions, Action1 body, Action2 bodyWithState, Func4 bodyWithLocal, Func1 localInit, Action1 localFinally)
at System.Threading.Tasks.Parallel.ForEachWorker[TSource,TLocal](IEnumerable1 source, ParallelOptions parallelOptions, Action1 body, Action2 bodyWithState, Action3 bodyWithStateAndIndex, Func4 bodyWithStateAndLocal, Func5 bodyWithEverything, Func1 localInit, Action1 localFinally)
at System.Threading.Tasks.Parallel.ForEach[TSource](IEnumerable1 source, ParallelOptions parallelOptions, Action1 body)
at AlgoTrading.HistoryTesting.Optimizer.Optimize() in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 129
at AlgoTrading.HistoryTesting.Program.Main() in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Program.cs:line 29
---> (Inner Exception #0) 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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83
at System.Threading.Tasks.Parallel.<>c__DisplayClassf`1.b__c()
at System.Threading.Tasks.Task.InnerInvokeWithArg(Task childTask)
at System.Threading.Tasks.Task.<>c__DisplayClass10.b__f(Object param0)<---
---> (Inner Exception #1) 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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83
at System.Threading.Tasks.Parallel.<>c__DisplayClassf`1.b__c()
at System.Threading.Tasks.Task.InnerInvokeWithArg(Task childTask)
at System.Threading.Tasks.Task.<>c__DisplayClass10.b__f(Object param0)<---
---> (Inner Exception #2) 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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83
at System.Threading.Tasks.Parallel.<>c__DisplayClassf`1.b__c()
at System.Threading.Tasks.Task.InnerInvokeWithArg(Task childTask)
at System.Threading.Tasks.Task.<>c__DisplayClass10.b__f(Object param0)<---
---> (Inner Exception #3) 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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83
at System.Threading.Tasks.Parallel.<>c__DisplayClassf`1.b__c()
at System.Threading.Tasks.Task.InnerInvokeWithArg(Task childTask)
at System.Threading.Tasks.Task.<>c__DisplayClass10.b__f(Object param0)<---
---> (Inner Exception #4) 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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83
at System.Threading.Tasks.Parallel.<>c__DisplayClassf`1.b__c()
at System.Threading.Tasks.Task.InnerInvokeWithArg(Task childTask)
at System.Threading.Tasks.Task.<>c__DisplayClass10.b__f(Object param0)<---
---> (Inner Exception #5) 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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83
at System.Threading.Tasks.Parallel.<>c__DisplayClassf`1.b__c()
at System.Threading.Tasks.Task.InnerInvokeWithArg(Task childTask)
at System.Threading.Tasks.Task.<>c__DisplayClass10.b__f(Object param0)<---
---> (Inner Exception #6) 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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83
at System.Threading.Tasks.Parallel.<>c__DisplayClassf`1.b__c()
at System.Threading.Tasks.Task.InnerInvokeWithArg(Task childTask)
at System.Threading.Tasks.Task.<>c__DisplayClass10.b__f(Object param0)<---
---> (Inner Exception #7) 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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83
at System.Threading.Tasks.Parallel.<>c__DisplayClassf`1.b__c()
at System.Threading.Tasks.Task.InnerInvokeWithArg(Task childTask)
at System.Threading.Tasks.Task.<>c__DisplayClass10.b__f(Object param0)<---[/code][/SPOILER]
|
|
|
|
Thanks:
|
|
|
|
|
|
pyhta4og
|
Date: 11/12/2012
судя по колстаку у вас Parallel.For или что-то в этом духе. Там точно нет ситуации что EmulationTrader дергается из двух разных потоков? Он вполне может быть не потокобезопасным.
если вам надо сделать оптимизацию гораздо быстрее будет сделать кучу экземпляров стратегии с разными параметрами и всю кучу прогнать в одном эмуляйшн-трейдере.
|
|
|
|
Thanks:
|
|
|
|
|
|
vk37
|
Date: 11/12/2012
|
|
|
|
|
В упрощенном виде код оптимизации такой:
[SPOILER][code=csharp] public class Optimizer
{
private IStorageRegistry _storageRegistry;
private LocalMarketDataDrive _defaultDrive;
public void Optimize()
{
var startTime = new DateTime(2012, 9, 10);
var stopTime = new DateTime(2012, 11, 8);
_storageRegistry = new StorageRegistry();
_defaultDrive = (LocalMarketDataDrive)_storageRegistry.DefaultDrive;
_defaultDrive.Path = @"D:\DBs\HydraData\Smart";
var security = Securities.Instance.RtsF;
var periods = MyStrategy.GetParamCombinations();
Parallel.ForEach(periods, new ParallelOptions { MaxDegreeOfParallelism = 8 }, period =>
{
using (var waitHandle = new AutoResetEvent(false))
{
var rts = security.Clone();
var portfolio = new Portfolio { Name = "test account", BeginValue = 100000m };
var trader = new EmulationTrader(
new[] { rts },
new[] { portfolio },
_storageRegistry)
{
UseMarketDepth = true,
StorageRegistry = _storageRegistry,
};
trader.MarketEmulator.Settings.Latency = TimeSpan.FromSeconds(1);
trader.RegisterMarketDepth(rts);
trader.Connect();
trader.StartExport();
var strategy = new MyStrategy(period)
{
Volume = 1,
Security = rts,
Portfolio = portfolio,
Trader = trader,
CommissionManager = rts.GetComissionManager(),
};
trader.StateChanged += (oldState, newState) =>
{
if (trader.State == EmulationStates.Started)
strategy.Start();
else if (trader.State == EmulationStates.Stopped)
{
new ExcelStrategyReport(strategy, path).Generate();
waitHandle.Set();
}
};
trader.Start(startTime, stopTime);
waitHandle.WaitOne();
}
});
}
}
[/code][/SPOILER]Вроде EmulationTrader на правильном месте. Не знаю как правильно )
|
|
|
|
Thanks:
|
|
|
|
|
|
Mikhail Sukhov
|
Date: 11/12/2012
[quote]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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83[/quote]
По стек трейсу видно, что напрямую вызывается BaseTrader.ProcessEvents. Зачем?
|
|
|
|
Thanks:
|
|
|
|
|
|
vk37
|
Date: 11/13/2012
|
|
|
|
|
[quote=Mikhail Sukhov;22442][quote]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.b__5(ParamsDto period) in c:\ActiveProjects\AlgoTrading3\trunk\SourceCode\HistoryTesting\Optimizer.cs:line 83[/quote]
По стек трейсу видно, что напрямую вызывается BaseTrader.ProcessEvents. Зачем?[/quote]
Даже не знаю что это такое. Строка 83 - инициализация стратегии.
Упрощенный код моей стратегии:
[SPOILER][code=csharp] public sealed class MyStrategy : AbstractStrategy
{
private bool _canProcess = true;
private readonly object _locker = new object();
public CsvLogManager CsvLogManager { get; set; }
protected override void OnStarted()
{
Security
.WhenMarketDepthChanged()
.Do(ProcessDepth)
.Sync(_locker)
.Apply(this);
this.WhenNewMyTrades()
.Do(myTrades =>
{
foreach (var myTrade in myTrades)
{
CsvLogManager.WriteLine(new MyTradeLogItem()
{
Now = DateTime.Now,
CurrentTime = CurrentTime,
TradeId = myTrade.Trade.Id,
TransactionId = myTrade.Order.TransactionId,
Time = myTrade.Trade.Time,
TradePrice = myTrade.Trade.Price,
OrderPrice = myTrade.Order.Price,
TradeVolume = myTrade.Trade.Volume,
Direction = myTrade.Order.Direction,
OrderId = myTrade.Order.Id,
Slippage = myTrade.GetSlippage(true),
SlippageQuoting = SlippageManager.GetSlippage(myTrade),
Comment = comment,
});
CsvLogManager.WriteLine(new MyTradeWmsLogItem()
{
Time = myTrade.Trade.Time,
SecurityCode = Security.Id == Securities.Instance.RtsF.Id ? "RTS" : Security.Code,
Direction = myTrade.Order.Direction,
Price = myTrade.Trade.Price,
Volume = myTrade.Trade.Volume,
Comission = myTrade.Trade.Volume * 2,
});
}
})
.Apply(this);
base.OnStarted();
}
protected override void OnStopped()
{
base.OnStopped();
CsvLogManager.Dispose();
}
private void ProcessDepth(MarketDepth depth)
{
if (!Security.Exchange.IsTradeTime(depth.LastChangeTime))
return;
if (CsvLogManager.MarketDepthLogEnabled)
CsvLogManager.WriteLine(new MarketDepthLogItem()
{
Now = DateTime.Now,
CurrentTime = CurrentTime,
MarketDepthTime = depth.LastChangeTime,
Ratio = ratio,
CanProcess = Convert.ToInt32(_canProcess),
CurrentPrice = price,
BestAsk = depth.BestAsk == null ? 0 : depth.BestAsk.Price,
BestBid = depth.BestBid == null ? 0 : depth.BestBid.Price,
PnL = PnL,
PortfolioBeginValue = Portfolio.BeginValue,
PortfolioCurrentValue = Portfolio.CurrentValue,
PortfolioVariationMargin = Portfolio.VariationMargin,
PortfolioComission = Portfolio.Commission,
PortfolioGetPrice = Portfolio.GetPrice(),
});
if (!_canProcess)
return;
var closePosition = ShouldClose();
var openPosition = ShouldOpen();;
if (closePosition || openPosition)
{
_canProcess = false;
var volume = 0m;
if (closePosition)
volume += Math.Abs(Position);
if (openPosition)
volume += Volume;
var strategy = new MyQuotingStrategy(orderDirection,
new Unit(price, UnitTypes.Absolute, Security),
new Unit(1, UnitTypes.Step, Security),
comment) { Volume = volume };
strategy
.WhenStopped()
.Do(() =>
{
_canProcess = true;
})
.Once()
.Sync(_locker)
.Apply(this);
ChildStrategies.Add(strategy);
}
}
}[/code][/SPOILER]Может неявно как-то вызывается. Могу выслать код стратегии котирования. Для ревью )
|
|
|
|
Thanks:
|
|
|
|
|
|
Mikhail Sukhov
|
Date: 11/13/2012
[quote=vk37;22446]Может неявно как-то вызывается. Могу выслать код стратегии котирования. Для ревью )
[/quote]
Если только Михаил заинтересуется[biggrin] Мне и своего кода для ревьирования хватает, спасибо. Надо поднтянуть матчасть связанную с отладкой ошибок. Дебаггер, рефлектор.
|
|
|
|
Thanks:
|
|
|
|
|
|
vk37
|
Date: 11/13/2012
[quote=Mikhail Sukhov;22449]Дебаггер, рефлектор.[/quote]деобфускатор? )
|
|
|
|
Thanks:
|
|
|
|
|
|
Mikhail Sukhov
|
Date: 11/13/2012
[quote=vk37;22451][quote=Mikhail Sukhov;22449]Дебаггер, рефлектор.[/quote]деобфускатор? )
[/quote]
Да я про ваш код имел ввиду. Хотя конечно я бы начал с основ - что такое исключение и что такое стектрейс. Но я так понял вы не из тех, кто любит на всякие разности отвлекаться.[rolleyes]
|
|
|
|
Thanks:
|
|
|
|
|
|
komaranton
|
Date: 9/8/2019
|
|
|
|
Thanks:
|
|
|
|
|