Ошибка в модуле Ipython memory_profiler,% mprun - PullRequest
1 голос
/ 12 мая 2019

Как видите, результат приведенного ниже кода несправедлив, потому что не может быть, чтобы итератор проводил то же время, что и «return» или «if y:». Почему это? Как я могу это исправить?

В некоторых тестах мой код слишком тяжел, поэтому я пытался проверить «расход памяти» каждой строки.

    def hmd(num):
        if num==1:
            return 1
        def resheto(num):
            t = list(range(num+1))
            t[1]=0
            for i in t:
                if t[i]:
                    for u in range(i**2, num+1, i):
                        t[u]=0
            end = [i for i in range(2,num+1) if t[i]]
            end = list(filter(lambda x: num%x==0, end))
            return end
        l = resheto(num)
        def end(num, l, minw, u=[]):
            u.append(minw)
            num=num//minw
            if num==1:
                return u
            ent = list(filter(lambda x: num%x==0, l))
            minw=ent[0]
            return end(num, l, minw, u)
        o = end(num, l, l[0])
        def hi(o, j=[]):
            if len(o)==0:
                return j
            y = len(list(filter(lambda x: o[0]==x, o)))
            u = list(filter(lambda x: o[0]!=x, o))
            if y:
                j.append('{p}^{y}'.format(p=o[0], y=y))
            else:
                j.append(str(o[0]))
            return hi(u, j)
        return ('*'.join(hi(o))).replace('^1','')
    from dgdgd_zooz_memory import hmd
    %mprun -f hmd hmd(100)

--- результат ---

Filename: /Users/Pro/Desktop/python/sirius/dgdgd_zooz_memory.py

Использование строки # Mem Увеличение содержания строки

 1     56.5 MiB     56.5 MiB   def hmd(num):
 2     56.5 MiB      0.0 MiB       if num==1:
 3                                     return 1
 4     56.5 MiB      0.0 MiB       def resheto(num):
 5     56.5 MiB      0.0 MiB           t = list(range(num+1))
 6     56.5 MiB      0.0 MiB           t[1]=0
 7     56.5 MiB      0.0 MiB           for i in t:
 8     56.5 MiB      0.0 MiB               if t[i]:
 9     56.5 MiB      0.0 MiB                   for u in range(i**2, num+1, i):
10     56.5 MiB      0.0 MiB                       t[u]=0
11     56.5 MiB      0.0 MiB           end = [i for i in range(2,num+1) if t[i]]
12     56.5 MiB      0.0 MiB           end = list(filter(lambda x: num%x==0, end))
13     56.5 MiB      0.0 MiB           return end
14     56.5 MiB      0.0 MiB       l = resheto(num)
15     56.5 MiB      0.0 MiB       def end(num, l, minw, u=[]):
16     56.5 MiB      0.0 MiB           u.append(minw)
17     56.5 MiB      0.0 MiB           num=num//minw
18     56.5 MiB      0.0 MiB           if num==1:
19     56.5 MiB      0.0 MiB               return u
20     56.5 MiB      0.0 MiB           ent = list(filter(lambda x: num%x==0, l))
21     56.5 MiB      0.0 MiB           minw=ent[0]
22     56.5 MiB      0.0 MiB           return end(num, l, minw, u)
23     56.5 MiB      0.0 MiB       o = end(num, l, l[0])
24     56.5 MiB      0.0 MiB       def hi(o, j=[]):
25     56.5 MiB      0.0 MiB           if len(o)==0:
26     56.5 MiB      0.0 MiB               return j
27     56.5 MiB      0.0 MiB           y = len(list(filter(lambda x: o[0]==x, o)))
28     56.5 MiB      0.0 MiB           u = list(filter(lambda x: o[0]!=x, o))
29     56.5 MiB      0.0 MiB           if y:
30     56.5 MiB      0.0 MiB               j.append('{p}^{y}'.format(p=o[0], y=y))
31                                     else:
32                                         j.append(str(o[0]))
33     56.5 MiB      0.0 MiB           return hi(u, j)
34     56.5 MiB      0.0 MiB       return ('*'.join(hi(o))).replace('^1','')
...