[FIXED] TakeProfitStrategy отправляет неправильный ордер

[FIXED] TakeProfitStrategy отправляет неправильный ордер
Atom
23.06.2011
President


Разобравшись с http://stocksharp.com/forum/1684/-BUG--BatchStrategy---Value-cannot-be-null--Parameter-name--security/ наткнулся на другую проблему:

var takeProfit = new TakeProfitStrategy(t, this.TakeProfitThreshold);

в момент срабатывания посылает в QUIK заявку с Price = this.TakeProfitThreshold что существенно ниже лимитов рынка и заявка отвергается:

23.06.2011 11:11:00.667 [BS] [BS] [SLS] System.ArgumentException: Транзакции 'ACCOUNT=SPBFUT00al8; CLIENT_CODE=S#; TRANS_ID=40036888; CLASSCODE=SPBFUT; SECCODE=LKU1; QUANTITY=1; OPERATION=B; TYPE=L; ACTION=NEW_ORDER; PRICE=6;' не была зарегистрирована. Причина 'Ошибка создания заявки. [FORTS] "Цена сделки вне лимита".'. Parameter name: transactionTxt at #=q3C5AM$iq8NbweFUGFWK_sU7Vcw7Z$U4vlB2Hc50kdH4=.#=qLgL84qMEfuN5KhECfgmmVtmEjdZHFTZu$WkBCYieTcI=(String #=qgclQ_YrKOL8W24OU8dAXtQ==, OrderStatus& #=q_xaMqAhWgI5tV2SZaQTgUw==, UInt32& #=q9f$NCAgNEA2P_dgSYQX4ag==, Int64& #=qwVmYFYP0ooLLxsTPLQePQg==, String& #=qR6gf_ntTXrn2yuZ9RSMZLQ==) at StockSharp.Quik.QuikTrader.#=q4vcoB7VlrVy4GatAp8_nMJ6AYLGi58dOpiGwxMBn6UQ=(Order #=qbn0ghccP_Nk8KrwPARMMqA==, TransactionBuilder #=qxOobaox1SG$xe4kqR2_8ZA==) at StockSharp.Quik.QuikTrader.OnRegisterOrder(Order order) at StockSharp.Algo.BaseTrader.RegisterOrder(Order order) at StockSharp.Algo.Strategies.Strategy.RegisterOrder(Order order) at StockSharp.Algo.Strategies.QuotingStrategy.#=qFNjSJ7N1u5acr$1keu3nHg==() at StockSharp.Algo.Strategies.QuotingStrategy.#=qeubD$wKedi$ApPCf6cLO3rlmhGW$ZeerQHKTqhIth$w=.#=qEsRZe$IDBR8A0j$0apLQ$Q==() at StockSharp.Algo.Strategies.StrategyRule.#=qm8VBf4GDpEbeabai3WtCE_YuhOxfkovbmj6wDnrDrR0=.#=q0OgKPN9vlMKZZIjBhTnAcw==(Object #=q0xxkRlvbFaZQkdN1O3pBCA==) at StockSharp.Algo.Strategies.StrategyRule.#=qwurDVpnPEgnquLK$nRLn9OHeSuX4XtP79q8cEhLyYMI=.#=qTxwzPP4CbQG2ITMlWDV$_nA93xIudHPYiyO3YFbU4x4=() at StockSharp.Algo.Strategies.Strategy.#=qIHDBOzkYlc1Ka0H4Q5rQnQ==(StrategyRule #=qsRkj9dGU3TX31YwcXiQefQ==, Action #=qREJnLkxJR0fsGiLETZNSBg==)

Environment: S# v3.2.2, QUIK


Теги:


Спасибо:


< 1 2 
President

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


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

а price - вот он выводится первой строкой Lku1Lku1 22.06.2011 23:28:27.699 Trade 340440040 at price 17664 for security LKU1 with volume 1 at 22.06.2011 23:28:25. Lku1Lku1 22.06.2011 23:28:27.722 [BS] Стратегия запущена. Lku1Lku1 22.06.2011 23:28:27.722 [BS] [BS] Стратегия запущена. Lku1Lku1 22.06.2011 23:28:27.727 [BS] [BS] [TPS] Стратегия запущена. Lku1Lku1 22.06.2011 23:28:27.727 [BS] [BS] [SLS] Стратегия запущена. Lku1Lku1 22.06.2011 23:28:27.992 Отмена заявки 84411747. Lku1Lku1 22.06.2011 23:28:28.212 [BS] [BS] [SLS] Регистрация новой заявки на Buy с ценой 8 и объемом 1. Lku1Lku1 22.06.2011 23:28:28.747 [BS] [BS] [SLS] System.ArgumentException: Транзакции 'ACCOUNT=SPBFUT00al8; CLIENT_CODE=S#; TRANS_ID=84411749; CLASSCODE=SPBFUT; SECCODE=LKU1; QUANTITY=1; OPERATION=B; TYPE=L; ACTION=NEW_ORDER; PRICE=8;' не была зарегистрирована. Причина 'Ошибка создания заявки. [FORTS] "Цена сделки вне лимита".'. Parameter name: transactionTxt at #=q3C5AM$iq8NbweFUGFWK_sU7Vcw7Z$U4vlB2Hc50kdH4=.#=qLgL84qMEfuN5KhECfgmmVtmEjdZHFTZu$WkBCYieTcI=(String #=qgclQ_YrKOL8W24OU8dAXtQ==, OrderStatus& #=q_xaMqAhWgI5tV2SZaQTgUw==, UInt32& #=q9f$NCAgNEA2P_dgSYQX4ag==, Int64& #=qwVmYFYP0ooLLxsTPLQePQg==, String& #=qR6gf_ntTXrn2yuZ9RSMZLQ==) at StockSharp.Quik.QuikTrader.#=q4vcoB7VlrVy4GatAp8_nMJ6AYLGi58dOpiGwxMBn6UQ=(Order #=qbn0ghccP_Nk8KrwPARMMqA==, TransactionBuilder #=qxOobaox1SG$xe4kqR2_8ZA==) at StockSharp.Quik.QuikTrader.OnRegisterOrder(Order order) at StockSharp.Algo.BaseTrader.RegisterOrder(Order order) at StockSharp.Algo.Strategies.Strategy.RegisterOrder(Order order) at StockSharp.Algo.Strategies.QuotingStrategy.#=qFNjSJ7N1u5acr$1keu3nHg==() at StockSharp.Algo.Strategies.QuotingStrategy.#=qeubD$wKedi$ApPCf6cLO3rlmhGW$ZeerQHKTqhIth$w=.#=qEsRZe$IDBR8A0j$0apLQ$Q==() at StockSharp.Algo.Strategies.StrategyRule.#=qm8VBf4GDpEbeabai3WtCE_YuhOxfkovbmj6wDnrDrR0=.#=q0OgKPN9vlMKZZIjBhTnAcw==(Object #=q0xxkRlvbFaZQkdN1O3pBCA==) at StockSharp.Algo.Strategies.StrategyRule.#=qwurDVpnPEgnquLK$nRLn9OHeSuX4XtP79q8cEhLyYMI=.#=qTxwzPP4CbQG2ITMlWDV$_nA93xIudHPYiyO3YFbU4x4=() at StockSharp.Algo.Strategies.Strategy.#=qIHDBOzkYlc1Ka0H4Q5rQnQ==(StrategyRule #=qsRkj9dGU3TX31YwcXiQefQ==, Action #=qREJnLkxJR0fsGiLETZNSBg==) Lku1Lku1 22.06.2011 23:28:28.749 [BS] [BS] Стратегия останавливается. Lku1Lku1 22.06.2011 23:28:28.751 [BS] [BS] [TPS] Стратегия останавливается. Lku1Lku1 22.06.2011 23:28:28.753 [BS] [BS] Стратегия остановлена. Lku1Lku1 22.06.2011 23:28:28.754 [BS] [BS] [TPS] Стратегия остановлена. Lku1Lku1 22.06.2011 23:28:28.754 [BS] [BS] [SLS] Стратегия остановлена.

Спасибо:

Mikhail Sukhov

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


President: возможно проблема только со StopLoss.

А трейлинг-стоп включен?

Спасибо:

President

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


Mikhail Sukhov:

President: возможно проблема только со StopLoss.

А трейлинг-стоп включен?

а что это такое?[blush]

моя догадка что это только со стоп лосс повторилась - я специально поставил большой порог для тейк профита - чтобы ближе был стоп лосс и вот что вышло:

Lku1Str 24.06.2011 12:17:15.152 Trade 341553398 with direction SELL at price 17521 for security LKU1 with volume 1 at 24.06.2011 12:17:15. Lku1Str 24.06.2011 12:17:15.165 [BS] Стратегия запущена. Lku1Str 24.06.2011 12:17:15.165 [BS] [BS] Стратегия запущена. Lku1Str 24.06.2011 12:17:15.168 [BS] [BS] [TPS] Стратегия запущена. Lku1Str 24.06.2011 12:17:15.168 [BS] [BS] [SLS] Стратегия запущена. Lku1Str 24.06.2011 12:17:15.394 [BS] [BS] [SLS] Регистрация новой заявки на Buy с ценой 6 и объемом 1. Lku1Str 24.06.2011 12:17:16.574 [BS] [BS] [SLS] System.ArgumentException: Транзакции 'ACCOUNT=SPBFUT00al8; CLIENT_CODE=S#; TRANS_ID=43945351; CLASSCODE=SPBFUT; SECCODE=LKU1; QUANTITY=1; OPERATION=B; TYPE=L; ACTION=NEW_ORDER; PRICE=6;' не была зарегистрирована. Причина 'Ошибка создания заявки. [FORTS] "Цена сделки вне лимита".'. Parameter name: transactionTxt at #=q3C5AM$iq8NbweFUGFWK_sU7Vcw7Z$U4vlB2Hc50kdH4=.#=qLgL84qMEfuN5KhECfgmmVtmEjdZHFTZu$WkBCYieTcI=(String #=qgclQ_YrKOL8W24OU8dAXtQ==, OrderStatus& #=q_xaMqAhWgI5tV2SZaQTgUw==, UInt32& #=q9f$NCAgNEA2P_dgSYQX4ag==, Int64& #=qwVmYFYP0ooLLxsTPLQePQg==, String& #=qR6gf_ntTXrn2yuZ9RSMZLQ==) at StockSharp.Quik.QuikTrader.#=q4vcoB7VlrVy4GatAp8_nMJ6AYLGi58dOpiGwxMBn6UQ=(Order #=qbn0ghccP_Nk8KrwPARMMqA==, TransactionBuilder #=qxOobaox1SG$xe4kqR2_8ZA==) at StockSharp.Quik.QuikTrader.OnRegisterOrder(Order order) at StockSharp.Algo.BaseTrader.RegisterOrder(Order order) at StockSharp.Algo.Strategies.Strategy.RegisterOrder(Order order) at StockSharp.Algo.Strategies.QuotingStrategy.#=qFNjSJ7N1u5acr$1keu3nHg==() at StockSharp.Algo.Strategies.QuotingStrategy.#=qeubD$wKedi$ApPCf6cLO3rlmhGW$ZeerQHKTqhIth$w=.#=qEsRZe$IDBR8A0j$0apLQ$Q==() at StockSharp.Algo.Strategies.StrategyRule.#=qm8VBf4GDpEbeabai3WtCE_YuhOxfkovbmj6wDnrDrR0=.#=q0OgKPN9vlMKZZIjBhTnAcw==(Object #=q0xxkRlvbFaZQkdN1O3pBCA==) at StockSharp.Algo.Strategies.StrategyRule.#=qwurDVpnPEgnquLK$nRLn9OHeSuX4XtP79q8cEhLyYMI=.#=qTxwzPP4CbQG2ITMlWDV$_nA93xIudHPYiyO3YFbU4x4=() at StockSharp.Algo.Strategies.Strategy.#=qIHDBOzkYlc1Ka0H4Q5rQnQ==(StrategyRule #=qsRkj9dGU3TX31YwcXiQefQ==, Action #=qREJnLkxJR0fsGiLETZNSBg==) Lku1Str 24.06.2011 12:17:16.575 [BS] [BS] Стратегия останавливается. Lku1Str 24.06.2011 12:17:16.577 [BS] [BS] [TPS] Стратегия останавливается. Lku1Str 24.06.2011 12:17:16.579 [BS] [BS] Стратегия остановлена. Lku1Str 24.06.2011 12:17:16.579 [BS] [BS] [TPS] Стратегия остановлена. Lku1Str 24.06.2011 12:17:16.579 [BS] [BS] [SLS] Стратегия остановлена. Lku1Str 24.06.2011 12:17:16.790 Отмена заявки 43945349. Lku1Str 24.06.2011 12:17:17.327 Отмена заявки 43945352.

PS. было this.StopLossThreshold = 6;

Спасибо:

Mikhail Sukhov

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


Ошибку нашел. Выложу в 3.2.3

Спасибо: President

President

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


Mikhail Sukhov: Ошибку нашел. Выложу в 3.2.3

спасибо

Спасибо:

critic

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


Я бы не спасибо Мише говорил, а морду набил. Как можно было попутать прайс с дельтой? Если бы биржа не защищала от таких тупых ошибок - человек потерял бы немалые деньги. Как можно использовать такую библиотеку не имея исходных её кодов? Где ещё найдём "случайные" баги, приводящие к убыткам? Да и не похоже это на ошибку. В документации точно написано дельта. На практике библиотека ставит заявку по абсолютному значению. Верим что это ошибка? :) Ну а про закрытый код стратегии дельта-хэджирования и отсутствие её описания я вообще молчу. Всё больше убеждаюсь в том, что библиотеку Михаил выложил не с целью того, чтобы народ деньги зарабатывал :)

Спасибо:
< 1 2 

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

loading
clippy