mirror of
https://github.com/vale981/arb
synced 2025-03-05 09:21:38 -05:00
long -> slong arb_poly.h.
This commit is contained in:
parent
44023ccc20
commit
66766f0c9b
1 changed files with 225 additions and 225 deletions
450
arb_poly.h
450
arb_poly.h
|
@ -44,8 +44,8 @@ extern "C" {
|
|||
typedef struct
|
||||
{
|
||||
arb_ptr coeffs;
|
||||
long length;
|
||||
long alloc;
|
||||
slong length;
|
||||
slong alloc;
|
||||
}
|
||||
arb_poly_struct;
|
||||
|
||||
|
@ -56,13 +56,13 @@ typedef arb_poly_struct arb_poly_t[1];
|
|||
|
||||
void arb_poly_init(arb_poly_t poly);
|
||||
|
||||
void arb_poly_init2(arb_poly_t poly, long len);
|
||||
void arb_poly_init2(arb_poly_t poly, slong len);
|
||||
|
||||
void arb_poly_clear(arb_poly_t poly);
|
||||
|
||||
void arb_poly_fit_length(arb_poly_t poly, long len);
|
||||
void arb_poly_fit_length(arb_poly_t poly, slong len);
|
||||
|
||||
void _arb_poly_set_length(arb_poly_t poly, long len);
|
||||
void _arb_poly_set_length(arb_poly_t poly, slong len);
|
||||
|
||||
void _arb_poly_normalise(arb_poly_t poly);
|
||||
|
||||
|
@ -76,16 +76,16 @@ arb_poly_swap(arb_poly_t poly1, arb_poly_t poly2)
|
|||
|
||||
void arb_poly_set(arb_poly_t poly, const arb_poly_t src);
|
||||
|
||||
void arb_poly_set_round(arb_poly_t poly, const arb_poly_t src, long prec);
|
||||
void arb_poly_set_round(arb_poly_t poly, const arb_poly_t src, slong prec);
|
||||
|
||||
/* Basic manipulation */
|
||||
|
||||
ARB_POLY_INLINE long arb_poly_length(const arb_poly_t poly)
|
||||
ARB_POLY_INLINE slong arb_poly_length(const arb_poly_t poly)
|
||||
{
|
||||
return poly->length;
|
||||
}
|
||||
|
||||
ARB_POLY_INLINE long arb_poly_degree(const arb_poly_t poly)
|
||||
ARB_POLY_INLINE slong arb_poly_degree(const arb_poly_t poly)
|
||||
{
|
||||
return poly->length - 1;
|
||||
}
|
||||
|
@ -103,31 +103,31 @@ arb_poly_one(arb_poly_t poly)
|
|||
_arb_poly_set_length(poly, 1);
|
||||
}
|
||||
|
||||
void arb_poly_set_coeff_si(arb_poly_t poly, long n, long x);
|
||||
void arb_poly_set_coeff_si(arb_poly_t poly, slong n, slong x);
|
||||
|
||||
void arb_poly_set_coeff_arb(arb_poly_t poly, long n, const arb_t x);
|
||||
void arb_poly_set_coeff_arb(arb_poly_t poly, slong n, const arb_t x);
|
||||
|
||||
void arb_poly_get_coeff_arb(arb_t x, const arb_poly_t poly, long n);
|
||||
void arb_poly_get_coeff_arb(arb_t x, const arb_poly_t poly, slong n);
|
||||
|
||||
#define arb_poly_get_coeff_ptr(poly, n) \
|
||||
((n) < (poly)->length ? (poly)->coeffs + (n) : NULL)
|
||||
|
||||
void _arb_poly_reverse(arb_ptr res, arb_srcptr poly, long len, long n);
|
||||
void _arb_poly_reverse(arb_ptr res, arb_srcptr poly, slong len, slong n);
|
||||
|
||||
void _arb_poly_shift_right(arb_ptr res, arb_srcptr poly, long len, long n);
|
||||
void _arb_poly_shift_right(arb_ptr res, arb_srcptr poly, slong len, slong n);
|
||||
|
||||
void arb_poly_shift_right(arb_poly_t res, const arb_poly_t poly, long n);
|
||||
void arb_poly_shift_right(arb_poly_t res, const arb_poly_t poly, slong n);
|
||||
|
||||
void _arb_poly_shift_left(arb_ptr res, arb_srcptr poly, long len, long n);
|
||||
void _arb_poly_shift_left(arb_ptr res, arb_srcptr poly, slong len, slong n);
|
||||
|
||||
void arb_poly_shift_left(arb_poly_t res, const arb_poly_t poly, long n);
|
||||
void arb_poly_shift_left(arb_poly_t res, const arb_poly_t poly, slong n);
|
||||
|
||||
ARB_POLY_INLINE void
|
||||
arb_poly_truncate(arb_poly_t poly, long newlen)
|
||||
arb_poly_truncate(arb_poly_t poly, slong newlen)
|
||||
{
|
||||
if (poly->length > newlen)
|
||||
{
|
||||
long i;
|
||||
slong i;
|
||||
for (i = newlen; i < poly->length; i++)
|
||||
arb_zero(poly->coeffs + i);
|
||||
poly->length = newlen;
|
||||
|
@ -137,9 +137,9 @@ arb_poly_truncate(arb_poly_t poly, long newlen)
|
|||
|
||||
/* Conversions */
|
||||
|
||||
void arb_poly_set_fmpz_poly(arb_poly_t poly, const fmpz_poly_t src, long prec);
|
||||
void arb_poly_set_fmpz_poly(arb_poly_t poly, const fmpz_poly_t src, slong prec);
|
||||
|
||||
void arb_poly_set_fmpq_poly(arb_poly_t poly, const fmpq_poly_t src, long prec);
|
||||
void arb_poly_set_fmpq_poly(arb_poly_t poly, const fmpq_poly_t src, slong prec);
|
||||
|
||||
ARB_POLY_INLINE void
|
||||
arb_poly_set_arb(arb_poly_t poly, const arb_t c)
|
||||
|
@ -149,7 +149,7 @@ arb_poly_set_arb(arb_poly_t poly, const arb_t c)
|
|||
_arb_poly_set_length(poly, !arb_is_zero(poly->coeffs));
|
||||
}
|
||||
|
||||
void arb_poly_set_si(arb_poly_t poly, long c);
|
||||
void arb_poly_set_si(arb_poly_t poly, slong c);
|
||||
|
||||
int arb_poly_get_unique_fmpz_poly(fmpz_poly_t res, const arb_poly_t src);
|
||||
|
||||
|
@ -163,40 +163,40 @@ int arb_poly_contains_fmpq_poly(const arb_poly_t poly1, const fmpq_poly_t poly2)
|
|||
|
||||
int arb_poly_equal(const arb_poly_t A, const arb_poly_t B);
|
||||
|
||||
int _arb_poly_overlaps(arb_srcptr poly1, long len1, arb_srcptr poly2, long len2);
|
||||
int _arb_poly_overlaps(arb_srcptr poly1, slong len1, arb_srcptr poly2, slong len2);
|
||||
|
||||
int arb_poly_overlaps(const arb_poly_t poly1, const arb_poly_t poly2);
|
||||
|
||||
/* Bounds */
|
||||
|
||||
void _arb_poly_majorant(arb_ptr res, arb_srcptr vec, long len, long prec);
|
||||
void _arb_poly_majorant(arb_ptr res, arb_srcptr vec, slong len, slong prec);
|
||||
|
||||
void arb_poly_majorant(arb_poly_t res, const arb_poly_t poly, long prec);
|
||||
void arb_poly_majorant(arb_poly_t res, const arb_poly_t poly, slong prec);
|
||||
|
||||
/* IO */
|
||||
|
||||
void arb_poly_printd(const arb_poly_t poly, long digits);
|
||||
void arb_poly_printd(const arb_poly_t poly, slong digits);
|
||||
|
||||
/* Random generation */
|
||||
|
||||
void arb_poly_randtest(arb_poly_t poly, flint_rand_t state, long len, long prec, long mag_bits);
|
||||
void arb_poly_randtest(arb_poly_t poly, flint_rand_t state, slong len, slong prec, slong mag_bits);
|
||||
|
||||
/* Arithmetic */
|
||||
|
||||
void
|
||||
_arb_poly_add(arb_ptr res, arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long prec);
|
||||
_arb_poly_add(arb_ptr res, arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong prec);
|
||||
|
||||
void arb_poly_add(arb_poly_t res, const arb_poly_t poly1,
|
||||
const arb_poly_t poly2, long prec);
|
||||
const arb_poly_t poly2, slong prec);
|
||||
|
||||
void arb_poly_add_si(arb_poly_t res, const arb_poly_t poly, long c, long prec);
|
||||
void arb_poly_add_si(arb_poly_t res, const arb_poly_t poly, slong c, slong prec);
|
||||
|
||||
void _arb_poly_sub(arb_ptr res, arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long prec);
|
||||
void _arb_poly_sub(arb_ptr res, arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong prec);
|
||||
|
||||
void arb_poly_sub(arb_poly_t res, const arb_poly_t poly1,
|
||||
const arb_poly_t poly2, long prec);
|
||||
const arb_poly_t poly2, slong prec);
|
||||
|
||||
ARB_POLY_INLINE void
|
||||
arb_poly_neg(arb_poly_t res, const arb_poly_t poly)
|
||||
|
@ -207,7 +207,7 @@ arb_poly_neg(arb_poly_t res, const arb_poly_t poly)
|
|||
}
|
||||
|
||||
ARB_POLY_INLINE void
|
||||
arb_poly_scalar_mul_2exp_si(arb_poly_t res, const arb_poly_t poly, long c)
|
||||
arb_poly_scalar_mul_2exp_si(arb_poly_t res, const arb_poly_t poly, slong c)
|
||||
{
|
||||
arb_poly_fit_length(res, poly->length);
|
||||
_arb_vec_scalar_mul_2exp_si(res->coeffs, poly->coeffs, poly->length, c);
|
||||
|
@ -215,45 +215,45 @@ arb_poly_scalar_mul_2exp_si(arb_poly_t res, const arb_poly_t poly, long c)
|
|||
}
|
||||
|
||||
void _arb_poly_mullow_ztrunc(arb_ptr res,
|
||||
arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long n, long prec);
|
||||
arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong n, slong prec);
|
||||
|
||||
void arb_poly_mullow_ztrunc(arb_poly_t res, const arb_poly_t poly1,
|
||||
const arb_poly_t poly2,
|
||||
long n, long prec);
|
||||
slong n, slong prec);
|
||||
|
||||
void _arb_poly_mullow_classical(arb_ptr res,
|
||||
arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long n, long prec);
|
||||
arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong n, slong prec);
|
||||
|
||||
void arb_poly_mullow_classical(arb_poly_t res, const arb_poly_t poly1,
|
||||
const arb_poly_t poly2,
|
||||
long n, long prec);
|
||||
slong n, slong prec);
|
||||
|
||||
void _arb_poly_mullow_block(arb_ptr C,
|
||||
arb_srcptr A, long lenA,
|
||||
arb_srcptr B, long lenB, long n, long prec);
|
||||
arb_srcptr A, slong lenA,
|
||||
arb_srcptr B, slong lenB, slong n, slong prec);
|
||||
|
||||
void arb_poly_mullow_block(arb_poly_t res, const arb_poly_t poly1,
|
||||
const arb_poly_t poly2, long len, long prec);
|
||||
const arb_poly_t poly2, slong len, slong prec);
|
||||
|
||||
void _arb_poly_mullow(arb_ptr C,
|
||||
arb_srcptr A, long lenA,
|
||||
arb_srcptr B, long lenB, long n, long prec);
|
||||
arb_srcptr A, slong lenA,
|
||||
arb_srcptr B, slong lenB, slong n, slong prec);
|
||||
|
||||
void arb_poly_mullow(arb_poly_t res, const arb_poly_t poly1,
|
||||
const arb_poly_t poly2, long len, long prec);
|
||||
const arb_poly_t poly2, slong len, slong prec);
|
||||
|
||||
void _arb_poly_mul(arb_ptr C,
|
||||
arb_srcptr A, long lenA,
|
||||
arb_srcptr B, long lenB, long prec);
|
||||
arb_srcptr A, slong lenA,
|
||||
arb_srcptr B, slong lenB, slong prec);
|
||||
|
||||
void arb_poly_mul(arb_poly_t res, const arb_poly_t poly1,
|
||||
const arb_poly_t poly2, long prec);
|
||||
const arb_poly_t poly2, slong prec);
|
||||
|
||||
ARB_POLY_INLINE void
|
||||
_arb_poly_mul_monic(arb_ptr res, arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long prec)
|
||||
_arb_poly_mul_monic(arb_ptr res, arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong prec)
|
||||
{
|
||||
if (len1 + len2 - 2 > 0)
|
||||
_arb_poly_mullow(res, poly1, len1, poly2, len2, len1 + len2 - 2, prec);
|
||||
|
@ -261,376 +261,376 @@ _arb_poly_mul_monic(arb_ptr res, arb_srcptr poly1, long len1,
|
|||
}
|
||||
|
||||
void _arb_poly_inv_series(arb_ptr Qinv,
|
||||
arb_srcptr Q, long Qlen, long len, long prec);
|
||||
arb_srcptr Q, slong Qlen, slong len, slong prec);
|
||||
|
||||
void arb_poly_inv_series(arb_poly_t Qinv, const arb_poly_t Q, long n, long prec);
|
||||
void arb_poly_inv_series(arb_poly_t Qinv, const arb_poly_t Q, slong n, slong prec);
|
||||
|
||||
void _arb_poly_div_series(arb_ptr Q, arb_srcptr A, long Alen,
|
||||
arb_srcptr B, long Blen, long n, long prec);
|
||||
void _arb_poly_div_series(arb_ptr Q, arb_srcptr A, slong Alen,
|
||||
arb_srcptr B, slong Blen, slong n, slong prec);
|
||||
|
||||
void arb_poly_div_series(arb_poly_t Q, const arb_poly_t A, const arb_poly_t B, long n, long prec);
|
||||
void arb_poly_div_series(arb_poly_t Q, const arb_poly_t A, const arb_poly_t B, slong n, slong prec);
|
||||
|
||||
void
|
||||
_arb_poly_div(arb_ptr Q,
|
||||
arb_srcptr A, long lenA,
|
||||
arb_srcptr B, long lenB, long prec);
|
||||
arb_srcptr A, slong lenA,
|
||||
arb_srcptr B, slong lenB, slong prec);
|
||||
|
||||
void _arb_poly_divrem(arb_ptr Q, arb_ptr R,
|
||||
arb_srcptr A, long lenA,
|
||||
arb_srcptr B, long lenB, long prec);
|
||||
arb_srcptr A, slong lenA,
|
||||
arb_srcptr B, slong lenB, slong prec);
|
||||
|
||||
void _arb_poly_rem(arb_ptr R,
|
||||
arb_srcptr A, long lenA,
|
||||
arb_srcptr B, long lenB, long prec);
|
||||
arb_srcptr A, slong lenA,
|
||||
arb_srcptr B, slong lenB, slong prec);
|
||||
|
||||
int arb_poly_divrem(arb_poly_t Q, arb_poly_t R,
|
||||
const arb_poly_t A, const arb_poly_t B, long prec);
|
||||
const arb_poly_t A, const arb_poly_t B, slong prec);
|
||||
|
||||
void _arb_poly_div_root(arb_ptr Q, arb_t R, arb_srcptr A,
|
||||
long len, const arb_t c, long prec);
|
||||
slong len, const arb_t c, slong prec);
|
||||
|
||||
/* Product trees */
|
||||
|
||||
void _arb_poly_product_roots(arb_ptr poly, arb_srcptr xs, long n, long prec);
|
||||
void _arb_poly_product_roots(arb_ptr poly, arb_srcptr xs, slong n, slong prec);
|
||||
|
||||
void arb_poly_product_roots(arb_poly_t poly, arb_srcptr xs, long n, long prec);
|
||||
void arb_poly_product_roots(arb_poly_t poly, arb_srcptr xs, slong n, slong prec);
|
||||
|
||||
arb_ptr * _arb_poly_tree_alloc(long len);
|
||||
arb_ptr * _arb_poly_tree_alloc(slong len);
|
||||
|
||||
void _arb_poly_tree_free(arb_ptr * tree, long len);
|
||||
void _arb_poly_tree_free(arb_ptr * tree, slong len);
|
||||
|
||||
void _arb_poly_tree_build(arb_ptr * tree, arb_srcptr roots, long len, long prec);
|
||||
void _arb_poly_tree_build(arb_ptr * tree, arb_srcptr roots, slong len, slong prec);
|
||||
|
||||
/* Composition */
|
||||
|
||||
void _arb_poly_compose(arb_ptr res,
|
||||
arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long prec);
|
||||
arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong prec);
|
||||
|
||||
void arb_poly_compose(arb_poly_t res,
|
||||
const arb_poly_t poly1, const arb_poly_t poly2, long prec);
|
||||
const arb_poly_t poly1, const arb_poly_t poly2, slong prec);
|
||||
|
||||
void _arb_poly_compose_horner(arb_ptr res,
|
||||
arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long prec);
|
||||
arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong prec);
|
||||
|
||||
void arb_poly_compose_horner(arb_poly_t res,
|
||||
const arb_poly_t poly1, const arb_poly_t poly2, long prec);
|
||||
const arb_poly_t poly1, const arb_poly_t poly2, slong prec);
|
||||
|
||||
void _arb_poly_compose_divconquer(arb_ptr res,
|
||||
arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long prec);
|
||||
arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong prec);
|
||||
|
||||
void arb_poly_compose_divconquer(arb_poly_t res,
|
||||
const arb_poly_t poly1, const arb_poly_t poly2, long prec);
|
||||
const arb_poly_t poly1, const arb_poly_t poly2, slong prec);
|
||||
|
||||
void _arb_poly_compose_series_horner(arb_ptr res, arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long n, long prec);
|
||||
void _arb_poly_compose_series_horner(arb_ptr res, arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong n, slong prec);
|
||||
|
||||
void arb_poly_compose_series_horner(arb_poly_t res,
|
||||
const arb_poly_t poly1,
|
||||
const arb_poly_t poly2, long n, long prec);
|
||||
const arb_poly_t poly2, slong n, slong prec);
|
||||
|
||||
void _arb_poly_compose_series(arb_ptr res, arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long n, long prec);
|
||||
void _arb_poly_compose_series(arb_ptr res, arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong n, slong prec);
|
||||
|
||||
void arb_poly_compose_series(arb_poly_t res,
|
||||
const arb_poly_t poly1,
|
||||
const arb_poly_t poly2, long n, long prec);
|
||||
const arb_poly_t poly2, slong n, slong prec);
|
||||
|
||||
/* Reversion */
|
||||
|
||||
void _arb_poly_revert_series_lagrange(arb_ptr Qinv, arb_srcptr Q, long Qlen, long n, long prec);
|
||||
void arb_poly_revert_series_lagrange(arb_poly_t Qinv, const arb_poly_t Q, long n, long prec);
|
||||
void _arb_poly_revert_series_lagrange(arb_ptr Qinv, arb_srcptr Q, slong Qlen, slong n, slong prec);
|
||||
void arb_poly_revert_series_lagrange(arb_poly_t Qinv, const arb_poly_t Q, slong n, slong prec);
|
||||
|
||||
void _arb_poly_revert_series_newton(arb_ptr Qinv, arb_srcptr Q, long Qlen, long n, long prec);
|
||||
void arb_poly_revert_series_newton(arb_poly_t Qinv, const arb_poly_t Q, long n, long prec);
|
||||
void _arb_poly_revert_series_newton(arb_ptr Qinv, arb_srcptr Q, slong Qlen, slong n, slong prec);
|
||||
void arb_poly_revert_series_newton(arb_poly_t Qinv, const arb_poly_t Q, slong n, slong prec);
|
||||
|
||||
void _arb_poly_revert_series_lagrange_fast(arb_ptr Qinv, arb_srcptr Q, long Qlen, long n, long prec);
|
||||
void arb_poly_revert_series_lagrange_fast(arb_poly_t Qinv, const arb_poly_t Q, long n, long prec);
|
||||
void _arb_poly_revert_series_lagrange_fast(arb_ptr Qinv, arb_srcptr Q, slong Qlen, slong n, slong prec);
|
||||
void arb_poly_revert_series_lagrange_fast(arb_poly_t Qinv, const arb_poly_t Q, slong n, slong prec);
|
||||
|
||||
void _arb_poly_revert_series(arb_ptr Qinv, arb_srcptr Q, long Qlen, long n, long prec);
|
||||
void arb_poly_revert_series(arb_poly_t Qinv, const arb_poly_t Q, long n, long prec);
|
||||
void _arb_poly_revert_series(arb_ptr Qinv, arb_srcptr Q, slong Qlen, slong n, slong prec);
|
||||
void arb_poly_revert_series(arb_poly_t Qinv, const arb_poly_t Q, slong n, slong prec);
|
||||
|
||||
/* Evaluation and interpolation */
|
||||
|
||||
void _arb_poly_evaluate_horner(arb_t res, arb_srcptr f, long len, const arb_t a, long prec);
|
||||
void arb_poly_evaluate_horner(arb_t res, const arb_poly_t f, const arb_t a, long prec);
|
||||
void _arb_poly_evaluate_horner(arb_t res, arb_srcptr f, slong len, const arb_t a, slong prec);
|
||||
void arb_poly_evaluate_horner(arb_t res, const arb_poly_t f, const arb_t a, slong prec);
|
||||
|
||||
void _arb_poly_evaluate_rectangular(arb_t y, arb_srcptr poly, long len, const arb_t x, long prec);
|
||||
void arb_poly_evaluate_rectangular(arb_t res, const arb_poly_t f, const arb_t a, long prec);
|
||||
void _arb_poly_evaluate_rectangular(arb_t y, arb_srcptr poly, slong len, const arb_t x, slong prec);
|
||||
void arb_poly_evaluate_rectangular(arb_t res, const arb_poly_t f, const arb_t a, slong prec);
|
||||
|
||||
void _arb_poly_evaluate(arb_t res, arb_srcptr f, long len, const arb_t a, long prec);
|
||||
void arb_poly_evaluate(arb_t res, const arb_poly_t f, const arb_t a, long prec);
|
||||
void _arb_poly_evaluate(arb_t res, arb_srcptr f, slong len, const arb_t a, slong prec);
|
||||
void arb_poly_evaluate(arb_t res, const arb_poly_t f, const arb_t a, slong prec);
|
||||
|
||||
void _arb_poly_evaluate2_horner(arb_t y, arb_t z, arb_srcptr f, long len, const arb_t x, long prec);
|
||||
void arb_poly_evaluate2_horner(arb_t y, arb_t z, const arb_poly_t f, const arb_t x, long prec);
|
||||
void _arb_poly_evaluate2_horner(arb_t y, arb_t z, arb_srcptr f, slong len, const arb_t x, slong prec);
|
||||
void arb_poly_evaluate2_horner(arb_t y, arb_t z, const arb_poly_t f, const arb_t x, slong prec);
|
||||
|
||||
void _arb_poly_evaluate2_rectangular(arb_t y, arb_t z, arb_srcptr f, long len, const arb_t x, long prec);
|
||||
void arb_poly_evaluate2_rectangular(arb_t y, arb_t z, const arb_poly_t f, const arb_t x, long prec);
|
||||
void _arb_poly_evaluate2_rectangular(arb_t y, arb_t z, arb_srcptr f, slong len, const arb_t x, slong prec);
|
||||
void arb_poly_evaluate2_rectangular(arb_t y, arb_t z, const arb_poly_t f, const arb_t x, slong prec);
|
||||
|
||||
void _arb_poly_evaluate2(arb_t y, arb_t z, arb_srcptr f, long len, const arb_t x, long prec);
|
||||
void arb_poly_evaluate2(arb_t y, arb_t z, const arb_poly_t f, const arb_t x, long prec);
|
||||
void _arb_poly_evaluate2(arb_t y, arb_t z, arb_srcptr f, slong len, const arb_t x, slong prec);
|
||||
void arb_poly_evaluate2(arb_t y, arb_t z, const arb_poly_t f, const arb_t x, slong prec);
|
||||
|
||||
|
||||
|
||||
|
||||
void _arb_poly_evaluate_vec_iter(arb_ptr ys, arb_srcptr poly, long plen,
|
||||
arb_srcptr xs, long n, long prec);
|
||||
void _arb_poly_evaluate_vec_iter(arb_ptr ys, arb_srcptr poly, slong plen,
|
||||
arb_srcptr xs, slong n, slong prec);
|
||||
|
||||
void arb_poly_evaluate_vec_iter(arb_ptr ys,
|
||||
const arb_poly_t poly, arb_srcptr xs, long n, long prec);
|
||||
const arb_poly_t poly, arb_srcptr xs, slong n, slong prec);
|
||||
|
||||
void _arb_poly_evaluate_vec_fast_precomp(arb_ptr vs, arb_srcptr poly,
|
||||
long plen, arb_ptr * tree, long len, long prec);
|
||||
slong plen, arb_ptr * tree, slong len, slong prec);
|
||||
|
||||
void _arb_poly_evaluate_vec_fast(arb_ptr ys, arb_srcptr poly, long plen,
|
||||
arb_srcptr xs, long n, long prec);
|
||||
void _arb_poly_evaluate_vec_fast(arb_ptr ys, arb_srcptr poly, slong plen,
|
||||
arb_srcptr xs, slong n, slong prec);
|
||||
|
||||
void arb_poly_evaluate_vec_fast(arb_ptr ys,
|
||||
const arb_poly_t poly, arb_srcptr xs, long n, long prec);
|
||||
const arb_poly_t poly, arb_srcptr xs, slong n, slong prec);
|
||||
|
||||
void _arb_poly_interpolate_newton(arb_ptr poly, arb_srcptr xs,
|
||||
arb_srcptr ys, long n, long prec);
|
||||
arb_srcptr ys, slong n, slong prec);
|
||||
|
||||
void arb_poly_interpolate_newton(arb_poly_t poly,
|
||||
arb_srcptr xs, arb_srcptr ys, long n, long prec);
|
||||
arb_srcptr xs, arb_srcptr ys, slong n, slong prec);
|
||||
|
||||
void
|
||||
_arb_poly_interpolate_barycentric(arb_ptr poly,
|
||||
arb_srcptr xs, arb_srcptr ys, long n, long prec);
|
||||
arb_srcptr xs, arb_srcptr ys, slong n, slong prec);
|
||||
|
||||
void arb_poly_interpolate_barycentric(arb_poly_t poly,
|
||||
arb_srcptr xs, arb_srcptr ys, long n, long prec);
|
||||
arb_srcptr xs, arb_srcptr ys, slong n, slong prec);
|
||||
|
||||
void _arb_poly_interpolation_weights(arb_ptr w,
|
||||
arb_ptr * tree, long len, long prec);
|
||||
arb_ptr * tree, slong len, slong prec);
|
||||
|
||||
void _arb_poly_interpolate_fast_precomp(arb_ptr poly,
|
||||
arb_srcptr ys, arb_ptr * tree, arb_srcptr weights,
|
||||
long len, long prec);
|
||||
slong len, slong prec);
|
||||
|
||||
void _arb_poly_interpolate_fast(arb_ptr poly,
|
||||
arb_srcptr xs, arb_srcptr ys, long len, long prec);
|
||||
arb_srcptr xs, arb_srcptr ys, slong len, slong prec);
|
||||
|
||||
void arb_poly_interpolate_fast(arb_poly_t poly,
|
||||
arb_srcptr xs, arb_srcptr ys, long n, long prec);
|
||||
arb_srcptr xs, arb_srcptr ys, slong n, slong prec);
|
||||
|
||||
/* Derivative and integral */
|
||||
|
||||
void _arb_poly_derivative(arb_ptr res, arb_srcptr poly, long len, long prec);
|
||||
void _arb_poly_derivative(arb_ptr res, arb_srcptr poly, slong len, slong prec);
|
||||
|
||||
void arb_poly_derivative(arb_poly_t res, const arb_poly_t poly, long prec);
|
||||
void arb_poly_derivative(arb_poly_t res, const arb_poly_t poly, slong prec);
|
||||
|
||||
void _arb_poly_integral(arb_ptr res, arb_srcptr poly, long len, long prec);
|
||||
void _arb_poly_integral(arb_ptr res, arb_srcptr poly, slong len, slong prec);
|
||||
|
||||
void arb_poly_integral(arb_poly_t res, const arb_poly_t poly, long prec);
|
||||
void arb_poly_integral(arb_poly_t res, const arb_poly_t poly, slong prec);
|
||||
|
||||
/* Transforms */
|
||||
|
||||
void arb_poly_borel_transform(arb_poly_t res, const arb_poly_t poly, long prec);
|
||||
void arb_poly_borel_transform(arb_poly_t res, const arb_poly_t poly, slong prec);
|
||||
|
||||
void _arb_poly_borel_transform(arb_ptr res, arb_srcptr poly, long len, long prec);
|
||||
void _arb_poly_borel_transform(arb_ptr res, arb_srcptr poly, slong len, slong prec);
|
||||
|
||||
void arb_poly_inv_borel_transform(arb_poly_t res, const arb_poly_t poly, long prec);
|
||||
void arb_poly_inv_borel_transform(arb_poly_t res, const arb_poly_t poly, slong prec);
|
||||
|
||||
void _arb_poly_inv_borel_transform(arb_ptr res, arb_srcptr poly, long len, long prec);
|
||||
void _arb_poly_inv_borel_transform(arb_ptr res, arb_srcptr poly, slong len, slong prec);
|
||||
|
||||
void _arb_poly_binomial_transform_basecase(arb_ptr b, arb_srcptr a, long alen, long len, long prec);
|
||||
void _arb_poly_binomial_transform_basecase(arb_ptr b, arb_srcptr a, slong alen, slong len, slong prec);
|
||||
|
||||
void arb_poly_binomial_transform_basecase(arb_poly_t b, const arb_poly_t a, long len, long prec);
|
||||
void arb_poly_binomial_transform_basecase(arb_poly_t b, const arb_poly_t a, slong len, slong prec);
|
||||
|
||||
void _arb_poly_binomial_transform_convolution(arb_ptr b, arb_srcptr a, long alen, long len, long prec);
|
||||
void _arb_poly_binomial_transform_convolution(arb_ptr b, arb_srcptr a, slong alen, slong len, slong prec);
|
||||
|
||||
void arb_poly_binomial_transform_convolution(arb_poly_t b, const arb_poly_t a, long len, long prec);
|
||||
void arb_poly_binomial_transform_convolution(arb_poly_t b, const arb_poly_t a, slong len, slong prec);
|
||||
|
||||
void _arb_poly_binomial_transform(arb_ptr b, arb_srcptr a, long alen, long len, long prec);
|
||||
void _arb_poly_binomial_transform(arb_ptr b, arb_srcptr a, slong alen, slong len, slong prec);
|
||||
|
||||
void arb_poly_binomial_transform(arb_poly_t b, const arb_poly_t a, long len, long prec);
|
||||
void arb_poly_binomial_transform(arb_poly_t b, const arb_poly_t a, slong len, slong prec);
|
||||
|
||||
/* Special functions */
|
||||
|
||||
void _arb_poly_pow_ui_trunc_binexp(arb_ptr res,
|
||||
arb_srcptr f, long flen, ulong exp, long len, long prec);
|
||||
arb_srcptr f, slong flen, ulong exp, slong len, slong prec);
|
||||
|
||||
void arb_poly_pow_ui_trunc_binexp(arb_poly_t res,
|
||||
const arb_poly_t poly, ulong exp, long len, long prec);
|
||||
const arb_poly_t poly, ulong exp, slong len, slong prec);
|
||||
|
||||
void _arb_poly_pow_ui(arb_ptr res, arb_srcptr f, long flen, ulong exp, long prec);
|
||||
void _arb_poly_pow_ui(arb_ptr res, arb_srcptr f, slong flen, ulong exp, slong prec);
|
||||
|
||||
void arb_poly_pow_ui(arb_poly_t res, const arb_poly_t poly, ulong exp, long prec);
|
||||
void arb_poly_pow_ui(arb_poly_t res, const arb_poly_t poly, ulong exp, slong prec);
|
||||
|
||||
void _arb_poly_pow_series(arb_ptr h,
|
||||
arb_srcptr f, long flen,
|
||||
arb_srcptr g, long glen, long len, long prec);
|
||||
arb_srcptr f, slong flen,
|
||||
arb_srcptr g, slong glen, slong len, slong prec);
|
||||
|
||||
void arb_poly_pow_series(arb_poly_t h,
|
||||
const arb_poly_t f, const arb_poly_t g, long len, long prec);
|
||||
const arb_poly_t f, const arb_poly_t g, slong len, slong prec);
|
||||
|
||||
void _arb_poly_pow_arb_series(arb_ptr h,
|
||||
arb_srcptr f, long flen, const arb_t g, long len, long prec);
|
||||
arb_srcptr f, slong flen, const arb_t g, slong len, slong prec);
|
||||
|
||||
void arb_poly_pow_arb_series(arb_poly_t h,
|
||||
const arb_poly_t f, const arb_t g, long len, long prec);
|
||||
const arb_poly_t f, const arb_t g, slong len, slong prec);
|
||||
|
||||
void _arb_poly_binomial_pow_arb_series(arb_ptr h, arb_srcptr f, long flen, const arb_t g, long len, long prec);
|
||||
void _arb_poly_binomial_pow_arb_series(arb_ptr h, arb_srcptr f, slong flen, const arb_t g, slong len, slong prec);
|
||||
|
||||
void _arb_poly_rsqrt_series(arb_ptr g,
|
||||
arb_srcptr h, long hlen, long len, long prec);
|
||||
arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
|
||||
void arb_poly_rsqrt_series(arb_poly_t g, const arb_poly_t h, long n, long prec);
|
||||
void arb_poly_rsqrt_series(arb_poly_t g, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_sqrt_series(arb_ptr g,
|
||||
arb_srcptr h, long hlen, long len, long prec);
|
||||
arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
|
||||
void arb_poly_sqrt_series(arb_poly_t g, const arb_poly_t h, long n, long prec);
|
||||
void arb_poly_sqrt_series(arb_poly_t g, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_log_series(arb_ptr res, arb_srcptr f, long flen, long n, long prec);
|
||||
void _arb_poly_log_series(arb_ptr res, arb_srcptr f, slong flen, slong n, slong prec);
|
||||
|
||||
void arb_poly_log_series(arb_poly_t res, const arb_poly_t f, long n, long prec);
|
||||
void arb_poly_log_series(arb_poly_t res, const arb_poly_t f, slong n, slong prec);
|
||||
|
||||
void _arb_poly_atan_series(arb_ptr res, arb_srcptr f, long flen, long n, long prec);
|
||||
void _arb_poly_atan_series(arb_ptr res, arb_srcptr f, slong flen, slong n, slong prec);
|
||||
|
||||
void arb_poly_atan_series(arb_poly_t res, const arb_poly_t f, long n, long prec);
|
||||
void arb_poly_atan_series(arb_poly_t res, const arb_poly_t f, slong n, slong prec);
|
||||
|
||||
void _arb_poly_asin_series(arb_ptr res, arb_srcptr f, long flen, long n, long prec);
|
||||
void _arb_poly_asin_series(arb_ptr res, arb_srcptr f, slong flen, slong n, slong prec);
|
||||
|
||||
void arb_poly_asin_series(arb_poly_t res, const arb_poly_t f, long n, long prec);
|
||||
void arb_poly_asin_series(arb_poly_t res, const arb_poly_t f, slong n, slong prec);
|
||||
|
||||
void _arb_poly_acos_series(arb_ptr res, arb_srcptr f, long flen, long n, long prec);
|
||||
void _arb_poly_acos_series(arb_ptr res, arb_srcptr f, slong flen, slong n, slong prec);
|
||||
|
||||
void arb_poly_acos_series(arb_poly_t res, const arb_poly_t f, long n, long prec);
|
||||
void arb_poly_acos_series(arb_poly_t res, const arb_poly_t f, slong n, slong prec);
|
||||
|
||||
void _arb_poly_exp_series_basecase(arb_ptr f,
|
||||
arb_srcptr h, long hlen, long n, long prec);
|
||||
arb_srcptr h, slong hlen, slong n, slong prec);
|
||||
|
||||
void arb_poly_exp_series_basecase(arb_poly_t f, const arb_poly_t h, long n, long prec);
|
||||
void arb_poly_exp_series_basecase(arb_poly_t f, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_exp_series(arb_ptr f, arb_srcptr h, long hlen, long n, long prec);
|
||||
void _arb_poly_exp_series(arb_ptr f, arb_srcptr h, slong hlen, slong n, slong prec);
|
||||
|
||||
void arb_poly_exp_series(arb_poly_t f, const arb_poly_t h, long n, long prec);
|
||||
void arb_poly_exp_series(arb_poly_t f, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_sin_cos_series_basecase(arb_ptr s,
|
||||
arb_ptr c, arb_srcptr h, long hlen, long n, long prec, int times_pi);
|
||||
arb_ptr c, arb_srcptr h, slong hlen, slong n, slong prec, int times_pi);
|
||||
|
||||
void arb_poly_sin_cos_series_basecase(arb_poly_t s, arb_poly_t c,
|
||||
const arb_poly_t h, long n, long prec, int times_pi);
|
||||
const arb_poly_t h, slong n, slong prec, int times_pi);
|
||||
|
||||
void _arb_poly_sin_cos_series_tangent(arb_ptr s, arb_ptr c,
|
||||
const arb_srcptr h, long hlen, long len, long prec, int times_pi);
|
||||
const arb_srcptr h, slong hlen, slong len, slong prec, int times_pi);
|
||||
|
||||
void arb_poly_sin_cos_series_tangent(arb_poly_t s, arb_poly_t c,
|
||||
const arb_poly_t h, long n, long prec, int times_pi);
|
||||
const arb_poly_t h, slong n, slong prec, int times_pi);
|
||||
|
||||
void _arb_poly_sin_cos_series(arb_ptr s, arb_ptr c,
|
||||
const arb_srcptr h, long hlen, long len, long prec);
|
||||
const arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
|
||||
void arb_poly_sin_cos_series(arb_poly_t s, arb_poly_t c,
|
||||
const arb_poly_t h, long n, long prec);
|
||||
const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_sin_cos_pi_series(arb_ptr s, arb_ptr c,
|
||||
const arb_srcptr h, long hlen, long len, long prec);
|
||||
const arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
|
||||
void arb_poly_sin_cos_pi_series(arb_poly_t s, arb_poly_t c,
|
||||
const arb_poly_t h, long n, long prec);
|
||||
const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_sin_series(arb_ptr g, arb_srcptr h, long hlen, long n, long prec);
|
||||
void _arb_poly_sin_series(arb_ptr g, arb_srcptr h, slong hlen, slong n, slong prec);
|
||||
|
||||
void arb_poly_sin_series(arb_poly_t g, const arb_poly_t h, long n, long prec);
|
||||
void arb_poly_sin_series(arb_poly_t g, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_cos_series(arb_ptr g, arb_srcptr h, long hlen, long n, long prec);
|
||||
void _arb_poly_cos_series(arb_ptr g, arb_srcptr h, slong hlen, slong n, slong prec);
|
||||
|
||||
void arb_poly_cos_series(arb_poly_t g, const arb_poly_t h, long n, long prec);
|
||||
void arb_poly_cos_series(arb_poly_t g, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_sin_pi_series(arb_ptr g, arb_srcptr h, long hlen, long n, long prec);
|
||||
void _arb_poly_sin_pi_series(arb_ptr g, arb_srcptr h, slong hlen, slong n, slong prec);
|
||||
|
||||
void arb_poly_sin_pi_series(arb_poly_t g, const arb_poly_t h, long n, long prec);
|
||||
void arb_poly_sin_pi_series(arb_poly_t g, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_cos_pi_series(arb_ptr g, arb_srcptr h, long hlen, long n, long prec);
|
||||
void _arb_poly_cos_pi_series(arb_ptr g, arb_srcptr h, slong hlen, slong n, slong prec);
|
||||
|
||||
void arb_poly_cos_pi_series(arb_poly_t g, const arb_poly_t h, long n, long prec);
|
||||
void arb_poly_cos_pi_series(arb_poly_t g, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_cot_pi_series(arb_ptr g, arb_srcptr h, long hlen, long n, long prec);
|
||||
void _arb_poly_cot_pi_series(arb_ptr g, arb_srcptr h, slong hlen, slong n, slong prec);
|
||||
|
||||
void arb_poly_cot_pi_series(arb_poly_t g, const arb_poly_t h, long n, long prec);
|
||||
void arb_poly_cot_pi_series(arb_poly_t g, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_tan_series(arb_ptr g, arb_srcptr h, long hlen, long len, long prec);
|
||||
void _arb_poly_tan_series(arb_ptr g, arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
|
||||
void arb_poly_tan_series(arb_poly_t g, const arb_poly_t h, long n, long prec);
|
||||
void arb_poly_tan_series(arb_poly_t g, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_compose_series_brent_kung(arb_ptr res, arb_srcptr poly1, long len1,
|
||||
arb_srcptr poly2, long len2, long n, long prec);
|
||||
void _arb_poly_compose_series_brent_kung(arb_ptr res, arb_srcptr poly1, slong len1,
|
||||
arb_srcptr poly2, slong len2, slong n, slong prec);
|
||||
|
||||
void arb_poly_compose_series_brent_kung(arb_poly_t res,
|
||||
const arb_poly_t poly1,
|
||||
const arb_poly_t poly2, long n, long prec);
|
||||
const arb_poly_t poly2, slong n, slong prec);
|
||||
|
||||
|
||||
void _arb_poly_evaluate_acb_horner(acb_t res, arb_srcptr f, long len, const acb_t x, long prec);
|
||||
void arb_poly_evaluate_acb_horner(acb_t res, const arb_poly_t f, const acb_t a, long prec);
|
||||
void _arb_poly_evaluate_acb_horner(acb_t res, arb_srcptr f, slong len, const acb_t x, slong prec);
|
||||
void arb_poly_evaluate_acb_horner(acb_t res, const arb_poly_t f, const acb_t a, slong prec);
|
||||
|
||||
void _arb_poly_evaluate_acb_rectangular(acb_t y, arb_srcptr poly, long len, const acb_t x, long prec);
|
||||
void arb_poly_evaluate_acb_rectangular(acb_t res, const arb_poly_t f, const acb_t a, long prec);
|
||||
void _arb_poly_evaluate_acb_rectangular(acb_t y, arb_srcptr poly, slong len, const acb_t x, slong prec);
|
||||
void arb_poly_evaluate_acb_rectangular(acb_t res, const arb_poly_t f, const acb_t a, slong prec);
|
||||
|
||||
void _arb_poly_evaluate_acb(acb_t res, arb_srcptr f, long len, const acb_t x, long prec);
|
||||
void arb_poly_evaluate_acb(acb_t res, const arb_poly_t f, const acb_t a, long prec);
|
||||
void _arb_poly_evaluate_acb(acb_t res, arb_srcptr f, slong len, const acb_t x, slong prec);
|
||||
void arb_poly_evaluate_acb(acb_t res, const arb_poly_t f, const acb_t a, slong prec);
|
||||
|
||||
void _arb_poly_evaluate2_acb_horner(acb_t y, acb_t z, arb_srcptr f, long len, const acb_t x, long prec);
|
||||
void arb_poly_evaluate2_acb_horner(acb_t y, acb_t z, const arb_poly_t f, const acb_t x, long prec);
|
||||
void _arb_poly_evaluate2_acb_horner(acb_t y, acb_t z, arb_srcptr f, slong len, const acb_t x, slong prec);
|
||||
void arb_poly_evaluate2_acb_horner(acb_t y, acb_t z, const arb_poly_t f, const acb_t x, slong prec);
|
||||
|
||||
void _arb_poly_evaluate2_acb_rectangular(acb_t y, acb_t z, arb_srcptr f, long len, const acb_t x, long prec);
|
||||
void arb_poly_evaluate2_acb_rectangular(acb_t y, acb_t z, const arb_poly_t f, const acb_t x, long prec);
|
||||
void _arb_poly_evaluate2_acb_rectangular(acb_t y, acb_t z, arb_srcptr f, slong len, const acb_t x, slong prec);
|
||||
void arb_poly_evaluate2_acb_rectangular(acb_t y, acb_t z, const arb_poly_t f, const acb_t x, slong prec);
|
||||
|
||||
void _arb_poly_evaluate2_acb(acb_t y, acb_t z, arb_srcptr f, long len, const acb_t x, long prec);
|
||||
void arb_poly_evaluate2_acb(acb_t y, acb_t z, const arb_poly_t f, const acb_t x, long prec);
|
||||
void _arb_poly_evaluate2_acb(acb_t y, acb_t z, arb_srcptr f, slong len, const acb_t x, slong prec);
|
||||
void arb_poly_evaluate2_acb(acb_t y, acb_t z, const arb_poly_t f, const acb_t x, slong prec);
|
||||
|
||||
void _arb_poly_gamma_series(arb_ptr res, arb_srcptr h, long hlen, long len, long prec);
|
||||
void arb_poly_gamma_series(arb_poly_t res, const arb_poly_t f, long n, long prec);
|
||||
void _arb_poly_gamma_series(arb_ptr res, arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
void arb_poly_gamma_series(arb_poly_t res, const arb_poly_t f, slong n, slong prec);
|
||||
|
||||
void _arb_poly_rgamma_series(arb_ptr res, arb_srcptr h, long hlen, long len, long prec);
|
||||
void arb_poly_rgamma_series(arb_poly_t res, const arb_poly_t f, long n, long prec);
|
||||
void _arb_poly_rgamma_series(arb_ptr res, arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
void arb_poly_rgamma_series(arb_poly_t res, const arb_poly_t f, slong n, slong prec);
|
||||
|
||||
void _arb_poly_lgamma_series(arb_ptr res, arb_srcptr h, long hlen, long len, long prec);
|
||||
void arb_poly_lgamma_series(arb_poly_t res, const arb_poly_t f, long n, long prec);
|
||||
void _arb_poly_lgamma_series(arb_ptr res, arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
void arb_poly_lgamma_series(arb_poly_t res, const arb_poly_t f, slong n, slong prec);
|
||||
|
||||
void _arb_poly_digamma_series(arb_ptr res, arb_srcptr h, long hlen, long len, long prec);
|
||||
void arb_poly_digamma_series(arb_poly_t res, const arb_poly_t f, long n, long prec);
|
||||
void _arb_poly_digamma_series(arb_ptr res, arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
void arb_poly_digamma_series(arb_poly_t res, const arb_poly_t f, slong n, slong prec);
|
||||
|
||||
void _arb_poly_rising_ui_series(arb_ptr res, arb_srcptr f, long flen, ulong r, long trunc, long prec);
|
||||
void arb_poly_rising_ui_series(arb_poly_t res, const arb_poly_t f, ulong r, long trunc, long prec);
|
||||
void _arb_poly_rising_ui_series(arb_ptr res, arb_srcptr f, slong flen, ulong r, slong trunc, slong prec);
|
||||
void arb_poly_rising_ui_series(arb_poly_t res, const arb_poly_t f, ulong r, slong trunc, slong prec);
|
||||
|
||||
void _arb_poly_zeta_series(arb_ptr res, arb_srcptr h, long hlen, const arb_t a, int deflate, long len, long prec);
|
||||
void arb_poly_zeta_series(arb_poly_t res, const arb_poly_t f, const arb_t a, int deflate, long n, long prec);
|
||||
void _arb_poly_zeta_series(arb_ptr res, arb_srcptr h, slong hlen, const arb_t a, int deflate, slong len, slong prec);
|
||||
void arb_poly_zeta_series(arb_poly_t res, const arb_poly_t f, const arb_t a, int deflate, slong n, slong prec);
|
||||
|
||||
void _arb_poly_riemann_siegel_theta_series(arb_ptr res, arb_srcptr h, long hlen, long len, long prec);
|
||||
void arb_poly_riemann_siegel_theta_series(arb_poly_t res, const arb_poly_t h, long n, long prec);
|
||||
void _arb_poly_riemann_siegel_theta_series(arb_ptr res, arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
void arb_poly_riemann_siegel_theta_series(arb_poly_t res, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
void _arb_poly_riemann_siegel_z_series(arb_ptr res, arb_srcptr h, long hlen, long len, long prec);
|
||||
void arb_poly_riemann_siegel_z_series(arb_poly_t res, const arb_poly_t h, long n, long prec);
|
||||
void _arb_poly_riemann_siegel_z_series(arb_ptr res, arb_srcptr h, slong hlen, slong len, slong prec);
|
||||
void arb_poly_riemann_siegel_z_series(arb_poly_t res, const arb_poly_t h, slong n, slong prec);
|
||||
|
||||
long _arb_poly_swinnerton_dyer_ui_prec(ulong n);
|
||||
void _arb_poly_swinnerton_dyer_ui(arb_ptr T, ulong n, long trunc, long prec);
|
||||
void arb_poly_swinnerton_dyer_ui(arb_poly_t poly, ulong n, long prec);
|
||||
void _arb_poly_swinnerton_dyer_ui(arb_ptr T, ulong n, slong trunc, slong prec);
|
||||
void arb_poly_swinnerton_dyer_ui(arb_poly_t poly, ulong n, slong prec);
|
||||
|
||||
/* Root-finding */
|
||||
|
||||
void _arb_poly_newton_convergence_factor(arf_t convergence_factor,
|
||||
arb_srcptr poly, long len,
|
||||
const arb_t convergence_interval, long prec);
|
||||
arb_srcptr poly, slong len,
|
||||
const arb_t convergence_interval, slong prec);
|
||||
|
||||
int _arb_poly_newton_step(arb_t xnew, arb_srcptr poly, long len,
|
||||
int _arb_poly_newton_step(arb_t xnew, arb_srcptr poly, slong len,
|
||||
const arb_t x,
|
||||
const arb_t convergence_interval,
|
||||
const arf_t convergence_factor, long prec);
|
||||
const arf_t convergence_factor, slong prec);
|
||||
|
||||
void _arb_poly_newton_refine_root(arb_t r, arb_srcptr poly,
|
||||
long len, const arb_t start,
|
||||
slong len, const arb_t start,
|
||||
const arb_t convergence_interval,
|
||||
const arf_t convergence_factor,
|
||||
long eval_extra_prec,
|
||||
long prec);
|
||||
slong eval_extra_prec,
|
||||
slong prec);
|
||||
|
||||
void _arb_poly_root_bound_fujiwara(mag_t bound, arb_srcptr poly, long len);
|
||||
void _arb_poly_root_bound_fujiwara(mag_t bound, arb_srcptr poly, slong len);
|
||||
|
||||
void arb_poly_root_bound_fujiwara(mag_t bound, arb_poly_t poly);
|
||||
|
||||
|
@ -653,7 +653,7 @@ n_zerobits(mp_limb_t e)
|
|||
}
|
||||
|
||||
ARB_POLY_INLINE long
|
||||
poly_pow_length(long poly_len, ulong exp, long trunc)
|
||||
poly_pow_length(slong poly_len, ulong exp, slong trunc)
|
||||
{
|
||||
mp_limb_t hi, lo;
|
||||
umul_ppmm(hi, lo, poly_len - 1, exp);
|
||||
|
@ -667,13 +667,13 @@ poly_pow_length(long poly_len, ulong exp, long trunc)
|
|||
|
||||
#define NEWTON_INIT(from, to) \
|
||||
{ \
|
||||
long __steps[FLINT_BITS], __i, __from, __to; \
|
||||
slong __steps[FLINT_BITS], __i, __from, __to; \
|
||||
__steps[__i = 0] = __to = (to); \
|
||||
__from = (from); \
|
||||
while (__to > __from) \
|
||||
__steps[++__i] = (__to = (__to + 1) / 2); \
|
||||
|
||||
#define NEWTON_BASECASE(bc_to) { long bc_to = __to;
|
||||
#define NEWTON_BASECASE(bc_to) { slong bc_to = __to;
|
||||
|
||||
#define NEWTON_END_BASECASE }
|
||||
|
||||
|
@ -681,8 +681,8 @@ poly_pow_length(long poly_len, ulong exp, long trunc)
|
|||
{ \
|
||||
for (__i--; __i >= 0; __i--) \
|
||||
{ \
|
||||
long step_from = __steps[__i+1]; \
|
||||
long step_to = __steps[__i]; \
|
||||
slong step_from = __steps[__i+1]; \
|
||||
slong step_to = __steps[__i]; \
|
||||
|
||||
#define NEWTON_END_LOOP }}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue