File: LRU-experiments2.py

package info (click to toggle)
pytables 3.10.2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 15,228 kB
  • sloc: ansic: 82,212; python: 65,296; cpp: 753; sh: 394; makefile: 100
file content (59 lines) | stat: -rw-r--r-- 1,509 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# Testbed to perform experiments in order to determine best values for
# the node numbers in LRU cache. Arrays version.

from time import perf_counter as clock

import tables as tb

print("PyTables version-->", tb.__version__)

filename = "/tmp/junk-array.h5"
NOBJS = 1000


def create_junk():
    fileh = tb.open_file(filename, mode="w")
    for i in range(NOBJS):
        fileh.create_array(fileh.root, "array" + str(i), [1])
    fileh.close()


def modify_junk_lru():
    fileh = tb.open_file(filename, "a")
    group = fileh.root
    for j in range(5):
        print("iter -->", j)
        for tt in fileh.walk_nodes(group):
            if isinstance(tt, tb.Array):
                #                 d = tt.read()
                pass

    fileh.close()


def modify_junk_lru2():
    fileh = tb.open_file(filename, "a")
    group = fileh.root
    for j in range(5):
        t1 = clock()
        for i in range(100):  # The number
            # print("table-->", tt._v_name)
            _ = getattr(group, "array" + str(i))
            # d = _.read()
        print(f"iter and time --> {j + 1} {clock() - t1:.3f}")
    fileh.close()


if 1:
    # create_junk()
    # modify_junk_LRU()    # uses the iterador version (walk_nodes)
    modify_junk_lru2()  # uses a regular loop (getattr)
else:
    import pstats
    import profile

    profile.run("modify_junk_LRU2()", "modify.prof")
    stats = pstats.Stats("modify.prof")
    stats.strip_dirs()
    stats.sort_stats("time", "calls")
    stats.print_stats()