forked from comp424mcgill/Project-COMP424-2022-Winter
-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathstudent_agent.py
40 lines (34 loc) · 1.25 KB
/
student_agent.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
# Student agent: Add your own agent here
from agents.agent import Agent
from store import register_agent
import sys
@register_agent("student_agent")
class StudentAgent(Agent):
"""
A dummy class for your implementation. Feel free to use this class to
add any helper functionalities needed for your agent.
"""
def __init__(self):
super(StudentAgent, self).__init__()
self.name = "StudentAgent"
self.dir_map = {
"u": 0,
"r": 1,
"d": 2,
"l": 3,
}
def step(self, chess_board, my_pos, adv_pos, max_step):
"""
Implement the step function of your agent here.
You can use the following variables to access the chess board:
- chess_board: a numpy array of shape (x_max, y_max, 4)
- my_pos: a tuple of (x, y)
- adv_pos: a tuple of (x, y)
- max_step: an integer
You should return a tuple of ((x, y), dir),
where (x, y) is the next position of your agent and dir is the direction of the wall
you want to put on.
Please check the sample implementation in agents/random_agent.py or agents/human_agent.py for more details.
"""
# dummy return
return my_pos, self.dir_map["u"]