1bigrat(3) User Contributed Perl Documentation bigrat(3)
2
3
4
6 bigrat - transparent big rational number support for Perl
7
9 use bigrat;
10
11 print 2 + 4.5; # Math::BigRat 13/2
12 print 1/3 + 1/4; # Math::BigRat 7/12
13 print inf + 42; # Math::BigRat inf
14 print NaN * 7; # Math::BigRat NaN
15 print hex("0x1234567890123490"); # Perl v5.10.0 or later
16
17 {
18 no bigrat;
19 print 1/3; # 0.33333...
20 }
21
22 # for older Perls, import into current package:
23 use bigrat qw/hex oct/;
24 print hex("0x1234567890123490");
25 print oct("01234567890123490");
26
28 All numeric literal in the given scope are converted to Math::BigRat
29 objects.
30
31 All operators (including basic math operations) except the range
32 operator ".." are overloaded.
33
34 So, the following:
35
36 use bigrat;
37 $x = 1234;
38
39 creates a Math::BigRat and stores a reference to in $x. This happens
40 transparently and behind your back, so to speak.
41
42 You can see this with the following:
43
44 perl -Mbigrat -le 'print ref(1234)'
45
46 Since numbers are actually objects, you can call all the usual methods
47 from Math::BigRat on them. This even works to some extent on
48 expressions:
49
50 perl -Mbigrat -le '$x = 1234; print $x->bdec()'
51 perl -Mbigrat -le 'print 1234->copy()->binc();'
52 perl -Mbigrat -le 'print 1234->copy()->binc->badd(6);'
53 perl -Mbigrat -le 'print +(1234)->copy()->binc()'
54
55 (Note that print doesn't do what you expect if the expression starts
56 with '(' hence the "+")
57
58 You can even chain the operations together as usual:
59
60 perl -Mbigrat -le 'print 1234->copy()->binc->badd(6);'
61 1241
62
63 Please note the following does not work as expected (prints nothing),
64 since overloading of '..' is not yet possible in Perl (as of v5.8.0):
65
66 perl -Mbigrat -le 'for (1..2) { print ref($_); }'
67
68 Options
69 "bigrat" recognizes some options that can be passed while loading it
70 via "use". The following options exist:
71
72 a or accuracy
73 This sets the accuracy for all math operations. The argument must
74 be greater than or equal to zero. See Math::BigInt's bround()
75 method for details.
76
77 perl -Mbigrat=a,50 -le 'print sqrt(20)'
78
79 Note that setting precision and accuracy at the same time is not
80 possible.
81
82 p or precision
83 This sets the precision for all math operations. The argument can
84 be any integer. Negative values mean a fixed number of digits after
85 the dot, while a positive value rounds to this digit left from the
86 dot. 0 means round to integer. See Math::BigInt's bfround() method
87 for details.
88
89 perl -Mbigrat=p,-50 -le 'print sqrt(20)'
90
91 Note that setting precision and accuracy at the same time is not
92 possible.
93
94 t or trace
95 This enables a trace mode and is primarily for debugging.
96
97 l, lib, try, or only
98 Load a different math lib, see "Math Library".
99
100 perl -Mbigrat=l,GMP -e 'print 2 ** 512'
101 perl -Mbigrat=lib,GMP -e 'print 2 ** 512'
102 perl -Mbigrat=try,GMP -e 'print 2 ** 512'
103 perl -Mbigrat=only,GMP -e 'print 2 ** 512'
104
105 hex Override the built-in hex() method with a version that can handle
106 big numbers. This overrides it by exporting it to the current
107 package. Under Perl v5.10.0 and higher, this is not so necessary,
108 as hex() is lexically overridden in the current scope whenever the
109 "bigrat" pragma is active.
110
111 oct Override the built-in oct() method with a version that can handle
112 big numbers. This overrides it by exporting it to the current
113 package. Under Perl v5.10.0 and higher, this is not so necessary,
114 as oct() is lexically overridden in the current scope whenever the
115 "bigrat" pragma is active.
116
117 v or version
118 this prints out the name and version of the modules and then exits.
119
120 perl -Mbigrat=v
121
122 Math Library
123 Math with the numbers is done (by default) by a backend library module
124 called Math::BigInt::Calc. The default is equivalent to saying:
125
126 use bigrat lib => 'Calc';
127
128 you can change this by using:
129
130 use bigrat lib => 'GMP';
131
132 The following would first try to find Math::BigInt::Foo, then
133 Math::BigInt::Bar, and if this also fails, revert to
134 Math::BigInt::Calc:
135
136 use bigrat lib => 'Foo,Math::BigInt::Bar';
137
138 Using c<lib> warns if none of the specified libraries can be found and
139 Math::BigInt fell back to one of the default libraries. To suppress
140 this warning, use c<try> instead:
141
142 use bigrat try => 'GMP';
143
144 If you want the code to die instead of falling back, use "only"
145 instead:
146
147 use bigrat only => 'GMP';
148
149 Please see the respective module documentation for further details.
150
151 Method calls
152 Since all numbers are now objects, you can use all methods that are
153 part of the Math::BigRat API.
154
155 But a warning is in order. When using the following to make a copy of a
156 number, only a shallow copy will be made.
157
158 $x = 9; $y = $x;
159 $x = $y = 7;
160
161 Using the copy or the original with overloaded math is okay, e.g., the
162 following work:
163
164 $x = 9; $y = $x;
165 print $x + 1, " ", $y,"\n"; # prints 10 9
166
167 but calling any method that modifies the number directly will result in
168 both the original and the copy being destroyed:
169
170 $x = 9; $y = $x;
171 print $x->badd(1), " ", $y,"\n"; # prints 10 10
172
173 $x = 9; $y = $x;
174 print $x->binc(1), " ", $y,"\n"; # prints 10 10
175
176 $x = 9; $y = $x;
177 print $x->bmul(2), " ", $y,"\n"; # prints 18 18
178
179 Using methods that do not modify, but test that the contents works:
180
181 $x = 9; $y = $x;
182 $z = 9 if $x->is_zero(); # works fine
183
184 See the documentation about the copy constructor and "=" in overload,
185 as well as the documentation in Math::BigFloat for further details.
186
187 Methods
188 inf()
189 A shortcut to return Math::BigRat->binf(). Useful because Perl does
190 not always handle bareword "inf" properly.
191
192 NaN()
193 A shortcut to return Math::BigRat->bnan(). Useful because Perl does
194 not always handle bareword "NaN" properly.
195
196 e
197 # perl -Mbigrat=e -wle 'print e'
198
199 Returns Euler's number "e", aka exp(1).
200
201 PI
202 # perl -Mbigrat=PI -wle 'print PI'
203
204 Returns PI.
205
206 bexp()
207 bexp($power, $accuracy);
208
209 Returns Euler's number "e" raised to the appropriate power, to the
210 wanted accuracy.
211
212 Example:
213
214 # perl -Mbigrat=bexp -wle 'print bexp(1,80)'
215
216 bpi()
217 bpi($accuracy);
218
219 Returns PI to the wanted accuracy.
220
221 Example:
222
223 # perl -Mbigrat=bpi -wle 'print bpi(80)'
224
225 accuracy()
226 Set or get the accuracy.
227
228 precision()
229 Set or get the precision.
230
231 round_mode()
232 Set or get the rounding mode.
233
234 div_scale()
235 Set or get the division scale.
236
237 in_effect()
238 use bigrat;
239
240 print "in effect\n" if bigrat::in_effect; # true
241 {
242 no bigrat;
243 print "in effect\n" if bigrat::in_effect; # false
244 }
245
246 Returns true or false if "bigrat" is in effect in the current
247 scope.
248
249 This method only works on Perl v5.9.4 or later.
250
252 Hexadecimal, octal, and binary floating point literals
253 Perl (and this module) accepts hexadecimal, octal, and binary
254 floating point literals, but use them with care with Perl versions
255 before v5.32.0, because some versions of Perl silently give the
256 wrong result.
257
258 Operator vs literal overloading
259 "bigrat" works by overloading handling of integer and floating
260 point literals, converting them to Math::BigRat objects.
261
262 This means that arithmetic involving only string values or string
263 literals are performed using Perl's built-in operators.
264
265 For example:
266
267 use bigrat;
268 my $x = "900000000000000009";
269 my $y = "900000000000000007";
270 print $x - $y;
271
272 outputs 0 on default 32-bit builds, since "bigrat" never sees the
273 string literals. To ensure the expression is all treated as
274 "Math::BigRat" objects, use a literal number in the expression:
275
276 print +(0+$x) - $y;
277
278 Ranges
279 Perl does not allow overloading of ranges, so you can neither
280 safely use ranges with "bigrat" endpoints, nor is the iterator
281 variable a "Math::BigRat".
282
283 use 5.010;
284 for my $i (12..13) {
285 for my $j (20..21) {
286 say $i ** $j; # produces a floating-point number,
287 # not an object
288 }
289 }
290
291 in_effect()
292 This method only works on Perl v5.9.4 or later.
293
294 hex()/oct()
295 "bigrat" overrides these routines with versions that can also
296 handle big integer values. Under Perl prior to version v5.9.4,
297 however, this will not happen unless you specifically ask for it
298 with the two import tags "hex" and "oct" - and then it will be
299 global and cannot be disabled inside a scope with "no bigrat":
300
301 use bigrat qw/hex oct/;
302
303 print hex("0x1234567890123456");
304 {
305 no bigrat;
306 print hex("0x1234567890123456");
307 }
308
309 The second call to hex() will warn about a non-portable constant.
310
311 Compare this to:
312
313 use bigrat;
314
315 # will warn only under Perl older than v5.9.4
316 print hex("0x1234567890123456");
317
319 perl -Mbigrat -le 'print sqrt(33)'
320 perl -Mbigrat -le 'print 2**255'
321 perl -Mbigrat -le 'print 4.5+2**255'
322 perl -Mbigrat -le 'print 3/7 + 5/7 + 8/3'
323 perl -Mbigrat -le 'print 12->is_odd()';
324 perl -Mbigrat=l,GMP -le 'print 7 ** 7777'
325
327 Please report any bugs or feature requests to "bug-bignum at
328 rt.cpan.org", or through the web interface at
329 <https://rt.cpan.org/Ticket/Create.html?Queue=bignum> (requires login).
330 We will be notified, and then you'll automatically be notified of
331 progress on your bug as I make changes.
332
334 You can find documentation for this module with the perldoc command.
335
336 perldoc bigrat
337
338 You can also look for information at:
339
340 • GitHub
341
342 <https://github.com/pjacklam/p5-bignum>
343
344 • RT: CPAN's request tracker
345
346 <https://rt.cpan.org/Dist/Display.html?Name=bignum>
347
348 • MetaCPAN
349
350 <https://metacpan.org/release/bignum>
351
352 • CPAN Testers Matrix
353
354 <http://matrix.cpantesters.org/?dist=bignum>
355
356 • CPAN Ratings
357
358 <https://cpanratings.perl.org/dist/bignum>
359
361 This program is free software; you may redistribute it and/or modify it
362 under the same terms as Perl itself.
363
365 bignum and bigint.
366
367 Math::BigInt, Math::BigFloat, Math::BigRat and Math::Big as well as
368 Math::BigInt::FastCalc, Math::BigInt::Pari and Math::BigInt::GMP.
369
371 • (C) by Tels <http://bloodgate.com/> in early 2002 - 2007.
372
373 • Maintained by Peter John Acklam <pjacklam@gmail.com>, 2014-.
374
375
376
377perl v5.34.1 2022-04-13 bigrat(3)