Test suite results for test file tbs/tb0185.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 "tbs/tb0185.pp" information:

t_id 420
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/09/26 18:42:00 90 2024/09/26 23:02:00 44
i386 4 8.0 2024/09/26 19:54:00 70 2024/09/26 22:38:00 79
powerpc 14 28.0 2024/09/26 19:41:00 35 2024/09/26 23:02:00 44
powerpc64 17 34.0 2024/09/26 18:42:00 90 2024/09/26 22:29:00 103
wasm32 7 14.0 2024/09/26 19:31:00 339 2024/09/26 22:50:00 299
riscv64 8 16.0 2024/09/26 19:14:00 123 2024/09/26 19:59:00 123
linux 39 78.0 2024/09/26 18:42:00 90 2024/09/26 23:02:00 44
go32v2 4 8.0 2024/09/26 19:54:00 70 2024/09/26 22:38:00 79
wasi 7 14.0 2024/09/26 19:31:00 339 2024/09/26 22:50:00 299
3.3.1 34 68.0 2024/09/26 18:42:00 90 2024/09/26 22:50:00 299
3.2.3 16 32.0 2024/09/26 21:17:00 71 2024/09/26 23:02:00 44

Source:

{ Old file: tbs0218.pp }
{ rounding errors with write/str (the bugs is fixed,    OK 0.99.11 (FK) }

Program Wrong_Output;
{}
Var r,rr,error:Extended;
    s:String;
    code : word;
{}
Begin
  Writeln('Size of Extended type (r)=',SizeOf(r),' bytes');
  r:=0.000058184639;
  Writeln('r=',r);
  Writeln('r=',r:16:13);
  Writeln('r=',r:15:12);
  Writeln('r=',r:14:11);
  Writeln('r=',r:13:10);
  Writeln('r=',r:12:9);
  Writeln('r=',r:11:8);
  Writeln('r=',r:10:7);
  Writeln('r=',r:9:6);
  Writeln('r=',r:8:5);
  Writeln('r=',r:7:4);
  Str(r,s);
  Writeln('r=',s,' (as string)');
  str(r,s);
  val(s,rr,code);
  { calculate maximum possible precision }
  if sizeof(extended) = 12 then
    error := exp(17*ln(10))
  else if sizeof(extended) = 10 then
    error := exp(17*ln(10))
  else if sizeof(extended) = 8 then
    error := exp(14*ln(10))
  else if sizeof(extended) = 4 then
    { the net may have to be 9 instead of 8, not sure }
    error := exp(8*ln(10))
  else
    begin
      Writeln('unknown extended type size!');
      halt(1)
    end;
  if abs(r-rr) > error then
    begin
      Writeln('r=',r);
      Writeln('is different from rr=',rr);
      halt(1);
    end;
End.

Link to SVN view of tbs/tb0185.pp source.