cache_usecases.py 1.45 KB
Newer Older
dugupeiwen's avatar
dugupeiwen committed
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
import numba as nb


#
# UFunc
#

def direct_ufunc_cache_usecase(**kwargs):
    @nb.vectorize(["intp(intp)", "float64(float64)"], cache=True, **kwargs)
    def ufunc(inp):
        return inp * 2

    return ufunc


def indirect_ufunc_cache_usecase(**kwargs):
    @nb.njit(cache=True)
    def indirect_ufunc_core(inp):
        return inp * 3

    @nb.vectorize(["intp(intp)", "float64(float64)", "complex64(complex64)"],
                  **kwargs)
    def ufunc(inp):
        return indirect_ufunc_core(inp)

    return ufunc


#
# DUFunc
#

def direct_dufunc_cache_usecase(**kwargs):
    @nb.vectorize(cache=True, **kwargs)
    def ufunc(inp):
        return inp * 2

    return ufunc


def indirect_dufunc_cache_usecase(**kwargs):
    @nb.njit(cache=True)
    def indirect_ufunc_core(inp):
        return inp * 3

    @nb.vectorize(**kwargs)
    def ufunc(inp):
        return indirect_ufunc_core(inp)

    return ufunc


#
# GUFunc
#

def direct_gufunc_cache_usecase(**kwargs):
    @nb.guvectorize(["(intp, intp[:])", "(float64, float64[:])"],
                    "()->()", cache=True, **kwargs)
    def gufunc(inp, out):
        out[0] = inp * 2

    return gufunc


def indirect_gufunc_cache_usecase(**kwargs):
    @nb.njit(cache=True)
    def core(x):
        return x * 3

    @nb.guvectorize(["(intp, intp[:])", "(float64, float64[:])",
                     "(complex64, complex64[:])"], "()->()", **kwargs)
    def gufunc(inp, out):
        out[0] = core(inp)

    return gufunc