-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathtry_vector.py
50 lines (39 loc) · 1.02 KB
/
try_vector.py
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
"""
Usage:
python try_vector.py -v
"""
import argparse
import math
import numpy as np
import py2llvm as llvm
parser = argparse.ArgumentParser()
parser.add_argument('-v', '--verbose', action='count', default=0)
args = parser.parse_args()
verbose = args.verbose
#print(verbose)
#@llvm.jit(verbose=verbose)
#def f(a1, a2, out):
# for i in range(a1.shape[0]):
# if a1[i] > a2[i]:
# out[i] = a1[i] + a2[i] * 2
# else:
# out[i] = a1[i] - a2[i]
#
# return 1
@llvm.jit(verbose=verbose, optimize=True)
def f(out, x, y):
n = out.shape[0]
for i in range(n):
out[i] = (math.sin(x[i]) - 1.35) * (x[i] - 4.45) * (y[i] - 8.5)
#out[i] = (x[i] - 1.35) * (x[i] - 4.45) * (x[i] - 8.5)
return 1
# Prepare function arguments
a1 = [1.0, 2.5, 1.3, 5.2] * 1000
a2 = [0.5, 1.5, 2.2, 2.9] * 1000
a1 = np.array(a1, dtype=np.float64)
a2 = np.array(a2, dtype=np.float64)
out = np.empty((4000,), dtype=np.float64)
f(out, a1, a2, verbose=verbose) # COMPILED
print(a1)
print(a2)
print(out)