forked from ihendley/treys
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathperf.py
60 lines (46 loc) · 1.34 KB
/
perf.py
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
import time
import random
from treys import Card, Deck, Evaluator
def setup(n, m):
deck = Deck()
boards = []
hands = []
for i in range(n):
boards.append(deck.draw(m))
hands.append(deck.draw(2))
deck.shuffle()
return boards, hands
n = 10000
cumtime = 0.0
evaluator = Evaluator()
boards, hands = setup(n, 5)
for i in range(len(boards)):
start = time.time()
evaluator.evaluate(boards[i], hands[i])
cumtime += (time.time() - start)
avg = float(cumtime / n)
print("7 card evaluation:")
print("[*] Treys: Average time per evaluation: %f" % avg)
print("[*] Treys: Evaluations per second = %f" % (1.0 / avg))
###
cumtime = 0.0
boards, hands = setup(n, 4)
for i in range(len(boards)):
start = time.time()
evaluator.evaluate(boards[i], hands[i])
cumtime += (time.time() - start)
avg = float(cumtime / n)
print("6 card evaluation:")
print("[*] Treys: Average time per evaluation: %f" % avg)
print("[*] Treys: Evaluations per second = %f" % (1.0 / avg))
###
cumtime = 0.0
boards, hands = setup(n, 3)
for i in range(len(boards)):
start = time.time()
evaluator.evaluate(boards[i], hands[i])
cumtime += (time.time() - start)
avg = float(cumtime / n)
print("5 card evaluation:")
print("[*] Treys: Average time per evaluation: %f" % avg)
print("[*] Treys: Evaluations per second = %f" % (1.0 / avg))