|
DEFINITION MODULE LowLong; (* Access to underlying properties of the type LONGREAL *) CONST radix = <implementation-defined whole number value>; places = <implementation-defined whole number value>; expoMin = <implementation-defined whole number value>; expoMax = <implementation-defined whole number value>; large = <implementation-defined real number value>; small = <implementation-defined real number value>; IEC559 = <implementation-defined BOOLEAN value>; LIA1 = <implementation-defined BOOLEAN value>; rounds = <implementation-defined BOOLEAN value>; gUnderflow = <implementation-defined BOOLEAN value>; exception = <implementation-defined BOOLEAN value>; extend = <implementation-defined BOOLEAN value>; nModes = <implementation-defined whole number value>; TYPE Modes = PACKEDSET OF [0 .. nModes-1]; PROCEDURE exponent (x: LONGREAL): INTEGER; (* Returns the exponent value of x *) PROCEDURE fraction (x: LONGREAL): LONGREAL; (* Returns the significand (or significant part) of x *) PROCEDURE sign (x: LONGREAL): LONGREAL; (* Returns the signum of x *) PROCEDURE succ (x: LONGREAL): LONGREAL; (* Returns the next value of the type LONGREAL greater than x *) PROCEDURE ulp (x: LONGREAL): LONGREAL; (* Returns the value of a unit in the last place of x *) PROCEDURE pred (x: LONGREAL): LONGREAL; (* Returns the previous value of the type LONGREAL less than x *) PROCEDURE intpart (x: LONGREAL): LONGREAL; (* Returns the integer part of x *) PROCEDURE fractpart (x: LONGREAL): LONGREAL; (* Returns the fractional part of x *) PROCEDURE scale (x: LONGREAL; n: INTEGER): LONGREAL; (* Returns the value of x * radix ** n *) PROCEDURE trunc (x: LONGREAL; n: INTEGER): LONGREAL; (* Returns the value of the first n places of x *) PROCEDURE round (x: LONGREAL; n: INTEGER): LONGREAL; (* Returns the value of x rounded to the first n places *) PROCEDURE synthesize (expart: INTEGER; frapart: LONGREAL): LONGREAL; (* Returns a value of the type LONGREAL constructed from the given expart and frapart *) PROCEDURE setMode (m: Modes); (* Sets status flags appropriate to the underlying implementation of the type LONGREAL *) PROCEDURE currentMode (): Modes; (* Returns the current status flags in the form set by setMode *) PROCEDURE IsLowException (): BOOLEAN; (* Returns TRUE if the current coroutine is in the exceptional execution state because of the raising of the LowLong exception; otherwise returns FALSE. *) END LowLong. |