#include "ulong_extras.h"
#include "mpn_extras.h"
#include "fft.h"
int
main(void)
{
flint_bitcnt_t depth, w;
mp_size_t iters;
double truncation;
FLINT_TEST_INIT(state);
flint_printf("mul_truncate_sqrt2....");
fflush(stdout);
depth = 13;
w = 1;
iters = 1;
truncation = 1.0;
{
mp_size_t n = (UWORD(1)<<depth);
flint_bitcnt_t bits1 = (n*w - (depth + 1))/2;
flint_bitcnt_t bits = 2*n*bits1;
mp_size_t int_limbs = ((mp_size_t)(truncation*bits))/FLINT_BITS;
mp_size_t j;
mp_limb_t * i1, *i2, *r1;
flint_printf("limbs = %wd\n", int_limbs);
i1 = flint_malloc(6*int_limbs*sizeof(mp_limb_t));
i2 = i1 + int_limbs;
r1 = i2 + int_limbs;
flint_mpn_urandomb(i1, state, int_limbs*FLINT_BITS);
flint_mpn_urandomb(i2, state, int_limbs*FLINT_BITS);
for (j = 0; j < iters; j++)
mul_truncate_sqrt2(r1, i1, int_limbs, i2, int_limbs, depth, w);
flint_free(i1);
}
FLINT_TEST_CLEAR(state);
flint_printf("done\n");
return 0;
}