возможно некорректная работа SampleSMA v.4.1.6
Atom Ответить
28.11.2012


Всем здравствуйте!
Только начинаю разбираться в stockslash и столкнулся со следующим.
Пример SampleSMA в версии 4.1.6 то-ли некорректно работает, то-ли ...
Чудесно компилируется, запускается, отрисовывает исторические данные по "LKOH" (которые идут в комплекте вместе с данным примером)
и скользящие средние для них. Но как только переходит на реальное время, все скользящие средние начинают вычисляться некорректно,
становятся фактически одной линией, которая проходит по закрытию свечей. Причём на изменение параметров
скользящей средней при отрисовке реальных данных не реагирует, что Length = 10, что 30, разницы никакой. Может подскажет кто, в чём дело?
рис.jpg 109 KB (0)

Теги:


Спасибо:




13 Ответов
Algonavt

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


Вчера на примере SampleSMA получил то же самое. Интересно узнать мнение разработчиков по этому поводу - бага это или где-то в самом примере недоработка.
Спасибо:

Mikhail Sukhov

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


Algonavt Перейти
Вчера на примере SampleSMA получил то же самое. Интересно узнать мнение разработчиков по этому поводу - бага это или где-то в самом примере недоработка.


Может потому что разница м/у историей и реалом 3 месяца? А что отладчик говорит? Или пример тоже обфусцирован?Cool
Спасибо:

Semen7

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


Когда отключаешь код загрузки истории, получается тоже самое. На всякий случай привожу отключаемый код (вдруш чаво лишнего закоментил).
/*IEnumerable<Candle> candles = CultureInfo.InvariantCulture.DoInCulture(() => File.ReadAllLines("LKOH_history.txt").Select(line =>
{
var parts = line.Split(',');
var time = (parts[0] + parts[1]).ToDateTime("yyyyMMddHHmmss");
return (Candle)new TimeFrameCandle
{
OpenPrice = parts[2].To<decimal>(),
HighPrice = parts[3].To<decimal>(),
LowPrice = parts[4].To<decimal>(),
ClosePrice = parts[5].To<decimal>(),
TimeFrame = _timeFrame,
OpenTime = time,
CloseTime = time + _timeFrame,
TotalVolume = parts[6].To<decimal>(),
Security = _lkoh,
State = CandleStates.Finished,
};
}).ToArray());

var lastCandleTime = default(DateTime);

// начинаем вычислять скользящие средние
foreach (var candle in candles)
{
ProcessCandle(candle);
lastCandleTime = candle.OpenTime;
}[img]null[/img]*/
/*var bounds = _timeFrame.GetCandleBounds(series.Security);

candles = _candleManager.Container.GetCandles(series, new Range<DateTime>(lastCandleTime + _timeFrame, bounds.Min));

foreach (var candle in candles)
{
ProcessCandle(candle);
}*/
На рисунке пример того, что получается при отключении истории. Вроде бы он должен рисовать две скользящие средние
с длиной 80 и 10 для реальных данных. А на деле получается рисует непонятно чего.
Эксепшены вроде не появлялись, а что именно в отладчике смотреть?
рис2.jpg 86 KB (0)
Автор топика
Спасибо:

Mikhail Sukhov

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


Semen7 Перейти
Эксепшены вроде не появлялись, а что именно в отладчике смотреть?


Реальные значения индикаторов, что идут на график.
Спасибо:

Semen7

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


Значения индикатор высчитывает, но как-то странно. Например для первой поступившей свечки 80-ти периодное скользящее среднее
выдает значение для вывода на график. Но как? Если ему минимум надо 80 свечек для вычисления первого значения.
Вычисленное значение совпадает с ценой закрытия свечки. И так для все остальных свечек. Такое ощущение, что все уже сформированные свечки,
которые индикатор проглотил, он не воспринимает,а считает только по текущей.
Может важно, свойство индикатора IsFormed после вычисления всегда == false.
Пробовал примеры, которые в хелпе стокшарпа. Всё для реала работает. А в этом примере почему-то такое непонятное происходит.
Автор топика
Спасибо:

Mikhail Sukhov

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


Semen7 Перейти
Значения индикатор высчитывает, но как-то странно. Например для первой поступившей свечки 80-ти периодное скользящее среднее
выдает значение для вывода на график. Но как?


В примере же написан код вывода.
Спасибо:

Semen7

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


В хелпе код вывода написан и он работает, а схема вывода, представленная в примере SampleSMA работает неправильно на реале.
А причина полагаю в том, что переменная series объявлена как локальная в private void StartClick(object sender, RoutedEventArgs e).
Надобно её в private класса MainWindow записать. С этим вроде всё.
Вот ещё попутно вопрос-заметка. Похоже индикатор Аллигатор считается неверно. На графике (на одних и тех же данных) в визуале (рисунок 1) он один, а
на графике в квике (рисунок 2) он совсем другой. Причем график квик совпадает с графиком в AmiBrocker.
Ошибка в построении (а возможно и в вычислении) следующая:
Челюсть аллигатора не может отображаться с 6-й свечи. Ей для расчета нужно 13 и сдвинуть её надо на 8.
Следовательно, отражаться она будет только с 22 свечи. Аналогично для зубов и губ. На картинке из квика аллигатор такой потому что данные идут с 4-х утра.
И ещё вопрос. Какой способ расчета скользящих средних применяется в Аллигаторе в стокшарпе: простая, сглаженная, экспоненциальная или по уайлдерсу??
рис3.jpg 305 KB (0) рис4.jpg 149 KB (0)
Автор топика
Спасибо:

Semen7

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


Кладу рисунки повторно, что-то загрузились с ошибкой.
рис3.jpg 305 KB (0)
Автор топика
Спасибо:

esper

Фотография
Программист
Дата: 30.11.2012
Ответить


Поправил на кодеплексе.
Спасибо:

Semen7

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


Спасибо! Но вопрос по Аллигатору по-прежнему остался.
Попробовал свой индикатор написать аналогичный аллигатору, но при переопределении метода OnProcess
вот так:

public override decimal OnProcess(IIndicatorValue input)
{
//если кол-во в буфере больше Shift, то первое значение отдали в прошлый раз, удалим его.
if (Buffer.Count > Shift)
Buffer.RemoveAt(0);

var smaResult = _sma.Process(_medianPrice.Process(input));
if (_sma.IsFormed)
Buffer.Add(smaResult.GetValue<decimal>());

return Buffer.Count > Shift ? Buffer[0] : LastValue;
}

получаю ошибку <Ошибка 1"SampleSMA.WildersAlligator.OnProcess(StockSharp.Algo.Indicators.IIndicatorValue)": невозможно изменить модификаторы доступа при переопределении унаследованного из "protected" члена "StockSharp.Algo.Indicators.BaseIndicator<decimal>.OnProcess(StockSharp.Algo.Indicators.IIndicatorValue)">.
При попытке смены модификатора на "protected" получаю
<Ошибка 1:Имя "LastValue" отсутствует в текущем контексте>. Если закрыть "LastValue", то компилится, но работать правильно естественно не будет.
Прям замкнутый круг какой-то.Confused
Подскажите как правильно переопределить OnProcess, чтоб на Public не ругался и "LastValue" увидел???
Автор топика
Спасибо:

esper

Фотография
Программист
Дата: 30.11.2012
Ответить


1. Он и должен быть protected.
2. LastValue уже давно нет, смотрите последние версии индикаторов.
Спасибо: Semen7

Semen7

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


Спасибо доктор, помогло:)
Автор топика
Спасибо:

Algonavt

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


Играясь с индикаторами и примером SampleCandles, обнаружил, следующее:
Если в методе DrawCandle обработку делать следующим образом, то средняя просто соединяет цены закрытия свечей:
Код
this.GuiAsync(() =>
               {

                   var wnd = _chartWindows.TryGetValue(series);

                   var bollingerValue = candle.State == CandleStates.Finished
                       ? new ChartIndicatorValue(_bollingerElement.Indicator, _bollingerElement.Indicator.Process(candle))
                       : null;

                   wnd.Chart.ProcessValues(candle.OpenTime, new Dictionary<IChartElement, object>
                    {
                        { _candlesElement, candle },
                        { _bollingerElement, bollingerValue }
                    });
               });


Если же код немного модифицировать, то индикатор отображается нормально:
Код
var wnd = _chartWindows.TryGetValue(series);

            var bollingerValue = candle.State == CandleStates.Finished
            ? new ChartIndicatorValue(_bollingerElement.Indicator, _bollingerElement.Indicator.Process(candle))
            : null;

            this.GuiAsync(() => wnd.Chart.ProcessValues(candle.OpenTime, new Dictionary<IChartElement, object>
                    {
                        { _candlesElement, candle },
                        { _bollingerElement, bollingerValue }
                    }));


С чем это может быть связано? Вроде как проблему решил, но всё равно хочется разобраться, почему проблема возникла.

PS: в аттаче работающий проект.
Спасибо:


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

loading
clippy