Click or drag to resize
mpfr_libmpfr_asin Method
Set rop to the arc-sine of op rounded in the direction rnd.

Namespace:  Math.Mpfr.Native
Assembly:  Math.Mpfr.Native (in Math.Mpfr.Native.dll) Version: 1.0.0.0 (1.0.0.0)
Syntax
public static int mpfr_asin(
	mpfr_t rop,
	mpfr_t op,
	mpfr_rnd_t rnd
)

Parameters

rop
Type: Math.Mpfr.Nativempfr_t
The result floating-point number.
op
Type: Math.Mpfr.Nativempfr_t
The operand floating-point number.
rnd
Type: Math.Mpfr.Nativempfr_rnd_t
The rounding direction.

Return Value

Type: Int32
Return zero, a positive, or a negative value if rop is respectively equal to, greater than, or lower than the exact result. See GNU MPFR - Rounding Modes for details.
Remarks

Note that since acos(-1) returns the floating-point number closest to Pi according to the given rounding mode, this number might not be in the output range 0 ≤ rop < Pi of the arc-cosine function; still, the result lies in the image of the output range by the rounding function. The same holds for asin(-1), asin(1), atan(-Inf), atan(+Inf) or for atan(op) with large op and small precision of rop.

Examples
// Create, initialize, and set a new floating-point number op to 1.
mpfr_t op = new mpfr_t();
mpfr_lib.mpfr_init2(op, 64U);
Assert.IsTrue(mpfr_lib.mpfr_set_si(op, 1, mpfr_rnd_t.MPFR_RNDN) == 0);

// Create and initialize a new floating-point number rop.
mpfr_t rop = new mpfr_t();
mpfr_lib.mpfr_init2(rop, 64U);

// Set rop = 2 * asin(op).
Assert.IsTrue(mpfr_lib.mpfr_asin(rop, op, mpfr_rnd_t.MPFR_RNDN) == 1);
Assert.IsTrue(mpfr_lib.mpfr_mul_si(rop, rop, 2, mpfr_rnd_t.MPFR_RNDN) == 0);

// Assert that the value of rop is PI.
Assert.IsTrue(mpfr_lib.mpfr_const_pi(op, mpfr_rnd_t.MPFR_RNDN) == 1);
Assert.IsTrue(mpfr_lib.mpfr_cmp(rop, op) == 0);

// Release unmanaged memory allocated for rop and op.
mpfr_lib.mpfr_clears(rop, op, null);
See Also