-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathgenerate_fast_exp_array.py
35 lines (30 loc) · 1.69 KB
/
generate_fast_exp_array.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
import sys
import os
if len(sys.argv) != 3:
print("Usage: " + sys.argv[0] + " <lower_bound> <upper_bound>")
print("Generates a fast exponential c file for values between the lower and upper bounds inclusive by precomputing and caching values in an array")
with open("fast_exp_array.cpp", "w") as fast_exp_file:
lower_bound = int(sys.argv[1])
upper_bound = int(sys.argv[2])
num_vals = upper_bound-lower_bound+1
fast_exp_file.write("#include <cmath>"+os.linesep)
fast_exp_file.write("#include \"parameters.hpp\""+os.linesep)
fast_exp_file.write("namespace pm {"+os.linesep)
fast_exp_file.write("namespace fastexp_array {"+os.linesep)
fast_exp_file.write(os.linesep)
fast_exp_file.write("float precomputed_vals["+str(num_vals)+"];"+os.linesep)
fast_exp_file.write("void setup_exp() {"+os.linesep)
fast_exp_file.write(" precomputed_vals[0] = std::exp(0);"+os.linesep)
fast_exp_file.write(" for (int i=1; i<"+str(num_vals)+"; i++) {"+os.linesep)
fast_exp_file.write(" precomputed_vals[i] = std::exp(-i/GAMMA);"+os.linesep)
fast_exp_file.write(" }"+os.linesep)
fast_exp_file.write("}"+os.linesep)
fast_exp_file.write("float fast_exp(int val) {"+os.linesep)
fast_exp_file.write(" // Assume value is in [-n,0]"+os.linesep)
fast_exp_file.write(" if (val<=0 || val>="+str(lower_bound)+") {"+os.linesep)
fast_exp_file.write(" return precomputed_vals[-val];"+os.linesep)
fast_exp_file.write(" }"+os.linesep)
fast_exp_file.write(" return std::exp(val/GAMMA);"+os.linesep)
fast_exp_file.write("}"+os.linesep)
fast_exp_file.write("} // namespace fastexp_array"+os.linesep)
fast_exp_file.write("} // namespace pm"+os.linesep)