forked from StockSharp/AlgoTools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSpeedTestStrategy.cs
114 lines (94 loc) · 2.27 KB
/
SpeedTestStrategy.cs
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
110
111
112
113
114
namespace SpeedTest
{
using System;
using System.Diagnostics;
using System.Linq;
using StockSharp.Algo;
using StockSharp.Algo.Strategies;
using StockSharp.BusinessEntities;
using StockSharp.Messages;
public class SpeedTestStrategy : Strategy
{
private readonly int _nummberofTests;
public string TraderName { get; set; }
public TimeSpan? MaxLatency
{
get { return Orders.Count() != 0 ? Orders.Max(o => o.LatencyRegistration) : null; }
}
public TimeSpan? MinLatency
{
get { return Orders.Count() != 0 ? Orders.Min(o => o.LatencyRegistration) : null; }
}
public SpeedTestStrategy(int nummberofTests)
{
_nummberofTests = nummberofTests;
}
private readonly object _locker = new object();
private TimeSpan _holeTime;
public TimeSpan AverageTime
{
get
{
return NumberOfOrders != 0
? TimeSpan.FromMilliseconds((int) Math.Round(_holeTime.TotalMilliseconds/NumberOfOrders))
: TimeSpan.FromMilliseconds(0);
}
}
public int NumberOfOrders { get; set; }
private void DeleteOrder(Order order)
{
if (order != null)
{
try
{
Connector.CancelOrder(order);
}
catch (Exception g)
{
Debug.Print("{0}", g);
}
}
}
public event Action OrderTimeChanged;
protected override void OnStarted()
{
base.OnStarted();
_holeTime = TimeSpan.FromMilliseconds(0);
NumberOfOrders = 0;
OrderRegistered += SpeedTestStrategyOrderRegistered;
RegisterOrder(SendNewOrder());
}
private void SpeedTestStrategyOrderRegistered(Order order)
{
lock (_locker)
{
if (order.LatencyRegistration != null)
_holeTime += order.LatencyRegistration.Value;
NumberOfOrders++;
if (OrderTimeChanged != null)
OrderTimeChanged();
DeleteOrder(order);
if (NumberOfOrders < _nummberofTests)
{
RegisterOrder(SendNewOrder());
}
else
{
Stop();
}
}
}
private Order SendNewOrder()
{
var price = this.GetSecurityValue<decimal>(Level1Fields.BestBidPrice) * (1 - 0.01M);
var testorder = this.CreateOrder(Sides.Buy, Security.ShrinkPrice(price));
return testorder;
}
protected override void OnStopping()
{
OrderRegistered -= SpeedTestStrategyOrderRegistered;
CancelActiveOrders();
base.OnStopping();
}
}
}