The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use strict;
use warnings;
use Math::Float128 qw(:all);

print "1..13\n";

my $uv = ~0;
my $iv = -21;
my $nv = -17.1;
my $str = "-17.1";
my $strp = "17.1";
my $obj = Math::Float128->new(19.0);
my $nan = F128toNV(Math::Float128->new());

my $zero = ZeroF128(-1);
my $one = UnityF128(1);
my $div;
my $ok = '';

# !=

$div = Math::Float128->new($uv) - 1;
if($uv != $div) {$ok .= 'a'}
else {warn "\n1a: ", $div, "\n"}

$div = Math::Float128->new($iv) + 0.1;
if($iv != $div) {$ok .= 'b'}
else {warn "\n1b: ", $div, "\n"}

$div = Math::Float128->new($nv) + 0.1;
if($nv != $div) {$ok .= 'c'}
else {warn "\n1c: ", $div, "\n"}

$div = Math::Float128->new("$str") + 0.1;
if("$str" != $div) {$ok .= 'd'}
else {warn "\n1d: ", $div, "\n"}

$div = Math::Float128->new($obj) + 0.1;
if($obj != $div) {$ok .= 'e'}
else {warn "\n1e: ", $div, "\n"}

unless($nan == $div) {$ok .= 'f'}
else {warn "\n1f: ", $div == $nan, "\n"}

if($nan != $div) {$ok .= 'g'}
else {warn "\n1g: ", $div != $nan, "\n"}

if($ok eq 'abcdefg') {print "ok 1\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 1\n";
}

$ok = '';

#############

# >=

$div = Math::Float128->new($uv) - 0.1;
if($uv >= $div) {$ok .= 'a'}
else {warn "\n2a: ", $div, "\n"}

$div = Math::Float128->new($iv) - 0.1;
if($iv >= $div) {$ok .= 'b'}
else {warn "\n2b: ", $div, "\n"}

$div = Math::Float128->new($nv) - 0.1;
if($nv >= $div) {$ok .= 'c'}
else {warn "\n2c: ", $div, "\n"}

$div = Math::Float128->new("$str") - 0.1;
if("$str" >= $div) {$ok .= 'd'}
else {warn "\n2d: ", $div, "\n"}

$div = Math::Float128->new($obj) - 0.1;
if($obj >= $div) {$ok .= 'e'}
else {warn "\n2e: ", $div, "\n"}

if($ok eq 'abcde') {print "ok 2\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 2\n";
}

$ok = '';

#############

# >=

$div = Math::Float128->new($uv);
if($uv >= $div) {$ok .= 'a'}
else {warn "\n3a: ", $div, "\n"}

$div = Math::Float128->new($iv);
if($iv >= $div) {$ok .= 'b'}
else {warn "\n3b: ", $div, "\n"}

$div = Math::Float128->new($nv);
if($nv >= $div) {$ok .= 'c'}
else {warn "\n3c: ", $div, "\n"}

$div = Math::Float128->new("$str");
if("$str" >= $div) {$ok .= 'd'}
else {warn "\n3d: ", $div, "\n"}

$div = Math::Float128->new($obj);
if($obj >= $div) {$ok .= 'e'}
else {warn "\n3e: ", $div, "\n"}

unless($nan >= $div) {$ok .= 'f'}
else {warn "\n3f: ", $div <= $nan, "\n"}

if($ok eq 'abcdef') {print "ok 3\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 3\n";
}

$ok = '';

#############

# >

$div = Math::Float128->new($uv) - 1;
if($uv > $div) {$ok .= 'a'}
else {warn "\n4a: ", $div, "\n"}

$div = Math::Float128->new($iv) - 0.1;
if($iv > $div) {$ok .= 'b'}
else {warn "\n4b: ", $div, "\n"}

$div = Math::Float128->new($nv) - 0.1;
if($nv > $div) {$ok .= 'c'}
else {warn "\n4c: ", $div, "\n"}

$div = Math::Float128->new("$str") - 0.1;
if("$str" > $div) {$ok .= 'd'}
else {warn "\n4d: ", $div, "\n"}

$div = Math::Float128->new($obj) - 0.1;
if($obj > $div) {$ok .= 'e'}
else {warn "\n4e: ", $div, "\n"}

unless($nan > $div) {$ok .= 'f'}
else {warn "\n4f: ", $div < $nan, "\n"}

if($ok eq 'abcdef') {print "ok 4\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 4\n";
}

$ok = '';

#############

# <=

$div = Math::Float128->new($uv) + 0.1;
if($uv <= $div) {$ok .= 'a'}
else {warn "\n5a: ", $div, "\n"}

$div = Math::Float128->new($iv) + 0.1;
if($iv <= $div) {$ok .= 'b'}
else {warn "\n5b: ", $div, "\n"}

$div = Math::Float128->new($nv) + 0.1;
if($nv <= $div) {$ok .= 'c'}
else {warn "\n5c: ", $div, "\n"}

$div = Math::Float128->new("$str") + 0.1;
if("$str" <= $div) {$ok .= 'd'}
else {warn "\n5d: ", $div, "\n"}

$div = Math::Float128->new($obj) + 0.1;
if($obj <= $div) {$ok .= 'e'}
else {warn "\n5e: ", $div, "\n"}

if($ok eq 'abcde') {print "ok 5\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 5\n";
}

$ok = '';

#############

# <=

$div = Math::Float128->new($uv);
if($uv <= $div) {$ok .= 'a'}
else {warn "\n6a: ", $div, "\n"}

$div = Math::Float128->new($iv);
if($iv <= $div) {$ok .= 'b'}
else {warn "\n6b: ", $div, "\n"}

$div = Math::Float128->new($nv);
if($nv <= $div) {$ok .= 'c'}
else {warn "\n6c: ", $div, "\n"}

$div = Math::Float128->new("$str");
if("$str" <= $div) {$ok .= 'd'}
else {warn "\n6d: ", $div, "\n"}

$div = Math::Float128->new($obj);
if($obj <= $div) {$ok .= 'e'}
else {warn "\n6e: ", $div, "\n"}

unless($nan <= $div) {$ok .= 'f'}
else {warn "\n6f: ", $div >= $nan, "\n"}

if($ok eq 'abcdef') {print "ok 6\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 6\n";
}

$ok = '';

#############

# <

$div = Math::Float128->new($uv) + 1;
if($uv < $div) {$ok .= 'a'}
else {warn "\n7a: ", $div, "\n"}

$div = Math::Float128->new($iv) + 0.1;
if($iv < $div) {$ok .= 'b'}
else {warn "\n7b: ", $div, "\n"}

$div = Math::Float128->new($nv) + 0.1;
if($nv < $div) {$ok .= 'c'}
else {warn "\n7c: ", $div, "\n"}

$div = Math::Float128->new("$str") + 0.1;
if("$str" < $div) {$ok .= 'd'}
else {warn "\n7d: ", $div, "\n"}

$div = Math::Float128->new($obj) + 0.1;
if($obj < $div) {$ok .= 'e'}
else {warn "\n7e: ", $div, "\n"}

unless($nan < $div) {$ok .= 'f'}
else {warn "\n7f: ", $div > $nan, "\n"}

if($ok eq 'abcdef') {print "ok 7\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 7\n";
}

$ok = '';

#############

# <=>

$div = Math::Float128->new($uv) + 1;
if(($uv <=> $div) < 0) {$ok .= 'a'}
else {warn "\n8a: ", $div, "\n"}

$div = Math::Float128->new($iv) + 0.1;
if(($iv <=> $div) < 0) {$ok .= 'b'}
else {warn "\n8b: ", $div, "\n"}

$div = Math::Float128->new($nv) + 0.1;
if(($nv <=> $div) < 0) {$ok .= 'c'}
else {warn "\n8c: ", $div, "\n"}

$div = Math::Float128->new("$str") + 0.1;
if(("$str" <=> $div) < 0) {$ok .= 'd'}
else {warn "\n8d: ", $div, "\n"}

$div = Math::Float128->new($obj) + 0.1;
if(($obj <=> $div) < 0) {$ok .= 'e'}
else {warn "\n8e: ", $div, "\n"}

if($ok eq 'abcde') {print "ok 8\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 8\n";
}

$ok = '';

#############

# <=>

$div = Math::Float128->new($uv) - 1;
if(($uv <=> $div) > 0) {$ok .= 'a'}
else {warn "\n9a: ", $div, "\n"}

$div = Math::Float128->new($iv) - 0.1;
if(($iv <=> $div) > 0) {$ok .= 'b'}
else {warn "\n9b: ", $div, "\n"}

$div = Math::Float128->new($nv) - 0.1;
if(($nv <=> $div) > 0) {$ok .= 'c'}
else {warn "\n9c: ", $div, "\n"}

$div = Math::Float128->new("$str") - 0.1;
if(("$str" <=> $div) > 0) {$ok .= 'd'}
else {warn "\n9d: ", $div, "\n"}

$div = Math::Float128->new($obj) - 0.1;
if(($obj <=> $div) > 0) {$ok .= 'e'}
else {warn "\n9e: ", $div, "\n"}

if($ok eq 'abcde') {print "ok 9\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 9\n";
}

$ok = '';

#############

# <=>

$div = Math::Float128->new($uv);
if(defined($uv <=> $div) && ($uv <=> $div) == 0) {$ok .= 'a'}
else {warn "\n10a: ", $div, "\n"}

$div = Math::Float128->new($iv);
if(defined($iv <=> $div) && ($iv <=> $div) == 0) {$ok .= 'b'}
else {warn "\n10b: ", $div, "\n"}

$div = Math::Float128->new($nv);
if(defined($nv <=> $div) && ($nv <=> $div) == 0) {$ok .= 'c'}
else {warn "\n10c: ", $div, "\n"}

$div = Math::Float128->new("$str");
if(defined("$str" <=> $div) && ("$str" <=> $div) == 0) {$ok .= 'd'}
else {warn "\n10d: ", $div, "\n"}

$div = Math::Float128->new($obj);
if(defined($obj <=> $div) && ($obj <=> $div) == 0) {$ok .= 'e'}
else {warn "\n10e: ", $div, "\n"}

if(!defined($nan <=> $div)) {$ok .= 'f'}
else {warn "\n10f: ", $nan <=> $div, "\n"}


if($ok eq 'abcdef') {print "ok 10\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 10\n";
}

$ok = '';

#############

# <=>

if(!defined($uv <=> NaNF128())) {$ok .= 'a'}
else {warn "\n11a: ", NaNF128() <=> $uv, "\n"}

if(!defined($iv <=> NaNF128())) {$ok .= 'b'}
else {warn "\n11b: ", NaNF128() <=> $iv, "\n"}

if(!defined($nv <=> NaNF128())) {$ok .= 'c'}
else {warn "\n11c: ", NaNF128() <=> $nv, "\n"}

if(!defined("$str" <=> NaNF128())) {$ok .= 'd'}
else {warn "\n11d: ", NaNF128() <=> "$str", "\n"}

if(!defined($obj <=> NaNF128())) {$ok .= 'e'}
else {warn "\n11e: ", NaNF128() <=> $obj, "\n"}

if($ok eq 'abcde') {print "ok 11\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 11\n";
}

$ok = '';

#############

# **

my $check = $uv ** Math::Float128->new(0);

if(Math::Float128::_itsa($check) == 113) {$ok .= 'a'}
else {
  warn "\n12a: Expected _itsa() to return 113, but got ", Math::Float128::_itsa($check), "\n";
}

if($check == 1) {$ok .= 'b'}
else {
  warn "\n12b: Expected 1, got $check\n";
}

$check = $uv ** Math::Float128->new(1.0);

if(Math::Float128::_itsa($check) == 113) {$ok .= 'c'}
else {
  warn "\n12c: Expected _itsa() to return 113, but got ", Math::Float128::_itsa($check), "\n";
}

if($check == ~0) {$ok .= 'd'}
else {
  warn "\n12d: Expected ", ~0, " got $check\n";
}

if(-2 ** Math::Float128->new(3.0) == -8) {$ok .= 'e'}
else {
  warn "\n12e: Expected -8, got ", -2 ** Math::Float128->new(3.0), "\n";
}

if(4 ** Math::Float128->new(2.5) == 32) {$ok .= 'f'}
else {
  warn "\n12f: Expected 32, got ", 4 ** Math::Float128->new(2.5), "\n";
}

if(2.5 ** Math::Float128->new(2) == 6.25) {$ok .= 'g'}
else {
  warn "\n12g: Expected 6.25, got ", 2.5 ** Math::Float128->new(2), "\n";
}

$check = '2.5' ** Math::Float128->new(2);

if($check == 6.25) {$ok .= 'h'}
else {
  warn "\n12h: Expected 6.25, got $check\n";
}

if($ok eq 'abcdefgh') {print "ok 12\n"}
else {
  warn "\n\$ok: $ok\n";
  print "not ok 12\n";
}

$ok = '';

if(Math::Float128::_itsa($uv) == 1) {print "ok 13\n"}
else {
  warn "\nExpected 1, got ", Math::Float128::_itsa($uv), "\n";
  print "not ok 13\n";
}