Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zxch3n/priority_memory
Prioritized sampling method for prioritized experience replay
https://github.com/zxch3n/priority_memory
Last synced: 2 months ago
JSON representation
Prioritized sampling method for prioritized experience replay
- Host: GitHub
- URL: https://github.com/zxch3n/priority_memory
- Owner: zxch3n
- License: apache-2.0
- Created: 2018-11-23T08:59:46.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2019-10-17T07:17:03.000Z (about 5 years ago)
- Last Synced: 2024-10-04T16:22:16.392Z (3 months ago)
- Language: Python
- Size: 12.7 KB
- Stars: 7
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Priority Memory
A prioritized sampling tool for priority memory replay.
The implementation is based on sum tree, i.e. segmentation tree.
- Set the priority of each sample at anytime.
- When you do not know the priorities of the samples, you can append
them to the buffer, and they will show up in the next sampling batch.
- When the buffer is full, it'll drop the samples with lowest priority.The time complexity for sampling a batch with batch size m
from a dataset with n samples is O(mlogn), for setting priority
for the batch is O(mlogn).# Usage
> pip install priority_memory
```python
from priority_memory import FastPriorReplayBuffer
buffer = FastPriorReplayBuffer(8000)
buffer.append(features=[0.1, 0.1, 0.1], prior=1)
buffer.append(features=[0.2, 0.2, 0.2], prior=2)
buffer.append(features=[0.3, 0.3, 0.3], prior=3)
buffer.append(features=[0.4, 0.4, 0.4], prior=4)
indexes, data, weights = buffer.sample_with_weights(batch_size=2)mae = [10, 20]
buffer.set_weights(indexes, mae)```