All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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);
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy