Test suite results for test file webtbs/tw0788.pp

Test run data :

Free Pascal Compiler Test Suite Results

View Test suite results

Please specify search criteria:
File:
Operating system:
Processor:
Version
Date
Submitter
Machine
Comment
Limit
Cond
Category
Only failed tests
Hide skipped tests
List all tests

Test file "webtbs/tw0788.pp" information:

t_id 693
t_adddate 2003/10/03
t_result 0
t_knownrunerror 0

Detailed test run results:

Record count: 50

Total = 50

OK=50 Percentage= 100.00

Result type Cat. Count Percentage First date Last Date
Successfully run 50 100.0 2024/05/17 11:04:00 38 2024/05/17 16:28:00 32
i386 10 20.0 2024/05/17 11:29:00 44 2024/05/17 12:24:00 45
sparc 1 2.0 2024/05/17 12:01:00 74 2024/05/17 12:01:00 74
powerpc 1 2.0 2024/05/17 11:30:00 242 2024/05/17 11:30:00 242
x86_64 26 52.0 2024/05/17 11:10:00 26 2024/05/17 14:42:00 39
powerpc64 2 4.0 2024/05/17 11:34:00 242 2024/05/17 11:39:00 59
mips 1 2.0 2024/05/17 11:21:00 241 2024/05/17 11:21:00 241
aarch64 7 14.0 2024/05/17 11:04:00 38 2024/05/17 16:28:00 32
sparc64 1 2.0 2024/05/17 12:19:00 173 2024/05/17 12:19:00 173
riscv64 1 2.0 2024/05/17 11:56:00 31 2024/05/17 11:56:00 31
linux 35 70.0 2024/05/17 11:04:00 38 2024/05/17 12:48:00 22
solaris 10 20.0 2024/05/17 11:29:00 44 2024/05/17 12:24:00 45
darwin 3 6.0 2024/05/17 16:15:00 32 2024/05/17 16:28:00 32
win64 2 4.0 2024/05/17 13:34:00 47 2024/05/17 14:42:00 39
3.3.1 19 38.0 2024/05/17 11:10:00 26 2024/05/17 14:42:00 39
3.2.2 10 20.0 2024/05/17 11:29:00 44 2024/05/17 12:24:00 45
3.2.3 21 42.0 2024/05/17 11:04:00 38 2024/05/17 16:28:00 32

Source:

{$ifdef FPC}
Uses Math;

{$else not FPC}
function degtorad(deg : extended) : extended;

  begin
     degtorad:=deg*(pi/180.0);
  end;

function radtodeg(rad : extended) : extended;

  begin
     radtodeg:=rad*(180.0/pi);
  end;

 function ArcSin(x : extended) : extended;
   begin
     if abs(x)=1.0 then
       arcsin:=Pi/2
     else
       arcsin:=ArcTan(x/sqrt(1-x*x));
   end;
 function ArcTan2(x,y : extended) : extended;
   begin
     ArcTan2:=ArcTan(x/y);
   end;
{$endif not FPC}

Var
   I : Integer;
   RI,RRI,R0 : extended;

Begin
   For I := -179 To 179 Do
   Begin
      RI:=I;
      WriteLn( RadToDeg(ArcSin(Sin(DegToRad(RI)))):3:18);
   End;
   For I := -89 To 89 Do
   Begin
      RI:=I;
      RRI:=RadToDeg(ArcSin( Sin(DegToRad(RI))));
      WriteLn(RI:3:18,' ',RRI:3:18);
      If RI<>RRI then
        begin
          Writeln('Not exact ',RRI-RI:3:18);
          if I<>0 then
            begin
              Writeln('Percentage error = ',Abs(RRI -RI) *100 / I:3:18);
              if abs((RRI -RI) *100 / I)>0.0001 then
                Begin
                  Writeln('Error too big ');
                  Halt(1);
                end;
            end;
        end;
   End;
   RI:=3;
   RRI:=1;
   R0:=1;
   Writeln(  ArcTan2(ArcTan2(1,1),R0):3:18 , ' should be 0.66577375...');
   if ArcTan2(ArcTan2(1,1),R0)<>ArcTan(ArcTan(1)/R0) then
     begin
       Writeln('There is still a bug in ArcTan2 !');
       Halt(1);
     end;
End.

Link to SVN view of webtbs/tw0788.pp source.