|
- 10 PRINT "PROGRAM FILE 119: ACCURACY OF ATN FUNCTION."
- 20 PRINT " ANSI STANDARD 7.6, 8.4"
- 30 PRINT
- 40 PRINT "SECTION 119.1: ACCURACY OF ATN FUNCTION."
- 50 PRINT
- 60 PRINT "THIS PROGRAM TESTS VALUES RETURNED BY INVOCATIONS OF THE"
- 70 PRINT "ATN FUNCTION FOR ACCURACY. THE INVOCATION MUST RETURN,"
- 80 PRINT "ACCURATE TO SIX DIGITS, SOME VALUE ACTUALLY TAKEN ON BY"
- 90 PRINT "THE FUNCTION WITHIN A DOMAIN BOUNDED BY THE ACTUAL ARGUMENT"
- 100 PRINT "PLUS OR MINUS ONE IN THE SIXTH DIGIT. ALSO, AN"
- 110 PRINT "'ERROR MEASURE' IS COMPUTED AND REPORTED. THIS MEASURE"
- 120 PRINT "IS JUST 2 * THE ABSOLUTE ERROR OVER THE SIZE OF THE RANGE;"
- 130 PRINT "THUS, A VALUE JUST BARELY PASSING OR FAILING WILL USUALLY"
- 140 PRINT "HAVE A MEASURE OF ABOUT 1. A VALUE 3 TIMES"
- 150 PRINT "AS INACCURATE AS EXPECTED WILL HAVE A MEASURE OF 3-"
- 160 PRINT
- 170 PRINT "THIS TEST IS INFORMATIVE ONLY, SINCE THE ANSI STANDARD"
- 180 PRINT "DOES NOT MANDATE ANY ACCURACY FOR SUPPLIED-FUNCTIONS."
- 190 PRINT
- 200 PRINT " BEGIN TEST"
- 210 PRINT
- 220 PRINT "ARGUMENT","TRUE","COMPUTED","ERROR","OUTCOME"
- 230 PRINT " ","VALUE","VALUE","MEASURE"
- 240 PRINT
- 250 LET F=0
- 260 READ A,T,L,H
- 270 IF A=999 THEN 2000
- 280 LET C=ATN(A)
- 290 IF C=T THEN 333
- 300 IF C<L THEN 444
- 310 IF C>H THEN 444
- 320 LET O$=" OK "
- 330 GOTO 500
- 333 LET O$=" OK - EXACT"
- 340 GOTO 500
- 444 LET O$="FAIL"
- 445 LET F=F+1
- 450 GOTO 500
- 500 LET R=H-L
- 510 IF R=0 THEN 700
- 520 LET E=ABS((C-T)/R)
- 525 LET E=E+E
- 530 PRINT A,T,C,E,O$
- 540 GOTO 260
- 700 PRINT A,T,C,"RANGE ZERO",O$
- 710 GOTO 260
- 2000 PRINT
- 2010 IF F=0 THEN 2100
- 2020 PRINT "*** INFORMATIVE TEST FAILED IN ";F;" CASE(S) ***"
- 2030 GOTO 2110
- 2100 PRINT "*** INFORMATIVE TEST PASSED ***"
- 2110 PRINT
- 2120 PRINT " END TEST"
- 2130 PRINT
- 2140 PRINT "END PROGRAM 119"
- 3000 DATA -0.100000000E+39,-0.157079633E+01
- 3010 DATA -0.157080133E+01,-0.157079132E+01
- 3020 DATA -0.999999000E+38,-0.157079633E+01
- 3030 DATA -0.157080133E+01,-0.157079132E+01
- 3040 DATA -0.300000000E+31,-0.157079633E+01
- 3050 DATA -0.157080133E+01,-0.157079132E+01
- 3060 DATA -0.200000000E+21,-0.157079633E+01
- 3070 DATA -0.157080133E+01,-0.157079132E+01
- 3080 DATA -0.900000000E+11,-0.157079633E+01
- 3090 DATA -0.157080133E+01,-0.157079132E+01
- 3100 DATA -0.900000000E+06,-0.157079522E+01
- 3110 DATA -0.157080022E+01,-0.157079021E+01
- 3120 DATA -0.300000000E+06,-0.157079299E+01
- 3130 DATA -0.157079800E+01,-0.157078799E+01
- 3140 DATA -0.200000000E+06,-0.157079133E+01
- 3150 DATA -0.157079633E+01,-0.157078632E+01
- 3160 DATA -0.100000000E+06,-0.157078633E+01
- 3170 DATA -0.157079133E+01,-0.157078132E+01
- 3180 DATA -0.987654000E+05,-0.157078620E+01
- 3190 DATA -0.157079121E+01,-0.157078120E+01
- 3200 DATA -0.987654000E+04,-0.157069508E+01
- 3210 DATA -0.157070008E+01,-0.157069007E+01
- 3220 DATA -0.987600000E+03,-0.156978377E+01
- 3230 DATA -0.156978878E+01,-0.156977877E+01
- 3240 DATA -0.987000000E+02,-0.156066496E+01
- 3250 DATA -0.156066998E+01,-0.156065995E+01
- 3260 DATA -0.980000000E+01,-0.146910748E+01
- 3270 DATA -0.146911258E+01,-0.146910237E+01
- 3280 DATA -0.880000000E+01,-0.145764535E+01
- 3290 DATA -0.145765048E+01,-0.145764021E+01
- 3300 DATA -0.770000000E+01,-0.144164904E+01
- 3310 DATA -0.144165421E+01,-0.144164387E+01
- 3320 DATA -0.660000000E+01,-0.142042490E+01
- 3330 DATA -0.142043013E+01,-0.142041967E+01
- 3340 DATA -0.550000000E+01,-0.139094283E+01
- 3350 DATA -0.139094815E+01,-0.139093750E+01
- 3360 DATA -0.440000000E+01,-0.134731973E+01
- 3370 DATA -0.134732522E+01,-0.134731423E+01
- 3380 DATA -0.330000000E+01,-0.127656176E+01
- 3390 DATA -0.127656761E+01,-0.127655592E+01
- 3400 DATA -0.220000000E+01,-0.114416883E+01
- 3410 DATA -0.114417555E+01,-0.114416212E+01
- 3420 DATA -0.110000000E+01,-0.832981267E+00
- 3430 DATA -0.832986292E+00,-0.832976241E+00
- 3440 DATA -0.900000000E+00,-0.732815102E+00
- 3450 DATA -0.732816155E+00,-0.732814049E+00
- 3460 DATA -0.600000000E+00,-0.540419500E+00
- 3470 DATA -0.540420736E+00,-0.540418264E+00
- 3480 DATA -0.100000000E+00,-0.996686525E-01
- 3490 DATA -0.996696926E-01,-0.996676123E-01
- 3500 DATA -0.900000000E-01,-0.897581742E-01
- 3510 DATA -0.897583234E-01,-0.897580249E-01
- 3520 DATA -0.900000000E-02,-0.899975701E-02
- 3530 DATA -0.899977202E-02,-0.899974201E-02
- 3540 DATA -0.600000000E-02,-0.599992800E-02
- 3550 DATA -0.599994301E-02,-0.599991300E-02
- 3560 DATA -0.300000000E-02,-0.299999100E-02
- 3570 DATA -0.300000600E-02,-0.299997600E-02
- 3580 DATA -0.200000000E-02,-0.199999733E-02
- 3590 DATA -0.200001234E-02,-0.199998233E-02
- 3600 DATA -0.100000000E-02,-0.999999667E-03
- 3610 DATA -0.100001467E-02,-0.999989166E-03
- 3620 DATA -0.900000000E-03,-0.899999757E-03
- 3630 DATA -0.900001257E-03,-0.899998257E-03
- 3640 DATA -0.400000000E-03,-0.399999979E-03
- 3650 DATA -0.400001479E-03,-0.399998478E-03
- 3660 DATA -0.900000000E-04,-0.899999998E-04
- 3670 DATA -0.900001498E-04,-0.899998497E-04
- 3680 DATA -0.900000000E-09,-0.900000000E-09
- 3690 DATA -0.900001500E-09,-0.899998500E-09
- 3700 DATA -0.900000000E-19,-0.900000000E-19
- 3710 DATA -0.900001500E-19,-0.899998500E-19
- 3720 DATA -0.900000000E-29,-0.900000000E-29
- 3730 DATA -0.900001500E-29,-0.899998500E-29
- 3740 DATA -0.900000000E-37,-0.900000000E-37
- 3750 DATA -0.900001500E-37,-0.899998500E-37
- 3760 DATA 0,0,0,0
- 3780 DATA 0.900000000E-37, 0.900000000E-37
- 3790 DATA 0.899998500E-37, 0.900001500E-37
- 3820 DATA 0.900000000E-29, 0.900000000E-29
- 3830 DATA 0.899998500E-29, 0.900001500E-29
- 3840 DATA 0.900000000E-19, 0.900000000E-19
- 3850 DATA 0.899998500E-19, 0.900001500E-19
- 3860 DATA 0.900000000E-09, 0.900000000E-09
- 3870 DATA 0.899998500E-09, 0.900001500E-09
- 3880 DATA 0.900000000E-04, 0.899999998E-04
- 3890 DATA 0.899998497E-04, 0.900001498E-04
- 3900 DATA 0.400000000E-03, 0.399999979E-03
- 3910 DATA 0.399998478E-03, 0.400001479E-03
- 3920 DATA 0.900000000E-03, 0.899999757E-03
- 3930 DATA 0.899998257E-03, 0.900001257E-03
- 3940 DATA 0.100000000E-02, 0.999999667E-03
- 3950 DATA 0.999989166E-03, 0.100001467E-02
- 3960 DATA 0.200000000E-02, 0.199999733E-02
- 3970 DATA 0.199998233E-02, 0.200001234E-02
- 3980 DATA 0.300000000E-02, 0.299999100E-02
- 3990 DATA 0.299997600E-02, 0.300000600E-02
- 4000 DATA 0.600000000E-02, 0.599992800E-02
- 4010 DATA 0.599991300E-02, 0.599994301E-02
- 4020 DATA 0.900000000E-02, 0.899975701E-02
- 4030 DATA 0.899974201E-02, 0.899977202E-02
- 4040 DATA 0.900000000E-01, 0.897581742E-01
- 4050 DATA 0.897580249E-01, 0.897583234E-01
- 4060 DATA 0.100000000E+00, 0.996686525E-01
- 4070 DATA 0.996676123E-01, 0.996696926E-01
- 4080 DATA 0.600000000E+00, 0.540419500E+00
- 4090 DATA 0.540418264E+00, 0.540420736E+00
- 4100 DATA 0.900000000E+00, 0.732815102E+00
- 4110 DATA 0.732814049E+00, 0.732816155E+00
- 4120 DATA 0.110000000E+01, 0.832981267E+00
- 4130 DATA 0.832976241E+00, 0.832986292E+00
- 4140 DATA 0.220000000E+01, 0.114416883E+01
- 4150 DATA 0.114416212E+01, 0.114417555E+01
- 4160 DATA 0.330000000E+01, 0.127656176E+01
- 4170 DATA 0.127655592E+01, 0.127656761E+01
- 4180 DATA 0.440000000E+01, 0.134731973E+01
- 4190 DATA 0.134731423E+01, 0.134732522E+01
- 4200 DATA 0.550000000E+01, 0.139094283E+01
- 4210 DATA 0.139093750E+01, 0.139094815E+01
- 4220 DATA 0.660000000E+01, 0.142042490E+01
- 4230 DATA 0.142041967E+01, 0.142043013E+01
- 4240 DATA 0.770000000E+01, 0.144164904E+01
- 4250 DATA 0.144164387E+01, 0.144165421E+01
- 4260 DATA 0.880000000E+01, 0.145764535E+01
- 4270 DATA 0.145764021E+01, 0.145765048E+01
- 4280 DATA 0.990000000E+01, 0.147012767E+01
- 4290 DATA 0.147012257E+01, 0.147013278E+01
- 4300 DATA 0.987000000E+02, 0.156066496E+01
- 4310 DATA 0.156065995E+01, 0.156066998E+01
- 4320 DATA 0.987600000E+03, 0.156978377E+01
- 4330 DATA 0.156977877E+01, 0.156978878E+01
- 4340 DATA 0.987654000E+04, 0.157069508E+01
- 4350 DATA 0.157069007E+01, 0.157070008E+01
- 4360 DATA 0.987654000E+05, 0.157078620E+01
- 4370 DATA 0.157078120E+01, 0.157079121E+01
- 4380 DATA 0.100000000E+06, 0.157078633E+01
- 4390 DATA 0.157078132E+01, 0.157079133E+01
- 4400 DATA 0.200000000E+06, 0.157079133E+01
- 4410 DATA 0.157078632E+01, 0.157079633E+01
- 4420 DATA 0.300000000E+06, 0.157079299E+01
- 4430 DATA 0.157078799E+01, 0.157079800E+01
- 4440 DATA 0.900000000E+06, 0.157079522E+01
- 4450 DATA 0.157079021E+01, 0.157080022E+01
- 4460 DATA 0.900000000E+11, 0.157079633E+01
- 4470 DATA 0.157079132E+01, 0.157080133E+01
- 4480 DATA 0.200000000E+21, 0.157079633E+01
- 4490 DATA 0.157079132E+01, 0.157080133E+01
- 4500 DATA 0.300000000E+31, 0.157079633E+01
- 4510 DATA 0.157079132E+01, 0.157080133E+01
- 4520 DATA 0.999999000E+38, 0.157079633E+01
- 4530 DATA 0.157079132E+01, 0.157080133E+01
- 4540 DATA 0.100000000E+39, 0.157079633E+01
- 4550 DATA 0.157079132E+01, 0.157080133E+01
- 9000 DATA 999,0,0,0
- 9400 END
|