forked from EA31337/EA31337-classes
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBacktest.mqh
90 lines (82 loc) · 3.34 KB
/
Backtest.mqh
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
//+------------------------------------------------------------------+
//| EA31337 - multi-strategy advanced trading robot. |
//| Copyright 2016, 31337 Investments Ltd. |
//| https://github.com/EA31337 |
//+------------------------------------------------------------------+
/*
This file is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
/*
* Class to provide functions to deal with backtesting.
*/
class Backtest {
public:
/*
* Check whether spread is valid.
*/
static bool ValidSpread(bool verbose = True) {
#ifdef __MQL4__
long symbol_spread = SymbolInfoInteger(_Symbol, SYMBOL_SPREAD);
int real_spread = (int)MathRound((Ask - Bid) * MathPow(10, Digits));
double lot_step = MarketInfo(_Symbol, MODE_LOTSTEP);
#else
// @todo
#endif
if (real_spread == 0 || symbol_spread != real_spread) {
if (verbose) {
PrintFormat("Reported spread: %d pts", symbol_spread);
PrintFormat("Real spread : %d pts", real_spread);
PrintFormat("Ask/Bid : %g/%g", NormalizeDouble(Ask, Digits), NormalizeDouble(Bid, Digits));
PrintFormat("Symbol digits : %g", Digits);
PrintFormat("Lot step : %g", lot_step);
PrintFormat("Error: Spread is not valid, it's %d!", real_spread);
}
return (FALSE);
}
return (TRUE);
}
/*
* Check whether lot step is valid.
*/
static bool ValidLotstep(bool verbose = True) {
#ifdef __MQL4__
long symbol_spread = SymbolInfoInteger(_Symbol, SYMBOL_SPREAD);
int real_spread = (int)MathRound((Ask - Bid) * MathPow(10, Digits));
double lot_step = MarketInfo(_Symbol, MODE_LOTSTEP);
#else
// @todo
#endif
switch (Digits) {
case 4:
if (lot_step != 0.1) {
if (verbose) {
PrintFormat("Symbol digits : %g", Digits);
PrintFormat("Lot step : %g", lot_step);
PrintFormat("Error: Expected lot step for %d digits: 0.1, found: %g", Digits, lot_step);
}
return (FALSE);
}
break;
case 5:
if (lot_step != 0.01) {
if (verbose) {
PrintFormat("Symbol digits : %g", Digits);
PrintFormat("Lot step : %g", lot_step);
PrintFormat("Error: Expected lot step for %d digits: 0.01, found: %g", Digits, lot_step);
}
return (FALSE);
}
break;
}
return (TRUE);
}
};