File: _2exp.t

package info (click to toggle)
libmath-mpfr-perl 3.23-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 856 kB
  • ctags: 51
  • sloc: perl: 507; makefile: 2
file content (193 lines) | stat: -rw-r--r-- 5,868 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
use warnings;
use strict;
use Math::MPFR qw(:mpfr);
#use Devel::Peek;

print "1..3\n";

my ($exp, $ret);
my $rop   = Math::MPFR->new();
my $op1   = Math::MPFR->new(64.75);
my $op2   = Math::MPFR->new(0.25);
my $nan   = Math::MPFR->new();
my $zero  = Math::MPFR->new(0);
my $unity = Math::MPFR->new(1);
my $inf   = $unity / $zero;
my $ninf  = -($inf);
my $nzero = $zero * -1;
my $ok = '';

if((MPFR_VERSION_MAJOR == 3 && MPFR_VERSION_MINOR >= 1) || MPFR_VERSION_MAJOR > 3) {
  $ret = Rmpfr_frexp($exp, $rop, $op1, GMP_RNDN);
  if($ret == 0 && $exp == 7 && $rop == 0.505859375) {$ok .= 'a'}
  #print "$ret $exp $rop\n", $rop * (2 ** $exp), "\n\n";

  $ret = Rmpfr_frexp($exp, $rop, $op2, GMP_RNDN);
  if($ret == 0 && $exp == -1 && $rop == 0.5) {$ok .= 'b'}
  #print "$ret $exp $rop\n", $rop * (2 ** $exp), "\n\n";

  $ret = Rmpfr_frexp($exp, $rop, -$op1, GMP_RNDN);
  if($ret == 0 && $exp == 7 && $rop == -0.505859375) {$ok .= 'c'}
  #print "$ret $exp $rop\n", $rop * (2 ** $exp), "\n\n";

  $ret = Rmpfr_frexp($exp, $rop, -$op2, GMP_RNDN);
  if($ret == 0 && $exp == -1 && $rop == -0.5) {$ok .= 'd'}
  #print "$ret $exp $rop\n", $rop * (2 ** $exp), "\n\n";

  $ret = Rmpfr_frexp($exp, $rop, $zero, GMP_RNDN);
  if($ret == 0 && $exp == 0 && $rop == 0 && Rmpfr_sgn($rop) == 0 && !Rmpfr_signbit($rop)) {$ok .= 'e'}
  #print "$ret $exp $rop\n", $rop * (2 ** $exp), "\n\n";

  $ret = Rmpfr_frexp($exp, $rop, $nzero, GMP_RNDN);
  if($ret == 0 && $exp == 0 && $rop == 0 && !Rmpfr_sgn($rop) && Rmpfr_signbit($rop)) {$ok .= 'f'}
  #print "$ret $exp $rop\n", $rop * (2 ** $exp), "\n\n";

  $ret = Rmpfr_frexp($exp, $rop, $nan, GMP_RNDN);
  if($ret == 0 && Rmpfr_nan_p($rop)) {$ok .= 'g'}
  #print "$ret $exp $rop\n", $rop * (2 ** $exp), "\n\n";

  $ret = Rmpfr_frexp($exp, $rop, $inf, GMP_RNDN);
  if($ret == 0 && Rmpfr_inf_p($rop) && !Rmpfr_signbit($rop)) {$ok .= 'h'}
  #print "$ret $exp $rop\n", $rop * (2 ** $exp), "\n\n";

  $ret = Rmpfr_frexp($exp, $rop, $ninf, GMP_RNDN);
  if($ret == 0 && Rmpfr_inf_p($rop) && Rmpfr_signbit($rop)) {$ok .= 'i'}
  #print "$ret $exp $rop\n", $rop * (2 ** $exp), "\n\n";

  if($ok eq 'abcdefghi') {print "ok 1\n"}
  else {
    warn "1: \$ok: $ok\n";
    print "not ok 1\n";
  }
}
else {
  eval{Rmpfr_frexp($exp, $rop, $op1, GMP_RNDN);};
  if($@ =~ /Rmpfr_frexp not implemented/) {print "ok 1\n"}
  else {
    warn "\$\@: $@";
    print "not ok 1\n";
  }
}

$ok = '';

$ret = Rmpfr_get_d_2exp($exp, $op1, GMP_RNDN);
if($exp == 7 && $ret == 0.505859375) {$ok .= 'a'}
#print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

$ret = Rmpfr_get_d_2exp($exp, $op2, GMP_RNDN);
if($exp == -1 && $ret == 0.5) {$ok .= 'b'}
#print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

$ret = Rmpfr_get_d_2exp($exp, -$op1, GMP_RNDN);
if($exp == 7 && $ret == -0.505859375) {$ok .= 'c'}
#print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

$ret = Rmpfr_get_d_2exp($exp, -$op2, GMP_RNDN);
if($exp == -1 && $ret == -0.5) {$ok .= 'd'}
#print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

$ret = Rmpfr_get_d_2exp($exp, $zero, GMP_RNDN);
if($exp == 0 && is_pzero($ret)) {$ok .= 'e'}
#print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

$ret = Rmpfr_get_d_2exp($exp, $nzero, GMP_RNDN);
if($exp == 0 && is_nzero($ret)) {$ok .= 'f'}
#print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

$ret = Rmpfr_get_d_2exp($exp, $nan, GMP_RNDN);
if(is_nan($ret)) {$ok .= 'g'}
#print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

$ret = Rmpfr_get_d_2exp($exp, $inf, GMP_RNDN);
if(is_pinf($ret)) {$ok .= 'h'}
#print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

$ret = Rmpfr_get_d_2exp($exp, $ninf, GMP_RNDN);
if(is_ninf($ret)) {$ok .= 'i'}
#print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

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

$ok = '';

if(Math::MPFR::_has_longdouble()) {
  $ret = Rmpfr_get_ld_2exp($exp, $op1, GMP_RNDN);
  if($exp == 7 && $ret == 0.505859375) {$ok .= 'a'}
  #print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

  $ret = Rmpfr_get_ld_2exp($exp, $op2, GMP_RNDN);
  if($exp == -1 && $ret == 0.5) {$ok .= 'b'}
  #print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

  $ret = Rmpfr_get_ld_2exp($exp, -$op1, GMP_RNDN);
  if($exp == 7 && $ret == -0.505859375) {$ok .= 'c'}
  #print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

  $ret = Rmpfr_get_ld_2exp($exp, -$op2, GMP_RNDN);
  if($exp == -1 && $ret == -0.5) {$ok .= 'd'}
  #print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

  $ret = Rmpfr_get_ld_2exp($exp, $zero, GMP_RNDN);
  if($exp == 0 && is_pzero($ret)) {$ok .= 'e'}
  #print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

  $ret = Rmpfr_get_ld_2exp($exp, $nzero, GMP_RNDN);
  if($exp == 0 && is_nzero($ret)) {$ok .= 'f'}
  #print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

  $ret = Rmpfr_get_ld_2exp($exp, $nan, GMP_RNDN);
  if(is_nan($ret)) {$ok .= 'g'}
  #print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

  $ret = Rmpfr_get_ld_2exp($exp, $inf, GMP_RNDN);
  if(is_pinf($ret)) {$ok .= 'h'}
  #print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

  $ret = Rmpfr_get_ld_2exp($exp, $ninf, GMP_RNDN);
  if(is_ninf($ret)) {$ok .= 'i'}
  #print "$ret $exp\n", $ret * (2 ** $exp), "\n\n";

  if($ok eq 'abcdefghi') {print "ok 3\n"}
  else {
    warn "3: \$ok: $ok\n";
    print "not ok 3\n";
  }
}
else {
  warn "Skipping test 3 - no long double support\n";
  print "ok 3\n";
}

sub is_nan {
    return Rmpfr_nan_p(Math::MPFR->new($_[0]));
}

sub is_pinf {
    my $x = Math::MPFR->new($_[0]);
    if(Rmpfr_inf_p($x) && !Rmpfr_signbit($x)) {return 1}
    return 0;
}

sub is_ninf {
    my $x = Math::MPFR->new($_[0]);
    if(Rmpfr_inf_p($x) && Rmpfr_signbit($x)) {return 1}
    return 0;
}

sub is_pzero {
    my $x = Math::MPFR->new($_[0]);
    if(Rmpfr_zero_p($x) && !Rmpfr_signbit($x)) {return 1}
    return 0;
}

sub is_nzero {
    my $x = Math::MPFR->new($_[0]);
    if(Rmpfr_zero_p($x) && Rmpfr_signbit($x)) {return 1}
    return 0;
}