#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <assert.h>
typedef uint32_t I_TYPE;
int FIG = 5;
I_TYPE RADIX = 100000;
const double pi = 3.1415926535897932385;
double cos1;
double sin1;
double err_max;
#define max(a,b) ((a)<(b)?(b):(a))
void fr(double* s1, double* s2, double* end, size_t add, size_t t90) {
for (; s1 < end; s1 += add, s2 += add) {
double r0, r1, r2, r3, m0, m1;
r0 = s1[0];
r1 = s2[0];
r2 = s1[t90];
r3 = s2[t90];
m0 = r2 * cos1 - r3 * sin1;
m1 = r2 * sin1 + r3 * cos1;
s1[0] = r0 + m0;
s2[0] = r0 - m0;
s1[t90] = -r1 + m1;
s2[t90] = r1 + m1;
}
}
void fri(double* s1, double* s2, double* end, size_t add, size_t t90) {
for (; s1 < end; s1 += add, s2 += add) {
double r0, r1, r2, r3, m0, m1, m2, m3;
r0 = s1[0];
r1 = s2[0];
r2 = s1[t90];
r3 = s2[t90];
m0 = r0 + r1;
m1 = -r2 + r3;
m2 = r0 - r1;
m3 = r2 + r3;
s1[0] = m0;
s2[0] = m1;
s1[t90] = m2 * cos1 + m3 * sin1;
s2[t90] = -m2 * sin1 + m3 * cos1;
}
}
void fr0(double* s1, double* end, size_t add, size_t t90) {
for (; s1 < end; s1 += add) {
double r0, r1;
r0 = s1[0];
r1 = s1[t90];
s1[0] = r0 + r1;
s1[t90] = r0 - r1;
}
}
void swap_d(double* a, double* b) {
double t = *a;
*a = *b;
*b = t;
}
void bxchg(double* s, int p) {
size_t t4, t5, t6, t045, t090, t180, t270;
t045 = (size_t)1 << p - 3;
t090 = t045 + t045;
t180 = t090 + t090;
t270 = t180 + t090;
t4 = t090 - 4;
t5 = t4;
do {
swap_d(&s[t4 + 1], &s[t180 + t5]);
swap_d(&s[t4 + 2], &s[t090 + t5]);
swap_d(&s[t4 + 3], &s[t270 + t5]);
swap_d(&s[t090 + t4 + 1], &s[t180 + t5 + 2]);
swap_d(&s[t090 + t4 + 3], &s[t270 + t5 + 2]);
swap_d(&s[t180 + t4 + 3], &s[t270 + t5 + 1]);
if (t4 < t5) {
swap_d(&s[t4], &s[t5]);
swap_d(&s[t090 + t4 + 2], &s[t090 + t5 + 2]);
swap_d(&s[t180 + t4 + 1], &s[t180 + t5 + 1]);
swap_d(&s[t270 + t4 + 3], &s[t270 + t5 + 3]);
}
if (t4 == 0) {
break;
}
t4 -= 4;
t6 = t045;
for (;;) {
t5 ^= t6;
if ((t5 & t6) == 0) {
break;
}
t6 >>= 1;
}
} while (1);
}
void bitexchg(double* s, int p) {
if (p <= 1) {
}
else if (p == 2) {
swap_d(&s[1], &s[2]);
}
else if (p == 3) {
swap_d(&s[1], &s[4]);
swap_d(&s[3], &s[6]);
}
else {
bxchg(s, p);
}
}
double* SIN_TABLE[64] = { 0 };
const double* sin_table(int p) {
if (p >= 2 && SIN_TABLE[p] == 0) {
size_t t090, i;
double k;
t090 = (size_t)1 << p - 2;
SIN_TABLE
[p
] = (double*)malloc(t090
* sizeof(double)); if (SIN_TABLE[p] == NULL) {
printf("malloc failed. sin_table %d\r\n", p
); }
k = 0.5 * pi / t090;
for (i = 0; i < t090; i++) {
SIN_TABLE
[p
][i
] = sin(k
* i
); }
}
return SIN_TABLE[p];
}
void fouri(double* s, int p) {
const double* table;
size_t t090, t360;
int i;
table = sin_table(p);
t360 = (size_t)1 << p;
t090 = t360 >> 2;
bitexchg(s, p);
for (i = 1; i <= p; i++) {
size_t r090, r180, r360, k1, k2, t0, t1, t2;
r360 = (size_t)1 << i;
r180 = r360 >> 1;
r090 = r180 >> 1;
fr0(&s[0], &s[t360], r360, r180);
k1 = 1;
k2 = r180 - 1;
t2 = (size_t)1 << p - i;
t0 = t2;
t1 = t090 - t2;
for (; k1 < r090; k1++, k2--) {
sin1 = table[t0];
cos1 = table[t1];
fr(&s[k1], &s[k2], &s[t360], r360, r180);
t0 += t2;
t1 -= t2;
}
}
}
void fouriinv(double* s, int p) {
const double* table;
size_t t090, t360;
int i;
table = sin_table(p);
t360 = (size_t)1 << p;
t090 = t360 >> 2;
for (i = p; i >= 1; i--) {
size_t r090, r180, r360, k1, k2, t0, t1, t2;
r360 = (size_t)1 << i;
r180 = r360 >> 1;
r090 = r180 >> 1;
fr0(&s[0], &s[t360], r360, r180);
k1 = 1;
k2 = r180 - 1;
t2 = (size_t)1 << p - i;
t0 = t2;
t1 = t090 - t2;
for (; k1 < r090; k1++, k2--) {
sin1 = table[t0];
cos1 = table[t1];
fri(&s[k1], &s[k2], &s[t360], r360, r180);
t0 += t2;
t1 -= t2;
}
}
bitexchg(s, p);
}
typedef struct I_ {
I_TYPE* data;
size_t capacity;
size_t size;
} I;
typedef struct F_ {
double* data;
size_t capacity;
int p;
} F;
void alloc_i(I* a, size_t cap) {
a
->data
= (I_TYPE
*)malloc(cap
* sizeof(I_TYPE
)); if (a->data == NULL) {
printf("malloc failed. alloc_i %zu\r\n", cap
); }
a->capacity = cap;
}
void free_i(I* a) {
}
void alloc_f(F* a, int p) {
size_t cap = (size_t)1 << p;
a
->data
= (double*)malloc(cap
* sizeof(double)); if (a->data == NULL) {
printf("malloc failed. alloc_f %d\r\n", p
); }
a->capacity = cap;
}
void free_f(F* a) {
}
void swap_i(I* a, I* b) {
I t = *a;
*a = *b;
*b = t;
}
void i2f(F* a, const I* b, int p) {
size_t i;
size_t t360;
int carry;
t360 = (size_t)1 << p;
a->p = p;
carry = 0;
for (i = 0; i < b->size - 1; i++) {
int t = b->data[i] + carry;
if (t < (int)RADIX / 2) {
a->data[i] = t;
carry = 0;
}
else {
a->data[i] = (int)t - (int)RADIX;
carry = 1;
}
}
a->data[i] = b->data[i] + carry;
i++;
for (; i < t360; i++) {
a->data[i] = 0.;
}
fouri(a->data, p);
}
void mul_f2i(I* a, const F* b, const F* c, F* d) {
int p;
size_t i, s, t, t180, t360, k1, k2;
int64_t carry;
double k;
p = b->p;
t180 = (size_t)1 << p - 1;
t360 = t180 + t180;
d->data[0] = b->data[0] * c->data[0] * .5;
d->data[t180] = b->data[t180] * c->data[t180] * .5;
k1 = 1;
k2 = t360 - 1;
for (; k1 < t180; k1++, k2--) {
double re, im;
re = b->data[k1] * c->data[k1] - b->data[k2] * c->data[k2];
im = b->data[k1] * c->data[k2] + b->data[k2] * c->data[k1];
d->data[k1] = re;
d->data[k2] = im;
}
fouriinv(d->data, p);
s = a->capacity < t360 ? a->capacity : t360;
carry = 0;
t = 1;
for (i = 0; i < s; i++) {
double x;
int64_t e, f;
x = d->data[i] * k;
e
= (int64_t)floor(x
+ .5); err_max
= max
(err_max
, fabs(x
- e
)); e += carry;
carry = e / RADIX;
f = e - carry * RADIX;
if (f < 0) {
f += RADIX;
carry--;
}
a->data[i] = (I_TYPE)f;
if (f != 0) {
t = i + 1;
}
}
a->size = t;
if (carry != 0) {
if (a->size < a->capacity) {
assert(0 <= carry
&& carry
< RADIX
); a->data[a->size++] = (I_TYPE)carry;
}
else {
}
}
for (; i < t360; i++) {
double x;
int64_t e;
x = d->data[i] * k;
e
= (int64_t)floor(x
+ .5); err_max
= max
(err_max
, fabs(x
- e
)); }
}
void add_i(I* a, const I* b, const I* c) {
I_TYPE carry, d;
size_t i;
if (b->size > c->size) {
const I* t = b;
b = c;
c = t;
}
assert(c
->size
<= a
->capacity
);
carry = 0;
for (i = 0; i < b->size; i++) {
d = b->data[i] + c->data[i] + carry;
carry = 0;
if (d >= RADIX) {
d -= RADIX;
carry++;
}
a->data[i] = d;
}
for (; i < c->size; i++) {
d = c->data[i] + carry;
carry = 0;
if (d >= RADIX) {
d -= RADIX;
carry++;
}
a->data[i] = d;
}
a->size = c->size;
if (carry != 0) {
a->data[a->size++] = carry;
assert(a
->size
<= a
->capacity
); }
}
void print(const char* filename, const I* a) {
char format[10];
size_t s;
FILE* fp;
assert(a
->size
<= a
->capacity
);
fp
= fopen(filename
, "w");
s = a->size;
while (s != 0) {
}
}
int s2p(size_t s1, size_t s2) {
int i;
for (i = 1; i < 64; i++) {
if (((size_t)1 << i) + 1 >= s1 + s2) {
break;
}
}
return i;
}
int main(int argc, char** argv) {
int n = 34;
I a;
F x;
int p
= s2p
((1llu
<< n
) * log(2) / log(10) / FIG
+ 1, 1); size_t cap = (size_t)1 << p;
alloc_i(&a, cap);
alloc_f(&x, p);
a.data[0] = 1;
a.size = 1;
for (int i = 0; i < n; i++) {
int p = s2p(a.size, a.size);
i2f(&x, &a, p);
mul_f2i(&a, &x, &x, &x);
add_i(&a, &a, &a);
{
char filename[200];
print(filename, &a);
}
printf("%d %f\n", i
+ 1, err_max
); }
free_i(&a);
free_f(&x);
return 0;
}
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <assert.h>

typedef uint32_t I_TYPE;

int FIG = 5;
I_TYPE RADIX = 100000;

const double pi = 3.1415926535897932385;

double cos1;
double sin1;
double err_max;

#define max(a,b)		((a)<(b)?(b):(a))

void fr(double* s1, double* s2, double* end, size_t add, size_t t90) {
	for (; s1 < end; s1 += add, s2 += add) {
		double r0, r1, r2, r3, m0, m1;

		r0 = s1[0];
		r1 = s2[0];
		r2 = s1[t90];
		r3 = s2[t90];

		m0 = r2 * cos1 - r3 * sin1;
		m1 = r2 * sin1 + r3 * cos1;

		s1[0] = r0 + m0;
		s2[0] = r0 - m0;
		s1[t90] = -r1 + m1;
		s2[t90] = r1 + m1;
	}
}

void fri(double* s1, double* s2, double* end, size_t add, size_t t90) {
	for (; s1 < end; s1 += add, s2 += add) {
		double r0, r1, r2, r3, m0, m1, m2, m3;

		r0 = s1[0];
		r1 = s2[0];
		r2 = s1[t90];
		r3 = s2[t90];

		m0 = r0 + r1;
		m1 = -r2 + r3;
		m2 = r0 - r1;
		m3 = r2 + r3;

		s1[0] = m0;
		s2[0] = m1;
		s1[t90] = m2 * cos1 + m3 * sin1;
		s2[t90] = -m2 * sin1 + m3 * cos1;
	}
}

void fr0(double* s1, double* end, size_t add, size_t t90) {
	for (; s1 < end; s1 += add) {
		double r0, r1;

		r0 = s1[0];
		r1 = s1[t90];

		s1[0] = r0 + r1;
		s1[t90] = r0 - r1;
	}
}

void swap_d(double* a, double* b) {
	double t = *a;
	*a = *b;
	*b = t;
}

void bxchg(double* s, int p) {
	size_t t4, t5, t6, t045, t090, t180, t270;

	t045 = (size_t)1 << p - 3;
	t090 = t045 + t045;
	t180 = t090 + t090;
	t270 = t180 + t090;

	t4 = t090 - 4;
	t5 = t4;
	do {
		swap_d(&s[t4 + 1], &s[t180 + t5]);
		swap_d(&s[t4 + 2], &s[t090 + t5]);
		swap_d(&s[t4 + 3], &s[t270 + t5]);
		swap_d(&s[t090 + t4 + 1], &s[t180 + t5 + 2]);
		swap_d(&s[t090 + t4 + 3], &s[t270 + t5 + 2]);
		swap_d(&s[t180 + t4 + 3], &s[t270 + t5 + 1]);

		if (t4 < t5) {
			swap_d(&s[t4], &s[t5]);
			swap_d(&s[t090 + t4 + 2], &s[t090 + t5 + 2]);
			swap_d(&s[t180 + t4 + 1], &s[t180 + t5 + 1]);
			swap_d(&s[t270 + t4 + 3], &s[t270 + t5 + 3]);
		}
		if (t4 == 0) {
			break;
		}

		t4 -= 4;
		t6 = t045;
		for (;;) {
			t5 ^= t6;
			if ((t5 & t6) == 0) {
				break;
			}
			t6 >>= 1;
		}
	} while (1);
}

void bitexchg(double* s, int p) {
	if (p <= 1) {
	}
	else if (p == 2) {
		swap_d(&s[1], &s[2]);
	}
	else if (p == 3) {
		swap_d(&s[1], &s[4]);
		swap_d(&s[3], &s[6]);
	}
	else {
		bxchg(s, p);
	}
}

double* SIN_TABLE[64] = { 0 };

const double* sin_table(int p) {
	if (p >= 2 && SIN_TABLE[p] == 0) {
		size_t t090, i;
		double k;

		t090 = (size_t)1 << p - 2;
		SIN_TABLE[p] = (double*)malloc(t090 * sizeof(double));
		if (SIN_TABLE[p] == NULL) {
			printf("malloc failed. sin_table %d\r\n", p);
			exit(0);
		}
		k = 0.5 * pi / t090;
		for (i = 0; i < t090; i++) {
			SIN_TABLE[p][i] = sin(k * i);
		}
	}
	return SIN_TABLE[p];
}

void fouri(double* s, int p) {
	const double* table;
	size_t t090, t360;
	int i;

	table = sin_table(p);
	t360 = (size_t)1 << p;
	t090 = t360 >> 2;

	bitexchg(s, p);

	for (i = 1; i <= p; i++) {
		size_t r090, r180, r360, k1, k2, t0, t1, t2;

		r360 = (size_t)1 << i;
		r180 = r360 >> 1;
		r090 = r180 >> 1;

		fr0(&s[0], &s[t360], r360, r180);

		k1 = 1;
		k2 = r180 - 1;
		t2 = (size_t)1 << p - i;
		t0 = t2;
		t1 = t090 - t2;
		for (; k1 < r090; k1++, k2--) {
			sin1 = table[t0];
			cos1 = table[t1];
			fr(&s[k1], &s[k2], &s[t360], r360, r180);
			t0 += t2;
			t1 -= t2;
		}
	}
}

void fouriinv(double* s, int p) {
	const double* table;
	size_t t090, t360;
	int i;

	table = sin_table(p);
	t360 = (size_t)1 << p;
	t090 = t360 >> 2;

	for (i = p; i >= 1; i--) {
		size_t r090, r180, r360, k1, k2, t0, t1, t2;

		r360 = (size_t)1 << i;
		r180 = r360 >> 1;
		r090 = r180 >> 1;

		fr0(&s[0], &s[t360], r360, r180);

		k1 = 1;
		k2 = r180 - 1;
		t2 = (size_t)1 << p - i;
		t0 = t2;
		t1 = t090 - t2;
		for (; k1 < r090; k1++, k2--) {
			sin1 = table[t0];
			cos1 = table[t1];
			fri(&s[k1], &s[k2], &s[t360], r360, r180);
			t0 += t2;
			t1 -= t2;
		}
	}
	bitexchg(s, p);
}

typedef struct I_ {
	I_TYPE* data;
	size_t capacity;
	size_t size;
} I;

typedef struct F_ {
	double* data;
	size_t capacity;
	int p;
} F;

void alloc_i(I* a, size_t cap) {
	a->data = (I_TYPE*)malloc(cap * sizeof(I_TYPE));
	if (a->data == NULL) {
		printf("malloc failed. alloc_i %zu\r\n", cap);
		exit(0);
	}
	a->capacity = cap;
}

void free_i(I* a) {
	free(a->data);
}

void alloc_f(F* a, int p) {
	size_t cap = (size_t)1 << p;
	a->data = (double*)malloc(cap * sizeof(double));
	if (a->data == NULL) {
		printf("malloc failed. alloc_f %d\r\n", p);
		exit(0);
	}
	a->capacity = cap;
}

void free_f(F* a) {
	free(a->data);
}

void swap_i(I* a, I* b) {
	I t = *a;
	*a = *b;
	*b = t;
}

void i2f(F* a, const I* b, int p) {
	size_t i;
	size_t t360;
	int carry;

	t360 = (size_t)1 << p;

	assert(b->size <= t360);
	assert(t360 <= a->capacity);

	a->p = p;
	carry = 0;
	for (i = 0; i < b->size - 1; i++) {
		int t = b->data[i] + carry;
		if (t < (int)RADIX / 2) {
			a->data[i] = t;
			carry = 0;
		}
		else {
			a->data[i] = (int)t - (int)RADIX;
			carry = 1;
		}
	}
	a->data[i] = b->data[i] + carry;
	i++;
	for (; i < t360; i++) {
		a->data[i] = 0.;
	}
	fouri(a->data, p);
}

void mul_f2i(I* a, const F* b, const F* c, F* d) {
	int p;
	size_t i, s, t, t180, t360, k1, k2;
	int64_t carry;
	double k;

	p = b->p;
	t180 = (size_t)1 << p - 1;
	t360 = t180 + t180;

	assert(p == c->p);
	assert(t360 <= b->capacity);
	assert(t360 <= c->capacity);
	assert(t360 <= d->capacity);

	d->data[0] = b->data[0] * c->data[0] * .5;
	d->data[t180] = b->data[t180] * c->data[t180] * .5;

	k1 = 1;
	k2 = t360 - 1;
	for (; k1 < t180; k1++, k2--) {
		double re, im;

		re = b->data[k1] * c->data[k1] - b->data[k2] * c->data[k2];
		im = b->data[k1] * c->data[k2] + b->data[k2] * c->data[k1];
		d->data[k1] = re;
		d->data[k2] = im;
	}

	fouriinv(d->data, p);

	s = a->capacity < t360 ? a->capacity : t360;

	carry = 0;
	t = 1;
	k = ldexp(1., -p + 1);
	for (i = 0; i < s; i++) {
		double x;
		int64_t e, f;

		x = d->data[i] * k;
		e = (int64_t)floor(x + .5);
		err_max = max(err_max, fabs(x - e));
		e += carry;
		carry = e / RADIX;
		f = e - carry * RADIX;
		if (f < 0) {
			f += RADIX;
			carry--;
		}
		a->data[i] = (I_TYPE)f;
		if (f != 0) {
			t = i + 1;
		}
	}
	a->size = t;
	if (carry != 0) {
		if (a->size < a->capacity) {
			assert(0 <= carry && carry < RADIX);
			a->data[a->size++] = (I_TYPE)carry;
		}
		else {
			assert(0);
		}
	}
	for (; i < t360; i++) {
		double x;
		int64_t e;

		x = d->data[i] * k;
		e = (int64_t)floor(x + .5);
		err_max = max(err_max, fabs(x - e));
		assert(e == 0);
	}
}

void add_i(I* a, const I* b, const I* c) {
	I_TYPE carry, d;
	size_t i;

	if (b->size > c->size) {
		const I* t = b;
		b = c;
		c = t;
	}
	assert(c->size <= a->capacity);

	carry = 0;
	for (i = 0; i < b->size; i++) {
		d = b->data[i] + c->data[i] + carry;
		carry = 0;
		if (d >= RADIX) {
			d -= RADIX;
			carry++;
		}
		a->data[i] = d;
	}
	for (; i < c->size; i++) {
		d = c->data[i] + carry;
		carry = 0;
		if (d >= RADIX) {
			d -= RADIX;
			carry++;
		}
		a->data[i] = d;
	}
	a->size = c->size;
	if (carry != 0) {
		a->data[a->size++] = carry;
		assert(a->size <= a->capacity);
	}
}

void print(const char* filename, const I* a) {
	char format[10];
	size_t s;
	FILE* fp;

	assert(a->data != NULL);
	assert(a->size > 0);
	assert(a->size <= a->capacity);

	fp = fopen(filename, "w");

	sprintf(format, "%%0%du", FIG);

	s = a->size;
	fprintf(fp, "%u", a->data[--s]);
	while (s != 0) {
		fprintf(fp, format, a->data[--s]);
	}
	fclose(fp);
}

int s2p(size_t s1, size_t s2) {
	int i;
	for (i = 1; i < 64; i++) {
		if (((size_t)1 << i) + 1 >= s1 + s2) {
			break;
		}
	}
	return i;
}

int main(int argc, char** argv) {
	int n = 34;
	I a;
	F x;

	int p = s2p((1llu << n) * log(2) / log(10) / FIG + 1, 1);
	size_t cap = (size_t)1 << p;
	alloc_i(&a, cap);
	alloc_f(&x, p);

	a.data[0] = 1;
	a.size = 1;

	for (int i = 0; i < n; i++) {

		int p = s2p(a.size, a.size);
		i2f(&x, &a, p);
		mul_f2i(&a, &x, &x, &x);
		add_i(&a, &a, &a);

		{
			char filename[200];
			sprintf(filename, "%d.txt", i+1);
			print(filename, &a);
		}
		printf("%d %f\n", i + 1, err_max);
	}

	free_i(&a);
	free_f(&x);
	return 0;
}
