-
Notifications
You must be signed in to change notification settings - Fork 42
/
crypto.c
109 lines (100 loc) · 3.66 KB
/
crypto.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
namespace QuantConnect
{
public class MultiCoinFramework : QCAlgorithm
{
string tickersString ="BTCUSD,ETHUSD,LTCUSD";
decimal changes1Ratio=-1.0m; //The influence of change upon fitness.
decimal changes2Ratio=0.0m; //The influence of change in change upon fitness.
int emaOfChanges1Length=24; //The length of the change indicator.
int emaOfChanges2Length=24; //The length of the change in change indicator.
decimal leverage=1m;
int historyLength=2;
int changes1Length=2;
int changes2Length=2;
Resolution resolution=Resolution.Hour;
List<StockData> stockDatas = new List<StockData>();
string stockHeld="";
public override void Initialize()
{
SetStartDate(2017, 3, 1);
SetEndDate(2018, 3, 1);
SetCash(1000);
string[] tickers = tickersString.Split(new string[1] { "," }, StringSplitOptions.RemoveEmptyEntries);
foreach (string ticker in tickers)
{
Symbol symbol = QuantConnect.Symbol.Create(ticker, SecurityType.Crypto, Market.GDAX);
AddCrypto(symbol, resolution);
StockData stockData=new StockData();
stockData.Ticker=ticker;
stockData.emaOfChanges1Indicator = new ExponentialMovingAverage(emaOfChanges1Length);
stockData.emaOfChanges2Indicator = new ExponentialMovingAverage(emaOfChanges2Length);
stockDatas.Add(stockData);
}
}
public override void OnData(Slice data)
{
foreach (StockData stockData in stockDatas)
{
stockData.history.Add(data[stockData.Ticker].Close);
if (stockData.history.Count>historyLength)
{
stockData.history.RemoveAt(0);
}
if (stockData.history.Count>=2)
{
if (stockData.history[stockData.history.Count-2]!=0)
{
decimal change=(stockData.history.Last()-stockData.history[stockData.history.Count-2])/stockData.history[stockData.history.Count-2];
stockData.changes1History.Add(change);
if (stockData.changes1History.Count>changes1Length)
{
stockData.changes1History.RemoveAt(0);
}
}
}
if (stockData.changes1History.Count>=2)
{
decimal change=stockData.changes1History.Last()-stockData.changes1History[stockData.changes1History.Count-2];
stockData.changes2History.Add(change);
if (stockData.changes2History.Count>changes2Length)
{
stockData.changes2History.RemoveAt(0);
}
}
if (stockData.changes1History.Count>0)
{
stockData.emaOfChanges1Indicator.Update(Time,stockData.changes1History.Last());
}
if (stockData.changes2History.Count>0)
{
stockData.emaOfChanges2Indicator.Update(Time,stockData.changes2History.Last());
}
stockData.Fitness=changes1Ratio*stockData.emaOfChanges1Indicator+changes2Ratio*stockData.emaOfChanges2Indicator;
}
var q1 = from x in stockDatas
orderby x.Fitness descending
select x;
List<StockData> q2=q1.ToList();
if (q2.Count>0)
{
StockData selectedStockData=q2.First();
if (selectedStockData.Ticker != stockHeld)
{
Liquidate();
SetHoldings(selectedStockData.Ticker, leverage);
stockHeld=selectedStockData.Ticker;
}
}
}
class StockData
{
public string Ticker;
public List<decimal> history=new List<decimal>();
public List<decimal> changes1History=new List<decimal>();
public List<decimal> changes2History=new List<decimal>();
public ExponentialMovingAverage emaOfChanges1Indicator;
public ExponentialMovingAverage emaOfChanges2Indicator;
public decimal Fitness;
}
}
}