Не проставляется OrderDirection в сделке

Не проставляется OrderDirection в сделке
Atom
8/25/2010
Alexander


ó ÐÏÍÏÝØÀ Ó×ÏÅÇÏ ÍÅÔÏÄÁ:
if (_multiTrader.Trades.Count() > 0)
{
if (!Directory.Exists("MarketData"))
{
Directory.CreateDirectory("MarketData");
}
var allTradesSw = new StreamWriter("MarketData\\{0}_{1:00}_{2:00}
_AllTrades.log".Put(_multiTrader.Trades.Last().Time.Year,
_multiTrader.Trades.Last().Time.Month,
_multiTrader.Trades.Last().Time.Day), false);
foreach (var trade in _multiTrader.Trades)
{
allTradesSw.WriteLine("{0} - {1} - {2} - {3}",
trade.Time,
trade.Price,
trade.Volume,
trade.OrderDirection);
}
allTradesSw.Close();
}

ðÅÞÁÔÁÀ ×ÓÅ ÓÄÅÌËÉ (ÌÅÎÔÕ) ÚÁ ÄÅÎØ. òÅÄËÏ, ÎÏ ÐÏÒÏÊ ÐÏÐÁÄÁÀÔÓÑ ÓÄÅÌËÉ
ÂÅÚ ÐÒÏÓÔÁ×ÌÅÎÎÏÇÏ ÐÏÌÑ OrderDirection. ôÏÌÉ ÜÔÏ ÎÅ×ÅÒÎÏ ÒÁÂÏÔÁÅÔ
ÐÅÞÁÔØ, ÔÏ ÌÉ ÄÅÊÓÔ×ÉÔÅÌØÎÏ ÞÔÏ-ÔÏ ÎÅ ÐÒÏÓÔÁ×ÌÑÅÔÓÑ (× Ë×ÉËÅ Õ ÄÁÎÎÙÈ
ÓÄÅÌÏË ÎÁÐÒÁ×ÌÅÎÉÅ ÐÒÏÓÔÁ×ÌÅÎÏ). ÷ÏÔ ÐÒÉÍÅÒ ÉÚ ÆÁÊÌÁ ÓÏ ×ÓÅÍÉ
ÓÄÅÌËÁÍÉ:

24.08.2010 23:45:01 - 138895 - 1 - Sell
24.08.2010 23:45:01 - 138890 - 1 - Sell
24.08.2010 23:45:01 - 138925 - 2 -
24.08.2010 23:45:01 - 138930 - 1 - Buy
24.08.2010 23:45:01 - 138930 - 3 - Buy
24.08.2010 23:45:01 - 138935 - 3 - Buy
24.08.2010 23:45:01 - 138935 - 2 - Buy
24.08.2010 23:45:01 - 138935 - 1 - Buy
24.08.2010 23:45:01 - 138940 - 3 - Buy
24.08.2010 23:45:02 - 138910 - 1 - Sell
24.08.2010 23:45:02 - 138935 - 2 -
24.08.2010 23:45:02 - 138935 - 1 -
24.08.2010 23:45:02 - 138930 - 2 - Buy
24.08.2010 23:45:02 - 138935 - 1 - Buy

úÁ×ÔÒÁ ×ÅÞÅÒÏÍ, ÅÓÌÉ OrderDirection ÎÅ ÓÅÌÌ É ÎÅ ÂÁÊ - ÂÕÄÅÔ ÏËÏÛËÏ
×ÙÄÁ×ÁÔØ. ôÁË ÈÏÔØ ÍÏÖÎÏ ÂÕÄÅÔ ÐÏÎÑÔØ × ËÁËÏÍ ÉÍÅÎÎÏ ÍÅÓÔÅ ×ÏÚÎÉËÁÅÔ
ÏÛÉÂËÁ, ÏÔÐÉÛÕÓØ.

Tags:


Thanks:


< 1 2 
Mikhail Sukhov

Avatar
Date: 2/3/2011
Reply


aerv
Та сделка которую совершил мой робот попадает в обе таблицы Квика: "Все сделки" и "Мои сделки" со всей требуемой информацией.


Только вот сканирования всех сделок на поиск направление не было сделано в целях оптимизации.

aerv

Затем эта сделка попадает в список _trader.Trades но почему-то уже без направления.
Почему - не понятно.


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

aerv

Я сначала подумал: может это ошибка какая-то? Но если это "by design" и так и должно быть, то ладно.


Я бы сказал так - исторически сложившаяся бага.[smile] Я занес в баг трекинг ссылку на топик. Но пока не скоро смогу что-то придумать - есть баги приоритетнее.
Thanks:

aerv

Avatar
Date: 2/4/2011
Reply


Mikhail Sukhov
aerv
Та сделка которую совершил мой робот попадает в обе таблицы Квика: "Все сделки" и "Мои сделки" со всей требуемой информацией.
Затем эта сделка попадает в список _trader.Trades но почему-то уже без направления.
Почему - не понятно.


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

Я бы сказал так - исторически сложившаяся бага.[smile] Я занес в баг трекинг ссылку на топик. Но пока не скоро смогу что-то придумать - есть баги приоритетнее.


Я бы предложил заполнять список QuikTrader.Trades только по данным ДДЕ из таблицы "Все сделки" Квика.
Пытаться мудрить и комбинировать его с данными из таблицы "Мои сделки" - ИМХО только лишние взаимосвязи городить. Запутаться и без этих сложностей можно. Я, например, точно смогу [smile]

Спасибо Вам Михаил за библиотеку и ее поддержку!
Thanks:

aerv

Avatar
Date: 2/4/2011
Reply


Кстати, в то же время когда мой робот совершает сделку, может возникнуть и дублирующаяся свеча:
20110203,172300,191535,191535,191535,191535,3
20110203,172300,191600,191655,191505,191550,1113
- это свечи, полученные _candleManager.GetTimeFrameCandles(...): дата, время, цены, объем.
"3" - как раз объем моей сделки.

20110203,172339,-1,191535,3
- это из списка всех сделок, полученных из QuikTrader.Trades.
"-1" - это нет направления.

Предположу, что это связанные проблемы:
заполнение Trades сделками из MyTrades
и дублирующиеся свечи http://stocksharp.com/forum/133...ger-GetTimeFrameCandles/
Thanks:

Mikhail Sukhov

Avatar
Date: 2/5/2011
Reply


aerv
Предположу, что это связанные проблемы:
заполнение Trades сделками из MyTrades
и дублирующиеся свечи http://stocksharp.com/forum/133...ger-GetTimeFrameCandles/


Точно, как раз из-за этого. Собственная сделка приходит раньше, поэтому на какой-то момент формируется свечка раньше времени. Поэтому, я решил сделать то, как Вы предложили, и убить сразу 2-ух зайцев. Но тогда ITrader.Trades.Contains(myTrade.Trade) будет возвращать false, но я пока не вижу, когда это может быть полезно.
Thanks:

aerv

Avatar
Date: 2/5/2011
Reply


Mikhail Sukhov
Но тогда ITrader.Trades.Contains(myTrade.Trade) будет возвращать false, но я пока не вижу, когда это может быть полезно.


Не думаю, что это сильно помешает. Искать свою сделку можно, например, так:
Code

_trader.Trades.Contains(myTrade.Trade, new TradeByIdComparer());
// Или так
int index = Array.BinarySearch(_trader.Trades.ToArray(), myTrade.Trade, new TradeByIdComparer());

// Где-то в другом месте
class TradeByIdComparer : IComparer<Trade>, IEqualityComparer<Trade> {
public int Compare(Trade t1, Trade t2) { return (int) (t1.Id - t2.Id); }
public bool Equals(Trade t1, Trade t2) { return t1.Id == t2.Id; }
public int GetHashCode(Trade obj) { return obj.Id.GetHashCode(); }
}
Thanks:
< 1 2 

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

loading
clippy