Ошибка защитных стратегий - коллекция котировок пуста
Atom Ответить
19.04.2011


Выводится в логи следующая ошибка (правильно я понял, что логируется только то, что описывается через AddLog()) :

Код
IS_01:00:10 10:12:00.1564059 Стратегия запущена.
IS_01:00:10 16:00:01.3877441 Регистрация заявки - цена 193245, направление Buy, объем 5
IS_01:00:10 16:00:02.9208318 Прошла сделка по цене 192375, объём 5, направление Buy.
IS_01:00:10 16:00:02.9618341 Регистрация стоп-лосс по цене 190550
IS_01:00:10 16:00:02.9618341 Регистрация тейк-профит по цене 192640
BS 16:00:02.9628342 Стратегия запущена.
BS 16:00:02.9628342 Стратегия запущена.
TPS 16:00:02.9628342 Стратегия запущена.
SLS 16:00:02.9628342 Стратегия запущена.
TPS 18:45:25.8543911 [h]System.ArgumentException: Коллекция котировок пуста.
Имя параметра: quotes
в Ecng.Trading.Algo.TraderHelper.GetFilteredQuotes(IEnumerable`1 quotes, Order currentOrder)
в Ecng.Trading.Algo.TraderHelper.GetFilteredQuotes(MarketDepth depth, OrderDirections orderDirection, Order currentOrder)
в Ecng.Trading.Algo.TraderHelper.GetFilteredQuotes(Security security, OrderDirections orderDirection, Order currentOrder)
в Ecng.Trading.Algo.Strategies.ProtectiveStrategy.GetNewPrice()
в Ecng.Trading.Algo.Strategies.TakeProfitStrategy.CanRegister()
в Ecng.Trading.Algo.Strategies.QuotingStrategy.OnProcess()
в Ecng.Trading.Algo.Strategies.Strategy.#=qnMN_PMdUfHysEK$_tfQ8grn_QTjzOIMGPiv$tYCH2Bw=.#=q3rD2zIrUx4ViUbhRH66B2w==()[/h]
TPS 18:45:25.8543911 Стратегия останавливается.
SLS 18:45:25.8543911 System.ArgumentException: Коллекция котировок пуста.
Имя параметра: quotes
в Ecng.Trading.Algo.TraderHelper.GetFilteredQuotes(IEnumerable`1 quotes, Order currentOrder)
в Ecng.Trading.Algo.TraderHelper.GetFilteredQuotes(MarketDepth depth, OrderDirections orderDirection, Order currentOrder)
в Ecng.Trading.Algo.TraderHelper.GetFilteredQuotes(Security security, OrderDirections orderDirection, Order currentOrder)
в Ecng.Trading.Algo.Strategies.ProtectiveStrategy.GetNewPrice()
в Ecng.Trading.Algo.Strategies.StopLossStrategy.CanRegister()
в Ecng.Trading.Algo.Strategies.QuotingStrategy.OnProcess()
в Ecng.Trading.Algo.Strategies.Strategy.#=qnMN_PMdUfHysEK$_tfQ8grn_QTjzOIMGPiv$tYCH2Bw=.#=q3rD2zIrUx4ViUbhRH66B2w==()
SLS 18:45:25.8543911 Стратегия останавливается.
TPS 18:45:26.8554483 Котирование закончилось.
TPS 18:45:26.8564484 Стратегия остановлена.
SLS 18:45:26.8574485 Котирование закончилось.
SLS 18:45:26.8574485 Стратегия остановлена.
BS 18:45:26.8794497 Стратегия останавливается.
BS 18:45:27.8795069 Стратегия остановлена.
BS 18:45:27.8795069 Стратегия останавливается.
BS 18:45:28.8795641 Стратегия остановлена.


Стратегии регистрирую как в примере:

Код
private void OnNewMyTrades(IEnumerable<MyTrade> trades)
{
foreach (var trade in trades)
{
AddLog(StrategyErrorStates.None, "Прошла сделка по цене {0}, объём {1}, направление {2}.",
trade.Trade.Price, trade.Trade.Volume, trade.Order.Direction);
}
// фильтруем сделки, чтобы найти те, которые произошли для заявки TargetOrder// сделать проверку не на последнюю заявку а на все заявки которые
trades = trades.Where(t => t.Order == TargetOrder);

// если не найдена ни одна сделка для заявки TargetOrder
if (trades.Count() == 0)
return;

// сама пакетная стратегия так же является параллельной, чтобы она не блокирована основной код робота
var batch = new BatchStrategy(BatchFinishModes.All) { IsParallel = true };

// для каждой сделки добавляем для защиты по пакетной стратегии
batch.ChildStrategies.AddRange(trades.Select(t =>
{

var s = new BatchStrategy(BatchFinishModes.First) { IsParallel = true };

// выставляет тейк-профит в N пунктов
var takeProfit = new TakeProfitStrategy(t,new Unit((decimal)Fractal.Up) + _takeDelta.Pips(Security));

// выставляет стоп-лосс в M пунктов
var stopLoss = new StopLossStrategy(t, new Unit((decimal)Fractal.Down) - _stopDelta.Pips(Security));

takeProfit.PriceDelta=stopLoss.PriceDelta = _priceDelta;

// делаем стратегии параллельными, чтобы они не блокировали работу контролирующей BatchStrategy
takeProfit.IsParallel = stopLoss.IsParallel = true;

s.ChildStrategies.Add(takeProfit);
s.ChildStrategies.Add(stopLoss);

AddLog(StrategyErrorStates.None, "Регистрация стоп-лосс по цене {0}", stopLoss.ProtectiveDelta);
AddLog(StrategyErrorStates.None, "Регистрация тейк-профит по цене {0}", takeProfit.ProtectiveDelta);

return s;
}).Cast<Strategy>());

if (batch.ChildStrategies.Count > 0)
{
base.ChildStrategies.Add(batch);
}
TargetOrder = null;
}


Заявки выставляю лимитированные через base.RegisterOrder(order).Процесс получения стакана происходит - _trader.RegisterQuotes(_strategy.Security). Что я неправильно делаю?
Спасибо

Теги:


Спасибо:




64 Ответов
< 1 2 3  >
Alexander

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


Евгений Перейти
А как задать время работы защитных стратегий в версии 3.2.5? До этого я переопределял OnProcess и там указывал.



Через When \ Do
в When - указывайте время когда не хотите чтобы ваша стратегия работала

+ у Trader есть событие MarketTimeChanged
Спасибо:

Евгений

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


Alexander Перейти
Евгений Перейти
А как задать время работы защитных стратегий в версии 3.2.5? До этого я переопределял OnProcess и там указывал.



Через When \ Do
в When - указывайте время когда не хотите чтобы ваша стратегия работала

+ у Trader есть событие MarketTimeChanged


А как через MarketTimeChanged можно? Мой вариант не работает, потому что коллекция ChildStrategies изменяется во время проверки

Код
 _trader.MarketTimeChanged += () => this.GuiAsync(() =>
                        {
                            if (_strategy != null)
                            {
                                if (_strategy.ChildStrategies.Count != 0)
                                    if (_security.Exchange.IsTradeTime(_trader.MarketTime) == false)
                                    {
                                        foreach (var s in this._strategy.ChildStrategies.Where(s => s.ProcessState == StrategyProcessStates.Runned))
                                            s.Stop();
                                    }
                                    else
                                        foreach (var s in this._strategy.ChildStrategies.Where(s => s.ProcessState == StrategyProcessStates.Stopped))
                                            s.Start();
                            }
                        });
Автор топика
Спасибо:

Alexander

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


Евгений Перейти
Alexander Перейти
Евгений Перейти
А как задать время работы защитных стратегий в версии 3.2.5? До этого я переопределял OnProcess и там указывал.



Через When \ Do
в When - указывайте время когда не хотите чтобы ваша стратегия работала

+ у Trader есть событие MarketTimeChanged


А как через MarketTimeChanged можно? Мой вариант не работает, потому что коллекция ChildStrategies изменяется во время проверки

Код
 _trader.MarketTimeChanged += () => this.GuiAsync(() =>
                        {
                            if (_strategy != null)
                            {
                                if (_strategy.ChildStrategies.Count != 0)
                                    if (_security.Exchange.IsTradeTime(_trader.MarketTime) == false)
                                    {
                                        foreach (var s in this._strategy.ChildStrategies.Where(s => s.ProcessState == StrategyProcessStates.Runned))
                                            s.Stop();
                                    }
                                    else
                                        foreach (var s in this._strategy.ChildStrategies.Where(s => s.ProcessState == StrategyProcessStates.Stopped))
                                            s.Start();
                            }
                        });



копируйте прежде чем использовать, либо сделайте лок
Спасибо: Евгений

Евгений

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


Возникает ошибка при логировании

Код
   for (int i = 0; i < base.ChildStrategies.Count; i++)
                    {
                        [h]AddLog(StrategyErrorStates.None, "Удаление стратегии {0}", base.ChildStrategies[i].Name);[/h]
                        base.ChildStrategies.RemoveAt(i);
                    }


Цитата:
System.NotSupportedException не обработано пользовательским кодом
Message=Указанный метод не поддерживается.
Source=Ecng.Collections
StackTrace:
в Ecng.Collections.SynchronizedSet`1.System.Collections.Generic.IList<T>.get_Item(Int32 index)
в Ecng.Collections.BaseCollection`1.get_Item(Int32 index)
в SampleSma.SmaStrategy.OnNewMyTrades(IEnumerable`1 trades) в D:\StockSharp_3.2.7_Sources\SmaStrategy.cs:строка 217
в System.Action`1.Invoke(T obj)
в Ecng.Common.DelegateHelper.SafeInvoke[T](Action`1 handler, T arg)
в StockSharp.Algo.Strategies.Strategy.#=qXQcTzmM0UE1f5yIY2j5kaA==(IEnumerable`1 #=qM5HbaFnvCFi7rkUr5cbHdQ==)
в StockSharp.Algo.Strategies.Strategy.#=qM0$gqkXG3MPOkX0bnBfw2A==(IEnumerable`1 #=qL4wEoMHRTP$ON_GriBYYEA==)
в System.Action`1.Invoke(T obj)
в Ecng.Common.DelegateHelper.SafeInvoke[T](Action`1 handler, T arg)
в StockSharp.Algo.Testing.RealTimeEmulationTrader`1.#=qPIAOBkVt1MhD9DGmazWqFXVeVjc6WER7AoUQ0gK7Sec=(IEnumerable`1 #=qWC4Z1rz_RGQAUzeSh1Cphw==)
в Ecng.Common.DelegateHelper.SafeInvoke[T](Action`1 handler, T arg)
в StockSharp.Algo.Testing.MarketEmulator.RaiseNewMyTrades(IEnumerable`1 trades)
в StockSharp.Algo.Testing.MarketEmulator.#=q2J23UVF1zXonLRlbjK309w==(Order #=q0wnjY82As$lGM3$R70XXZA==, Int32 #=qri0DP6B4pNy7fx3oHmxVqA==, Decimal #=quoai2hjCHpHfZ1q8j3z$ew==)
в StockSharp.Algo.Testing.MarketEmulator.#=qE7E7qt9g1c47ZkBqOFQjyQFedGLvvuLEiZjEuWXdWe8=(MarketDepth #=qtMm0MpCgzrjyUmIY37DQGQ==, Order #=qN7KRs9k9LSYRBZ6MhxRoHA==, Quote #=qN7Znv2zz9zpDeRNGHg_Wow==, Boolean #=qreLQ9GB8WhUEds76X0M828yCTL2n9cda$8T1MfjlO18=)
в StockSharp.Algo.Testing.MarketEmulator.#=qUkyP0_M9OMEy$SkKYfYJOtahWlDktGcqM5WL10p_80s=(Order #=qghTCyYil3z9plTAIH0h7ZQ==, MarketDepth #=qLR63QCgY7j2YwdM8UiJ_RA==)
в StockSharp.Algo.Testing.MarketEmulator.#=qtVjIJmyUftYFmfFY5O4f0g==(SynchronizedDictionary`2 #=q9J8oLVIQhe2_0P3XQ18a7Q==)
в Ecng.Collections.CollectionHelper.SyncDo[TCollection](TCollection collection, Action`1 action)
в StockSharp.Algo.Testing.MarketEmulator.#=qcAGUpJziDHjwYUgUkdFL0g==()
в StockSharp.Algo.Testing.MarketEmulator.UpdateQuotes(IEnumerable`1 marketDepths)
в StockSharp.Algo.Testing.RealTimeEmulationTrader`1.#=q0xtw_MzKkmFKPWfyFMG2VeXM$PE6NDpWY9PTT7IQgHE=(IEnumerable`1 #=qa1P$uiol4QhZBoQzjZJhMw==)
в System.Action`1.Invoke(T obj)
в Ecng.Common.DelegateHelper.SafeInvoke[T](Action`1 handler, T arg)
в StockSharp.Algo.BaseTrader.#=qifrQr7se$_OPI_WBxefq0RZ$hXHpoMKbn3PHl9eAJYM=.#=qq46wFSKy$Z5naYx_yW1qIw==(IEnumerable`1 #=q_TiYF80HDzj2r9IIRRL14g==)
InnerException:
Автор топика
Спасибо:

Alexander

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


Евгений Перейти
Возникает ошибка при логировании

Код
   for (int i = 0; i < base.ChildStrategies.Count; i++)
                    {
                        [h]AddLog(StrategyErrorStates.None, "Удаление стратегии {0}", base.ChildStrategies[i].Name);[/h]
                        base.ChildStrategies.RemoveAt(i);
                    }


Цитата:
System.NotSupportedException не обработано пользовательским кодом
Message=Указанный метод не поддерживается.
Source=Ecng.Collections
StackTrace:
в Ecng.Collections.SynchronizedSet`1.System.Collections.Generic.IList<T>.get_Item(Int32 index)
в Ecng.Collections.BaseCollection`1.get_Item(Int32 index)
в SampleSma.SmaStrategy.OnNewMyTrades(IEnumerable`1 trades) в D:\StockSharp_3.2.7_Sources\SmaStrategy.cs:строка 217
в System.Action`1.Invoke(T obj)
в Ecng.Common.DelegateHelper.SafeInvoke[T](Action`1 handler, T arg)
в StockSharp.Algo.Strategies.Strategy.#=qXQcTzmM0UE1f5yIY2j5kaA==(IEnumerable`1 #=qM5HbaFnvCFi7rkUr5cbHdQ==)
в StockSharp.Algo.Strategies.Strategy.#=qM0$gqkXG3MPOkX0bnBfw2A==(IEnumerable`1 #=qL4wEoMHRTP$ON_GriBYYEA==)
в System.Action`1.Invoke(T obj)
в Ecng.Common.DelegateHelper.SafeInvoke[T](Action`1 handler, T arg)
в StockSharp.Algo.Testing.RealTimeEmulationTrader`1.#=qPIAOBkVt1MhD9DGmazWqFXVeVjc6WER7AoUQ0gK7Sec=(IEnumerable`1 #=qWC4Z1rz_RGQAUzeSh1Cphw==)
в Ecng.Common.DelegateHelper.SafeInvoke[T](Action`1 handler, T arg)
в StockSharp.Algo.Testing.MarketEmulator.RaiseNewMyTrades(IEnumerable`1 trades)
в StockSharp.Algo.Testing.MarketEmulator.#=q2J23UVF1zXonLRlbjK309w==(Order #=q0wnjY82As$lGM3$R70XXZA==, Int32 #=qri0DP6B4pNy7fx3oHmxVqA==, Decimal #=quoai2hjCHpHfZ1q8j3z$ew==)
в StockSharp.Algo.Testing.MarketEmulator.#=qE7E7qt9g1c47ZkBqOFQjyQFedGLvvuLEiZjEuWXdWe8=(MarketDepth #=qtMm0MpCgzrjyUmIY37DQGQ==, Order #=qN7KRs9k9LSYRBZ6MhxRoHA==, Quote #=qN7Znv2zz9zpDeRNGHg_Wow==, Boolean #=qreLQ9GB8WhUEds76X0M828yCTL2n9cda$8T1MfjlO18=)
в StockSharp.Algo.Testing.MarketEmulator.#=qUkyP0_M9OMEy$SkKYfYJOtahWlDktGcqM5WL10p_80s=(Order #=qghTCyYil3z9plTAIH0h7ZQ==, MarketDepth #=qLR63QCgY7j2YwdM8UiJ_RA==)
в StockSharp.Algo.Testing.MarketEmulator.#=qtVjIJmyUftYFmfFY5O4f0g==(SynchronizedDictionary`2 #=q9J8oLVIQhe2_0P3XQ18a7Q==)
в Ecng.Collections.CollectionHelper.SyncDo[TCollection](TCollection collection, Action`1 action)
в StockSharp.Algo.Testing.MarketEmulator.#=qcAGUpJziDHjwYUgUkdFL0g==()
в StockSharp.Algo.Testing.MarketEmulator.UpdateQuotes(IEnumerable`1 marketDepths)
в StockSharp.Algo.Testing.RealTimeEmulationTrader`1.#=q0xtw_MzKkmFKPWfyFMG2VeXM$PE6NDpWY9PTT7IQgHE=(IEnumerable`1 #=qa1P$uiol4QhZBoQzjZJhMw==)
в System.Action`1.Invoke(T obj)
в Ecng.Common.DelegateHelper.SafeInvoke[T](Action`1 handler, T arg)
в StockSharp.Algo.BaseTrader.#=qifrQr7se$_OPI_WBxefq0RZ$hXHpoMKbn3PHl9eAJYM=.#=qq46wFSKy$Z5naYx_yW1qIw==(IEnumerable`1 #=q_TiYF80HDzj2r9IIRRL14g==)
InnerException:



А судя по стэктрэйсу - ошибка вовсе не при логировании:
Цитата:
в Ecng.Collections.SynchronizedSet`1.System.Collections.Generic.IList<T>.get_Item(Int32 index)
в Ecng.Collections.BaseCollection`1.get_Item(Int32 index)
в SampleSma.SmaStrategy.OnNewMyTrades(IEnumerable`1 trades) в D:\StockSharp_3.2.7_Sources\SmaStrategy.cs:строка 217


судя по всему - это что-то ваше, внутреннее. в исходниках в SmaStrategy.cs заметно меньше строчек :)
Спасибо:

Евгений

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


А судя по стэктрэйсу - ошибка вовсе не при логировании:
Цитата:
в Ecng.Collections.SynchronizedSet`1.System.Collections.Generic.IList<T>.get_Item(Int32 index)
в Ecng.Collections.BaseCollection`1.get_Item(Int32 index)
в SampleSma.SmaStrategy.OnNewMyTrades(IEnumerable`1 trades) в D:\StockSharp_3.2.7_Sources\SmaStrategy.cs:строка 217


судя по всему - это что-то ваше, внутреннее. в исходниках в SmaStrategy.cs заметно меньше строчек :)

Да, пример переделанный, Александр, вы прям Шерлок Хомс :) я добавил в OnNewMyTrades обработку защитных стратегий. Так, а в чем ошибка, я тогда не понимаю...

Как я выяснил сейчас, ошибка возникает и в строке
Код
AddLog(StrategyErrorStates.None, "Удаление стратегии {0}", base.ChildStrategies[i].Name);
.

и в
Код
base.ChildStrategies.RemoveAt(i);


Метод есть, но он не поддерживается... При чем я помню, что в какой-то версии S# этот код работал...


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

Alexander

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


что у вас на 217 строчке файла?
Спасибо:

Евгений

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


Alexander Перейти
что у вас на 217 строчке файла?


Код
AddLog(StrategyErrorStates.None, "Удаление стратегии {0}", base.ChildStrategies[i].Name);

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

Alexander

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


В 3.2.9 ошибка осталась?
Спасибо:

Евгений

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


Alexander Перейти
В 3.2.9 ошибка осталась?


А уже есть 3.2.9? На боксе и на кодплех не вижу...
Автор топика
Спасибо:

Alexander

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


Евгений Перейти
Alexander Перейти
В 3.2.9 ошибка осталась?


А уже есть 3.2.9? На боксе и на кодплех не вижу...


Скоро будет Cool
Поспешил я.
Спасибо:

Евгений

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


Alexander Перейти
Евгений Перейти
Alexander Перейти
В 3.2.9 ошибка осталась?


А уже есть 3.2.9? На боксе и на кодплех не вижу...


Скоро будет Cool
Поспешил я.


Ошибка осталась.
Автор топика
Спасибо:

Alexander

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


Да, нет доступа по [] и GetItem не поддерживается.
А сильно надо?
Спасибо:

Евгений

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


Alexander Перейти
Да, нет доступа по [] и GetItem не поддерживается.
А сильно надо?


Собственно задача в том, чтобы защитные стратегии выставленные при покупке удалить после сделки продажи на основе сигнала. Может как-то это можно сделать по другому?
Автор топика
Спасибо:

Alexander

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


Евгений Перейти
Alexander Перейти
Да, нет доступа по [] и GetItem не поддерживается.
А сильно надо?


Собственно задача в том, чтобы защитные стратегии выставленные при покупке удалить после сделки продажи на основе сигнала. Может как-то это можно сделать по другому?


Так они автоматом удаляются :)
Спасибо:

Евгений

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


Alexander Перейти
Евгений Перейти
Alexander Перейти
Да, нет доступа по [] и GetItem не поддерживается.
А сильно надо?


Собственно задача в том, чтобы защитные стратегии выставленные при покупке удалить после сделки продажи на основе сигнала. Может как-то это можно сделать по другому?


Так они автоматом удаляются :)


Ситуация. Сигнал на покупку. Покупка. Создание защитной стратегии. Сигнал на продажу (защитная стратегия не начала свою работу). Продажа. В такой ситуации защитная стратегия автоматически удаляется?

А еще я получил такой лог, но может он уже не актуальный (в.3.2.7). Тут защитная стратегия продолжает свою работу несколько раз.


Цитата:
IS 16.08.2011 10:34:37.134 Стратегия запущена.
IS 16.08.2011 17:30:01.313 Регистрация заявки - цена 162565, направление Buy, объем 3
IS 16.08.2011 17:30:02.234 Новая Limit заявка 38070639 на Buy с номером 1.
IS 16.08.2011 17:30:02.468 Новая Buy сделка 1 на 3 заявки 38070639.
IS 16.08.2011 17:30:02.903 Прошла сделка по цене 161715, объём 3, направление Buy.
IS 16.08.2011 17:30:03.094 Регистрация стоп-лосс по цене 160277,87500
IS 16.08.2011 17:30:03.094 Регистрация тейк-профит по цене 163152,12500
IS 16.08.2011 17:30:03.122 [BS] Стратегия запущена.
IS 16.08.2011 17:30:03.132 [BS] [BS] Стратегия запущена.
IS 16.08.2011 17:30:03.132 [BS] [BS] [MTPS] Стратегия запущена.
IS 16.08.2011 17:30:03.141 [BS] [BS] [MSLS] Стратегия запущена.
IS 16.08.2011 17:36:01.087 [BS] [BS] [MTPS] Регистрация новой заявки на Sell с ценой 162215 и объемом 3.
IS 16.08.2011 17:36:01.089 [BS] [BS] [MTPS] Заявка 38070640 на Sell отправлена с ценой 162215 объемом 3.
IS 16.08.2011 17:36:02.097 [BS] [BS] [MTPS] Новая Limit заявка 38070640 на Sell с номером 2.
IS 16.08.2011 17:36:02.097 [BS] [BS] Новая Limit заявка 38070640 на Sell с номером 2.
IS 16.08.2011 17:36:02.097 [BS] Новая Limit заявка 38070640 на Sell с номером 2.
IS 16.08.2011 17:36:02.098 Новая Limit заявка 38070640 на Sell с номером 2.
IS 16.08.2011 17:36:02.098 Новая Sell сделка 2 на 3 заявки 38070640.
IS 16.08.2011 17:36:02.099 Прошла сделка по цене 162270, объём 3, направление Sell.
IS 16.08.2011 17:40:37.909 [BS] [BS] [MTPS] Котируемая заявка 38070640 исполнилась.
IS 16.08.2011 17:40:37.910 [BS] [BS] [MTPS] Регистрация новой заявки на Sell с ценой 162215 и объемом 3.
IS 16.08.2011 17:40:37.911 [BS] [BS] [MTPS] Заявка 38070641 на Sell отправлена с ценой 162215 объемом 3.
IS 16.08.2011 17:40:38.924 [BS] [BS] [MTPS] Новая Limit заявка 38070641 на Sell с номером 3.
IS 16.08.2011 17:40:38.924 [BS] [BS] Новая Limit заявка 38070641 на Sell с номером 3.
IS 16.08.2011 17:40:38.924 [BS] Новая Limit заявка 38070641 на Sell с номером 3.
IS 16.08.2011 17:40:38.924 Новая Limit заявка 38070641 на Sell с номером 3.
IS 16.08.2011 17:49:33.358 [BS] [BS] [MSLS] Регистрация новой заявки на Sell с ценой 161215 и объемом 3.
IS 16.08.2011 17:49:33.358 [BS] [BS] [MSLS] Заявка 38070642 на Sell отправлена с ценой 161215 объемом 3.
IS 16.08.2011 17:49:34.370 [BS] [BS] [MSLS] Новая Limit заявка 38070642 на Sell с номером 4.
IS 16.08.2011 17:49:34.370 [BS] [BS] Новая Limit заявка 38070642 на Sell с номером 4.
IS 16.08.2011 17:49:34.370 [BS] Новая Limit заявка 38070642 на Sell с номером 4.
IS 16.08.2011 17:49:34.370 Новая Limit заявка 38070642 на Sell с номером 4.
IS 16.08.2011 17:49:43.497 Новая Sell сделка 3 на 3 заявки 38070642.
IS 16.08.2011 17:49:43.500 Прошла сделка по цене 161215, объём 3, направление Sell.
IS 16.08.2011 17:51:16.790 [BS] [BS] [MSLS] Котируемая заявка 38070642 исполнилась.
IS 16.08.2011 17:51:16.790 [BS] [BS] [MSLS] Регистрация новой заявки на Sell с ценой 161215 и объемом 3.
IS 16.08.2011 17:51:16.792 [BS] [BS] [MSLS] Заявка 38070643 на Sell отправлена с ценой 161215 объемом 3.
IS 16.08.2011 17:51:17.802 [BS] [BS] [MSLS] Новая Limit заявка 38070643 на Sell с номером 5.
IS 16.08.2011 17:51:17.802 [BS] [BS] Новая Limit заявка 38070643 на Sell с номером 5.
IS 16.08.2011 17:51:17.802 [BS] Новая Limit заявка 38070643 на Sell с номером 5.
IS 16.08.2011 17:51:17.802 Новая Limit заявка 38070643 на Sell с номером 5.
Автор топика
Спасибо:

Евгений

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


Так защитная стратегия автоматически удаляется после сделки на продажу, даже если не сработала?
Автор топика
Спасибо:

Mikhail Sukhov

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


Евгений Перейти
Так защитная стратегия автоматически удаляется после сделки на продажу, даже если не сработала?


Защитная стратегия (пара СЛ + ТП) удаляется тогда, когда одна из них закончила свою работу (выставила заявку и по ней была совершена сделка).
Спасибо:

Евгений

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


Mikhail Sukhov Перейти
Евгений Перейти
Так защитная стратегия автоматически удаляется после сделки на продажу, даже если не сработала?


Защитная стратегия (пара СЛ + ТП) удаляется тогда, когда одна из них закончила свою работу (выставила заявку и по ней была совершена сделка).


Ну значит я все правильно понял. Так а ак тогда удалить стратегию если она не закончила свою работу?
Автор топика
Спасибо:

Mikhail Sukhov

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


Евгений Перейти
Ну значит я все правильно понял. Так а ак тогда удалить стратегию если она не закончила свою работу?


Остановить ее через метод Stop.
Спасибо:

Евгений

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


Mikhail Sukhov Перейти
Евгений Перейти
Ну значит я все правильно понял. Так а ак тогда удалить стратегию если она не закончила свою работу?


Остановить ее через метод Stop.


Ну она же в коллекции останется?

У меня идет проверка для защитных стратегий, чтобы они в не торговое время отключались, а в торговое включались. Получается включатся все стратегии в коллекции, когда нужны только последние.

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

Alexander

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


Евгений Перейти
Mikhail Sukhov Перейти
Евгений Перейти
Ну значит я все правильно понял. Так а ак тогда удалить стратегию если она не закончила свою работу?


Остановить ее через метод Stop.


Ну она же в коллекции останется?

У меня идет проверка для защитных стратегий, чтобы они в не торговое время отключались, а в торговое включались. Получается включатся все стратегии в коллекции, когда нужны только последние.



Запомните какие стратегии надо включать, какие - нет.
Зачем отключать стратегии в не торговое время?
Спасибо:

Евгений

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


Alexander Перейти


Запомните какие стратегии надо включать, какие - нет.
Зачем отключать стратегии в не торговое время?



Ну как я понял защитные стратегии продолжают работать во время клиринга, собственно, когда стакан пуст. И возникает ошибка, о чем я писал выше.

Цитата:
TPS 14:11:52.7958984 System.ArgumentException: Коллекция котировок пуста.
Имя параметра: quotes....
.

Защитные стратегии могут работать без использования стакана?
Автор топика
Спасибо:

Alexander

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


Исправил, такой ошибки больше не будет.
Спасибо за фидбэк
Спасибо:

Евгений

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


Alexander Перейти
Исправил, такой ошибки больше не будет.
Спасибо за фидбэк


Пожалуйста Smile Так, а как мне быть с проверкой? Что конкретно вы исправили?
Автор топика
Спасибо:
< 1 2 3  >

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

loading
clippy