z3-z3-4.13.0.src.api.dotnet.FPNum.cs Maven / Gradle / Ivy
The newest version!
/*++
Copyright (c) 2013 Microsoft Corporation
Module Name:
FPNum.cs
Abstract:
Z3 Managed API: Floating Point Numerals
Author:
Christoph Wintersteiger (cwinter) 2013-06-10
Notes:
--*/
using System.Diagnostics;
using System;
namespace Microsoft.Z3
{
///
/// FloatiungPoint Numerals
///
public class FPNum : FPExpr
{
///
/// The sign of a floating-point numeral as a bit-vector expression
///
///
/// NaN's do not have a bit-vector sign, so they are invalid arguments.
///
public BitVecExpr SignBV
{
get
{
return new BitVecExpr(Context, Native.Z3_fpa_get_numeral_sign_bv(Context.nCtx, NativeObject));
}
}
///
/// Retrieves the sign of a floating-point literal
///
///
/// Remarks: returns true if the numeral is negative
///
public bool Sign
{
get
{
int res = 0;
if (Native.Z3_fpa_get_numeral_sign(Context.nCtx, NativeObject, ref res) == 0)
throw new Z3Exception("Sign is not a Boolean value");
return res != 0;
}
}
///
/// The significand value of a floating-point numeral as a string
///
///
/// The significand s is always 0 < s < 2.0; the resulting string is long
/// enough to represent the real significand precisely.
///
public string Significand
{
get
{
return Native.Z3_fpa_get_numeral_significand_string(Context.nCtx, NativeObject);
}
}
///
/// The significand value of a floating-point numeral as a UInt64
///
///
/// This function extracts the significand bits, without the
/// hidden bit or normalization. Throws an exception if the
/// significand does not fit into a UInt64.
///
public UInt64 SignificandUInt64
{
get
{
UInt64 result = 0;
if (Native.Z3_fpa_get_numeral_significand_uint64(Context.nCtx, NativeObject, ref result) == 0)
throw new Z3Exception("Significand is not a 64 bit unsigned integer");
return result;
}
}
///
/// The significand of a floating-point numeral as a bit-vector expression
///
///
/// +oo, -oo and NaN's do not have a bit-vector significand, so they are invalid arguments.
///
public BitVecExpr SignificandBV
{
get
{
return new BitVecExpr(Context, Native.Z3_fpa_get_numeral_significand_bv(Context.nCtx, NativeObject));
}
}
///
/// Return the (biased) exponent value of a floating-point numeral as a string
///
public string Exponent(bool biased = true)
{
return Native.Z3_fpa_get_numeral_exponent_string(Context.nCtx, NativeObject, (byte)(biased ? 1 : 0));
}
///
/// Return the exponent value of a floating-point numeral as a signed 64-bit integer
///
public Int64 ExponentInt64(bool biased = true)
{
Int64 result = 0;
if (Native.Z3_fpa_get_numeral_exponent_int64(Context.nCtx, NativeObject, ref result, (byte)(biased? 1 : 0)) == 0)
throw new Z3Exception("Exponent is not a 64 bit integer");
return result;
}
///
/// The exponent of a floating-point numeral as a bit-vector expression
///
///
/// +oo, -oo and NaN's do not have a bit-vector exponent, so they are invalid arguments.
///
public BitVecExpr ExponentBV(bool biased = true)
{
return new BitVecExpr(Context, Native.Z3_fpa_get_numeral_exponent_bv(Context.nCtx, NativeObject, (byte)(biased ? 1 : 0)));
}
///
/// Indicates whether the numeral is a NaN.
///
public bool IsNaN { get { return Native.Z3_fpa_is_numeral_nan(Context.nCtx, NativeObject) != 0; } }
///
/// Indicates whether the numeral is a +oo or -oo.
///
public bool IsInf { get { return Native.Z3_fpa_is_numeral_inf(Context.nCtx, NativeObject) != 0; } }
///
/// Indicates whether the numeral is +zero or -zero.
///
public bool IsZero{ get { return Native.Z3_fpa_is_numeral_zero(Context.nCtx, NativeObject) != 0; } }
///
/// Indicates whether the numeral is normal.
///
public bool IsNormal { get { return Native.Z3_fpa_is_numeral_normal(Context.nCtx, NativeObject) != 0; } }
///
/// Indicates whether the numeral is subnormal.
///
public bool IsSubnormal { get { return Native.Z3_fpa_is_numeral_subnormal(Context.nCtx, NativeObject) != 0; } }
///
/// Indicates whether the numeral is positive.
///
public bool IsPositive { get { return Native.Z3_fpa_is_numeral_positive(Context.nCtx, NativeObject) != 0; } }
///
/// Indicates whether the numeral is negative.
///
public bool IsNegative { get { return Native.Z3_fpa_is_numeral_negative(Context.nCtx, NativeObject) != 0; } }
#region Internal
internal FPNum(Context ctx, IntPtr obj)
: base(ctx, obj)
{
Debug.Assert(ctx != null);
}
#endregion
///
/// Returns a string representation of the numeral.
///
public override string ToString()
{
return Native.Z3_get_numeral_string(Context.nCtx, NativeObject);
}
}
}