-
Notifications
You must be signed in to change notification settings - Fork 149
/
Copy pathmain.py
120 lines (108 loc) · 5.21 KB
/
main.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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
import argparse, os
import gym
import numpy as np
import agents as Agents
from utils import plot_learning_curve, make_env
if __name__ == '__main__':
parser = argparse.ArgumentParser(
description='Deep Q Learning: From Paper to Code')
# the hyphen makes the argument optional
parser.add_argument('-n_games', type=int, default=1,
help='Number of games to play')
parser.add_argument('-lr', type=float, default=0.0001,
help='Learning rate for optimizer')
parser.add_argument('-eps_min', type=float, default=0.1,
help='Minimum value for epsilon in epsilon-greedy action selection')
parser.add_argument('-gamma', type=float, default=0.99,
help='Discount factor for update equation.')
parser.add_argument('-eps_dec', type=float, default=1e-5,
help='Linear factor for decreasing epsilon')
parser.add_argument('-eps', type=float, default=1.0,
help='Starting value for epsilon in epsilon-greedy action selection')
parser.add_argument('-max_mem', type=int, default=50000, #~13Gb
help='Maximum size for memory replay buffer')
parser.add_argument('-repeat', type=int, default=4,
help='Number of frames to repeat & stack')
parser.add_argument('-bs', type=int, default=32,
help='Batch size for replay memory sampling')
parser.add_argument('-replace', type=int, default=1000,
help='interval for replacing target network')
parser.add_argument('-env', type=str, default='PongNoFrameskip-v4',
help='Atari environment.\nPongNoFrameskip-v4\n \
BreakoutNoFrameskip-v4\n \
SpaceInvadersNoFrameskip-v4\n \
EnduroNoFrameskip-v4\n \
AtlantisNoFrameskip-v4')
parser.add_argument('-gpu', type=str, default='0', help='GPU: 0 or 1')
parser.add_argument('-load_checkpoint', type=bool, default=False,
help='load model checkpoint')
parser.add_argument('-path', type=str, default='models/',
help='path for model saving/loading')
parser.add_argument('-algo', type=str, default='DQNAgent',
help='DQNAgent/DDQNAgent/DuelingDQNAgent/DuelingDDQNAgent')
parser.add_argument('-clip_rewards', type=bool, default=False,
help='Clip rewards to range -1 to 1')
parser.add_argument('-no_ops', type=int, default=0,
help='Max number of no ops for testing')
parser.add_argument('-fire_first', type=bool, default=False,
help='Set first action of episode to fire')
args = parser.parse_args()
os.environ['CUDA_DEVICE_ORDER'] = 'PCI_BUS_ID'
os.environ['CUDA_VISIBLE_DEVICES'] = args.gpu
env = make_env(env_name=args.env, repeat=args.repeat,
clip_rewards=args.clip_rewards, no_ops=args.no_ops,
fire_first=args.fire_first)
best_score = -np.inf
agent_ = getattr(Agents, args.algo)
agent = agent_(gamma=args.gamma,
epsilon=args.eps,
lr=args.lr,
input_dims=env.observation_space.shape,
n_actions=env.action_space.n,
mem_size=args.max_mem,
eps_min=args.eps_min,
batch_size=args.bs,
replace=args.replace,
eps_dec=args.eps_dec,
chkpt_dir=args.path,
algo=args.algo,
env_name=args.env)
if args.load_checkpoint:
agent.load_models()
fname = args.algo + '_' + args.env + '_alpha' + str(args.lr) +'_' \
+ str(args.n_games) + 'games'
figure_file = 'plots/' + fname + '.png'
scores_file = fname + '_scores.npy'
scores, eps_history = [], []
n_steps = 0
steps_array = []
for i in range(args.n_games):
done = False
observation = env.reset()
score = 0
while not done:
action = agent.choose_action(observation)
observation_, reward, done, info = env.step(action)
score += reward
if not args.load_checkpoint:
agent.store_transition(observation, action,
reward, observation_, int(done))
agent.learn()
observation = observation_
n_steps += 1
scores.append(score)
steps_array.append(n_steps)
avg_score = np.mean(scores[-100:])
print('episode: ', i,'score: ', score,
' average score %.1f' % avg_score, 'best score %.2f' % best_score,
'epsilon %.2f' % agent.epsilon, 'steps', n_steps)
if avg_score > best_score:
if not args.load_checkpoint:
agent.save_models()
best_score = avg_score
eps_history.append(agent.epsilon)
if args.load_checkpoint and n_steps >= 18000:
break
x = [i+1 for i in range(len(scores))]
plot_learning_curve(steps_array, scores, eps_history, figure_file)
#np.save(scores_file, np.array(scores))