2014-02-11 11:26:28 +01:00
|
|
|
void rpn_e(void)
|
|
|
|
{
|
2017-05-02 10:45:28 +02:00
|
|
|
number* euler = (number*)_stack->allocate_back(number::calc_size(), cmd_number);
|
|
|
|
euler->_value = 1L;
|
|
|
|
CHECK_MPFR(mpfr_exp(euler->_value.mpfr, euler->_value.mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_log()
|
|
|
|
{
|
2017-04-20 22:46:48 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
|
|
|
|
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
2017-04-29 16:48:14 +02:00
|
|
|
CHECK_MPFR(mpfr_log10(left->mpfr, left->mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_alog()
|
|
|
|
{
|
2017-04-20 22:46:48 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
|
|
|
|
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
2017-04-29 16:48:14 +02:00
|
|
|
CHECK_MPFR(mpfr_exp10(left->mpfr, left->mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
2017-05-22 13:48:06 +02:00
|
|
|
void rpn_log2()
|
|
|
|
{
|
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
|
|
|
|
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
|
|
|
CHECK_MPFR(mpfr_log2(left->mpfr, left->mpfr, s_mpfr_rnd));
|
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_alog2()
|
|
|
|
{
|
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
|
|
|
|
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
|
|
|
CHECK_MPFR(mpfr_exp2(left->mpfr, left->mpfr, s_mpfr_rnd));
|
|
|
|
}
|
|
|
|
|
2014-02-11 11:26:28 +01:00
|
|
|
void rpn_ln()
|
|
|
|
{
|
2017-04-20 22:46:48 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
|
|
|
|
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
2017-04-29 16:48:14 +02:00
|
|
|
CHECK_MPFR(mpfr_log(left->mpfr, left->mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_exp()
|
|
|
|
{
|
2017-04-20 22:46:48 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
|
|
|
|
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
2017-04-29 16:48:14 +02:00
|
|
|
CHECK_MPFR(mpfr_exp(left->mpfr, left->mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_sinh()
|
|
|
|
{
|
2017-04-20 22:46:48 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
|
|
|
|
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
2017-04-29 16:48:14 +02:00
|
|
|
CHECK_MPFR(mpfr_sinh(left->mpfr, left->mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_asinh()
|
|
|
|
{
|
2017-04-20 22:46:48 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
2014-02-11 11:26:28 +01:00
|
|
|
|
2017-04-20 22:46:48 +02:00
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
2017-04-29 16:48:14 +02:00
|
|
|
CHECK_MPFR(mpfr_asinh(left->mpfr, left->mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_cosh()
|
|
|
|
{
|
2017-04-20 22:46:48 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
|
|
|
|
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
2017-04-29 16:48:14 +02:00
|
|
|
CHECK_MPFR(mpfr_cosh(left->mpfr, left->mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_acosh()
|
|
|
|
{
|
2017-04-20 22:46:48 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
2014-02-11 11:26:28 +01:00
|
|
|
|
2017-04-20 22:46:48 +02:00
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
2017-04-29 16:48:14 +02:00
|
|
|
CHECK_MPFR(mpfr_cosh(left->mpfr, left->mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_tanh()
|
|
|
|
{
|
2017-04-20 22:46:48 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
|
|
|
|
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
2017-04-29 16:48:14 +02:00
|
|
|
CHECK_MPFR(mpfr_tanh(left->mpfr, left->mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_atanh()
|
|
|
|
{
|
2017-04-20 22:46:48 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
2014-02-11 11:26:28 +01:00
|
|
|
|
2017-04-20 22:46:48 +02:00
|
|
|
floating_t* left = &((number*)_stack->get_obj(0))->_value;
|
2017-04-29 16:48:14 +02:00
|
|
|
CHECK_MPFR(mpfr_atanh(left->mpfr, left->mpfr, s_mpfr_rnd));
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|