blob: 0e1bbb5081f7c4137081908bc48f6abad302ba10 [file] [log] [blame]
-- C45251A.ADA
-- Grant of Unlimited Rights
--
-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
-- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
-- unlimited rights in the software and documentation contained herein.
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
-- this public release, the Government intends to confer upon all
-- recipients unlimited rights equal to those held by the Government.
-- These rights include rights to use, duplicate, release or disclose the
-- released technical data and computer software in whole or in part, in
-- any manner and for any purpose whatsoever, and to have or permit others
-- to do so.
--
-- DISCLAIMER
--
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
-- PARTICULAR PURPOSE OF SAID MATERIAL.
--*
-- CHECK THAT FOR RELATIONAL OPERATIONS ON FIXED POINT TYPES THE
-- FOLLOWING HOLD:
-- (A) A /= B IS THE SAME AS NOT (A = B).
-- (B) A < B IS THE SAME AS NOT (A >= B).
-- (C) A > B IS THE SAME AS NOT (A <= B).
-- (D) ADJACENT MODEL NUMBERS GIVE CORRECT RESULTS.
-- (E) NON-MODEL NUMBERS WITH DISTINCT MODEL INTERVALS GIVE
-- CORRECT RESULTS.
-- (F) CASE WHERE MODEL INTERVALS INTERSECT IN A SINGLE MODEL
-- NUMBER GIVES CORRECT RESULT.
-- CASE A: BASIC TYPES THAT FIT THE CHARACTERISTICS OF DURATION'BASE.
-- WRG 8/26/86
WITH REPORT; USE REPORT;
PROCEDURE C45251A IS
-- THE NAME OF EACH TYPE OR SUBTYPE ENDS WITH THAT TYPE'S
-- 'MANTISSA VALUE.
TYPE LIKE_DURATION_M23 IS DELTA 0.020 RANGE -86_400.0 .. 86_400.0;
TYPE DECIMAL_M4 IS DELTA 100.0 RANGE -1000.0 .. 1000.0;
BEGIN
TEST ("C45251A", "CHECK RELATIONAL OPERATIONS FOR FIXED POINT " &
"TYPES - BASIC TYPES");
-------------------------------------------------------------------
DECLARE
A, B : LIKE_DURATION_M23 := 0.0;
C, D : DECIMAL_M4 := 0.0;
BEGIN
IF EQUAL (3, 3) THEN
A := 2#0.0000_0011#; -- JUST BELOW LIKE_DURATION'SMALL.
B := 2#0.0000_0101#; -- JUST ABOVE LIKE_DURATION'SMALL.
END IF;
-- (A)
IF A /= B XOR NOT (A = B) THEN
FAILED ("A /= B IS NOT THE SAME AS NOT (A = B)");
END IF;
-- (B)
IF A < B XOR NOT (A >= B) THEN
FAILED ("A < B IS NOT THE SAME AS NOT (A >= B)");
END IF;
-- (C)
IF A > B XOR NOT (A <= B) THEN
FAILED ("A > B IS NOT THE SAME AS NOT (A <= B)");
END IF;
-- (D)
IF EQUAL (3, 3) THEN
A := -(16#1_5180.00#); -- (-86_400.0)
B := -(16#1_517F.FC#); -- (-86_400.0 + 1.0/64)
C := 64.0; -- DECIMAL_M4'SMALL.
D := 128.0; -- 2 * DECIMAL_M4'SMALL.
END IF;
IF "=" (LEFT => A, RIGHT => B) THEN
FAILED ("ADJACENT MODEL NUMBERS GIVE INCORRECT RESULT " &
"- (A = B)");
END IF;
IF NOT "/=" (LEFT => C, RIGHT => D) THEN
FAILED ("ADJACENT MODEL NUMBERS GIVE INCORRECT RESULT " &
"- (C /= D)");
END IF;
IF "<" (LEFT => B, RIGHT => A) THEN
FAILED ("ADJACENT MODEL NUMBERS GIVE INCORRECT RESULT " &
"- (B < A)");
END IF;
IF ">" (LEFT => C, RIGHT => D) THEN
FAILED ("ADJACENT MODEL NUMBERS GIVE INCORRECT RESULT " &
"- (C > D)");
END IF;
IF ">=" (LEFT => A, RIGHT => B) THEN
FAILED ("ADJACENT MODEL NUMBERS GIVE INCORRECT RESULT " &
"- (A >= B)");
END IF;
IF "<=" (LEFT => D, RIGHT => C) THEN
FAILED ("ADJACENT MODEL NUMBERS GIVE INCORRECT RESULT " &
"- (D <= C)");
END IF;
-- (E)
IF EQUAL (3, 3) THEN
A := 0.02; -- INTERVAL IS 1.0/64 .. 2.0/64.
B := -0.02; -- INTERVAL IS -2.0/64 .. -1.0/64.
C := 800.0; -- INTERVAL IS 768.0 .. 832.0.
D := 900.0; -- INTERVAL IS 896.0 .. 960.0.
END IF;
IF A = B THEN
FAILED ("NON-MODEL NUMBERS WITH DISTINCT MODEL " &
"INTERVALS GIVE INCORRECT RESULT - (A = B)");
END IF;
IF NOT (C /= D) THEN
FAILED ("NON-MODEL NUMBERS WITH DISTINCT MODEL " &
"INTERVALS GIVE INCORRECT RESULT - (C /= D)");
END IF;
IF A < B THEN
FAILED ("NON-MODEL NUMBERS WITH DISTINCT MODEL " &
"INTERVALS GIVE INCORRECT RESULT - (A < B)");
END IF;
IF C > D THEN
FAILED ("NON-MODEL NUMBERS WITH DISTINCT MODEL " &
"INTERVALS GIVE INCORRECT RESULT - (C > D)");
END IF;
IF B >= A THEN
FAILED ("NON-MODEL NUMBERS WITH DISTINCT MODEL " &
"INTERVALS GIVE INCORRECT RESULT - (B >= A)");
END IF;
IF D <= C THEN
FAILED ("NON-MODEL NUMBERS WITH DISTINCT MODEL " &
"INTERVALS GIVE INCORRECT RESULT - (D <= C)");
END IF;
-- (F)
IF EQUAL (3, 3) THEN
B := 0.035; -- INTERVAL IS 2.0/64 .. 3.0/64.
C := 850.0; -- INTERVAL IS 832.0 .. 896.0.
END IF;
IF NOT (A <= B) THEN
FAILED ("COMPARISON OF NON-MODEL NUMBERS WITH ONE " &
"COMMON MODEL INTERVAL END-POINT GIVES " &
"INCORRECT RESULT - (A <= B)");
END IF;
IF A > B THEN
FAILED ("COMPARISON OF NON-MODEL NUMBERS WITH ONE " &
"COMMON MODEL INTERVAL END-POINT GIVES " &
"INCORRECT RESULT - (A > B)");
END IF;
IF NOT (D >= C) THEN
FAILED ("COMPARISON OF NON-MODEL NUMBERS WITH ONE " &
"COMMON MODEL INTERVAL END-POINT GIVES " &
"INCORRECT RESULT - (D >= C)");
END IF;
IF D < C THEN
FAILED ("COMPARISON OF NON-MODEL NUMBERS WITH ONE " &
"COMMON MODEL INTERVAL END-POINT GIVES " &
"INCORRECT RESULT - (D < C)");
END IF;
END;
-------------------------------------------------------------------
RESULT;
END C45251A;