-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsurface_experiments.py
108 lines (87 loc) · 3.58 KB
/
surface_experiments.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
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
from samplers import *
from solvers import *
from plots import *
from multiprocessing import Pool
import pickle
def test_block(n, ovs, nl, tests, slopes, verbose, save, directory, b, f, plots):
errors_ = []
sig_pow = []
np.random.seed(10*n + ovs)
noise_ampl = 0.0
if nl is not 0:
noise_ampl = 10.0 ** (-nl)
version = "{}_{}_{:.2f}".format(n, ovs, nl)
print("starting version:", version)
params = np.loadtxt("example_polynomials{}.csv".format(n), delimiter=",")
if tests > params.shape[0]:
print("not enough polynomials!")
return
for test in range(tests):
tmp_err = []
start_param = params[test,:]
for slope in slopes:
polynomial = SecondSurfacePolynomial(start_param)
sampler = SurfaceSampler(polynomial, 2 * ovs * n, [slope, b, f], interval_length=2, sigma=0.0, beg=-1)
noise = noise_ampl * nr.randn(2 * ovs * n)
sig_pow.append(np.mean(np.power(sampler.sample_values,2)))
sample_values = sampler.sample_values + noise
solver = ConstrainedALS(
sample_values,
polynomial.model_size,
SecondSurfacePolynomial,
start_pos=sampler.sample_positions,
stopping_error=1e-14,
beta=0.1/ovs,
show_plots=plots,
max_iter=1000,
fl=f,
verbose=verbose)
try:
solver.solve()
true_error = abs(slope - solver.tr_param[0])
except AssertionError as as_err:
print("assertion error:", as_err.args[0])
true_error = np.NAN
except Exception as other_exc:
print("unexpected error:", other_exc.args[0])
true_error = np.NAN
if(verbose):
np.save("offline_errors" + version, solver.error_over_time)
np.save("offline_params" + version, solver.tr_params_over_time)
np.save("offline_beta" + version, solver.beta_over_time)
tmp_err.append(true_error)
errors_.append(np.array(tmp_err))
errors_ = np.array(errors_)
sig_pow = np.array(sig_pow)
print("finished version:", version)
if verbose:
print("mean:", np.degrees(np.nanmean(errors_)))
print("median:", np.degrees(np.nanmedian(errors_)))
print("std:", np.degrees(np.nanstd(errors_)))
print("NANS:", str(np.count_nonzero(np.isnan(errors_)) / len(errors_.flatten()) * 100) + "%")
print("signal_power:", np.mean(sig_pow))
if save:
np.save(directory + "errors_" + version, errors_)
np.save(directory + "pow_" + version, sig_pow)
np.save(directory + "params_" + version, params)
print("saved version:", version)
return errors_, sig_pow,
if __name__ == '__main__':
# set parameters
save = False
plots = False
verbose = False
n_tests = 100 # number of tests (should be at least two, because)
directory = "results/"
f = 1.0 # distance between the origin and the image plane
b = 1.0 # intersection between camera axis and the surface
slopes = np.linspace(-np.pi / 9, np.pi / 9, 13)
def test_block_unpack(t):
return test_block(t[0], t[1], t[2], n_tests, slopes, verbose, save, directory, b, f, plots)
with open('parameters/test_set', 'rb') as in_file:
test_set = pickle.load(in_file)
for t in test_set:
print(t)
# start 4 worker processes
pool = Pool(processes=4)
pool.map(test_block_unpack, test_set)