LSST Applications g0fba68d861+2e894914a0,g1ec0fe41b4+e220e2fb2f,g1f759649c2+d3ce33c3e0,g1fd858c14a+2b9bf32e51,g35bb328faa+fcb1d3bbc8,g4d2262a081+1dc91b7776,g53246c7159+fcb1d3bbc8,g56a49b3a55+1053ce1741,g60b5630c4e+d3ce33c3e0,g67b6fd64d1+fad15079a7,g78460c75b0+2f9a1b4bcd,g786e29fd12+cf7ec2a62a,g8180f54f50+9253e245c2,g8352419a5c+fcb1d3bbc8,g8852436030+f11a5d3b0b,g89139ef638+fad15079a7,g9125e01d80+fcb1d3bbc8,g94187f82dc+d3ce33c3e0,g989de1cb63+fad15079a7,g9ccd5d7f00+44d9ee3d90,g9d31334357+d3ce33c3e0,g9f33ca652e+9a8c17f5f6,gabe3b4be73+1e0a283bba,gabf8522325+94c30d56e9,gb1101e3267+90933e15fb,gb58c049af0+f03b321e39,gb89ab40317+fad15079a7,gc0af124501+26f6120d90,gcf25f946ba+f11a5d3b0b,gd6cbbdb0b4+8d7f1baacb,gd794735e4e+4bba874dfe,gdb1c4ca869+16879ca1a6,gde0f65d7ad+0609b2c34e,ge278dab8ac+4d6e48c014,ge410e46f29+fad15079a7,gf5e32f922b+fcb1d3bbc8,gf618743f1b+dd10d22602,gf67bdafdda+fad15079a7,w.2025.17
LSST Data Management Base Package
|
BigInteger
is an arbitrary precision signed integer class.
More...
#include <BigInteger.h>
Public Member Functions | |
BigInteger (std::uint32_t *digits, unsigned capacity) | |
This constructor creates a zero-valued integer with the given digit array. | |
BigInteger & | operator= (BigInteger const &b) |
int | getSign () const |
getSign returns -1, 0 or 1 if this integer is negative, zero or positive. | |
unsigned | getSize () const |
getSize returns the number of digits in the value of this integer. | |
unsigned | getCapacity () const |
getCapacity returns the number of digits in the underlying digit array. | |
std::uint32_t const * | getDigits () const |
getDigits returns the underlying digit array. | |
void | setToZero () |
setToZero sets this integer to zero. | |
void | setTo (std::int64_t x) |
setTo sets this integer to the given signed 64 bit integer value. | |
void | setTo (std::uint64_t x) |
setTo sets this integer to the given unsigned 64 bit integer value. | |
void | negate () |
negate multiplies this integer by -1. | |
BigInteger & | add (BigInteger const &b) |
add adds b to this integer. | |
BigInteger & | subtract (BigInteger const &b) |
subtract subtracts b from this integer. | |
BigInteger & | multiplyPow2 (unsigned n) |
multiplyPow2 multiplies this integer by 2ⁿ. | |
BigInteger & | multiply (BigInteger const &b) |
multiply multiplies this integer by b. | |
BigInteger
is an arbitrary precision signed integer class.
It is intended to be used in applications which need relatively small integers, and only supports addition, subtraction and multiplication.
Internally, a BigInteger consists of a sign and an unsigned magnitude. The magnitude is represented by an array of 32 bit digits, stored from least to most significant. All non-zero integers have at least one digit, the most significant of which is non-zero. Zero is defined to have no digits.
Definition at line 51 of file BigInteger.h.
|
inline |
This constructor creates a zero-valued integer with the given digit array.
Definition at line 55 of file BigInteger.h.
BigInteger & lsst::sphgeom::BigInteger::add | ( | BigInteger const & | b | ) |
add
adds b to this integer.
Definition at line 163 of file BigInteger.cc.
|
inline |
getCapacity
returns the number of digits in the underlying digit array.
Definition at line 81 of file BigInteger.h.
|
inline |
getDigits
returns the underlying digit array.
Definition at line 84 of file BigInteger.h.
|
inline |
getSign
returns -1, 0 or 1 if this integer is negative, zero or positive.
Definition at line 74 of file BigInteger.h.
|
inline |
getSize
returns the number of digits in the value of this integer.
Definition at line 77 of file BigInteger.h.
BigInteger & lsst::sphgeom::BigInteger::multiply | ( | BigInteger const & | b | ) |
multiply
multiplies this integer by b.
Definition at line 256 of file BigInteger.cc.
BigInteger & lsst::sphgeom::BigInteger::multiplyPow2 | ( | unsigned | n | ) |
multiplyPow2
multiplies this integer by 2ⁿ.
Definition at line 221 of file BigInteger.cc.
|
inline |
negate
multiplies this integer by -1.
Definition at line 109 of file BigInteger.h.
|
inline |
Definition at line 62 of file BigInteger.h.
|
inline |
setTo
sets this integer to the given signed 64 bit integer value.
Definition at line 90 of file BigInteger.h.
|
inline |
setTo
sets this integer to the given unsigned 64 bit integer value.
Definition at line 100 of file BigInteger.h.
|
inline |
setToZero
sets this integer to zero.
Definition at line 87 of file BigInteger.h.
BigInteger & lsst::sphgeom::BigInteger::subtract | ( | BigInteger const & | b | ) |
subtract
subtracts b from this integer.
Definition at line 208 of file BigInteger.cc.