-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathreward_functions.py
More file actions
49 lines (32 loc) · 1.14 KB
/
reward_functions.py
File metadata and controls
49 lines (32 loc) · 1.14 KB
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
from enum import Enum
import numpy as np
class RewardFunctions(Enum):
KeepUpright = "keep_upright"
TestReward = "test_reward"
class RewardFunction:
def __init__(self, func: RewardFunctions):
self.function = None
self.function_enum = func
self._set_function()
def _set_function(self):
self.function = globals()[self.function_enum.value]
def set_function(self, func: RewardFunctions):
self.function_enum = func
self._set_function()
def get_reward(self, env):
return self.function(env)
# Define reward functions down here.
def keep_upright(env):
euler_angles = np.rad2deg(env.sim.state.euler_angles)
initial_angle = np.array([0, 90.0, 0])
sum_abs_euler_angles = -np.linalg.norm(euler_angles - initial_angle)
if sum_abs_euler_angles >= -0.5:
return 1
else:
return sum_abs_euler_angles
# Testing
def test_reward(env: None):
return 7
if __name__ == "__main__":
reward_func = RewardFunction(RewardFunctions.TestReward)
print("Probably working fine" if reward_func.get_reward(None) == test_reward(None) else "Something went wrong")