0

我遇到了我的 python 程序的一些奇怪行为。基本上,当我尝试创建并填充长度大于 1000 的 SumTree 时,我的磁盘使用量增加了很多,达到 ~300MB/s,然后程序就死了。

我很确定这个过程中没有文件 r/w,问题出在add函数上。代码如下所示。

import numpy as np

class SumTree():

    trans_idx = 0

    def __init__(self, capacity):
        self.num_samples = 0
        self.capacity = capacity
        self.tree = np.zeros(2 * capacity - 1)
        self.transitions = np.empty(self.capacity, dtype=object)

    def add(self, p, experience):
        tree_idx = self.trans_idx + self.capacity - 1
        self.transitions[self.trans_idx] = experience
        self.transitions.append(experience)
        self.update(tree_idx, p)

        self.trans_idx += 1
        if self.trans_idx >= self.capacity:
            self.trans_idx = 0

        self.num_samples = min(self.num_samples + 1, self.capacity)

    def update(self, tree_idx, p):
        diff = p - self.tree[tree_idx]
        self.tree[tree_idx] = p
        while tree_idx != 0:
            tree_idx = (tree_idx - 1) // 2
            self.tree[tree_idx] += diff

    def get_leaf(self, value):
        parent_idx = 0
        while True:  
            childleft_idx = 2 * parent_idx + 1  
            childright_idx = childleft_idx + 1
            if childleft_idx >= len(self.tree):  
                leaf_idx = parent_idx
                break
            else:  
                if value <= self.tree[childleft_idx]:
                    parent_idx = childleft_idx
                else:
                    value -= self.tree[childleft_idx]
                    parent_idx = childright_idx

        data_idx = leaf_idx - self.capacity + 1
        return leaf_idx, self.tree[leaf_idx], self.transitions[data_idx]

    @property
    def total_p(self):
        return self.tree[0]  # the root

    @property
    def volume(self):
        return self.num_samples  # number of transistions stored

这是一个将使用此 SumTree 对象的示例:

def add(self, experience)
    max_p = np.max(self.tree.tree[-self.tree.capacity:])
    if max_p == 0:
        max_p = 1.0
    exp = self.Experience(*experience)
    self.tree.add(max_p, exp)  

whereExperience是一个命名元组并且self.tree是一个 Sumtree 实例,当我删除最后一行时,高磁盘使用率消失了。

谁能帮我这个?

4

1 回答 1

0

我终于解决了这个问题,因为每个experience都是 namedtuple 的元组,我正在Experience从中创建另一个 namedtuple。通过更改experience为 numpy 数组的元组来修复。

于 2018-07-12T02:30:29.300 回答