Crypto++
8.0
Free C++ class library of cryptographic schemes
|
Multiple precision integer with arithmetic operations. More...
Classes | |
class | DivideByZero |
Exception thrown when division by 0 is encountered. More... | |
class | OpenPGPDecodeErr |
Exception thrown when an error is encountered decoding an OpenPGP integer. More... | |
class | RandomNumberNotFound |
Exception thrown when a random number cannot be found that satisfies the condition. More... | |
Friends | |
Integer | a_times_b_mod_c (const Integer &x, const Integer &y, const Integer &m) |
Modular multiplication. More... | |
Integer | a_exp_b_mod_c (const Integer &x, const Integer &e, const Integer &m) |
Modular exponentiation. More... | |
ENUMS, EXCEPTIONS, and TYPEDEFS | |
enum | Sign { POSITIVE =0, NEGATIVE =1 } |
Used internally to represent the integer. More... | |
enum | Signedness { UNSIGNED, SIGNED } |
Used when importing and exporting integers. More... | |
enum | RandomNumberType { ANY, PRIME } |
Properties of a random integer. More... | |
CREATORS | |
Integer () | |
Creates the zero integer. | |
Integer (const Integer &t) | |
copy constructor | |
Integer (signed long value) | |
Convert from signed long. | |
Integer (Sign sign, lword value) | |
Convert from lword. More... | |
Integer (Sign sign, word highWord, word lowWord) | |
Convert from two words. More... | |
Integer (const char *str, ByteOrder order=BIG_ENDIAN_ORDER) | |
Convert from a C-string. More... | |
Integer (const wchar_t *str, ByteOrder order=BIG_ENDIAN_ORDER) | |
Convert from a wide C-string. More... | |
Integer (const byte *encodedInteger, size_t byteCount, Signedness sign=UNSIGNED, ByteOrder order=BIG_ENDIAN_ORDER) | |
Convert from a big-endian byte array. More... | |
Integer (BufferedTransformation &bt, size_t byteCount, Signedness sign=UNSIGNED, ByteOrder order=BIG_ENDIAN_ORDER) | |
Convert from a big-endian array. More... | |
Integer (BufferedTransformation &bt) | |
Convert from a BER encoded byte array. More... | |
Integer (RandomNumberGenerator &rng, size_t bitCount) | |
Create a random integer. More... | |
Integer (RandomNumberGenerator &rng, const Integer &min, const Integer &max, RandomNumberType rnType=ANY, const Integer &equiv=Zero(), const Integer &mod=One()) | |
Create a random integer of special form. More... | |
static const Integer & | Zero () |
Integer representing 0. More... | |
static const Integer & | One () |
Integer representing 1. More... | |
static const Integer & | Two () |
Integer representing 2. More... | |
static Integer | Power2 (size_t e) |
Exponentiates to a power of 2. More... | |
ENCODE/DECODE | |
size_t | MinEncodedSize (Signedness sign=UNSIGNED) const |
Minimum number of bytes to encode this integer. More... | |
void | Encode (byte *output, size_t outputLen, Signedness sign=UNSIGNED) const |
Encode in big-endian format. More... | |
void | Encode (BufferedTransformation &bt, size_t outputLen, Signedness sign=UNSIGNED) const |
Encode in big-endian format. More... | |
void | DEREncode (BufferedTransformation &bt) const |
Encode in DER format. More... | |
void | DEREncodeAsOctetString (BufferedTransformation &bt, size_t length) const |
Encode absolute value as big-endian octet string. More... | |
size_t | OpenPGPEncode (byte *output, size_t bufferSize) const |
Encode absolute value in OpenPGP format. More... | |
size_t | OpenPGPEncode (BufferedTransformation &bt) const |
Encode absolute value in OpenPGP format. More... | |
void | Decode (const byte *input, size_t inputLen, Signedness sign=UNSIGNED) |
Decode from big-endian byte array. More... | |
void | Decode (BufferedTransformation &bt, size_t inputLen, Signedness sign=UNSIGNED) |
Decode nonnegative value from big-endian byte array. More... | |
void | BERDecode (const byte *input, size_t inputLen) |
Decode from BER format. More... | |
void | BERDecode (BufferedTransformation &bt) |
Decode from BER format. More... | |
void | BERDecodeAsOctetString (BufferedTransformation &bt, size_t length) |
Decode nonnegative value from big-endian octet string. More... | |
void | OpenPGPDecode (const byte *input, size_t inputLen) |
Decode from OpenPGP format. More... | |
void | OpenPGPDecode (BufferedTransformation &bt) |
Decode from OpenPGP format. More... | |
ACCESSORS | |
bool | IsConvertableToLong () const |
Determines if the Integer is convertable to Long. More... | |
signed long | ConvertToLong () const |
Convert the Integer to Long. More... | |
unsigned int | BitCount () const |
Determines the number of bits required to represent the Integer. More... | |
unsigned int | ByteCount () const |
Determines the number of bytes required to represent the Integer. More... | |
unsigned int | WordCount () const |
Determines the number of words required to represent the Integer. More... | |
bool | GetBit (size_t i) const |
Provides the i-th bit of the Integer. More... | |
byte | GetByte (size_t i) const |
Provides the i-th byte of the Integer. More... | |
lword | GetBits (size_t i, size_t n) const |
Provides the low order bits of the Integer. More... | |
bool | IsZero () const |
Determines if the Integer is 0. More... | |
bool | NotZero () const |
Determines if the Integer is non-0. More... | |
bool | IsNegative () const |
Determines if the Integer is negative. More... | |
bool | NotNegative () const |
Determines if the Integer is non-negative. More... | |
bool | IsPositive () const |
Determines if the Integer is positive. More... | |
bool | NotPositive () const |
Determines if the Integer is non-positive. More... | |
bool | IsEven () const |
Determines if the Integer is even parity. More... | |
bool | IsOdd () const |
Determines if the Integer is odd parity. More... | |
MANIPULATORS | |
Integer & | operator= (const Integer &t) |
Assignment. | |
Integer & | operator+= (const Integer &t) |
Addition Assignment. | |
Integer & | operator-= (const Integer &t) |
Subtraction Assignment. | |
Integer & | operator*= (const Integer &t) |
Multiplication Assignment. More... | |
Integer & | operator/= (const Integer &t) |
Division Assignment. | |
Integer & | operator%= (const Integer &t) |
Remainder Assignment. More... | |
Integer & | operator/= (word t) |
Division Assignment. | |
Integer & | operator%= (word t) |
Remainder Assignment. More... | |
Integer & | operator<<= (size_t n) |
Left-shift Assignment. | |
Integer & | operator>>= (size_t n) |
Right-shift Assignment. | |
Integer & | operator &= (const Integer &t) |
Bitwise AND Assignment. More... | |
Integer & | operator|= (const Integer &t) |
Bitwise OR Assignment. More... | |
Integer & | operator^= (const Integer &t) |
Bitwise XOR Assignment. More... | |
void | Randomize (RandomNumberGenerator &rng, size_t bitCount) |
Set this Integer to random integer. More... | |
void | Randomize (RandomNumberGenerator &rng, const Integer &min, const Integer &max) |
Set this Integer to random integer. More... | |
bool | Randomize (RandomNumberGenerator &rng, const Integer &min, const Integer &max, RandomNumberType rnType, const Integer &equiv=Zero(), const Integer &mod=One()) |
Set this Integer to random integer of special form. More... | |
bool | GenerateRandomNoThrow (RandomNumberGenerator &rng, const NameValuePairs ¶ms=g_nullNameValuePairs) |
Generate a random number. More... | |
void | GenerateRandom (RandomNumberGenerator &rng, const NameValuePairs ¶ms=g_nullNameValuePairs) |
Generate a random number. More... | |
void | SetBit (size_t n, bool value=1) |
Set the n-th bit to value. More... | |
void | SetByte (size_t n, byte value) |
Set the n-th byte to value. More... | |
void | Negate () |
Reverse the Sign of the Integer. | |
void | SetPositive () |
Sets the Integer to positive. | |
void | SetNegative () |
Sets the Integer to negative. | |
void | swap (Integer &a) |
Swaps this Integer with another Integer. | |
UNARY OPERATORS | |
bool | operator! () const |
Negation. | |
Integer | operator+ () const |
Addition. | |
Integer | operator- () const |
Subtraction. | |
Integer & | operator++ () |
Pre-increment. | |
Integer & | operator-- () |
Pre-decrement. | |
Integer | operator++ (int) |
Post-increment. | |
Integer | operator-- (int) |
Post-decrement. | |
BINARY OPERATORS | |
int | Compare (const Integer &a) const |
Perform signed comparison. More... | |
Integer | Plus (const Integer &b) const |
Addition. | |
Integer | Minus (const Integer &b) const |
Subtraction. | |
Integer | Times (const Integer &b) const |
Multiplication. More... | |
Integer | DividedBy (const Integer &b) const |
Division. | |
Integer | Modulo (const Integer &b) const |
Remainder. More... | |
Integer | DividedBy (word b) const |
Division. | |
word | Modulo (word b) const |
Remainder. More... | |
Integer | And (const Integer &t) const |
Bitwise AND. More... | |
Integer | Or (const Integer &t) const |
Bitwise OR. More... | |
Integer | Xor (const Integer &t) const |
Bitwise XOR. More... | |
Integer | operator>> (size_t n) const |
Right-shift. | |
Integer | operator<< (size_t n) const |
Left-shift. | |
OTHER ARITHMETIC FUNCTIONS | |
Integer | AbsoluteValue () const |
Retrieve the absolute value of this integer. | |
Integer | Doubled () const |
Add this integer to itself. | |
Integer | Squared () const |
Multiply this integer by itself. More... | |
Integer | SquareRoot () const |
Extract square root. More... | |
bool | IsSquare () const |
Determine whether this integer is a perfect square. | |
bool | IsUnit () const |
Determine if 1 or -1. More... | |
Integer | MultiplicativeInverse () const |
Calculate multiplicative inverse. More... | |
Integer | InverseMod (const Integer &n) const |
Calculate multiplicative inverse. More... | |
word | InverseMod (word n) const |
Calculate multiplicative inverse. More... | |
static void | Divide (Integer &r, Integer &q, const Integer &a, const Integer &d) |
Extended Division. More... | |
static void | Divide (word &r, Integer &q, const Integer &a, word d) |
Extended Division. More... | |
static void | DivideByPowerOf2 (Integer &r, Integer &q, const Integer &a, unsigned int n) |
Extended Division. More... | |
static Integer | Gcd (const Integer &a, const Integer &n) |
Calculate greatest common divisor. More... | |
INPUT/OUTPUT | |
std::istream & | operator>> (std::istream &in, Integer &a) |
Extraction operator. More... | |
std::ostream & | operator<< (std::ostream &out, const Integer &a) |
Insertion operator. More... | |
Additional Inherited Members | |
![]() | |
virtual void | BEREncode (BufferedTransformation &bt) const |
Encode this object into a BufferedTransformation. More... | |
Multiple precision integer with arithmetic operations.
The Integer class can represent positive and negative integers with absolute value less than (256**sizeof(word))(256**sizeof(int)).
Internally, the library uses a sign magnitude representation, and the class has two data members. The first is a IntegerSecBlock (a SecBlock<word>) and it is used to hold the representation. The second is a Sign (an enumeration), and it is used to track the sign of the Integer.
For details on how the Integer class initializes its function pointers using InitializeInteger and how it creates Integer::Zero(), Integer::One(), and Integer::Two(), then see the comments at the top of integer.cpp
.
enum Integer::Sign |
Used internally to represent the integer.
Sign is used internally to represent the integer. It is also used in a few API functions.
Enumerator | |
---|---|
POSITIVE | the value is positive or 0 |
NEGATIVE | the value is negative |
enum Integer::Signedness |
Integer::Integer | ( | Sign | sign, |
lword | value | ||
) |
Convert from lword.
sign | enumeration indicating Sign |
value | the long word |
Definition at line 2970 of file integer.cpp.
Integer::Integer | ( | Sign | sign, |
word | highWord, | ||
word | lowWord | ||
) |
Convert from two words.
sign | enumeration indicating Sign |
highWord | the high word |
lowWord | the low word |
Definition at line 2991 of file integer.cpp.
|
explicit |
Convert from a C-string.
str | C-string value |
order | the ByteOrder of the string to be processed |
str
can be in base 2, 8, 10, or 16. Base is determined by a case insensitive suffix of 'h', 'o', or 'b'. No suffix means base 10.
Byte order was added at Crypto++ 5.7 to allow use of little-endian integers with curve25519, Poly1305 and Microsoft CAPI.
Definition at line 3319 of file integer.cpp.
|
explicit |
Convert from a wide C-string.
str | wide C-string value |
order | the ByteOrder of the string to be processed |
str
can be in base 2, 8, 10, or 16. Base is determined by a case insensitive suffix of 'h', 'o', or 'b'. No suffix means base 10.
Byte order was added at Crypto++ 5.7 to allow use of little-endian integers with curve25519, Poly1305 and Microsoft CAPI.
Definition at line 3325 of file integer.cpp.
Integer::Integer | ( | const byte * | encodedInteger, |
size_t | byteCount, | ||
Signedness | sign = UNSIGNED , |
||
ByteOrder | order = BIG_ENDIAN_ORDER |
||
) |
Convert from a big-endian byte array.
encodedInteger | big-endian byte array |
byteCount | length of the byte array |
sign | enumeration indicating Signedness |
order | the ByteOrder of the array to be processed |
Byte order was added at Crypto++ 5.7 to allow use of little-endian integers with curve25519, Poly1305 and Microsoft CAPI.
Definition at line 3039 of file integer.cpp.
Integer::Integer | ( | BufferedTransformation & | bt, |
size_t | byteCount, | ||
Signedness | sign = UNSIGNED , |
||
ByteOrder | order = BIG_ENDIAN_ORDER |
||
) |
Convert from a big-endian array.
bt | BufferedTransformation object with big-endian byte array |
byteCount | length of the byte array |
sign | enumeration indicating Signedness |
order | the ByteOrder of the data to be processed |
Byte order was added at Crypto++ 5.7 to allow use of little-endian integers with curve25519, Poly1305 and Microsoft CAPI.
Definition at line 3021 of file integer.cpp.
|
explicit |
Convert from a BER encoded byte array.
bt | BufferedTransformation object with BER encoded byte array |
Definition at line 3062 of file integer.cpp.
Integer::Integer | ( | RandomNumberGenerator & | rng, |
size_t | bitCount | ||
) |
Create a random integer.
rng | RandomNumberGenerator used to generate material |
bitCount | the number of bits in the resulting integer |
The random integer created is uniformly distributed over [0, 2bitCount]
.
Definition at line 3068 of file integer.cpp.
Integer::Integer | ( | RandomNumberGenerator & | rng, |
const Integer & | min, | ||
const Integer & | max, | ||
RandomNumberType | rnType = ANY , |
||
const Integer & | equiv = Zero() , |
||
const Integer & | mod = One() |
||
) |
Create a random integer of special form.
rng | RandomNumberGenerator used to generate material |
min | the minimum value |
max | the maximum value |
rnType | RandomNumberType to specify the type |
equiv | the equivalence class based on the parameter mod |
mod | the modulus used to reduce the equivalence class |
RandomNumberNotFound | if the set is empty. |
Ideally, the random integer created should be uniformly distributed over {x | min <= x <= max
and x
is of rnType and x % mod == equiv}
. However the actual distribution may not be uniform because sequential search is used to find an appropriate number from a random starting point.
May return (with very small probability) a pseudoprime when a prime is requested and max > lastSmallPrime*lastSmallPrime
. lastSmallPrime
is declared in nbtheory.h.
Definition at line 3073 of file integer.cpp.
|
static |
Integer representing 0.
Zero() avoids calling constructors for frequently used integers
Definition at line 4856 of file integer.cpp.
|
static |
Integer representing 1.
One() avoids calling constructors for frequently used integers
Definition at line 4868 of file integer.cpp.
|
static |
Integer representing 2.
Two() avoids calling constructors for frequently used integers
Definition at line 4880 of file integer.cpp.
|
static |
Exponentiates to a power of 2.
Definition at line 3079 of file integer.cpp.
size_t Integer::MinEncodedSize | ( | Signedness | sign = UNSIGNED | ) | const |
Minimum number of bytes to encode this integer.
sign | enumeration indicating Signedness |
Definition at line 3393 of file integer.cpp.
void Integer::Encode | ( | byte * | output, |
size_t | outputLen, | ||
Signedness | sign = UNSIGNED |
||
) | const |
Encode in big-endian format.
output | big-endian byte array |
outputLen | length of the byte array |
sign | enumeration indicating Signedness |
Unsigned means encode absolute value, signed means encode two's complement if negative.
outputLen can be used to ensure an Integer is encoded to an exact size (rather than a minimum size). An exact size is useful, for example, when encoding to a field element size.
Definition at line 3410 of file integer.cpp.
void Integer::Encode | ( | BufferedTransformation & | bt, |
size_t | outputLen, | ||
Signedness | sign = UNSIGNED |
||
) | const |
Encode in big-endian format.
bt | BufferedTransformation object |
outputLen | length of the encoding |
sign | enumeration indicating Signedness |
Unsigned means encode absolute value, signed means encode two's complement if negative.
outputLen can be used to ensure an Integer is encoded to an exact size (rather than a minimum size). An exact size is useful, for example, when encoding to a field element size.
Definition at line 3417 of file integer.cpp.
|
virtual |
Encode in DER format.
bt | BufferedTransformation object |
Encodes the Integer using Distinguished Encoding Rules The result is placed into a BufferedTransformation object
Implements ASN1Object.
Definition at line 3432 of file integer.cpp.
void Integer::DEREncodeAsOctetString | ( | BufferedTransformation & | bt, |
size_t | length | ||
) | const |
Encode absolute value as big-endian octet string.
bt | BufferedTransformation object |
length | the number of mytes to decode |
Definition at line 3455 of file integer.cpp.
size_t Integer::OpenPGPEncode | ( | byte * | output, |
size_t | bufferSize | ||
) | const |
Encode absolute value in OpenPGP format.
output | big-endian byte array |
bufferSize | length of the byte array |
OpenPGPEncode places result into the buffer and returns the number of bytes used for the encoding
Definition at line 3471 of file integer.cpp.
size_t Integer::OpenPGPEncode | ( | BufferedTransformation & | bt | ) | const |
Encode absolute value in OpenPGP format.
bt | BufferedTransformation object |
OpenPGPEncode places result into a BufferedTransformation object and returns the number of bytes used for the encoding
Definition at line 3479 of file integer.cpp.
void Integer::Decode | ( | const byte * | input, |
size_t | inputLen, | ||
Signedness | sign = UNSIGNED |
||
) |
Decode from big-endian byte array.
input | big-endian byte array |
inputLen | length of the byte array |
sign | enumeration indicating Signedness |
Definition at line 3354 of file integer.cpp.
void Integer::Decode | ( | BufferedTransformation & | bt, |
size_t | inputLen, | ||
Signedness | sign = UNSIGNED |
||
) |
Decode nonnegative value from big-endian byte array.
bt | BufferedTransformation object |
inputLen | length of the byte array |
sign | enumeration indicating Signedness |
bt.MaxRetrievable() >= inputLen
. Definition at line 3361 of file integer.cpp.
void Integer::BERDecode | ( | const byte * | input, |
size_t | inputLen | ||
) |
Decode from BER format.
input | big-endian byte array |
inputLen | length of the byte array |
Definition at line 3439 of file integer.cpp.
|
virtual |
Decode from BER format.
bt | BufferedTransformation object |
Implements ASN1Object.
Definition at line 3446 of file integer.cpp.
void Integer::BERDecodeAsOctetString | ( | BufferedTransformation & | bt, |
size_t | length | ||
) |
Decode nonnegative value from big-endian octet string.
bt | BufferedTransformation object |
length | length of the byte array |
Definition at line 3462 of file integer.cpp.
void Integer::OpenPGPDecode | ( | const byte * | input, |
size_t | inputLen | ||
) |
Decode from OpenPGP format.
input | big-endian byte array |
inputLen | length of the byte array |
Definition at line 3488 of file integer.cpp.
void Integer::OpenPGPDecode | ( | BufferedTransformation & | bt | ) |
Decode from OpenPGP format.
bt | BufferedTransformation object |
Definition at line 3495 of file integer.cpp.
bool Integer::IsConvertableToLong | ( | ) | const |
Determines if the Integer is convertable to Long.
Definition at line 2998 of file integer.cpp.
signed long Integer::ConvertToLong | ( | ) | const |
Convert the Integer to Long.
Definition at line 3012 of file integer.cpp.
unsigned int Integer::BitCount | ( | ) | const |
Determines the number of bits required to represent the Integer.
Definition at line 3345 of file integer.cpp.
unsigned int Integer::ByteCount | ( | ) | const |
Determines the number of bytes required to represent the Integer.
Definition at line 3336 of file integer.cpp.
unsigned int Integer::WordCount | ( | ) | const |
Determines the number of words required to represent the Integer.
Definition at line 3331 of file integer.cpp.
bool Integer::GetBit | ( | size_t | i | ) | const |
Provides the i-th bit of the Integer.
Definition at line 3103 of file integer.cpp.
byte Integer::GetByte | ( | size_t | i | ) | const |
Provides the i-th byte of the Integer.
Definition at line 3128 of file integer.cpp.
lword Integer::GetBits | ( | size_t | i, |
size_t | n | ||
) | const |
Provides the low order bits of the Integer.
Definition at line 3146 of file integer.cpp.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Multiplication Assignment.
Remainder Assignment.
|
inline |
Remainder Assignment.
Bitwise AND Assignment.
t | the other Integer |
operator&=() performs a bitwise AND on *this. Missing bits are truncated at the most significant bit positions, so the result is as small as the smaller of the operands.
Internally, Crypto++ uses a sign-magnitude representation. The library does not attempt to interpret bits, and the result is always POSITIVE. If needed, the integer should be converted to a 2's compliment representation before performing the operation.
Bitwise OR Assignment.
t | the second Integer |
operator|=() performs a bitwise OR on *this. Missing bits are shifted in at the most significant bit positions, so the result is as large as the larger of the operands.
Internally, Crypto++ uses a sign-magnitude representation. The library does not attempt to interpret bits, and the result is always POSITIVE. If needed, the integer should be converted to a 2's compliment representation before performing the operation.
Definition at line 4058 of file integer.cpp.
Bitwise XOR Assignment.
t | the other Integer |
operator^=() performs a bitwise XOR on *this. Missing bits are shifted in at the most significant bit positions, so the result is as large as the larger of the operands.
Internally, Crypto++ uses a sign-magnitude representation. The library does not attempt to interpret bits, and the result is always POSITIVE. If needed, the integer should be converted to a 2's compliment representation before performing the operation.
Definition at line 4079 of file integer.cpp.
void Integer::Randomize | ( | RandomNumberGenerator & | rng, |
size_t | bitCount | ||
) |
Set this Integer to random integer.
rng | RandomNumberGenerator used to generate material |
bitCount | the number of bits in the resulting integer |
The random integer created is uniformly distributed over [0, 2bitCount]
.
Definition at line 3503 of file integer.cpp.
void Integer::Randomize | ( | RandomNumberGenerator & | rng, |
const Integer & | min, | ||
const Integer & | max | ||
) |
Set this Integer to random integer.
rng | RandomNumberGenerator used to generate material |
min | the minimum value |
max | the maximum value |
The random integer created is uniformly distributed over [min, max]
.
Definition at line 3513 of file integer.cpp.
bool Integer::Randomize | ( | RandomNumberGenerator & | rng, |
const Integer & | min, | ||
const Integer & | max, | ||
RandomNumberType | rnType, | ||
const Integer & | equiv = Zero() , |
||
const Integer & | mod = One() |
||
) |
Set this Integer to random integer of special form.
rng | RandomNumberGenerator used to generate material |
min | the minimum value |
max | the maximum value |
rnType | RandomNumberType to specify the type |
equiv | the equivalence class based on the parameter mod |
mod | the modulus used to reduce the equivalence class |
RandomNumberNotFound | if the set is empty. |
Ideally, the random integer created should be uniformly distributed over {x | min <= x <= max
and x
is of rnType and x % mod == equiv}
. However the actual distribution may not be uniform because sequential search is used to find an appropriate number from a random starting point.
May return (with very small probability) a pseudoprime when a prime is requested and max > lastSmallPrime*lastSmallPrime
. lastSmallPrime
is declared in nbtheory.h.
Definition at line 3530 of file integer.cpp.
bool Integer::GenerateRandomNoThrow | ( | RandomNumberGenerator & | rng, |
const NameValuePairs & | params = g_nullNameValuePairs |
||
) |
Generate a random number.
rng | RandomNumberGenerator used to generate material |
params | additional parameters that cannot be passed directly to the function |
GenerateRandomNoThrow attempts to generate a random number according to the parameters specified in params. The function does not throw RandomNumberNotFound.
The example below generates a prime number using NameValuePairs that Integer class recognizes. The names are not provided in argnames.h.
AutoSeededRandomPool prng; AlgorithmParameters params = MakeParameters("BitLength", 2048) ("RandomNumberType", Integer::PRIME); Integer x; if (x.GenerateRandomNoThrow(prng, params) == false) throw std::runtime_error("Failed to generate prime number");
Definition at line 3558 of file integer.cpp.
|
inline |
Generate a random number.
rng | RandomNumberGenerator used to generate material |
params | additional parameters that cannot be passed directly to the function |
RandomNumberNotFound | if a random number is not found |
GenerateRandom attempts to generate a random number according to the parameters specified in params.
The example below generates a prime number using NameValuePairs that Integer class recognizes. The names are not provided in argnames.h.
AutoSeededRandomPool prng; AlgorithmParameters params = MakeParameters("BitLength", 2048) ("RandomNumberType", Integer::PRIME); Integer x; try { x.GenerateRandom(prng, params); } catch (RandomNumberNotFound&) { x = -1; }
void Integer::SetBit | ( | size_t | n, |
bool | value = 1 |
||
) |
void Integer::SetByte | ( | size_t | n, |
byte | value | ||
) |
int Integer::Compare | ( | const Integer & | a | ) | const |
Perform signed comparison.
a | the Integer to comapre |
-1 | if *this < a |
0 | if *this = a |
1 | if *this > a |
Definition at line 4345 of file integer.cpp.
Multiplication.
Definition at line 4124 of file integer.cpp.
Remainder.
Definition at line 4235 of file integer.cpp.
word Integer::Modulo | ( | word | b | ) | const |
Remainder.
Definition at line 4286 of file integer.cpp.
Bitwise AND.
t | the other Integer |
*this & t
And() performs a bitwise AND on the operands. Missing bits are truncated at the most significant bit positions, so the result is as small as the smaller of the operands.
Internally, Crypto++ uses a sign-magnitude representation. The library does not attempt to interpret bits, and the result is always POSITIVE. If needed, the integer should be converted to a 2's compliment representation before performing the operation.
Definition at line 3774 of file integer.cpp.
Bitwise OR.
t | the other Integer |
*this | t
Or() performs a bitwise OR on the operands. Missing bits are shifted in at the most significant bit positions, so the result is as large as the larger of the operands.
Internally, Crypto++ uses a sign-magnitude representation. The library does not attempt to interpret bits, and the result is always POSITIVE. If needed, the integer should be converted to a 2's compliment representation before performing the operation.
Definition at line 3800 of file integer.cpp.
Bitwise XOR.
t | the other Integer |
*this ^ t
Xor() performs a bitwise XOR on the operands. Missing bits are shifted in at the most significant bit positions, so the result is as large as the larger of the operands.
Internally, Crypto++ uses a sign-magnitude representation. The library does not attempt to interpret bits, and the result is always POSITIVE. If needed, the integer should be converted to a 2's compliment representation before performing the operation.
Definition at line 3826 of file integer.cpp.
|
inline |
Multiply this integer by itself.
Integer Integer::SquareRoot | ( | ) | const |
Extract square root.
if negative return 0, else return floor of square root
Definition at line 4363 of file integer.cpp.
bool Integer::IsUnit | ( | ) | const |
Determine if 1 or -1.
Definition at line 4387 of file integer.cpp.
Integer Integer::MultiplicativeInverse | ( | ) | const |
Calculate multiplicative inverse.
Definition at line 4392 of file integer.cpp.
Extended Division.
r | a reference for the remainder |
q | a reference for the quotient |
a | a reference to the dividend |
d | a reference to the divisor |
Divide calculates r and q such that (a == d*q + r) && (0 <= r < abs(d)).
Definition at line 4182 of file integer.cpp.
Extended Division.
r | a reference for the remainder |
q | a reference for the quotient |
a | a reference to the dividend |
d | a reference to the divisor |
Divide calculates r and q such that (a == d*q + r) && (0 <= r < abs(d)). This overload uses a faster division algorithm because the divisor is short.
Definition at line 4242 of file integer.cpp.
|
static |
Extended Division.
r | a reference for the remainder |
q | a reference for the quotient |
a | a reference to the dividend |
n | a reference to the divisor |
DivideByPowerOf2 calculates r and q such that (a == d*q + r) && (0 <= r < abs(d)). It returns same result as Divide(r, q, a, Power2(n)), but faster. This overload uses a faster division algorithm because the divisor is a power of 2.
Definition at line 4200 of file integer.cpp.
Calculate greatest common divisor.
a | a reference to the first number |
n | a reference to the secind number |
a
and n
. Definition at line 4416 of file integer.cpp.
Calculate multiplicative inverse.
n | a reference to the modulus |
*this % n
.InverseMod returns the multiplicative inverse of the Integer *this
modulo the Integer n
. If no Integer exists then Integer 0 is returned.
Definition at line 4421 of file integer.cpp.
word Integer::InverseMod | ( | word | n | ) | const |
Calculate multiplicative inverse.
n | the modulus |
*this % n
.InverseMod returns the multiplicative inverse of the Integer *this
modulo the word n
. If no Integer exists then word 0 is returned.
Definition at line 4460 of file integer.cpp.
|
friend |
Extraction operator.
in | a reference to a std::istream |
a | a reference to an Integer |
Definition at line 3651 of file integer.cpp.
|
friend |
Insertion operator.
out | a reference to a std::ostream |
a | a constant reference to an Integer |
The output integer responds to std::hex, std::oct, std::hex, std::upper and std::lower. The output includes the suffix h (for hex), . (dot, for dec) and o (for octal). There is currently no way to suppress the suffix.
If you want to print an Integer without the suffix or using an arbitrary base, then use IntToString<Integer>().
Definition at line 3686 of file integer.cpp.
Modular multiplication.
x | a reference to the first term |
y | a reference to the second term |
m | a reference to the modulus |
(a * b) % m
. Definition at line 4397 of file integer.cpp.
Modular exponentiation.
x | a reference to the base |
e | a reference to the exponent |
m | a reference to the modulus |
(a ^ b) % m
. Definition at line 4406 of file integer.cpp.