Mikhail Sukhov
|
Date: 6/20/2013
Приведите пожалуйста StackTrace. Картинки с ошибками и сам код не несут практически никакой полезной информации.
|
|
Thanks:
|
|
|
|
|
UsilaDobry
|
Date: 6/20/2013
Михаил Сухов Приведите пожалуйста StackTrace. Картинки с ошибками и сам код не несут практически никакой полезной информации. StackTrace? Это трассировка исключения? Не знаю правильно ли я понял, Вы имеете ввиду вот эту информацию?
|
|
Thanks:
|
|
|
|
|
Mikhail Sukhov
|
Date: 6/20/2013
UsilaDobry Михаил Сухов Приведите пожалуйста StackTrace. Картинки с ошибками и сам код не несут практически никакой полезной информации. StackTrace? Это трассировка исключения? Не знаю правильно ли я понял, Вы имеете ввиду вот эту информацию? Да это. А теперь нажмите на это окно Ctrl+C и вставьте сообщение как текст на форум. Спасибо.
|
|
Thanks:
|
|
|
|
|
UsilaDobry
|
Date: 6/20/2013
|
|
|
|
Quote:---------------------------
--------------------------- System.InvalidCastException: Не удалось привести тип объекта "StockSharp.Algo.Candles.TimeFrameCandle[]" к типу "System.Collections.Generic.List`1[StockSharp.Algo.Candles.Candle]".
в StockSharp.AlfaDirect.AlfaTrader.#=qNmkP6QzBPHM7MSi3K7zNb8hpEPmvaemYv5w1q7pSlzs=(CandleSeries #=qw2Ij9lcQ52_YjUxYlygqJQ==, AlfaTimeFrames #=qmt9jajmekZJ3lvX4EWDlsw==, Range`1 #=qUa$g1WHcmZt7GKP9MHGYdQ==, Boolean #=qyMqxPE6iw9OG3w187t$YJg==, #=qrYpFuQVysBZ8IKEVqMgJNeOJnek4Tqt17H5Lhdsr7oOl5WXmF$V4OcRiLRkcvZGh& #=qdyEgQw5_gfsmxp61TgMHpQ==)
в StockSharp.AlfaDirect.AlfaTrader.SubscribeHistoricalCandles(CandleSeries series, DateTime from, DateTime to)
в StockSharp.Algo.Candles.CandleManager.#=qMxwX6RCGPPukCh3ls8RxBpA7IM61KWm0NtodaOEzPbw=.#=q6S9eoetqGa49tVuWloNQCnRypxcDn7PYNPl2C$RaYnkKcnu1wUHa2NHB6vFg6y0WaNoYZQe4eQyVPI8HWrXBIyz4LMDluX5GlBYwdeY220k=(CandleSeries #=q1SVIqTyklP0v2Vmdbxf5pQ==, DateTime #=qv2yp$YhyUweWh$XfcRdgUw==, DateTime #=qHyx5tP4ns5E8bwaA97HB6A==)
в #=qX3OhqnqEph0ylOwbVoprdaRyUdFykOOlTJqNaUikiywB2d5GxCHY1J7pgbbIcyah1whRfbIIDuqG1CROSXDxrw==.#=qXRmgGHeIzniBfKG_gUxziw==()
в StockSharp.Algo.Candles.CandleManager.Start(CandleSeries series, DateTime from, DateTime to)
в StockSharp.Algo.Candles.CandleHelper.Start(ICandleManager manager, CandleSeries series)
в MARKET_SUCCESS_ALFA.MainWindow.ShowChartClick(Object sender, RoutedEventArgs e) в c:\Users\UsilaDobry\Documents\Visual Studio 2012\Projects\MARKET SUCCESS ALFA\MainWindow.xaml.cs:строка 241 --------------------------- ОК ---------------------------
|
|
Thanks:
|
|
|
|
|
Mikhail Sukhov
|
Date: 6/20/2013
Ошибка найдена и поправлена. Я постучался в скайп. Давайте проведем тестирование, может там еще что-то есть. Демо у Альфы теперь не предоставляется, а ради небольшой ошибки ехать к ним в офис нет совсем времени.
|
|
|
|
|
UsilaDobry
|
Date: 6/20/2013
|
|
|
|
Благодарю, реальные свечи выводятся корректно. Красота. Вот только значения индикатора BollingerBands выводятся странно. Это мой код Code
private void ShowChartClick(object sender, RoutedEventArgs e)
{
try
{
var security = SelectedSecurity;
var timeFrame = (AlfaTimeFrames)((ComboBoxItem)HistoryInterval.SelectedItem).Tag;
if (From.Value != null)
{
var from = From.Value.Value;
if (To.Value != null)
{
var to = To.Value.Value;
if (@from > to)
{
return;
}
var candles = _trader.GetHistoryData(security, timeFrame, new Range<DateTime>(@from, to));
_chartWindow = new ChartWindow
{
Title = "{0}, {1}, {2} - {3}".Put(security.Code,
((ComboBoxItem)HistoryInterval.SelectedItem).Content,
@from.ToString(CultureInfo.InvariantCulture), to.ToString(CultureInfo.InvariantCulture))
};
var area = new ChartArea();
_chartWindow.Chart.ChartTheme = "ExpressionDark";
_chartWindow.Chart.IsAutoScroll = true;
_chartWindow.Chart.Areas.Add(area);
_candlesElem = new ChartCandleElement
{
Antialiasinig = false,
UpBodyColor = Colors.Chartreuse,
UpWickColor = Colors.Chartreuse,
DownBodyColor = Colors.Red,
DownWickColor = Colors.Red,
IsLegend = true,
};
_chartBollingerElement = new ChartIndicatorElement
{
Antialiasinig = false,
Color = Colors.DeepSkyBlue,
IsLegend = true,
Indicator = new BollingerBands
{
Length = 20,
Width = 2
},
Title = "Bollinger Bands",
DrawStyle = ChartIndicatorDrawStyles.Line,
};
_chartBollingerElement.DrawTemplate.VisualTree.SetValue(Shape.FillProperty, new SolidColorBrush(Colors.DeepSkyBlue));
area.Elements.Add(_candlesElem);
area.Elements.Add(_chartBollingerElement);
this.GuiAsync(() =>
{
foreach (var candle in candles)
_chartWindow.Chart.ProcessCandle(_candlesElem, candle);
});
_candleManager = new CandleManager(_trader);
_series = new CandleSeries(typeof(TimeFrameCandle), security, (TimeSpan)AlfaTimeFrames.Minute10);
_series.ProcessCandle += candle =>
{
if (candle.State == CandleStates.Finished || candle.State == CandleStates.Changed)
{
var final = candle.State == CandleStates.Finished;
var val = _chartBollingerElement.Indicator.Process(new DecimalIndicatorValue(candle.ClosePrice) { IsFinal = final });
var bollingerValue = new ChartIndicatorValue(_chartBollingerElement.Indicator, val);
this.GuiAsync(() => _chartWindow.Chart.ProcessValues(candle.OpenTime, new Dictionary<IChartElement, object>
{
{_candlesElem, candle},
{_chartBollingerElement, bollingerValue},
}));
}
};
_candleManager.Start(_series);
_chartWindow.Show();
}
}
}
catch (Exception exc)
{
MessageBox.Show(exc.ToString());
}
}
|
|
Thanks:
|
|
|
|
|
UsilaDobry
|
Date: 6/20/2013
|
|
Thanks:
|
|
|
|
|
UsilaDobry
|
Date: 6/21/2013
|
|
|
|
При выводе реальных свечек AlfaTrader засыпает logFile каждые 5 секунд сообщениями Code
2013/06/21 10:15:08.168| |AlfaTrader|StartExport()
2013/06/21 10:15:08.169| |AlfaTrader|Экспорт в процессе запуска.
2013/06/21 10:15:08.174| |AlfaTrader|Экспорт запущен.
2013/06/21 10:15:09.204| |AlfaTrader|RegisterTrades: RTSI-9.13@FORTS
2013/06/21 10:15:09.236| |AlfaTrader|create order: id = 117646314, tr. id = 853345110
2013/06/21 10:15:09.236| |AlfaTrader|Создание ордера из терминала, tr. id 853345110
2013/06/21 10:15:09.244| |AlfaTrader|update order: id = 117646314
2013/06/21 10:15:09.246| |AlfaTrader|Order changed: 853345110/117646314 Покупка Цена=121000 Объем=1 Сост=Done Бал=1
2013/06/21 10:15:09.249| |AlfaTrader|New order: 853345110/117646314 Покупка Цена=121000 Объем=1 Сост=Done Бал=1
2013/06/21 10:15:15.662| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 01.01.0001 0:00:00 - 21.06.2013 10:15:15
2013/06/21 10:15:17.308| |AlfaTrader|RegisterQuotes: RTSI-9.13@FORTS
2013/06/21 10:15:18.185| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 01.01.0001 0:01:00 - 21.06.2013 10:16:18
2013/06/21 10:16:32.576| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:16:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.629| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.677| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.725| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.772| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.819| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.874| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.928| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.976| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:33.024| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:33.130| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:33.183| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:33.230| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:33.278| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:33.325| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:38.326| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:38
2013/06/21 10:16:43.328| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:43
2013/06/21 10:16:48.336| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:48
2013/06/21 10:16:53.346| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:53
2013/06/21 10:16:58.352| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:58
2013/06/21 10:17:03.359| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:18:03
2013/06/21 10:17:08.366| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:18:08
2013/06/21 10:17:13.376| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:13
2013/06/21 10:17:18.382| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:18
2013/06/21 10:17:23.388| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:23
2013/06/21 10:17:28.401| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:28
2013/06/21 10:17:33.407| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:33
2013/06/21 10:17:38.416| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:38
2013/06/21 10:17:43.419| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:43
2013/06/21 10:17:48.428| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:48
2013/06/21 10:17:53.438| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:53
2013/06/21 10:17:58.442| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:58
2013/06/21 10:18:03.451| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:19:03
2013/06/21 10:18:08.462| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:19:08
2013/06/21 10:18:13.468| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:19:13
2013/06/21 10:18:18.473| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:19:18
2013/06/21 10:18:23.480| |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:19:23
Запустил простую стратегию для пробы, для контроля вывожу законченные свечи в debug, но законченные свечи не выводятся, свечи выводятся в debug каждые 5 секунд... И стратегия не понимает состояние свечки Finished, срабатывает на каждые 5 секунд... Возможно из-за этого и индикатор выводится не корректно?.. Код запуска стратегии Code
private void TradingBtn_Click(object sender, RoutedEventArgs e)
{
try
{
if (_strategyFirst == null)
{
var security = SelectedSecurity;
_candleManager = new CandleManager(_trader);
_series = new CandleSeries(typeof(TimeFrameCandle), security, (TimeSpan)AlfaTimeFrames.Minute1);
_candleManager.Start(_series);
_series.ProcessCandle += candle =>
{
if (candle.State != CandleStates.Finished)
return;
Debug.WriteLine("{0}", candle.ToString());
};
_strategyFirst = new StrategyFirst(_series)
{
Trader = _trader,
Security = SelectedSecurity,
Portfolio = SelectedPortfolio,
Volume = 1
};
_strategyFirst.WhenOrderRegistered()
.Do(order => this.GuiAsync(() => _chartWindow.Chart.ProcessValues(order.Time, new Dictionary<IChartElement, object> { { _chartOrderElement, order }, })))
.Apply();
_strategyFirst.WhenNewMyTrades()
.Do(trades => trades.ForEach(t => this.GuiAsync(() => _chartWindow.Chart.ProcessValues(t.Trade.Time, new Dictionary<IChartElement, object> { { _chartTradeElement, t }, }))))
.Apply();
_strategyFirst.ProcessStateChanged += s =>
{
TradingBtn.Content = s.ProcessState == ProcessStates.Started
? "Cтоп"
: "Старт";
};
_trader.RegisterMarketDepth(SelectedSecurity);
_logManager.Sources.Add(_strategyFirst);
_strategyFirst.Start();
}
else if (_strategyFirst.ProcessState == ProcessStates.Stopping ||
_strategyFirst.ProcessState == ProcessStates.Stopped)
{
// в ином случаем запускаем стратегию
_strategyFirst.Start();
}
else
{
//или останавливаем
if (_strategyFirst.Position != 0)
_strategyFirst.ClosePosition();
_strategyFirst.Stop();
}
}
catch (Exception exc)
{
MessageBox.Show(exc.ToString());
}
}
Код стратегии Code
using System;
using System.Windows;
using StockSharp.Algo.Candles;
using StockSharp.Algo.Strategies;
using StockSharp.Logging;
namespace MARKET_SUCCESS_ALFA
{
class StrategyFirst : Strategy
{
private readonly CandleSeries _candleSeries;
public StrategyFirst(CandleSeries series)
{
_candleSeries = series;
}
protected override void OnStarted()
{
try
{
_candleSeries.ProcessCandle += candle =>
{
if (candle.State != CandleStates.Finished) return;
//Получаем последнюю свечу
Candle candleLastFinish = _candleSeries.GetCandle<TimeFrameCandle>(0);
//Получаем предпослежнюю свечу
Candle candlePenultFinish = _candleSeries.GetCandle<TimeFrameCandle>(1);
//Сигнал на покупку
bool signalBuy = candleLastFinish.OpenPrice <
candleLastFinish.ClosePrice;
signalBuy = signalBuy &&
candlePenultFinish.OpenPrice <
candlePenultFinish.ClosePrice;
signalBuy = signalBuy && Position == 0;
//Сигнал на закрытие длинной позиции
bool signalStopBuy = Position > 0;
signalStopBuy = signalStopBuy &&
candleLastFinish.OpenPrice >
candleLastFinish.ClosePrice;
//Сигнал на продажу
bool signalSell = candleLastFinish.OpenPrice >
candleLastFinish.ClosePrice;
signalSell = signalSell &&
candlePenultFinish.OpenPrice >
candlePenultFinish.ClosePrice;
signalSell = signalSell && Position == 0;
//Сигнал на закрытие короткой позиции
bool signalStopSell = Position < 0;
signalStopSell = signalStopSell &&
candleLastFinish.OpenPrice <
candleLastFinish.ClosePrice;
//Реагируем на сигнал покупки
if (signalBuy)
{
//RegisterOrder(this.BuyAtLimit(Security.MaxPrice));
this.AddInfoLog("ОТКРЫВАЕМ ДЛИННУЮ позицию {0}.", candleLastFinish.CloseTime);
}
//Реагируем на сигнал закрытия позиции
if (signalStopBuy)
{
//RegisterOrder(this.SellAtLimit(Security.MinPrice));
this.AddInfoLog("ЗАКРЫВАЕМ ДЛИННУЮ позицию {0}.", candleLastFinish.CloseTime);
}
//Реагируем на сигнал продажи
if (signalSell)
{
//RegisterOrder(this.SellAtLimit(Security.MinPrice));
this.AddInfoLog("ОТКРЫВАЕМ КОРОТКУЮ позицию {0}.", candleLastFinish.CloseTime);
}
//Реагируем на сигнал закрытия позиции
if (signalStopSell)
{
//RegisterOrder(this.BuyAtLimit(Security.MaxPrice));
this.AddInfoLog("ЗАКРЫВАЕМ КОРОТКУЮ позицию {0}.", candleLastFinish.CloseTime);
}
};
}
catch (Exception exc)
{
MessageBox.Show(exc.ToString());
}
}
protected override void OnStopped()
{
}
}
}
Вывод в debug
|
|
Thanks:
|
|
|
|
|
Mikhail Sukhov
|
Date: 6/21/2013
UsilaDobry Изменил немного код вывода значений индикатора, картинка без изменений...
IIndicator.IsFormed проверяется?
|
|
Thanks:
|
|
|
|
|
UsilaDobry
|
Date: 6/21/2013
Михаил Сухов UsilaDobry Изменил немного код вывода значений индикатора, картинка без изменений...
IIndicator.IsFormed проверяется? Разве свойство значения индикатора IsFinal = true не решает эту проверку? Значение окончательное, более неизменное в данный момент времени... У меня такое чувство, что значения индикатора считаются каждые 5 секунд по мере поступления исторических тиков, это как-то пересекается с моим предыдущим постом... Code
_series.ProcessCandle += candle =>
{
if (candle.State == CandleStates.Finished)
{
var valueBb = _chartBollingerElement.Indicator.Process(new CandleIndicatorValue(candle) { IsFinal = true });
this.GuiAsync(() => _chartWindow.Chart.ProcessValues(candle.OpenTime, new Dictionary<IChartElement, object>
{
{_candlesElem, candle},
{_chartBollingerElement, new ChartIndicatorValue(_chartBollingerElement.Indicator, valueBb)},
}));
}
else
{
this.GuiAsync(() => _chartWindow.Chart.ProcessCandle(_candlesElem, candle));
}
};
|
|
Thanks:
|
|
|
|