forked from girving/mandelbrot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathknown.h
154 lines (146 loc) · 8.29 KB
/
known.h
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
// Known Mandelbrot area bounds
#pragma once
namespace mandelbrot {
struct Known {
int k; // Estimate from 2^k terms
double time; // time of refinement step in seconds (negative for unknown)
int prec; // Arb precision
const char* value; // serialized arb_t value
};
extern const Known known_areas[16+1];
// Bittner et al.'s Tables 1 and 2 (https://arxiv.org/abs/1410.1212):
struct Bittner {
int terms;
double value;
};
extern const Bittner bittner_areas[10];
// 8 terms of f and g = log f:
// f = [(1 +/- 0), (-0.5 +/- 0), (0.125 +/- 0), (-0.25 +/- 9.3345e-61),
// (0.117 +/- 1.3224e-60), (2.33e-62 +/- 1.7859e-60), (-0.0459 +/- 3.3449e-60), (-0.0625 +/- 4.9784e-60)]
// g = [(0 +/- 0), (-0.5 +/- 0), (0 +/- 0), (-0.229 +/- 1.1927e-60),
// (7.78e-62 +/- 1.7891e-60), (0.0289 +/- 2.6331e-60), (-0.0625 +/- 4.8099e-60), (-0.0836 +/- 7.5565e-60)]
// Arb history:
// 15jan2022, prec 200:
// k 11 refine, 2.06 s: mu = 1.854656777 +/- 6.3116e-18
// 16jan2022, prec 200, Newton refinement:
// k 11 refine, 5.65 s: mu = 1.854656777 +/- 1.2799e-37
// k 12 refine, 13.9 s: mu = 1.834655733 +/- 9.6986e-33
// 17jan2022, prec 200, log1p_exp_shift:
// k 11 refine, 20.0 s: mu = 1.854656777 +/- 2.3030e-45
// k 12 refine, 61.5 s: mu = 1.834655733 +/- 7.6881e-43
// k 13 refine, 169 s: mu = 1.806178886 +/- 4.6439e-40
// k 14 refine, 422 s: mu = 1.786389717 +/- 3.9121e-37
// 17jan2022, prec 200, poly_inv_refine → f(y0)/f'(y):
// k 11 refine, 25.1 s: mu = 1.854656777 +/- 1.1026e-45
// k 12 refine, 72.4 s: mu = 1.834655733 +/- 3.3779e-43
// k 13 refine, 206 s: mu = 1.806178886 +/- 1.8539e-40
// k 14 refine, 694 s: mu = 1.786389717 +/- 1.4147e-37
// 17jan2022, prec 200, solve in g = log f space:
// k 11 refine, 26.7 s: mu = 1.854656777 +/- 8.9856e-46
// k 12 refine, 84.4 s: mu = 1.834655733 +/- 2.7409e-43
// Series history:
// 22jan2022, double, fft_mul:
// k 14, 39.5 s: mu = 1.786389717, error = 7.11e-15
// 22jan2022, double, no bit reverse:
// k 14, 36.1 s: mu = 1.786389717, error = 2.11e-14
// 27jan2022, double, srfft:
// k 14, 17.9 s: mu = 1.786389717, error = 1.82e-14
// 27jan2022, double, cache twiddle factors:
// k 14, 2.90 s: mu = 1.786389717, error = 1.82e-14
// k 15, 6.99 s: mu = 1.766837674, error = 3.55e-14
// k 16, 19.1 s: mu = 1.753375772, error = 9.37e-13
// k 17, 44.9 s: mu = nan
// 29jan2022, double, Newton refine more often:
// k 15, 13.7 s: mu = 1.766837674, error = 9.77e-15
// k 16, 33.4 s: mu = 1.753375772, error = 4.29e-14
// k 17, 86.2 s: mu = 1.736187979
// k 18, 208 s: mu = 1.726163785
// k 19, 524 s: mu = 1.712556954 (0.01 below Ewing-Schober)
// 29jan2022, double, track known zeros:
// k 15, 13.1 s: mu = 1.766837674, error = 2.82e-14
// k 16, 32.1 s: mu = 1.753375772, error = 3.55e-15
// k 17, 84.4 s: mu = 1.736187979
// k 18, 210 s: mu = 1.726163785
// 29jan2022, double, compute twiddles via arb:
// k 15, 13.1 s: mu = 1.766837674, error = 3.11e-15
// k 16, 35.5 s: mu = 1.753375772, error = 3e-14
// k 17, 86.9 s: mu = 1.736187979
// k 18, 214 s: mu = 1.726163785
// k 19, 545 s: mu = 1.712556954 (still 0.01 below Ewing-Schober, but same as above?)
// 31jan2022, exp2, expansion arithmetic works:
// k 13, 26.1 s: mu = 1.80617888585652252315542830417844, error = 1.36e-31
// k 14, 63.8 s: mu = 1.78638971655198525707933106215495, error < 2.07e-20
// k 15, 150 s: mu = 1.76683767419408303662440486811699, error < 2.44e-20
// k 16, 352 s: mu = 1.753375772356926299663688533777756, error < 3.63e-20
// k 17, 833 s: mu = 1.73618797890571568324245734657981
// 7feb2022, exp2, OpenMP loops:
// k 13, 10.4 s: mu = [1.8061788858565224, 1.0287197403756847e-16], error = 2.05e-31
// k 14, 21.6 s: mu = [1.7863897165519853, -5.0111999258920122e-17], error < 4.14e-20
// k 15, 47.4 s: mu = [1.766837674194083, 4.0031735280416123e-17], error < 4.89e-20
// k 16, 111 s: mu = [1.7533757723569263, -2.1274753143068704e-17], error < 7.27e-20
// k 17, 236 s: mu = [1.7361879789057157, -6.2027842174938069e-17]
// CUDA series history (on an A100)
// 4feb2022, cuda-double, first working version:
// k 10, 11.0 s: mu = 1.895943075803316, error = 3.41e-15
// k 11, 16.4 s: mu = 1.8546567767819579, error = 2.83e-15
// 4feb2022, cuda-double, mul/sqr base cases:
// k 10, 8.0 s: mu = 1.8959430758033156, error = 3.85e-15
// k 11, 12.4 s: mu = 1.8546567767819575, error = 3.27e-15
// 4feb2022, cuda-double, inv/exp base cases:
// k 11, 10.1 s: mu = 1.8546567767819564, error = 4.38e-15
// k 12, 15.0 s: mu = 1.834655732626151, error = 4.65e-15
// k 13, 21.7 s: mu = 1.8061788858565135, error = 8.98e-15
// k 14, 30.5 s: mu = 1.78638971655198, error = 5.28e-15
// k 15, 41.7 s: mu = 1.7668376741940959, error = 1.28e-14
// k 16, 56.1 s: mu = 1.7533757723569496, error = 2.33e-14
// k 17, 74.0 s: mu = 1.7361879789057115, error ≈ 5e-15 (vs. exp2)
// k 18, 96.3 s: mu = 1.7261637845417952
// k 19, 124 s: mu = 1.7125569540291936
// k 20, 160 s: mu = 1.7032798671348994, error ≲ 1e-3 (vs. Bittner 1M)
// k 21, 213 s: mu = 1.6933586065947914, error ≲ 1e-3 (vs. Bittner 2M)
// k 22, 301 s: mu = 1.6858651156374813, error ≲ 1e-3 (vs. Bittner 4M)
// 10mar2022, cuda-double, higher radix FFTs:
// k 16, 33.6 s: mu = 1.7533757723569587, error = 3.24e-14
// k 17, 44.4 s: mu = 1.7361879789057599, error ≈ 5e-14 (vs. exp2)
// k 18, 58.2 s: mu = 1.7261637845418298
// k 19, 75.6 s: mu = 1.712556954028907
// k 20, 98.4 s: mu = 1.7032798671345499
// bittner 1000000 = 1.7039, ours = 1.7039270269453779, error = 2.97e-06
// k 21, 130 s: mu = 1.6933586065945569
// bittner 1500000 = 1.697, ours = 1.6970195803123127, error = 4.2e-07
// bittner 2000000 = 1.6939, ours = 1.6938826380240775, error = 2.64e-06
// k 22, 178 s: mu = 1.6858651156276676
// bittner 2500000 = 1.691, ours = 1.6909573635586672, error = 2.64e-06
// bittner 3000000 = 1.6889, ours = 1.6889472776858034, error = 2.72e-06
// bittner 3500000 = 1.6874, ours = 1.687396798755451, error = 3.2e-06
// bittner 4000000 = 1.6863, ours = 1.6863310308133068, error = 1.03e-06
// k 23, 145 s: mu = nan
// 11mar2022, cuda-exp2:
// k 12, 11.8 s: mu = 1.834655732626155658169747764209792, error = 2.72e-31
// k 13, 17.3 s: mu = 1.80617888585652252315542830417852, error = 2.26e-31
// k 14, 24.7 s: mu = 1.786389716551985257079331062155, error < 4.14e-20
// k 15, 34.5 s: mu = 1.766837674194083036624404868115474, error < 4.89e-20
// k 16, 47.3 s: mu = 1.753375772356926299663688533777565, error < 7.27e-20
// k 17, 63.5 s: mu = 1.73618797890571568324245734656815, cpu diff ~ 1.2e-29
// k 18, 84.9 s: mu = 1.72616378454179070011874376004819
// k 19, 114. s: mu = 1.71255695402917003284325027139466
// k 20, 154 s: mu = 1.70327986713499777272132592742127
// bittner 1000000 = 1.7039, ours = 1.70392702694580798963833922009993, error = 2.97e-06
// k 21, 229 s: mu = 1.69335860659487455982519139771477
// bittner 1500000 = 1.697, ours = 1.69701958031269638101109603580289, error = 4.2e-07
// bittner 2000000 = 1.6939, ours = 1.693882638024406526140276379392128, error = 2.64e-06
// k 22, 316 s: mu = 1.685865115638091230676164061117897
// bittner 2500000 = 1.691, ours = 1.6909573635655301684668460787165658, error = 2.64e-06
// bittner 3000000 = 1.6889, ours = 1.68894727769447682259288765882548, error = 2.72e-06
// bittner 3500000 = 1.6874, ours = 1.68739679876469395230821847804315, error = 3.2e-06
// bittner 4000000 = 1.6863, ours = 1.68633103082317483817521485590169, error = 1.03e-06
// k 23, 494 s: mu = 1.676454088173227014017191753727393
// bittner 4500000 = 1.6845, ours = 1.68447255010118883114213247866676, error = 2.55e-06
// bittner 5000000 = 1.6829, ours = 1.68287880053016590987652661041036, error = 1.2e-06
// k 24, 824 s: mu = 1.67062597369528674552070608041071
// k 25, 1.47e3 s: mu = 1.663453295463339439026761882950975
// k 26, 2.8e3 s: mu = 1.65768997893642502342942699620219
// k 27: out of memory
// 12mar2022, cuda-exp2, fewer temporaries and symmetry-reduced twiddles:
// k 27, 5.16e+03 s: mu = 1.65158703583485945828819972180538
} // namespace mandelbrot