ttrig1.pp 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. program test03;
  2. uses
  3. {$IFDEF CPU86}
  4. CMem,
  5. {$ENDIF}
  6. SysUtils,Math;
  7. const
  8. dim = 36;
  9. MaxFloat = 1.1000000000000000E+4932;
  10. // from dcc
  11. sinus : array[1..dim] of double = (
  12. 1.7364817766693035E-0001, 3.4202014332566873E-0001, 5.0000000000000000E-0001, 6.4278760968653933E-0001,
  13. 7.6604444311897804E-0001, 8.6602540378443865E-0001, 9.3969262078590838E-0001, 9.8480775301220806E-0001,
  14. 1.0000000000000000E+0000, 9.8480775301220806E-0001, 9.3969262078590838E-0001, 8.6602540378443865E-0001,
  15. 7.6604444311897804E-0001, 6.4278760968653933E-0001, 5.0000000000000000E-0001, 3.4202014332566873E-0001,
  16. 1.7364817766693035E-0001,-5.4210108624275222E-0020,-1.7364817766693035E-0001,-3.4202014332566873E-0001,
  17. -5.0000000000000000E-0001,-6.4278760968653933E-0001,-7.6604444311897804E-0001,-8.6602540378443865E-0001,
  18. -9.3969262078590838E-0001,-9.8480775301220806E-0001,-1.0000000000000000E+0000,-9.8480775301220806E-0001,
  19. -9.3969262078590838E-0001,-8.6602540378443865E-0001,-7.6604444311897804E-0001,-6.4278760968653933E-0001,
  20. -5.0000000000000000E-0001,-3.4202014332566873E-0001,-1.7364817766693035E-0001, 1.0842021724855044E-0019
  21. );
  22. var
  23. i : integer;
  24. Delta,Ref,Value : Double;
  25. begin
  26. for i:=1 to dim do
  27. begin
  28. // Generate constant array above output
  29. write(sin(i*10/180.0*pi),',');
  30. if i mod 4 = 0 then writeln;
  31. end;
  32. writeln('Testing SIN');
  33. for i:=1 to dim do
  34. begin
  35. Ref:=sinus[i];
  36. Value:=sin(i*10/180.0*pi);
  37. Delta := Value - Ref;
  38. if Abs(Delta) > 1E-15 then
  39. begin
  40. writeln(' Error for Sin(',i*10,') was:',Value,' should be:',Ref) ;
  41. halt(1);
  42. end;
  43. end;
  44. writeln('Testing COS');
  45. for i:=1 to dim do
  46. begin
  47. Ref := sin(pi/2-i*10/180*pi);
  48. Value := cos(i*10/180*pi);
  49. Delta := Value - Ref;
  50. if Abs(Delta) > 1E-15 then
  51. begin
  52. writeln(' Error for Cos(',i*10,') was:',Value,' should be:',Ref) ;
  53. halt(1);
  54. end;
  55. end;
  56. writeln('Testing TAN');
  57. for i:=1 to dim do
  58. begin
  59. { if i=9 then Ref := MaxFloat
  60. else if i=27 then Ref := -Maxfloat
  61. else } Ref:=sin(i*10/180*pi)/cos(i*10/180*pi);
  62. Value := tan(i*10/180*pi);
  63. Delta := Value - Ref;
  64. if Abs(Delta) > 1E-15 then
  65. begin
  66. writeln(' Error for Tan(',i*10,') was:',Value,' should be:',Ref) ;
  67. halt(1);
  68. end;
  69. end;
  70. writeln('Testing ARCTAN...');
  71. for i:=1 to 8 do
  72. begin
  73. Ref := i*10;
  74. Value := arctan(tan(i*10/180*pi))/pi*180;
  75. Delta := Value - Ref;
  76. if Abs(Delta) > 1E-14 then
  77. begin
  78. writeln(' Error for ArcTan(',i*10,') was:',Value,' should be:',Ref);
  79. halt(1);
  80. end;
  81. end;
  82. for i:=-1 downto -8 do
  83. begin
  84. Ref := i*10;
  85. Value := arctan(tan(i*10/180*pi))/pi*180;
  86. Delta := Value - Ref;
  87. if Abs(Delta) > 1E-14 then
  88. begin
  89. writeln(' Error for ArcTan(',i*10,') was:',Value,' should be:',Ref);
  90. halt(1);
  91. end;
  92. end;
  93. writeln('Tan +/- 90 deg test:');
  94. writeln('tan(89.999):',tan(89.999/180*pi));
  95. writeln('tan(90.000):',tan(90.000/180*pi));
  96. writeln('tan(-89.999):',tan(-89.999/180*pi));
  97. writeln('tan(-90.000):',tan(-90.000/180*pi));
  98. writeln('ArcTan2 kwadrants:');
  99. writeln('Kwadrant 1 ( 1, 1):',arctan2( 1, 1)/pi*180:5:1,' deg');
  100. writeln('Kwadrant 2 (-1, 1):',arctan2( 1,-1)/pi*180:5:1,' deg');
  101. writeln('Kwadrant 3 (-1,-1):',arctan2(-1,-1)/pi*180:5:1,' deg');
  102. writeln('Kwadrant 4 ( 1,-1):',arctan2(-1, 1)/pi*180:5:1,' deg');
  103. writeln('ArcTan2 special cases:');
  104. writeln('Kwadrant X ( 0, 0):',arctan2( 0, 0)/pi*180:5:1,' deg');
  105. writeln('Kwadrant 1 ( 1, 0):',arctan2( 0, 1)/pi*180:5:1,' deg');
  106. writeln('Kwadrant 2 ( 0, 1):',arctan2( 1, 0)/pi*180:5:1,' deg');
  107. writeln('Kwadrant 3 (-1, 0):',arctan2( 0,-1)/pi*180:5:1,' deg');
  108. writeln('Kwadrant 4 ( 0,-1):',arctan2(-1, 0)/pi*180:5:1,' deg');
  109. end.