⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 math::bigint::calc.3

📁 视频监控网络部分的协议ddns,的模块的实现代码,请大家大胆指正.
💻 3
字号:
.\" Automatically generated by Pod::Man 2.16 (Pod::Simple 3.05).\".\" Standard preamble:.\" ========================================================================.de Sh \" Subsection heading.br.if t .Sp.ne 5.PP\fB\\$1\fR.PP...de Sp \" Vertical space (when we can't use .PP).if t .sp .5v.if n .sp...de Vb \" Begin verbatim text.ft CW.nf.ne \\$1...de Ve \" End verbatim text.ft R.fi...\" Set up some character translations and predefined strings.  \*(-- will.\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left.\" double quote, and \*(R" will give a right double quote.  \*(C+ will.\" give a nicer C++.  Capital omega is used to do unbreakable dashes and.\" therefore won't be available.  \*(C` and \*(C' expand to `' in nroff,.\" nothing in troff, for use with C<>..tr \(*W-.ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p'.ie n \{\.    ds -- \(*W-.    ds PI pi.    if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch.    if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\"  diablo 12 pitch.    ds L" "".    ds R" "".    ds C` "".    ds C' ""'br\}.el\{\.    ds -- \|\(em\|.    ds PI \(*p.    ds L" ``.    ds R" '''br\}.\".\" Escape single quotes in literal strings from groff's Unicode transform..ie \n(.g .ds Aq \(aq.el       .ds Aq '.\".\" If the F register is turned on, we'll generate index entries on stderr for.\" titles (.TH), headers (.SH), subsections (.Sh), items (.Ip), and index.\" entries marked with X<> in POD.  Of course, you'll have to process the.\" output yourself in some meaningful fashion..ie \nF \{\.    de IX.    tm Index:\\$1\t\\n%\t"\\$2"...    nr % 0.    rr F.\}.el \{\.    de IX...\}.\".\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2)..\" Fear.  Run.  Save yourself.  No user-serviceable parts..    \" fudge factors for nroff and troff.if n \{\.    ds #H 0.    ds #V .8m.    ds #F .3m.    ds #[ \f1.    ds #] \fP.\}.if t \{\.    ds #H ((1u-(\\\\n(.fu%2u))*.13m).    ds #V .6m.    ds #F 0.    ds #[ \&.    ds #] \&.\}.    \" simple accents for nroff and troff.if n \{\.    ds ' \&.    ds ` \&.    ds ^ \&.    ds , \&.    ds ~ ~.    ds /.\}.if t \{\.    ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u".    ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u'.    ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u'.    ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u'.    ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u'.    ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u'.\}.    \" troff and (daisy-wheel) nroff accents.ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V'.ds 8 \h'\*(#H'\(*b\h'-\*(#H'.ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#].ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H'.ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u'.ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#].ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#].ds ae a\h'-(\w'a'u*4/10)'e.ds Ae A\h'-(\w'A'u*4/10)'E.    \" corrections for vroff.if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u'.if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u'.    \" for low resolution devices (crt and lpr).if \n(.H>23 .if \n(.V>19 \\{\.    ds : e.    ds 8 ss.    ds o a.    ds d- d\h'-1'\(ga.    ds D- D\h'-1'\(hy.    ds th \o'bp'.    ds Th \o'LP'.    ds ae ae.    ds Ae AE.\}.rm #[ #] #H #V #F C.\" ========================================================================.\".IX Title "Math::BigInt::Calc 3".TH Math::BigInt::Calc 3 "2007-12-18" "perl v5.10.0" "Perl Programmers Reference Guide".\" For nroff, turn off justification.  Always turn off hyphenation; it makes.\" way too many mistakes in technical documents..if n .ad l.nh.SH "NAME"Math::BigInt::Calc \- Pure Perl module to support Math::BigInt.SH "SYNOPSIS".IX Header "SYNOPSIS"Provides support for big integer calculations. Not intended to be used by othermodules. Other modules which sport the same functions can also be used to supportMath::BigInt, like Math::BigInt::GMP or Math::BigInt::Pari..SH "DESCRIPTION".IX Header "DESCRIPTION"In order to allow for multiple big integer libraries, Math::BigInt wasrewritten to use library modules for core math routines. Any module whichfollows the same \s-1API\s0 as this can be used instead by using the following:.PP.Vb 1\&        use Math::BigInt lib => \*(Aqlibname\*(Aq;.Ve.PP\&'libname' is either the long name ('Math::BigInt::Pari'), or only the shortversion like 'Pari'..SH "STORAGE".IX Header "STORAGE".SH "METHODS".IX Header "METHODS"The following functions \s-1MUST\s0 be defined in order to support the use byMath::BigInt v1.70 or later:.PP.Vb 6\&        api_version()   return API version, 1 for v1.70, 2 for v1.83\&        _new(string)    return ref to new object from ref to decimal string\&        _zero()         return a new object with value 0\&        _one()          return a new object with value 1\&        _two()          return a new object with value 2\&        _ten()          return a new object with value 10\&\&        _str(obj)       return ref to a string representing the object\&        _num(obj)       returns a Perl integer/floating point number\&                        NOTE: because of Perl numeric notation defaults,\&                        the _num\*(Aqified obj may lose accuracy due to \&                        machine\-dependent floating point size limitations\&                    \&        _add(obj,obj)   Simple addition of two objects\&        _mul(obj,obj)   Multiplication of two objects\&        _div(obj,obj)   Division of the 1st object by the 2nd\&                        In list context, returns (result,remainder).\&                        NOTE: this is integer math, so no\&                        fractional part will be returned.\&                        The second operand will be not be 0, so no need to\&                        check for that.\&        _sub(obj,obj)   Simple subtraction of 1 object from another\&                        a third, optional parameter indicates that the params\&                        are swapped. In this case, the first param needs to\&                        be preserved, while you can destroy the second.\&                        sub (x,y,1) => return x \- y and keep x intact!\&        _dec(obj)       decrement object by one (input is guaranteed to be > 0)\&        _inc(obj)       increment object by one\&\&\&        _acmp(obj,obj)  <=> operator for objects (return \-1, 0 or 1)\&\&        _len(obj)       returns count of the decimal digits of the object\&        _digit(obj,n)   returns the n\*(Aqth decimal digit of object\&\&        _is_one(obj)    return true if argument is 1\&        _is_two(obj)    return true if argument is 2\&        _is_ten(obj)    return true if argument is 10\&        _is_zero(obj)   return true if argument is 0\&        _is_even(obj)   return true if argument is even (0,2,4,6..)\&        _is_odd(obj)    return true if argument is odd (1,3,5,7..)\&\&        _copy           return a ref to a true copy of the object\&\&        _check(obj)     check whether internal representation is still intact\&                        return 0 for ok, otherwise error message as string\&\&        _from_hex(str)  return new object from a hexadecimal string\&        _from_bin(str)  return new object from a binary string\&        _from_oct(str)  return new object from an octal string\&        \&        _as_hex(str)    return string containing the value as\&                        unsigned hex string, with the \*(Aq0x\*(Aq prepended.\&                        Leading zeros must be stripped.\&        _as_bin(str)    Like as_hex, only as binary string containing only\&                        zeros and ones. Leading zeros must be stripped and a\&                        \*(Aq0b\*(Aq must be prepended.\&        \&        _rsft(obj,N,B)  shift object in base B by N \*(Aqdigits\*(Aq right\&        _lsft(obj,N,B)  shift object in base B by N \*(Aqdigits\*(Aq left\&        \&        _xor(obj1,obj2) XOR (bit\-wise) object 1 with object 2\&                        Note: XOR, AND and OR pad with zeros if size mismatches\&        _and(obj1,obj2) AND (bit\-wise) object 1 with object 2\&        _or(obj1,obj2)  OR (bit\-wise) object 1 with object 2\&\&        _mod(obj1,obj2) Return remainder of div of the 1st by the 2nd object\&        _sqrt(obj)      return the square root of object (truncated to int)\&        _root(obj)      return the n\*(Aqth (n >= 3) root of obj (truncated to int)\&        _fac(obj)       return factorial of object 1 (1*2*3*4..)\&        _pow(obj1,obj2) return object 1 to the power of object 2\&                        return undef for NaN\&        _zeros(obj)     return number of trailing decimal zeros\&        _modinv         return inverse modulus\&        _modpow         return modulus of power ($x ** $y) % $z\&        _log_int(X,N)   calculate integer log() of X in base N\&                        X >= 0, N >= 0 (return undef for NaN)\&                        returns (RESULT, EXACT) where EXACT is:\&                         1     : result is exactly RESULT\&                         0     : result was truncated to RESULT\&                         undef : unknown whether result is exactly RESULT\&        _gcd(obj,obj)   return Greatest Common Divisor of two objects.Ve.PPThe following functions are \s-1REQUIRED\s0 for an api_version of 2 or greater:.PP.Vb 5\&        _1ex($x)        create the number 1Ex where x >= 0\&        _alen(obj)      returns approximate count of the decimal digits of the\&                        object. This estimate MUST always be greater or equal\&                        to what _len() returns.\&        _nok(n,k)       calculate n over k (binomial coefficient).Ve.PPThe following functions are optional, and can be defined if the underlying libhas a fast way to do them. If undefined, Math::BigInt will use pure Perl (henceslow) fallback routines to emulate these:.PP.Vb 3\&        _signed_or\&        _signed_and\&        _signed_xor.Ve.PPInput strings come in as unsigned but with prefix (i.e. as '123', '0xabc'or '0b1101')..PPSo the library needs only to deal with unsigned big integers. Testing of inputparameter validity is done by the caller, so you need not worry aboutunderflow (f.i. in \f(CW\*(C`_sub()\*(C'\fR, \f(CW\*(C`_dec()\*(C'\fR) nor about division by zero or similarcases..PPThe first parameter can be modified, that includes the possibility that youreturn a reference to a completely different object instead. Although keepingthe reference and just changing its contents is preferred over creating andreturning a different reference..PPReturn values are always references to objects, strings, or true/false forcomparison routines..SH "WRAP YOUR OWN".IX Header "WRAP YOUR OWN"If you want to port your own favourite c\-lib for big numbers to theMath::BigInt interface, you can take any of the already existing modules asa rough guideline. You should really wrap up the latest BigInt and BigFloattestsuites with your module, and replace in them any of the following:.PP.Vb 1\&        use Math::BigInt;.Ve.PPby this:.PP.Vb 1\&        use Math::BigInt lib => \*(Aqyourlib\*(Aq;.Ve.PPThis way you ensure that your library really works 100% within Math::BigInt..SH "LICENSE".IX Header "LICENSE"This program is free software; you may redistribute it and/or modify it underthe same terms as Perl itself..SH "AUTHORS".IX Header "AUTHORS"Original math code by Mark Biggar, rewritten by Tels <http://bloodgate.com/>in late 2000.Seperated from BigInt and shaped \s-1API\s0 with the help of John Peacock..PPFixed, speed-up, streamlined and enhanced by Tels 2001 \- 2007..SH "SEE ALSO".IX Header "SEE ALSO"Math::BigInt, Math::BigFloat,Math::BigInt::GMP, Math::BigInt::FastCalc and Math::BigInt::Pari.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -