Skip to content

Commit

Permalink
update common
Browse files Browse the repository at this point in the history
  • Loading branch information
johnjim0816 committed Mar 15, 2021
1 parent 66fd8ef commit 5b5d78c
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 4 deletions.
34 changes: 34 additions & 0 deletions codes/common/memory.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
#!/usr/bin/env python
# coding=utf-8
'''
@Author: John
@Email: johnjim0816@gmail.com
@Date: 2020-06-10 15:27:16
@LastEditor: John
LastEditTime: 2021-03-13 11:37:15
@Discription:
@Environment: python 3.7.7
'''
import random

class ReplayBuffer:

def __init__(self, capacity):
self.capacity = capacity
self.buffer = []
self.position = 0

def push(self, state, action, reward, next_state, done):
if len(self.buffer) < self.capacity:
self.buffer.append(None)
self.buffer[self.position] = (state, action, reward, next_state, done)
self.position = (self.position + 1) % self.capacity

def sample(self, batch_size):
batch = random.sample(self.buffer, batch_size)
state, action, reward, next_state, done = zip(*batch)
return state, action, reward, next_state, done

def __len__(self):
return len(self.buffer)

26 changes: 22 additions & 4 deletions codes/common/model.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,19 @@
Email: johnjim0816@gmail.com
Date: 2021-03-12 21:14:12
LastEditor: John
LastEditTime: 2021-03-13 11:51:38
LastEditTime: 2021-03-13 13:48:35
Discription:
Environment:
'''
import torch.nn as nn
import torch.nn.functional as F
class MLP(nn.Module):
class MLP1(nn.Module):
''' 多层感知机
输入:state维度
输出:概率
'''
def __init__(self,n_states,hidden_dim = 36):
super(MLP, self).__init__()
super(MLP1, self).__init__()
# 24和36为hidden layer的层数,可根据state_dim, n_actions的情况来改变
self.fc1 = nn.Linear(n_states, hidden_dim)
self.fc2 = nn.Linear(hidden_dim,hidden_dim)
Expand All @@ -27,4 +27,22 @@ def forward(self, x):
x = F.relu(self.fc1(x))
x = F.relu(self.fc2(x))
x = F.sigmoid(self.fc3(x))
return x
return x


class MLP2(nn.Module):
def __init__(self, n_states,n_actions,hidden_dim=128):
""" 初始化q网络,为全连接网络
n_states: 输入的feature即环境的state数目
n_actions: 输出的action总个数
"""
super(MLP2, self).__init__()
self.fc1 = nn.Linear(n_states, hidden_dim) # 输入层
self.fc2 = nn.Linear(hidden_dim,hidden_dim) # 隐藏层
self.fc3 = nn.Linear(hidden_dim, n_actions) # 输出层

def forward(self, x):
# 各层对应的激活函数
x = F.relu(self.fc1(x))
x = F.relu(self.fc2(x))
return self.fc3(x)

0 comments on commit 5b5d78c

Please sign in to comment.