c45251a.ada

来自「linux下编程用 编译软件」· ADA 代码 · 共 179 行

ADA
179
字号
-- 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/86WITH 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;

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?