home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / perl560.zip / t / lib / bigfloat.t < prev    next >
Text File  |  1999-07-20  |  8KB  |  409 lines

  1. #!./perl
  2.  
  3. BEGIN { @INC = '../lib' }
  4. require "bigfloat.pl";
  5.  
  6. $test = 0;
  7. $| = 1;
  8. print "1..355\n";
  9. while (<DATA>) {
  10.     chop;
  11.     if (/^&/) {
  12.         $f = $_;
  13.     } elsif (/^\$.*/) {
  14.         eval "$_;";
  15.     } else {
  16.         ++$test;
  17.         @args = split(/:/,$_,99);
  18.         $ans = pop(@args);
  19.         $try = "$f('" . join("','", @args) . "');";
  20.         if (($ans1 = eval($try)) eq $ans) {
  21.             print "ok $test\n";
  22.         } else {
  23.             print "not ok $test\n";
  24.             print "# '$try' expected: '$ans' got: '$ans1'\n";
  25.         }
  26.     }
  27. __END__
  28. &fnorm
  29. abc:NaN
  30.    1 a:NaN
  31. 1bcd2:NaN
  32. 11111b:NaN
  33. +1z:NaN
  34. -1z:NaN
  35. 0:+0E+0
  36. +0:+0E+0
  37. +00:+0E+0
  38. +0 0 0:+0E+0
  39. 000000  0000000   00000:+0E+0
  40. -0:+0E+0
  41. -0000:+0E+0
  42. +1:+1E+0
  43. +01:+1E+0
  44. +001:+1E+0
  45. +00000100000:+1E+5
  46. 123456789:+123456789E+0
  47. -1:-1E+0
  48. -01:-1E+0
  49. -001:-1E+0
  50. -123456789:-123456789E+0
  51. -00000100000:-1E+5
  52. 123.456a:NaN
  53. 123.456:+123456E-3
  54. 0.01:+1E-2
  55. .002:+2E-3
  56. -0.0003:-3E-4
  57. -.0000000004:-4E-10
  58. 123456E2:+123456E+2
  59. 123456E-2:+123456E-2
  60. -123456E2:-123456E+2
  61. -123456E-2:-123456E-2
  62. 1e1:+1E+1
  63. 2e-11:+2E-11
  64. -3e111:-3E+111
  65. -4e-1111:-4E-1111
  66. &fneg
  67. abd:NaN
  68. +0:+0E+0
  69. +1:-1E+0
  70. -1:+1E+0
  71. +123456789:-123456789E+0
  72. -123456789:+123456789E+0
  73. +123.456789:-123456789E-6
  74. -123456.789:+123456789E-3
  75. &fabs
  76. abc:NaN
  77. +0:+0E+0
  78. +1:+1E+0
  79. -1:+1E+0
  80. +123456789:+123456789E+0
  81. -123456789:+123456789E+0
  82. +123.456789:+123456789E-6
  83. -123456.789:+123456789E-3
  84. &fround
  85. $bigfloat::rnd_mode = 'trunc'
  86. +10123456789:5:+10123E+6
  87. -10123456789:5:-10123E+6
  88. +10123456789:9:+101234567E+2
  89. -10123456789:9:-101234567E+2
  90. +101234500:6:+101234E+3
  91. -101234500:6:-101234E+3
  92. $bigfloat::rnd_mode = 'zero'
  93. +20123456789:5:+20123E+6
  94. -20123456789:5:-20123E+6
  95. +20123456789:9:+201234568E+2
  96. -20123456789:9:-201234568E+2
  97. +201234500:6:+201234E+3
  98. -201234500:6:-201234E+3
  99. $bigfloat::rnd_mode = '+inf'
  100. +30123456789:5:+30123E+6
  101. -30123456789:5:-30123E+6
  102. +30123456789:9:+301234568E+2
  103. -30123456789:9:-301234568E+2
  104. +301234500:6:+301235E+3
  105. -301234500:6:-301234E+3
  106. $bigfloat::rnd_mode = '-inf'
  107. +40123456789:5:+40123E+6
  108. -40123456789:5:-40123E+6
  109. +40123456789:9:+401234568E+2
  110. -40123456789:9:-401234568E+2
  111. +401234500:6:+401234E+3
  112. -401234500:6:-401235E+3
  113. $bigfloat::rnd_mode = 'odd'
  114. +50123456789:5:+50123E+6
  115. -50123456789:5:-50123E+6
  116. +50123456789:9:+501234568E+2
  117. -50123456789:9:-501234568E+2
  118. +501234500:6:+501235E+3
  119. -501234500:6:-501235E+3
  120. $bigfloat::rnd_mode = 'even'
  121. +60123456789:5:+60123E+6
  122. -60123456789:5:-60123E+6
  123. +60123456789:9:+601234568E+2
  124. -60123456789:9:-601234568E+2
  125. +601234500:6:+601234E+3
  126. -601234500:6:-601234E+3
  127. &ffround
  128. $bigfloat::rnd_mode = 'trunc'
  129. +1.23:-1:+12E-1
  130. -1.23:-1:-12E-1
  131. +1.27:-1:+12E-1
  132. -1.27:-1:-12E-1
  133. +1.25:-1:+12E-1
  134. -1.25:-1:-12E-1
  135. +1.35:-1:+13E-1
  136. -1.35:-1:-13E-1
  137. -0.006:-1:+0E+0
  138. -0.006:-2:+0E+0
  139. $bigfloat::rnd_mode = 'zero'
  140. +2.23:-1:+22E-1
  141. -2.23:-1:-22E-1
  142. +2.27:-1:+23E-1
  143. -2.27:-1:-23E-1
  144. +2.25:-1:+22E-1
  145. -2.25:-1:-22E-1
  146. +2.35:-1:+23E-1
  147. -2.35:-1:-23E-1
  148. -0.0065:-1:+0E+0
  149. -0.0065:-2:-1E-2
  150. -0.0065:-3:-6E-3
  151. -0.0065:-4:-65E-4
  152. -0.0065:-5:-65E-4
  153. $bigfloat::rnd_mode = '+inf'
  154. +3.23:-1:+32E-1
  155. -3.23:-1:-32E-1
  156. +3.27:-1:+33E-1
  157. -3.27:-1:-33E-1
  158. +3.25:-1:+33E-1
  159. -3.25:-1:-32E-1
  160. +3.35:-1:+34E-1
  161. -3.35:-1:-33E-1
  162. -0.0065:-1:+0E+0
  163. -0.0065:-2:-1E-2
  164. -0.0065:-3:-6E-3
  165. -0.0065:-4:-65E-4
  166. -0.0065:-5:-65E-4
  167. $bigfloat::rnd_mode = '-inf'
  168. +4.23:-1:+42E-1
  169. -4.23:-1:-42E-1
  170. +4.27:-1:+43E-1
  171. -4.27:-1:-43E-1
  172. +4.25:-1:+42E-1
  173. -4.25:-1:-43E-1
  174. +4.35:-1:+43E-1
  175. -4.35:-1:-44E-1
  176. -0.0065:-1:+0E+0
  177. -0.0065:-2:-1E-2
  178. -0.0065:-3:-7E-3
  179. -0.0065:-4:-65E-4
  180. -0.0065:-5:-65E-4
  181. $bigfloat::rnd_mode = 'odd'
  182. +5.23:-1:+52E-1
  183. -5.23:-1:-52E-1
  184. +5.27:-1:+53E-1
  185. -5.27:-1:-53E-1
  186. +5.25:-1:+53E-1
  187. -5.25:-1:-53E-1
  188. +5.35:-1:+53E-1
  189. -5.35:-1:-53E-1
  190. -0.0065:-1:+0E+0
  191. -0.0065:-2:-1E-2
  192. -0.0065:-3:-7E-3
  193. -0.0065:-4:-65E-4
  194. -0.0065:-5:-65E-4
  195. $bigfloat::rnd_mode = 'even'
  196. +6.23:-1:+62E-1
  197. -6.23:-1:-62E-1
  198. +6.27:-1:+63E-1
  199. -6.27:-1:-63E-1
  200. +6.25:-1:+62E-1
  201. -6.25:-1:-62E-1
  202. +6.35:-1:+64E-1
  203. -6.35:-1:-64E-1
  204. -0.0065:-1:+0E+0
  205. -0.0065:-2:-1E-2
  206. -0.0065:-3:-6E-3
  207. -0.0065:-4:-65E-4
  208. -0.0065:-5:-65E-4
  209. &fcmp
  210. abc:abc:
  211. abc:+0:
  212. +0:abc:
  213. +0:+0:0
  214. -1:+0:-1
  215. +0:-1:1
  216. +1:+0:1
  217. +0:+1:-1
  218. -1:+1:-1
  219. +1:-1:1
  220. -1:-1:0
  221. +1:+1:0
  222. +123:+123:0
  223. +123:+12:1
  224. +12:+123:-1
  225. -123:-123:0
  226. -123:-12:-1
  227. -12:-123:1
  228. +123:+124:-1
  229. +124:+123:1
  230. -123:-124:1
  231. -124:-123:-1
  232. &fadd
  233. abc:abc:NaN
  234. abc:+0:NaN
  235. +0:abc:NaN
  236. +0:+0:+0E+0
  237. +1:+0:+1E+0
  238. +0:+1:+1E+0
  239. +1:+1:+2E+0
  240. -1:+0:-1E+0
  241. +0:-1:-1E+0
  242. -1:-1:-2E+0
  243. -1:+1:+0E+0
  244. +1:-1:+0E+0
  245. +9:+1:+1E+1
  246. +99:+1:+1E+2
  247. +999:+1:+1E+3
  248. +9999:+1:+1E+4
  249. +99999:+1:+1E+5
  250. +999999:+1:+1E+6
  251. +9999999:+1:+1E+7
  252. +99999999:+1:+1E+8
  253. +999999999:+1:+1E+9
  254. +9999999999:+1:+1E+10
  255. +99999999999:+1:+1E+11
  256. +10:-1:+9E+0
  257. +100:-1:+99E+0
  258. +1000:-1:+999E+0
  259. +10000:-1:+9999E+0
  260. +100000:-1:+99999E+0
  261. +1000000:-1:+999999E+0
  262. +10000000:-1:+9999999E+0
  263. +100000000:-1:+99999999E+0
  264. +1000000000:-1:+999999999E+0
  265. +10000000000:-1:+9999999999E+0
  266. +123456789:+987654321:+111111111E+1
  267. -123456789:+987654321:+864197532E+0
  268. -123456789:-987654321:-111111111E+1
  269. +123456789:-987654321:-864197532E+0
  270. &fsub
  271. abc:abc:NaN
  272. abc:+0:NaN
  273. +0:abc:NaN
  274. +0:+0:+0E+0
  275. +1:+0:+1E+0
  276. +0:+1:-1E+0
  277. +1:+1:+0E+0
  278. -1:+0:-1E+0
  279. +0:-1:+1E+0
  280. -1:-1:+0E+0
  281. -1:+1:-2E+0
  282. +1:-1:+2E+0
  283. +9:+1:+8E+0
  284. +99:+1:+98E+0
  285. +999:+1:+998E+0
  286. +9999:+1:+9998E+0
  287. +99999:+1:+99998E+0
  288. +999999:+1:+999998E+0
  289. +9999999:+1:+9999998E+0
  290. +99999999:+1:+99999998E+0
  291. +999999999:+1:+999999998E+0
  292. +9999999999:+1:+9999999998E+0
  293. +99999999999:+1:+99999999998E+0
  294. +10:-1:+11E+0
  295. +100:-1:+101E+0
  296. +1000:-1:+1001E+0
  297. +10000:-1:+10001E+0
  298. +100000:-1:+100001E+0
  299. +1000000:-1:+1000001E+0
  300. +10000000:-1:+10000001E+0
  301. +100000000:-1:+100000001E+0
  302. +1000000000:-1:+1000000001E+0
  303. +10000000000:-1:+10000000001E+0
  304. +123456789:+987654321:-864197532E+0
  305. -123456789:+987654321:-111111111E+1
  306. -123456789:-987654321:+864197532E+0
  307. +123456789:-987654321:+111111111E+1
  308. &fmul
  309. abc:abc:NaN
  310. abc:+0:NaN
  311. +0:abc:NaN
  312. +0:+0:+0E+0
  313. +0:+1:+0E+0
  314. +1:+0:+0E+0
  315. +0:-1:+0E+0
  316. -1:+0:+0E+0
  317. +123456789123456789:+0:+0E+0
  318. +0:+123456789123456789:+0E+0
  319. -1:-1:+1E+0
  320. -1:+1:-1E+0
  321. +1:-1:-1E+0
  322. +1:+1:+1E+0
  323. +2:+3:+6E+0
  324. -2:+3:-6E+0
  325. +2:-3:-6E+0
  326. -2:-3:+6E+0
  327. +111:+111:+12321E+0
  328. +10101:+10101:+102030201E+0
  329. +1001001:+1001001:+1002003002001E+0
  330. +100010001:+100010001:+10002000300020001E+0
  331. +10000100001:+10000100001:+100002000030000200001E+0
  332. +11111111111:+9:+99999999999E+0
  333. +22222222222:+9:+199999999998E+0
  334. +33333333333:+9:+299999999997E+0
  335. +44444444444:+9:+399999999996E+0
  336. +55555555555:+9:+499999999995E+0
  337. +66666666666:+9:+599999999994E+0
  338. +77777777777:+9:+699999999993E+0
  339. +88888888888:+9:+799999999992E+0
  340. +99999999999:+9:+899999999991E+0
  341. &fdiv
  342. abc:abc:NaN
  343. abc:+1:abc:NaN
  344. +1:abc:NaN
  345. +0:+0:NaN
  346. +0:+1:+0E+0
  347. +1:+0:NaN
  348. +0:-1:+0E+0
  349. -1:+0:NaN
  350. +1:+1:+1E+0
  351. -1:-1:+1E+0
  352. +1:-1:-1E+0
  353. -1:+1:-1E+0
  354. +1:+2:+5E-1
  355. +2:+1:+2E+0
  356. +10:+5:+2E+0
  357. +100:+4:+25E+0
  358. +1000:+8:+125E+0
  359. +10000:+16:+625E+0
  360. +10000:-16:-625E+0
  361. +999999999999:+9:+111111111111E+0
  362. +999999999999:+99:+10101010101E+0
  363. +999999999999:+999:+1001001001E+0
  364. +999999999999:+9999:+100010001E+0
  365. +999999999999999:+99999:+10000100001E+0
  366. +1000000000:+9:+1111111111111111111111111111111111111111E-31
  367. +2000000000:+9:+2222222222222222222222222222222222222222E-31
  368. +3000000000:+9:+3333333333333333333333333333333333333333E-31
  369. +4000000000:+9:+4444444444444444444444444444444444444444E-31
  370. +5000000000:+9:+5555555555555555555555555555555555555556E-31
  371. +6000000000:+9:+6666666666666666666666666666666666666667E-31
  372. +7000000000:+9:+7777777777777777777777777777777777777778E-31
  373. +8000000000:+9:+8888888888888888888888888888888888888889E-31
  374. +9000000000:+9:+1E+9
  375. +35500000:+113:+3141592920353982300884955752212389380531E-34
  376. +71000000:+226:+3141592920353982300884955752212389380531E-34
  377. +106500000:+339:+3141592920353982300884955752212389380531E-34
  378. +1000000000:+3:+3333333333333333333333333333333333333333E-31
  379. $bigfloat::div_scale = 20
  380. +1000000000:+9:+11111111111111111111E-11
  381. +2000000000:+9:+22222222222222222222E-11
  382. +3000000000:+9:+33333333333333333333E-11
  383. +4000000000:+9:+44444444444444444444E-11
  384. +5000000000:+9:+55555555555555555556E-11
  385. +6000000000:+9:+66666666666666666667E-11
  386. +7000000000:+9:+77777777777777777778E-11
  387. +8000000000:+9:+88888888888888888889E-11
  388. +9000000000:+9:+1E+9
  389. +35500000:+113:+314159292035398230088E-15
  390. +71000000:+226:+314159292035398230088E-15
  391. +106500000:+339:+31415929203539823009E-14
  392. +1000000000:+3:+33333333333333333333E-11
  393. $bigfloat::div_scale = 40
  394. &fsqrt
  395. +0:+0E+0
  396. -1:NaN
  397. -2:NaN
  398. -16:NaN
  399. -123.456:NaN
  400. +1:+1E+0
  401. +1.44:+12E-1
  402. +2:+141421356237309504880168872420969807857E-38
  403. +4:+2E+0
  404. +16:+4E+0
  405. +100:+1E+1
  406. +123.456:+1111107555549866648462149404118219234119E-38
  407. +15241.383936:+123456E-3
  408.