-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathDrawThroughPass.py
85 lines (76 loc) · 2.56 KB
/
DrawThroughPass.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
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
from BaseCode.Cycle import GameMode
from BaseCode.Game import Game
import matplotlib.pyplot as plt
from multiprocessing import Pool
from PyrusGeom.line_2d import Line2D
from PyrusGeom.vector_2d import Vector2D
from PyrusGeom.angle_deg import AngleDeg
import os
def read_log(add):
path, file_name, team = add[0], add[1], add[2]
g = Game.read_log(os.path.join(path, file_name))
passes = []
for c in g.cycles():
if c.game_mode() != GameMode.play_on:
continue
if not (c.next_kicker_team == 'r' and c.kicker_team == 'r'):
continue
if len(c.next_kicker_player) > 1:
continue
if c.next_kicker_player[0] == c.kicker_players[0]:
continue
players_x = []
for p in c.players().keys():
if p >= 0:
continue
players_x.append(c.players()[p].pos_().x())
players_x.sort()
min_def_line = players_x[1]
if c.ball().pos_().x() < min_def_line:
continue
if c.next_kick_ball_pos.x() > min_def_line:
continue
passes.append((c.ball().pos_(), c.next_kick_ball_pos, c.left_offside_line))
return passes
def main(path, team):
"""
Showing player move point by plot
:param path: path of rcg files
:param team: left team possession or right team [-1, 0, 1]
"""
pool = Pool(25)
files = []
for f in os.listdir(path)[:10]:
files.append([path, f, team])
passes_list = pool.map(read_log, files)
all_passes = []
for passes in passes_list:
all_passes += passes
passes_x1 = []
passes_x2 = []
passes_y1 = []
passes_y2 = []
def_lines = []
for p in all_passes:
passes_x1.append(p[0].x())
passes_x2.append(p[1].x())
passes_y1.append(p[0].y())
passes_y2.append(p[1].y())
pass_line = Line2D(p[0], p[1])
print(p)
def_line = Line2D(Vector2D(p[2], 0), AngleDeg(90))
intersect = pass_line.intersection(def_line)
if intersect.is_valid():
def_lines.append(intersect)
plt.xlim(-55, +55)
plt.ylim(-34, +34)
for p in range(len(all_passes)):
color = 'g' if passes_x1[p] < passes_x2[p] else 'r'
plt.plot([passes_x1[p], passes_x2[p]], [passes_y1[p], passes_y2[p]], linewidth=0.4, color=color)
plt.scatter([x.x() for x in def_lines], [x.y() for x in def_lines], s=1, c='blue')
plt.title(path + " " + "Passes")
plt.show()
if __name__ == "__main__":
path = '/home/nader/workspace/robo/icjai/unmark/'
team = 'l' # 'r' 'n'
main(path, team)