📄 gmpxx.h
字号:
}
}
static void eval(mpz_ptr z, mpz_srcptr w, double d)
{
mpz_t temp;
mpz_init_set_d(temp, d);
mpz_mul(z, w, temp);
mpz_clear(temp);
}
static void eval(mpz_ptr z, double d, mpz_srcptr w)
{
mpz_t temp;
mpz_init_set_d(temp, d);
mpz_mul(z, temp, w);
mpz_clear(temp);
}
static void eval(mpq_ptr q, mpq_srcptr r, mpq_srcptr s)
{ mpq_mul(q, r, s); }
static void eval(mpq_ptr q, mpq_srcptr r, unsigned long int l)
{
mpq_t temp;
mpq_init(temp);
mpq_set_ui(temp, l, 1);
mpq_mul(q, r, temp);
mpq_clear(temp);
}
static void eval(mpq_ptr q, unsigned long int l, mpq_srcptr r)
{
mpq_t temp;
mpq_init(temp);
mpq_set_ui(temp, l, 1);
mpq_mul(q, temp, r);
mpq_clear(temp);
}
static void eval(mpq_ptr q, mpq_srcptr r, signed long int l)
{
mpq_t temp;
mpq_init(temp);
mpq_set_si(temp, l, 1);
mpq_mul(q, r, temp);
mpq_clear(temp);
}
static void eval(mpq_ptr q, signed long int l, mpq_srcptr r)
{
mpq_t temp;
mpq_init(temp);
mpq_set_si(temp, l, 1);
mpq_mul(q, temp, r);
mpq_clear(temp);
}
static void eval(mpq_ptr q, mpq_srcptr r, double d)
{
mpq_t temp;
mpq_init(temp);
mpq_set_d(temp, d);
mpq_mul(q, r, temp);
mpq_clear(temp);
}
static void eval(mpq_ptr q, double d, mpq_srcptr r)
{
mpq_t temp;
mpq_init(temp);
mpq_set_d(temp, d);
mpq_mul(q, temp, r);
mpq_clear(temp);
}
static void eval(mpf_ptr f, mpf_srcptr g, mpf_srcptr h)
{ mpf_mul(f, g, h); }
static void eval(mpf_ptr f, mpf_srcptr g, unsigned long int l)
{ mpf_mul_ui(f, g, l); }
static void eval(mpf_ptr f, unsigned long int l, mpf_srcptr g)
{ mpf_mul_ui(f, g, l); }
static void eval(mpf_ptr f, mpf_srcptr g, signed long int l)
{
if (l >= 0)
mpf_mul_ui(f, g, l);
else
{
mpf_mul_ui(f, g, -l);
mpf_neg(f, f);
}
}
static void eval(mpf_ptr f, signed long int l, mpf_srcptr g)
{
if (l >= 0)
mpf_mul_ui(f, g, l);
else
{
mpf_mul_ui(f, g, -l);
mpf_neg(f, f);
}
}
static void eval(mpf_ptr f, mpf_srcptr g, double d)
{
mpf_t temp;
mpf_init2(temp, 8*sizeof(double));
mpf_set_d(temp, d);
mpf_mul(f, g, temp);
mpf_clear(temp);
}
static void eval(mpf_ptr f, double d, mpf_srcptr g)
{
mpf_t temp;
mpf_init2(temp, 8*sizeof(double));
mpf_set_d(temp, d);
mpf_mul(f, temp, g);
mpf_clear(temp);
}
#ifdef __MPFR_H
static void eval(mpfr_ptr f, mpfr_srcptr g, mpfr_srcptr h, mp_rnd_t mode)
{ mpfr_mul(f, g, h, mode); }
static void eval(mpfr_ptr f, mpfr_srcptr g, unsigned long int l,
mp_rnd_t mode)
{ mpfr_mul_ui(f, g, l, mode); }
static void eval(mpfr_ptr f, unsigned long int l, mpfr_srcptr g,
mp_rnd_t mode)
{ mpfr_mul_ui(f, g, l, mode); }
static void eval(mpfr_ptr f, mpfr_srcptr g, signed long int l,
mp_rnd_t mode)
{
if (l >= 0)
mpfr_mul_ui(f, g, l, mode);
else
{
mpfr_mul_ui(f, g, -l, mode);
mpfr_neg(f, f, mode);
}
}
static void eval(mpfr_ptr f, signed long int l, mpfr_srcptr g,
mp_rnd_t mode)
{
if (l >= 0)
mpfr_mul_ui(f, g, l, mode);
else
{
mpfr_mul_ui(f, g, -l, mode);
mpfr_neg(f, f, mode);
}
}
static void eval(mpfr_ptr f, mpfr_srcptr g, double d, mp_rnd_t mode)
{
mpfr_t temp;
mpfr_init2(temp, 8*sizeof(double));
mpfr_set_d(temp, d, mode);
mpfr_mul(f, g, temp, mode);
mpfr_clear(temp);
}
static void eval(mpfr_ptr f, double d, mpfr_srcptr g, mp_rnd_t mode)
{
mpfr_t temp;
mpfr_init2(temp, 8*sizeof(double));
mpfr_set_d(temp, d, mode);
mpfr_mul(f, temp, g, mode);
mpfr_clear(temp);
}
#endif
};
struct __gmp_binary_divides
{
static void eval(mpz_ptr z, mpz_srcptr w, mpz_srcptr v)
{ mpz_tdiv_q(z, w, v); }
static void eval(mpz_ptr z, mpz_srcptr w, unsigned long int l)
{ mpz_tdiv_q_ui(z, w, l); }
static void eval(mpz_ptr z, unsigned long int l, mpz_srcptr w)
{
if (mpz_sgn(w) >= 0)
{
if (mpz_fits_ulong_p(w))
mpz_set_ui(z, l / mpz_get_ui(w));
else
mpz_set_ui(z, 0);
}
else
{
mpz_neg(z, w);
if (mpz_fits_ulong_p(z))
{
mpz_set_ui(z, l / mpz_get_ui(z));
mpz_neg(z, z);
}
else
mpz_set_ui(z, 0);
}
}
static void eval(mpz_ptr z, mpz_srcptr w, signed long int l)
{
if (l >= 0)
mpz_tdiv_q_ui(z, w, l);
else
{
mpz_tdiv_q_ui(z, w, -l);
mpz_neg(z, z);
}
}
static void eval(mpz_ptr z, signed long int l, mpz_srcptr w)
{
if (mpz_fits_slong_p(w))
mpz_set_si(z, l / mpz_get_si(w));
else
mpz_set_si(z, 0);
}
static void eval(mpz_ptr z, mpz_srcptr w, double d)
{
mpz_t temp;
mpz_init_set_d(temp, d);
mpz_tdiv_q(z, w, temp);
mpz_clear(temp);
}
static void eval(mpz_ptr z, double d, mpz_srcptr w)
{
mpz_t temp;
mpz_init_set_d(temp, d);
mpz_tdiv_q(z, temp, w);
mpz_clear(temp);
}
static void eval(mpq_ptr q, mpq_srcptr r, mpq_srcptr s)
{ mpq_div(q, r, s); }
static void eval(mpq_ptr q, mpq_srcptr r, unsigned long int l)
{
mpq_t temp;
mpq_init(temp);
mpq_set_ui(temp, l, 1);
mpq_div(q, r, temp);
mpq_clear(temp);
}
static void eval(mpq_ptr q, unsigned long int l, mpq_srcptr r)
{
mpq_t temp;
mpq_init(temp);
mpq_set_ui(temp, l, 1);
mpq_div(q, temp, r);
mpq_clear(temp);
}
static void eval(mpq_ptr q, mpq_srcptr r, signed long int l)
{
mpq_t temp;
mpq_init(temp);
mpq_set_si(temp, l, 1);
mpq_div(q, r, temp);
mpq_clear(temp);
}
static void eval(mpq_ptr q, signed long int l, mpq_srcptr r)
{
mpq_t temp;
mpq_init(temp);
mpq_set_si(temp, l, 1);
mpq_div(q, temp, r);
mpq_clear(temp);
}
static void eval(mpq_ptr q, mpq_srcptr r, double d)
{
mpq_t temp;
mpq_init(temp);
mpq_set_d(temp, d);
mpq_div(q, r, temp);
mpq_clear(temp);
}
static void eval(mpq_ptr q, double d, mpq_srcptr r)
{
mpq_t temp;
mpq_init(temp);
mpq_set_d(temp, d);
mpq_div(q, temp, r);
mpq_clear(temp);
}
static void eval(mpf_ptr f, mpf_srcptr g, mpf_srcptr h)
{ mpf_div(f, g, h); }
static void eval(mpf_ptr f, mpf_srcptr g, unsigned long int l)
{ mpf_div_ui(f, g, l); }
static void eval(mpf_ptr f, unsigned long int l, mpf_srcptr g)
{ mpf_ui_div(f, l, g); }
static void eval(mpf_ptr f, mpf_srcptr g, signed long int l)
{
if (l >= 0)
mpf_div_ui(f, g, l);
else
{
mpf_div_ui(f, g, -l);
mpf_neg(f, f);
}
}
static void eval(mpf_ptr f, signed long int l, mpf_srcptr g)
{
if (l >= 0)
mpf_ui_div(f, l, g);
else
{
mpf_ui_div(f, -l, g);
mpf_neg(f, f);
}
}
static void eval(mpf_ptr f, mpf_srcptr g, double d)
{
mpf_t temp;
mpf_init2(temp, 8*sizeof(double));
mpf_set_d(temp, d);
mpf_div(f, g, temp);
mpf_clear(temp);
}
static void eval(mpf_ptr f, double d, mpf_srcptr g)
{
mpf_t temp;
mpf_init2(temp, 8*sizeof(double));
mpf_set_d(temp, d);
mpf_div(f, temp, g);
mpf_clear(temp);
}
#ifdef __MPFR_H
static void eval(mpfr_ptr f, mpfr_srcptr g, mpfr_srcptr h, mp_rnd_t mode)
{ mpfr_div(f, g, h, mode); }
static void eval(mpfr_ptr f, mpfr_srcptr g, unsigned long int l,
mp_rnd_t mode)
{ mpfr_div_ui(f, g, l, mode); }
static void eval(mpfr_ptr f, unsigned long int l, mpfr_srcptr g,
mp_rnd_t mode)
{ mpfr_ui_div(f, l, g, mode); }
static void eval(mpfr_ptr f, mpfr_srcptr g, signed long int l,
mp_rnd_t mode)
{
if (l >= 0)
mpfr_div_ui(f, g, l, mode);
else
{
mpfr_div_ui(f, g, -l, mode);
mpfr_neg(f, f, mode);
}
}
static void eval(mpfr_ptr f, signed long int l, mpfr_srcptr g,
mp_rnd_t mode)
{
if (l >= 0)
mpfr_ui_div(f, l, g, mode);
else
{
mpfr_ui_div(f, -l, g, mode);
mpfr_neg(f, f, mode);
}
}
static void eval(mpfr_ptr f, mpfr_srcptr g, double d, mp_rnd_t mode)
{
mpfr_t temp;
mpfr_init2(temp, 8*sizeof(double));
mpfr_set_d(temp, d, mode);
mpfr_div(f, g, temp, mode);
mpfr_clear(temp);
}
static void eval(mpfr_ptr f, double d, mpfr_srcptr g, mp_rnd_t mode)
{
mpfr_t temp;
mpfr_init2(temp, 8*sizeof(double));
mpfr_set_d(temp, d, mode);
mpfr_div(f, temp, g, mode);
mpfr_clear(temp);
}
#endif
};
struct __gmp_binary_modulus
{
static void eval(mpz_ptr z, mpz_srcptr w, mpz_srcptr v)
{ mpz_tdiv_r(z, w, v); }
static void eval(mpz_ptr z, mpz_srcptr w, unsigned long int l)
{ mpz_tdiv_r_ui(z, w, l); }
static void eval(mpz_ptr z, unsigned long int l, mpz_srcptr w)
{
if (mpz_sgn(w) >= 0)
{
if (mpz_fits_ulong_p(w))
mpz_set_ui(z, l % mpz_get_ui(w));
else
mpz_set_ui(z, l);
}
else
{
mpz_neg(z, w);
if (mpz_fits_ulong_p(z))
mpz_set_ui(z, l % mpz_get_ui(z));
else
mpz_set_ui(z, l);
}
}
static void eval(mpz_ptr z, mpz_srcptr w, signed long int l)
{
if (l >= 0)
mpz_mod_ui(z, w, l);
else
mpz_mod_ui(z, w, -l);
}
static void eval(mpz_ptr z, signed long int l, mpz_srcptr w)
{
if (mpz_fits_slong_p(w))
mpz_set_si(z, l % mpz_get_si(w));
else
mpz_set_si(z, l);
}
static void eval(mpz_ptr z, mpz_srcptr w, double d)
{
mpz_t temp;
mpz_init_set_d(temp, d);
mpz_tdiv_r(z, w, temp);
mpz_clear(temp);
}
static void eval(mpz_ptr z, double d, mpz_srcptr w)
{
mpz_t temp;
mpz_init_set_d(temp, d);
mpz_tdiv_r(z, temp, w);
mpz_clear(temp);
}
};
struct __gmp_binary_and
{
static void eval(mpz_ptr z, mpz_srcptr w, mpz_srcptr v)
{ mpz_and(z, w, v); }
};
struct __gmp_binary_ior
{
static void eval(mpz_ptr z, mpz_srcptr w, mpz_srcptr v)
{ mpz_ior(z, w, v); }
};
struct __gmp_binary_xor
{
static void eval(mpz_ptr z, mpz_srcptr w, mpz_srcptr v)
{ mpz_xor(z, w, v); }
};
struct __gmp_binary_lshift
{
static void eval(mpz_ptr z, mpz_srcptr w, unsigned long int l)
{ mpz_mul_2exp(z, w, l); }
static void eval(mpq_ptr q, mpq_srcptr r, unsigned long int l)
{ mpq_mul_2exp(q, r, l); }
static void eval(mpf_ptr f, mpf_srcptr g, unsigned long int l)
{ mpf_mul_2exp(f, g, l); }
#ifdef __MPFR_H
static void eval(mpfr_ptr f, mpfr_srcptr g, unsigned long int l,
mp_rnd_t mode)
{ mpfr_mul_2exp(f, g, l, mode); }
#endif
};
struct __gmp_binary_rshift
{
static void eval(mpz_ptr z, mpz_srcptr w, unsigned long int l)
{ mpz_tdiv_q_2exp(z, w, l); }
static void eval(mpq_ptr q, mpq_srcptr r, unsigned long int l)
{ mpq_div_2exp(q, r, l); }
static void eval(mpf_ptr f, mpf_srcptr g, unsigned long int l)
{ mpf_div_2exp(f, g, l); }
#ifdef __MPFR_H
static void eval(mpfr_ptr f, mpfr_srcptr g, unsigned long int l,
mp_rnd_t mode)
{ mpfr_div_2exp(f, g, l, mode); }
#endif
};
struct __gmp_binary_equal
{
static bool eval(mpz_srcptr z, mpz_srcptr w) { return mpz_cmp(z, w) == 0; }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -