forked from IDSIA/hhmarl_2D
-
Notifications
You must be signed in to change notification settings - Fork 0
/
policy_export.py
34 lines (27 loc) · 1.07 KB
/
policy_export.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
"""
This file exports policy models to use during inference / self-play.
"""
import os
from ray.rllib.policy.policy import Policy
from ray.rllib.models import ModelCatalog
from models.ac_models_hetero import Esc1, Esc2, Fight1, Fight2
#define experiment folder name
LEVEL = 3
MODE = 'escape'
EXP_DIR = f'L{LEVEL}_{MODE}_2-vs-2'
#define policy folder name
POL_DIR = 'policies'
if MODE == "escape":
ModelCatalog.register_custom_model(f"ac1_model_esc",Esc1)
ModelCatalog.register_custom_model(f"ac2_model_esc",Esc2)
else:
ModelCatalog.register_custom_model(f"ac1_model",Fight1)
ModelCatalog.register_custom_model(f"ac2_model",Fight2)
for i in range(1,3):
check = os.path.join(os.path.dirname(__file__), 'results', EXP_DIR, 'checkpoint', 'policies', f'ac{i}_policy')
pol = Policy.from_checkpoint(check)
save_dir = os.path.join(os.path.dirname(__file__), POL_DIR)
pol.export_model(save_dir)
policy_name = f'L{LEVEL}_AC{i}_{MODE}'
os.rename(f'{POL_DIR}/model.pt', f'{POL_DIR}/{policy_name}.pt')
print(f"{MODE} policies exported to folder {POL_DIR}")