mirror of
https://github.com/ArthurDanjou/handson-ml3.git
synced 2026-02-02 13:07:51 +01:00
use list with circular indexing instead of deque as the replay buffer
This commit is contained in:
@@ -1576,6 +1576,23 @@
|
|||||||
"replay_memory_size = 500000\n",
|
"replay_memory_size = 500000\n",
|
||||||
"replay_memory = deque([], maxlen=replay_memory_size)\n",
|
"replay_memory = deque([], maxlen=replay_memory_size)\n",
|
||||||
"\n",
|
"\n",
|
||||||
|
"\n",
|
||||||
|
"class ReplayMemory:\n",
|
||||||
|
" \n",
|
||||||
|
" def __init__(self, size):\n",
|
||||||
|
" self.size = size\n",
|
||||||
|
" self.buf= [None] * self.size\n",
|
||||||
|
" self.index = 0\n",
|
||||||
|
" \n",
|
||||||
|
" def append(self, data):\n",
|
||||||
|
" self.buf[self.index] = data\n",
|
||||||
|
" self.index = (self.index + 1) % self.size\n",
|
||||||
|
" \n",
|
||||||
|
" def __getitem__(self, idx):\n",
|
||||||
|
" return self.buf[idx]\n",
|
||||||
|
"\n",
|
||||||
|
" \n",
|
||||||
|
"\n",
|
||||||
"def sample_memories(batch_size):\n",
|
"def sample_memories(batch_size):\n",
|
||||||
" indices = np.random.permutation(len(replay_memory))[:batch_size]\n",
|
" indices = np.random.permutation(len(replay_memory))[:batch_size]\n",
|
||||||
" cols = [[], [], [], [], []] # state, action, reward, next_state, continue\n",
|
" cols = [[], [], [], [], []] # state, action, reward, next_state, continue\n",
|
||||||
|
|||||||
Reference in New Issue
Block a user