CandleBuilder.CandleStarted вызывается несколько раз для одной свечки


CandleBuilder.CandleStarted вызывается несколько раз для одной свечки
Atom Reply
2/27/2012


Для построения графиков по сделкам использую следующий код:
Код

var trades = Core.Storage.GetTradeStorage(Security).Load(Core.Yesterday, Core.Yesterday + TimeSpan.FromTicks(TimeSpan.TicksPerDay - 1));
var bld = new CandleBuilder(new RawConvertableCandleBuilderSource<Trade>(trades)) { IsSyncRegister = true };
bld.CandlesStarted += (t, c) =>
{
	var candles = c.Cast<TimeFrameCandle>();
	Storage.Save(candles);

	Core.LogMessage(candles.Count() + " свечек построено для " + this);

	bld.Dispose();
};
bld.RegisterTimeFrameCandles(Security, TimeFrame);

Через событие CandlesStarted отдается массив сразу всех свечек за день.
Всегда работал хорошо, но сегодня обнаружил что для RIH2 за 24.02.12 с минутным таймфреймом почему-то косячит - свечки 12:32 и 12:33 в возвращаемом CandlesStarted массиве присутствуют много раз:
Код

...
candleStarted candle time: 24.02.2012 12:30:00
candleStarted candle time: 24.02.2012 12:31:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:32:00
candleStarted candle time: 24.02.2012 12:33:00
candleStarted candle time: 24.02.2012 12:34:00


Обновился до 4.0.20v2, качал сделки заново, строил заново - ничего не помогает.
Сделки качаю с финама, в получаемом текстовом файле смотрел - сделки по вермени расположены без нарушений, вроде все в порядке...

Tags:


Thanks:




19 Answers
Supervisor

Avatar
Date: 2/27/2012
Reply


Попробовал гидрой - точно так же неправильно строит.
Плюс обнаружил аналогичные ошибки в 10:04 и 10:45.
Topic starter
Thanks:

Alexander

Avatar
Date: 2/27/2012
Reply


Посмотрим как будет время.
Thanks:

Alexander

Avatar
Date: 2/29/2012
Reply


На SampleEmulationTesting воспроизводится?
Добавил подписку на событие сразу после инициализации builder - ни разу не пришли повторные свечки.

Запускал 3 раза для верности.

Код
			builder.CandlesStarted += builder_CandlesStarted;


		private SynchronizedList<Candle> finishedCandles = new SynchronizedList<Candle>();

		void builder_CandlesStarted(CandleToken arg1, IEnumerable<Candle> arg2)
		{
			foreach (var candle in arg2)
			{
				if (!finishedCandles.Contains(candle))
					finishedCandles.Add(candle);
				else
				{
					MessageBox.Show("found!");
				}
			}
		}



Ни окошка, ни брэйкпоинт не сработали - всё ок, добавляются все неповторные.
Thanks:

Supervisor

Avatar
Date: 2/29/2012
Reply


Хочу уточнить - а нужно проверять на SampleEmulationTesting если у меня на гидре воспроизводится?
При чем только в этом дне - 24.02 наблюдается проблема, если пробовать на других то все нормально.

Topic starter
Thanks:

Alexander

Avatar
Date: 2/29/2012
Reply


Сделал всё тоже самое, не воспроизвелось:

гидра

Для исправления конечно надо такое, что и я смогу воспроизвести. А то исправлять непонятно что и непонятно где.
Thanks:

Supervisor

Avatar
Date: 2/29/2012
Reply


Возможно у Вас сделки скачаны не с Финама, а с другого источника.
Сейчас попробовал в гидре удалить сделки финамовские, скачать с ртс и построить по ним - все построило правильно.
А по финамовским - опять то же самое.
Topic starter
Thanks:

Alexander

Avatar
Date: 2/29/2012
Reply


Для SampleEmulationTesting воспроизводится?
Thanks:

Supervisor

Avatar
Date: 3/1/2012
Reply


Прогнал пару раз - не воспроизводится
Topic starter
Thanks:

Supervisor

Avatar
Date: 3/5/2012
Reply


То есть, я так понимаю, выход один - не использовать финам, использовать ртс
Topic starter
Thanks:

Alexander

Avatar
Date: 3/5/2012
Reply


Supervisor Перейти
То есть, я так понимаю, выход один - не использовать финам, использовать ртс


Либо ждать фикса
Thanks:

Mikhail Sukhov

Avatar
Articles author Programmer Trader
Date: 3/5/2012
Reply


Supervisor Перейти
То есть, я так понимаю, выход один - не использовать финам, использовать ртс


А вы нашли разницу в данных?
Thanks:

Supervisor

Avatar
Date: 3/6/2012
Reply


Mikhail Sukhov Перейти
Supervisor Перейти
То есть, я так понимаю, выход один - не использовать финам, использовать ртс


А вы нашли разницу в данных?

В получающихся свечках - нашел. Я так понимаю нужно сравнить получающиеся сделки по двум источникам. Будет время - займусь..
Topic starter
Thanks:

Mikhail Sukhov

Avatar
Articles author Programmer Trader
Date: 3/6/2012
Reply


Supervisor Перейти
В получающихся свечках - нашел. Я так понимаю нужно сравнить получающиеся сделки по двум источникам. Будет время - займусь..


Да правильно. Потому что без этой информации не понятно, у нас ли бага, или так отдает Финам.
Thanks:

Alexander

Avatar
Date: 3/7/2012
Reply


Удалось сравнить?
Thanks:

Supervisor

Avatar
Date: 3/11/2012
Reply


Посмотрел...
Во-первых, тот день - не единственный, на прошлой неделе снова аналогичное наблюдал.
Но вернемся к 24 февраля. И с финама и с РТС качал гидрой. Получилось с РТС - 566831 сделок, с финама - 567661.
Начал сравнивать, вот что обнаружил в финаме (файл 2012-02-24.txt):

...
20120224;100046;165815.00000;5;509791824
20120224;100046;165805.00000;3;509791825
20120224;100046;165810.00000;1;509791826
20120224;100047;165805.00000;3;509791825
20120224;100047;165810.00000;1;509791826
...
20120224;100226;165770.00000;2;509798933
20120224;100226;165775.00000;2;509798934
20120224;100226;165750.00000;2;509798939
20120224;100227;165750.00000;2;509798939
20120224;100227;165770.00000;2;509798942
20120224;100227;165770.00000;1;509798944
...

Проскакивают сделки с одинаковым id и разным временем, чего нет в сделках от РТС. Я так понимаю косяк финама?)
Если надо, приложил все файлики.
trades.zip 3 MB (0)
Topic starter
Thanks:

Alexander

Avatar
Date: 3/11/2012
Reply


Да, косяк финама. Я потому последний месяц стал скачивать сделки с ртс - тоже заметил расхождения финама с терминалом.
Thanks:

Supervisor

Avatar
Date: 3/11/2012
Reply


А в РТС можно организовать утром скачивание сделок за вчерашний день целиком? Насколько помню там же сессии с 19 до 19...
Topic starter
Thanks:

Alexander

Avatar
Date: 3/11/2012
Reply


нельзя, да
напишите в финам, скажите что у них такой косяк с данными. может оперативно поправят

сообщите о результатах письма, тоже интересно :)
Thanks:

Supervisor

Avatar
Date: 3/12/2012
Reply


Спустя 3 часа написали что ошибка исправлена, и действительно за этот день и за другой проблемный день история теперь похоже сходится :)
Topic starter
Thanks: Alexander


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

loading
clippy