forked from logicchains/ArrayAccessBench
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ST.st
83 lines (76 loc) · 1.6 KB
/
ST.st
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
Object subclass: #MemTester.
MemTester instanceVariableNames: 'numRecords trades'.
MemTester class extend [
new [
| n |
n := super new.
n init.
^n
]
]
MemTester extend [
init [
numRecords := 50 * 1000 * 444.
trades := (Array new: numRecords).
1 to: numRecords do: [ :i | trades at: i put: (STMemoryTrade new). ].
]
initTrades [
1 to: numRecords do: [ :i | (trades at: i) fromI: i. ].
]
perfRun: i [
|start buyCost sellCost |
Transcript show: i asString; cr.
start := Time primMillisecondClock.
self initTrades.
buyCost := 0.
sellCost := 0.
trades do: [:each | ((each side) == $B)
ifTrue: [buyCost := (buyCost + ((each price) * (each quantity)))]
ifFalse: [sellCost := (sellCost + ((each price) * (each quantity)))]
].
Transcript show: 'Run ', (i asString), ' had duration ', ((Time primMillisecondClock) - start) asString, 'ms'; cr.
]
run [
0 to: 5 do: [:i | self perfRun: i.].
]
]
Object subclass: #STMemoryTrade.
STMemoryTrade instanceVariableNames: 'tradeId clientId venueCode instrumentCode price quantity side'.
STMemoryTrade class extend [
new [
| n |
n := super new.
n init.
^n
]
]
STMemoryTrade extend [
init [
tradeId := 0.
clientId := 0.
venueCode := 0.
instrumentCode := 0.
price := 0.
quantity := 0.
side := $a
]
fromI: i [
tradeId := i.
clientId := 1.
venueCode := 123.
instrumentCode := 321.
price := i.
quantity := i.
side := (i even) ifTrue: $B; ifFalse: $S.
]
side [
^side
]
quantity [
^quantity
]
price [
^price
]
]
MemTester new run.