Struct num::BigInt

source ·
pub struct BigInt { /* private fields */ }
Expand description

A big signed integer type.

Implementations§

source§

impl BigInt

source

pub fn new(sign: Sign, digits: Vec<u32>) -> BigInt

Creates and initializes a BigInt.

The base 232 digits are ordered least significant digit first.

source

pub fn from_biguint(sign: Sign, data: BigUint) -> BigInt

Creates and initializes a BigInt.

The base 232 digits are ordered least significant digit first.

source

pub fn from_slice(sign: Sign, slice: &[u32]) -> BigInt

Creates and initializes a BigInt.

The base 232 digits are ordered least significant digit first.

source

pub fn assign_from_slice(&mut self, sign: Sign, slice: &[u32])

Reinitializes a BigInt.

The base 232 digits are ordered least significant digit first.

source

pub fn from_bytes_be(sign: Sign, bytes: &[u8]) -> BigInt

Creates and initializes a BigInt.

The bytes are in big-endian byte order.

§Examples
use num_bigint::{BigInt, Sign};

assert_eq!(BigInt::from_bytes_be(Sign::Plus, b"A"),
           BigInt::parse_bytes(b"65", 10).unwrap());
assert_eq!(BigInt::from_bytes_be(Sign::Plus, b"AA"),
           BigInt::parse_bytes(b"16705", 10).unwrap());
assert_eq!(BigInt::from_bytes_be(Sign::Plus, b"AB"),
           BigInt::parse_bytes(b"16706", 10).unwrap());
assert_eq!(BigInt::from_bytes_be(Sign::Plus, b"Hello world!"),
           BigInt::parse_bytes(b"22405534230753963835153736737", 10).unwrap());
source

pub fn from_bytes_le(sign: Sign, bytes: &[u8]) -> BigInt

Creates and initializes a BigInt.

The bytes are in little-endian byte order.

source

pub fn from_signed_bytes_be(digits: &[u8]) -> BigInt

Creates and initializes a BigInt from an array of bytes in two’s complement binary representation.

The digits are in big-endian base 28.

source

pub fn from_signed_bytes_le(digits: &[u8]) -> BigInt

Creates and initializes a BigInt from an array of bytes in two’s complement.

The digits are in little-endian base 28.

source

pub fn parse_bytes(buf: &[u8], radix: u32) -> Option<BigInt>

Creates and initializes a BigInt.

§Examples
use num_bigint::{BigInt, ToBigInt};

assert_eq!(BigInt::parse_bytes(b"1234", 10), ToBigInt::to_bigint(&1234));
assert_eq!(BigInt::parse_bytes(b"ABCD", 16), ToBigInt::to_bigint(&0xABCD));
assert_eq!(BigInt::parse_bytes(b"G", 16), None);
source

pub fn from_radix_be(sign: Sign, buf: &[u8], radix: u32) -> Option<BigInt>

Creates and initializes a BigInt. Each u8 of the input slice is interpreted as one digit of the number and must therefore be less than radix.

The bytes are in big-endian byte order. radix must be in the range 2...256.

§Examples
use num_bigint::{BigInt, Sign};

let inbase190 = vec![15, 33, 125, 12, 14];
let a = BigInt::from_radix_be(Sign::Minus, &inbase190, 190).unwrap();
assert_eq!(a.to_radix_be(190), (Sign:: Minus, inbase190));
source

pub fn from_radix_le(sign: Sign, buf: &[u8], radix: u32) -> Option<BigInt>

Creates and initializes a BigInt. Each u8 of the input slice is interpreted as one digit of the number and must therefore be less than radix.

The bytes are in little-endian byte order. radix must be in the range 2...256.

§Examples
use num_bigint::{BigInt, Sign};

let inbase190 = vec![14, 12, 125, 33, 15];
let a = BigInt::from_radix_be(Sign::Minus, &inbase190, 190).unwrap();
assert_eq!(a.to_radix_be(190), (Sign::Minus, inbase190));
source

pub fn to_bytes_be(&self) -> (Sign, Vec<u8>)

Returns the sign and the byte representation of the BigInt in big-endian byte order.

§Examples
use num_bigint::{ToBigInt, Sign};

let i = -1125.to_bigint().unwrap();
assert_eq!(i.to_bytes_be(), (Sign::Minus, vec![4, 101]));
source

pub fn to_bytes_le(&self) -> (Sign, Vec<u8>)

Returns the sign and the byte representation of the BigInt in little-endian byte order.

§Examples
use num_bigint::{ToBigInt, Sign};

let i = -1125.to_bigint().unwrap();
assert_eq!(i.to_bytes_le(), (Sign::Minus, vec![101, 4]));
source

pub fn to_u32_digits(&self) -> (Sign, Vec<u32>)

Returns the sign and the u32 digits representation of the BigInt ordered least significant digit first.

§Examples
use num_bigint::{BigInt, Sign};

assert_eq!(BigInt::from(-1125).to_u32_digits(), (Sign::Minus, vec![1125]));
assert_eq!(BigInt::from(4294967295u32).to_u32_digits(), (Sign::Plus, vec![4294967295]));
assert_eq!(BigInt::from(4294967296u64).to_u32_digits(), (Sign::Plus, vec![0, 1]));
assert_eq!(BigInt::from(-112500000000i64).to_u32_digits(), (Sign::Minus, vec![830850304, 26]));
assert_eq!(BigInt::from(112500000000i64).to_u32_digits(), (Sign::Plus, vec![830850304, 26]));
source

pub fn to_u64_digits(&self) -> (Sign, Vec<u64>)

Returns the sign and the u64 digits representation of the BigInt ordered least significant digit first.

§Examples
use num_bigint::{BigInt, Sign};

assert_eq!(BigInt::from(-1125).to_u64_digits(), (Sign::Minus, vec![1125]));
assert_eq!(BigInt::from(4294967295u32).to_u64_digits(), (Sign::Plus, vec![4294967295]));
assert_eq!(BigInt::from(4294967296u64).to_u64_digits(), (Sign::Plus, vec![4294967296]));
assert_eq!(BigInt::from(-112500000000i64).to_u64_digits(), (Sign::Minus, vec![112500000000]));
assert_eq!(BigInt::from(112500000000i64).to_u64_digits(), (Sign::Plus, vec![112500000000]));
assert_eq!(BigInt::from(1u128 << 64).to_u64_digits(), (Sign::Plus, vec![0, 1]));
source

pub fn iter_u32_digits(&self) -> U32Digits<'_>

Returns an iterator of u32 digits representation of the BigInt ordered least significant digit first.

§Examples
use num_bigint::BigInt;

assert_eq!(BigInt::from(-1125).iter_u32_digits().collect::<Vec<u32>>(), vec![1125]);
assert_eq!(BigInt::from(4294967295u32).iter_u32_digits().collect::<Vec<u32>>(), vec![4294967295]);
assert_eq!(BigInt::from(4294967296u64).iter_u32_digits().collect::<Vec<u32>>(), vec![0, 1]);
assert_eq!(BigInt::from(-112500000000i64).iter_u32_digits().collect::<Vec<u32>>(), vec![830850304, 26]);
assert_eq!(BigInt::from(112500000000i64).iter_u32_digits().collect::<Vec<u32>>(), vec![830850304, 26]);
source

pub fn iter_u64_digits(&self) -> U64Digits<'_>

Returns an iterator of u64 digits representation of the BigInt ordered least significant digit first.

§Examples
use num_bigint::BigInt;

assert_eq!(BigInt::from(-1125).iter_u64_digits().collect::<Vec<u64>>(), vec![1125u64]);
assert_eq!(BigInt::from(4294967295u32).iter_u64_digits().collect::<Vec<u64>>(), vec![4294967295u64]);
assert_eq!(BigInt::from(4294967296u64).iter_u64_digits().collect::<Vec<u64>>(), vec![4294967296u64]);
assert_eq!(BigInt::from(-112500000000i64).iter_u64_digits().collect::<Vec<u64>>(), vec![112500000000u64]);
assert_eq!(BigInt::from(112500000000i64).iter_u64_digits().collect::<Vec<u64>>(), vec![112500000000u64]);
assert_eq!(BigInt::from(1u128 << 64).iter_u64_digits().collect::<Vec<u64>>(), vec![0, 1]);
source

pub fn to_signed_bytes_be(&self) -> Vec<u8>

Returns the two’s-complement byte representation of the BigInt in big-endian byte order.

§Examples
use num_bigint::ToBigInt;

let i = -1125.to_bigint().unwrap();
assert_eq!(i.to_signed_bytes_be(), vec![251, 155]);
source

pub fn to_signed_bytes_le(&self) -> Vec<u8>

Returns the two’s-complement byte representation of the BigInt in little-endian byte order.

§Examples
use num_bigint::ToBigInt;

let i = -1125.to_bigint().unwrap();
assert_eq!(i.to_signed_bytes_le(), vec![155, 251]);
source

pub fn to_str_radix(&self, radix: u32) -> String

Returns the integer formatted as a string in the given radix. radix must be in the range 2...36.

§Examples
use num_bigint::BigInt;

let i = BigInt::parse_bytes(b"ff", 16).unwrap();
assert_eq!(i.to_str_radix(16), "ff");
source

pub fn to_radix_be(&self, radix: u32) -> (Sign, Vec<u8>)

Returns the integer in the requested base in big-endian digit order. The output is not given in a human readable alphabet but as a zero based u8 number. radix must be in the range 2...256.

§Examples
use num_bigint::{BigInt, Sign};

assert_eq!(BigInt::from(-0xFFFFi64).to_radix_be(159),
           (Sign::Minus, vec![2, 94, 27]));
// 0xFFFF = 65535 = 2*(159^2) + 94*159 + 27
source

pub fn to_radix_le(&self, radix: u32) -> (Sign, Vec<u8>)

Returns the integer in the requested base in little-endian digit order. The output is not given in a human readable alphabet but as a zero based u8 number. radix must be in the range 2...256.

§Examples
use num_bigint::{BigInt, Sign};

assert_eq!(BigInt::from(-0xFFFFi64).to_radix_le(159),
           (Sign::Minus, vec![27, 94, 2]));
// 0xFFFF = 65535 = 27 + 94*159 + 2*(159^2)
source

pub fn sign(&self) -> Sign

Returns the sign of the BigInt as a Sign.

§Examples
use num_bigint::{BigInt, Sign};
use num_traits::Zero;

assert_eq!(BigInt::from(1234).sign(), Sign::Plus);
assert_eq!(BigInt::from(-4321).sign(), Sign::Minus);
assert_eq!(BigInt::zero().sign(), Sign::NoSign);
source

pub fn magnitude(&self) -> &BigUint

Returns the magnitude of the BigInt as a BigUint.

§Examples
use num_bigint::{BigInt, BigUint};
use num_traits::Zero;

assert_eq!(BigInt::from(1234).magnitude(), &BigUint::from(1234u32));
assert_eq!(BigInt::from(-4321).magnitude(), &BigUint::from(4321u32));
assert!(BigInt::zero().magnitude().is_zero());
source

pub fn into_parts(self) -> (Sign, BigUint)

Convert this BigInt into its Sign and BigUint magnitude, the reverse of BigInt::from_biguint.

§Examples
use num_bigint::{BigInt, BigUint, Sign};
use num_traits::Zero;

assert_eq!(BigInt::from(1234).into_parts(), (Sign::Plus, BigUint::from(1234u32)));
assert_eq!(BigInt::from(-4321).into_parts(), (Sign::Minus, BigUint::from(4321u32)));
assert_eq!(BigInt::zero().into_parts(), (Sign::NoSign, BigUint::zero()));
source

pub fn bits(&self) -> u64

Determines the fewest bits necessary to express the BigInt, not including the sign.

source

pub fn to_biguint(&self) -> Option<BigUint>

Converts this BigInt into a BigUint, if it’s not negative.

source

pub fn checked_add(&self, v: &BigInt) -> Option<BigInt>

source

pub fn checked_sub(&self, v: &BigInt) -> Option<BigInt>

source

pub fn checked_mul(&self, v: &BigInt) -> Option<BigInt>

source

pub fn checked_div(&self, v: &BigInt) -> Option<BigInt>

source

pub fn pow(&self, exponent: u32) -> BigInt

Returns self ^ exponent.

source

pub fn modpow(&self, exponent: &BigInt, modulus: &BigInt) -> BigInt

Returns (self ^ exponent) mod modulus

Note that this rounds like mod_floor, not like the % operator, which makes a difference when given a negative self or modulus. The result will be in the interval [0, modulus) for modulus > 0, or in the interval (modulus, 0] for modulus < 0

Panics if the exponent is negative or the modulus is zero.

source

pub fn sqrt(&self) -> BigInt

Returns the truncated principal square root of self – see Roots::sqrt.

source

pub fn cbrt(&self) -> BigInt

Returns the truncated principal cube root of self – see Roots::cbrt.

source

pub fn nth_root(&self, n: u32) -> BigInt

Returns the truncated principal nth root of self – See Roots::nth_root.

source

pub fn trailing_zeros(&self) -> Option<u64>

Returns the number of least-significant bits that are zero, or None if the entire number is zero.

source

pub fn bit(&self, bit: u64) -> bool

Returns whether the bit in position bit is set, using the two’s complement for negative numbers

source

pub fn set_bit(&mut self, bit: u64, value: bool)

Sets or clears the bit in the given position, using the two’s complement for negative numbers

Note that setting/clearing a bit (for positive/negative numbers, respectively) greater than the current bit length, a reallocation may be needed to store the new digits

Trait Implementations§

source§

impl<'a, 'b> Add<&'b BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &BigInt) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a BigInt> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &BigInt) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &i128) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a i128> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &i128) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &i16) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a i16> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &i16) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &i32) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a i32> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &i32) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &i64) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a i64> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &i64) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &i8) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a i8> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &i8) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &isize) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a isize> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &isize) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &u128) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a u128> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &u128) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &u16) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a u16> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &u16) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &u32) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a u32> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &u32) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &u64) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a u64> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &u64) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &u8) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a u8> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &u8) -> BigInt

Performs the + operation. Read more
source§

impl<'a, 'b> Add<&'b usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &usize) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<&'a usize> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: &usize) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: BigInt) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: i128) -> BigInt

Performs the + operation. Read more
source§

impl Add<i128> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: i128) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: i16) -> BigInt

Performs the + operation. Read more
source§

impl Add<i16> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: i16) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: i32) -> BigInt

Performs the + operation. Read more
source§

impl Add<i32> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: i32) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: i64) -> BigInt

Performs the + operation. Read more
source§

impl Add<i64> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: i64) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: i8) -> BigInt

Performs the + operation. Read more
source§

impl Add<i8> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: i8) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: isize) -> BigInt

Performs the + operation. Read more
source§

impl Add<isize> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: isize) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: u128) -> BigInt

Performs the + operation. Read more
source§

impl Add<u128> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: u128) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: u16) -> BigInt

Performs the + operation. Read more
source§

impl Add<u16> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: u16) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: u32) -> BigInt

Performs the + operation. Read more
source§

impl Add<u32> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: u32) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: u64) -> BigInt

Performs the + operation. Read more
source§

impl Add<u64> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: u64) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: u8) -> BigInt

Performs the + operation. Read more
source§

impl Add<u8> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: u8) -> BigInt

Performs the + operation. Read more
source§

impl<'a> Add<usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: usize) -> BigInt

Performs the + operation. Read more
source§

impl Add<usize> for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: usize) -> BigInt

Performs the + operation. Read more
source§

impl Add for BigInt

§

type Output = BigInt

The resulting type after applying the + operator.
source§

fn add(self, other: BigInt) -> BigInt

Performs the + operation. Read more
source§

impl<'a> AddAssign<&'a BigInt> for BigInt

source§

fn add_assign(&mut self, other: &BigInt)

Performs the += operation. Read more
source§

impl AddAssign<i128> for BigInt

source§

fn add_assign(&mut self, other: i128)

Performs the += operation. Read more
source§

impl AddAssign<i16> for BigInt

source§

fn add_assign(&mut self, other: i16)

Performs the += operation. Read more
source§

impl AddAssign<i32> for BigInt

source§

fn add_assign(&mut self, other: i32)

Performs the += operation. Read more
source§

impl AddAssign<i64> for BigInt

source§

fn add_assign(&mut self, other: i64)

Performs the += operation. Read more
source§

impl AddAssign<i8> for BigInt

source§

fn add_assign(&mut self, other: i8)

Performs the += operation. Read more
source§

impl AddAssign<isize> for BigInt

source§

fn add_assign(&mut self, other: isize)

Performs the += operation. Read more
source§

impl AddAssign<u128> for BigInt

source§

fn add_assign(&mut self, other: u128)

Performs the += operation. Read more
source§

impl AddAssign<u16> for BigInt

source§

fn add_assign(&mut self, other: u16)

Performs the += operation. Read more
source§

impl AddAssign<u32> for BigInt

source§

fn add_assign(&mut self, other: u32)

Performs the += operation. Read more
source§

impl AddAssign<u64> for BigInt

source§

fn add_assign(&mut self, other: u64)

Performs the += operation. Read more
source§

impl AddAssign<u8> for BigInt

source§

fn add_assign(&mut self, other: u8)

Performs the += operation. Read more
source§

impl AddAssign<usize> for BigInt

source§

fn add_assign(&mut self, other: usize)

Performs the += operation. Read more
source§

impl AddAssign for BigInt

source§

fn add_assign(&mut self, other: BigInt)

Performs the += operation. Read more
source§

impl Binary for BigInt

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl<'a, 'b> BitAnd<&'b BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the & operator.
source§

fn bitand(self, other: &BigInt) -> BigInt

Performs the & operation. Read more
source§

impl<'a> BitAnd<&'a BigInt> for BigInt

§

type Output = BigInt

The resulting type after applying the & operator.
source§

fn bitand(self, other: &BigInt) -> BigInt

Performs the & operation. Read more
source§

impl<'a> BitAnd<BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the & operator.
source§

fn bitand(self, other: BigInt) -> BigInt

Performs the & operation. Read more
source§

impl BitAnd for BigInt

§

type Output = BigInt

The resulting type after applying the & operator.
source§

fn bitand(self, other: BigInt) -> BigInt

Performs the & operation. Read more
source§

impl<'a> BitAndAssign<&'a BigInt> for BigInt

source§

fn bitand_assign(&mut self, other: &BigInt)

Performs the &= operation. Read more
source§

impl BitAndAssign for BigInt

source§

fn bitand_assign(&mut self, other: BigInt)

Performs the &= operation. Read more
source§

impl<'a, 'b> BitOr<&'b BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the | operator.
source§

fn bitor(self, other: &BigInt) -> BigInt

Performs the | operation. Read more
source§

impl<'a> BitOr<&'a BigInt> for BigInt

§

type Output = BigInt

The resulting type after applying the | operator.
source§

fn bitor(self, other: &BigInt) -> BigInt

Performs the | operation. Read more
source§

impl<'a> BitOr<BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the | operator.
source§

fn bitor(self, other: BigInt) -> BigInt

Performs the | operation. Read more
source§

impl BitOr for BigInt

§

type Output = BigInt

The resulting type after applying the | operator.
source§

fn bitor(self, other: BigInt) -> BigInt

Performs the | operation. Read more
source§

impl<'a> BitOrAssign<&'a BigInt> for BigInt

source§

fn bitor_assign(&mut self, other: &BigInt)

Performs the |= operation. Read more
source§

impl BitOrAssign for BigInt

source§

fn bitor_assign(&mut self, other: BigInt)

Performs the |= operation. Read more
source§

impl<'a, 'b> BitXor<&'b BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the ^ operator.
source§

fn bitxor(self, other: &BigInt) -> BigInt

Performs the ^ operation. Read more
source§

impl<'a> BitXor<&'a BigInt> for BigInt

§

type Output = BigInt

The resulting type after applying the ^ operator.
source§

fn bitxor(self, other: &BigInt) -> BigInt

Performs the ^ operation. Read more
source§

impl<'a> BitXor<BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the ^ operator.
source§

fn bitxor(self, other: BigInt) -> BigInt

Performs the ^ operation. Read more
source§

impl BitXor for BigInt

§

type Output = BigInt

The resulting type after applying the ^ operator.
source§

fn bitxor(self, other: BigInt) -> BigInt

Performs the ^ operation. Read more
source§

impl<'a> BitXorAssign<&'a BigInt> for BigInt

source§

fn bitxor_assign(&mut self, other: &BigInt)

Performs the ^= operation. Read more
source§

impl BitXorAssign for BigInt

source§

fn bitxor_assign(&mut self, other: BigInt)

Performs the ^= operation. Read more
source§

impl CheckedAdd for BigInt

source§

fn checked_add(&self, v: &BigInt) -> Option<BigInt>

Adds two numbers, checking for overflow. If overflow happens, None is returned.
source§

impl CheckedDiv for BigInt

source§

fn checked_div(&self, v: &BigInt) -> Option<BigInt>

Divides two numbers, checking for underflow, overflow and division by zero. If any of that happens, None is returned.
source§

impl CheckedMul for BigInt

source§

fn checked_mul(&self, v: &BigInt) -> Option<BigInt>

Multiplies two numbers, checking for underflow or overflow. If underflow or overflow happens, None is returned.
source§

impl CheckedSub for BigInt

source§

fn checked_sub(&self, v: &BigInt) -> Option<BigInt>

Subtracts two numbers, checking for underflow. If underflow happens, None is returned.
source§

impl Clone for BigInt

source§

fn clone(&self) -> BigInt

Returns a copy of the value. Read more
source§

fn clone_from(&mut self, other: &BigInt)

Performs copy-assignment from source. Read more
source§

impl Debug for BigInt

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl Default for BigInt

source§

fn default() -> BigInt

Returns the “default value” for a type. Read more
source§

impl Display for BigInt

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl Distribution<BigInt> for RandomBits

source§

fn sample<R>(&self, rng: &mut R) -> BigInt
where R: Rng + ?Sized,

Generate a random value of T, using rng as the source of randomness.
source§

fn sample_iter<R>(self, rng: R) -> DistIter<Self, R, T>
where R: Rng, Self: Sized,

Create an iterator that generates random values of T, using rng as the source of randomness. Read more
source§

fn map<F, S>(self, func: F) -> DistMap<Self, F, T, S>
where F: Fn(T) -> S, Self: Sized,

Create a distribution of values of ‘S’ by mapping the output of Self through the closure F Read more
source§

impl<'a, 'b> Div<&'b BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &BigInt) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a BigInt> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &BigInt) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &i128) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a i128> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &i128) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &i16) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a i16> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &i16) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &i32) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a i32> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &i32) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &i64) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a i64> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &i64) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &i8) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a i8> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &i8) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &isize) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a isize> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &isize) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &u128) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a u128> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &u128) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &u16) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a u16> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &u16) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &u32) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a u32> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &u32) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &u64) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a u64> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &u64) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &u8) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a u8> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &u8) -> BigInt

Performs the / operation. Read more
source§

impl<'a, 'b> Div<&'b usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &usize) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<&'a usize> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: &usize) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: BigInt) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: i128) -> BigInt

Performs the / operation. Read more
source§

impl Div<i128> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: i128) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: i16) -> BigInt

Performs the / operation. Read more
source§

impl Div<i16> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: i16) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: i32) -> BigInt

Performs the / operation. Read more
source§

impl Div<i32> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: i32) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: i64) -> BigInt

Performs the / operation. Read more
source§

impl Div<i64> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: i64) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: i8) -> BigInt

Performs the / operation. Read more
source§

impl Div<i8> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: i8) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: isize) -> BigInt

Performs the / operation. Read more
source§

impl Div<isize> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: isize) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: u128) -> BigInt

Performs the / operation. Read more
source§

impl Div<u128> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: u128) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: u16) -> BigInt

Performs the / operation. Read more
source§

impl Div<u16> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: u16) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: u32) -> BigInt

Performs the / operation. Read more
source§

impl Div<u32> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: u32) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: u64) -> BigInt

Performs the / operation. Read more
source§

impl Div<u64> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: u64) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: u8) -> BigInt

Performs the / operation. Read more
source§

impl Div<u8> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: u8) -> BigInt

Performs the / operation. Read more
source§

impl<'a> Div<usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: usize) -> BigInt

Performs the / operation. Read more
source§

impl Div<usize> for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: usize) -> BigInt

Performs the / operation. Read more
source§

impl Div for BigInt

§

type Output = BigInt

The resulting type after applying the / operator.
source§

fn div(self, other: BigInt) -> BigInt

Performs the / operation. Read more
source§

impl<'a> DivAssign<&'a BigInt> for BigInt

source§

fn div_assign(&mut self, other: &BigInt)

Performs the /= operation. Read more
source§

impl DivAssign<i128> for BigInt

source§

fn div_assign(&mut self, other: i128)

Performs the /= operation. Read more
source§

impl DivAssign<i16> for BigInt

source§

fn div_assign(&mut self, other: i16)

Performs the /= operation. Read more
source§

impl DivAssign<i32> for BigInt

source§

fn div_assign(&mut self, other: i32)

Performs the /= operation. Read more
source§

impl DivAssign<i64> for BigInt

source§

fn div_assign(&mut self, other: i64)

Performs the /= operation. Read more
source§

impl DivAssign<i8> for BigInt

source§

fn div_assign(&mut self, other: i8)

Performs the /= operation. Read more
source§

impl DivAssign<isize> for BigInt

source§

fn div_assign(&mut self, other: isize)

Performs the /= operation. Read more
source§

impl DivAssign<u128> for BigInt

source§

fn div_assign(&mut self, other: u128)

Performs the /= operation. Read more
source§

impl DivAssign<u16> for BigInt

source§

fn div_assign(&mut self, other: u16)

Performs the /= operation. Read more
source§

impl DivAssign<u32> for BigInt

source§

fn div_assign(&mut self, other: u32)

Performs the /= operation. Read more
source§

impl DivAssign<u64> for BigInt

source§

fn div_assign(&mut self, other: u64)

Performs the /= operation. Read more
source§

impl DivAssign<u8> for BigInt

source§

fn div_assign(&mut self, other: u8)

Performs the /= operation. Read more
source§

impl DivAssign<usize> for BigInt

source§

fn div_assign(&mut self, other: usize)

Performs the /= operation. Read more
source§

impl DivAssign for BigInt

source§

fn div_assign(&mut self, other: BigInt)

Performs the /= operation. Read more
source§

impl From<BigUint> for BigInt

source§

fn from(n: BigUint) -> BigInt

Converts to this type from the input type.
source§

impl From<i128> for BigInt

source§

fn from(n: i128) -> BigInt

Converts to this type from the input type.
source§

impl From<i16> for BigInt

source§

fn from(n: i16) -> BigInt

Converts to this type from the input type.
source§

impl From<i32> for BigInt

source§

fn from(n: i32) -> BigInt

Converts to this type from the input type.
source§

impl From<i64> for BigInt

source§

fn from(n: i64) -> BigInt

Converts to this type from the input type.
source§

impl From<i8> for BigInt

source§

fn from(n: i8) -> BigInt

Converts to this type from the input type.
source§

impl From<isize> for BigInt

source§

fn from(n: isize) -> BigInt

Converts to this type from the input type.
source§

impl From<u128> for BigInt

source§

fn from(n: u128) -> BigInt

Converts to this type from the input type.
source§

impl From<u16> for BigInt

source§

fn from(n: u16) -> BigInt

Converts to this type from the input type.
source§

impl From<u32> for BigInt

source§

fn from(n: u32) -> BigInt

Converts to this type from the input type.
source§

impl From<u64> for BigInt

source§

fn from(n: u64) -> BigInt

Converts to this type from the input type.
source§

impl From<u8> for BigInt

source§

fn from(n: u8) -> BigInt

Converts to this type from the input type.
source§

impl From<usize> for BigInt

source§

fn from(n: usize) -> BigInt

Converts to this type from the input type.
source§

impl FromPrimitive for BigInt

source§

fn from_i64(n: i64) -> Option<BigInt>

Converts an i64 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_i128(n: i128) -> Option<BigInt>

Converts an i128 to return an optional value of this type. If the value cannot be represented by this type, then None is returned. Read more
source§

fn from_u64(n: u64) -> Option<BigInt>

Converts an u64 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_u128(n: u128) -> Option<BigInt>

Converts an u128 to return an optional value of this type. If the value cannot be represented by this type, then None is returned. Read more
source§

fn from_f64(n: f64) -> Option<BigInt>

Converts a f64 to return an optional value of this type. If the value cannot be represented by this type, then None is returned. Read more
source§

fn from_isize(n: isize) -> Option<Self>

Converts an isize to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_i8(n: i8) -> Option<Self>

Converts an i8 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_i16(n: i16) -> Option<Self>

Converts an i16 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_i32(n: i32) -> Option<Self>

Converts an i32 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_usize(n: usize) -> Option<Self>

Converts a usize to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_u8(n: u8) -> Option<Self>

Converts an u8 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_u16(n: u16) -> Option<Self>

Converts an u16 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_u32(n: u32) -> Option<Self>

Converts an u32 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_f32(n: f32) -> Option<Self>

Converts a f32 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

impl FromStr for BigInt

§

type Err = ParseBigIntError

The associated error which can be returned from parsing.
source§

fn from_str(s: &str) -> Result<BigInt, ParseBigIntError>

Parses a string s to return a value of this type. Read more
source§

impl Hash for BigInt

source§

fn hash<H>(&self, state: &mut H)
where H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl Integer for BigInt

source§

fn gcd(&self, other: &BigInt) -> BigInt

Calculates the Greatest Common Divisor (GCD) of the number and other.

The result is always positive.

source§

fn lcm(&self, other: &BigInt) -> BigInt

Calculates the Lowest Common Multiple (LCM) of the number and other.

source§

fn gcd_lcm(&self, other: &BigInt) -> (BigInt, BigInt)

Calculates the Greatest Common Divisor (GCD) and Lowest Common Multiple (LCM) together.

source§

fn extended_gcd_lcm(&self, other: &BigInt) -> (ExtendedGcd<BigInt>, BigInt)

Greatest common divisor, least common multiple, and Bézout coefficients.

source§

fn divides(&self, other: &BigInt) -> bool

Deprecated, use is_multiple_of instead.

source§

fn is_multiple_of(&self, other: &BigInt) -> bool

Returns true if the number is a multiple of other.

source§

fn is_even(&self) -> bool

Returns true if the number is divisible by 2.

source§

fn is_odd(&self) -> bool

Returns true if the number is not divisible by 2.

source§

fn next_multiple_of(&self, other: &BigInt) -> BigInt

Rounds up to nearest multiple of argument.

source§

fn prev_multiple_of(&self, other: &BigInt) -> BigInt

Rounds down to nearest multiple of argument.

source§

fn div_rem(&self, other: &BigInt) -> (BigInt, BigInt)

Simultaneous truncated integer division and modulus. Returns (quotient, remainder). Read more
source§

fn div_floor(&self, other: &BigInt) -> BigInt

Floored integer division. Read more
source§

fn mod_floor(&self, other: &BigInt) -> BigInt

Floored integer modulo, satisfying: Read more
source§

fn div_mod_floor(&self, other: &BigInt) -> (BigInt, BigInt)

Simultaneous floored integer division and modulus. Returns (quotient, remainder). Read more
source§

fn div_ceil(&self, other: &BigInt) -> BigInt

Ceiled integer division. Read more
source§

fn extended_gcd(&self, other: &Self) -> ExtendedGcd<Self>
where Self: Clone,

Greatest common divisor and Bézout coefficients. Read more
source§

impl LowerHex for BigInt

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl<'a, 'b> Mul<&'b BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &'b BigInt) -> BigInt

Performs the * operation. Read more
source§

impl<'b> Mul<&'b BigInt> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &'b BigInt) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &i128) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i128> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &i128) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &i16) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i16> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &i16) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &i32) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i32> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &i32) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &i64) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i64> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &i64) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &i8) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i8> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &i8) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &isize) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a isize> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &isize) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &u128) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u128> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &u128) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &u16) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u16> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &u16) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &u32) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u32> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &u32) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &u64) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u64> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &u64) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &u8) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u8> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &u8) -> BigInt

Performs the * operation. Read more
source§

impl<'a, 'b> Mul<&'b usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &usize) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<&'a usize> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: &usize) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: BigInt) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: i128) -> BigInt

Performs the * operation. Read more
source§

impl Mul<i128> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: i128) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: i16) -> BigInt

Performs the * operation. Read more
source§

impl Mul<i16> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: i16) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: i32) -> BigInt

Performs the * operation. Read more
source§

impl Mul<i32> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: i32) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: i64) -> BigInt

Performs the * operation. Read more
source§

impl Mul<i64> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: i64) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: i8) -> BigInt

Performs the * operation. Read more
source§

impl Mul<i8> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: i8) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: isize) -> BigInt

Performs the * operation. Read more
source§

impl Mul<isize> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: isize) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: u128) -> BigInt

Performs the * operation. Read more
source§

impl Mul<u128> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: u128) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: u16) -> BigInt

Performs the * operation. Read more
source§

impl Mul<u16> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: u16) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: u32) -> BigInt

Performs the * operation. Read more
source§

impl Mul<u32> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: u32) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: u64) -> BigInt

Performs the * operation. Read more
source§

impl Mul<u64> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: u64) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: u8) -> BigInt

Performs the * operation. Read more
source§

impl Mul<u8> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: u8) -> BigInt

Performs the * operation. Read more
source§

impl<'a> Mul<usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: usize) -> BigInt

Performs the * operation. Read more
source§

impl Mul<usize> for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: usize) -> BigInt

Performs the * operation. Read more
source§

impl Mul for BigInt

§

type Output = BigInt

The resulting type after applying the * operator.
source§

fn mul(self, other: BigInt) -> BigInt

Performs the * operation. Read more
source§

impl<'a> MulAssign<&'a BigInt> for BigInt

source§

fn mul_assign(&mut self, other: &'a BigInt)

Performs the *= operation. Read more
source§

impl MulAssign<i128> for BigInt

source§

fn mul_assign(&mut self, other: i128)

Performs the *= operation. Read more
source§

impl MulAssign<i16> for BigInt

source§

fn mul_assign(&mut self, other: i16)

Performs the *= operation. Read more
source§

impl MulAssign<i32> for BigInt

source§

fn mul_assign(&mut self, other: i32)

Performs the *= operation. Read more
source§

impl MulAssign<i64> for BigInt

source§

fn mul_assign(&mut self, other: i64)

Performs the *= operation. Read more
source§

impl MulAssign<i8> for BigInt

source§

fn mul_assign(&mut self, other: i8)

Performs the *= operation. Read more
source§

impl MulAssign<isize> for BigInt

source§

fn mul_assign(&mut self, other: isize)

Performs the *= operation. Read more
source§

impl MulAssign<u128> for BigInt

source§

fn mul_assign(&mut self, other: u128)

Performs the *= operation. Read more
source§

impl MulAssign<u16> for BigInt

source§

fn mul_assign(&mut self, other: u16)

Performs the *= operation. Read more
source§

impl MulAssign<u32> for BigInt

source§

fn mul_assign(&mut self, other: u32)

Performs the *= operation. Read more
source§

impl MulAssign<u64> for BigInt

source§

fn mul_assign(&mut self, other: u64)

Performs the *= operation. Read more
source§

impl MulAssign<u8> for BigInt

source§

fn mul_assign(&mut self, other: u8)

Performs the *= operation. Read more
source§

impl MulAssign<usize> for BigInt

source§

fn mul_assign(&mut self, other: usize)

Performs the *= operation. Read more
source§

impl MulAssign for BigInt

source§

fn mul_assign(&mut self, other: BigInt)

Performs the *= operation. Read more
source§

impl<'a> Neg for &'a BigInt

§

type Output = BigInt

The resulting type after applying the - operator.
source§

fn neg(self) -> BigInt

Performs the unary - operation. Read more
source§

impl Neg for BigInt

§

type Output = BigInt

The resulting type after applying the - operator.
source§

fn neg(self) -> BigInt

Performs the unary - operation. Read more
source§

impl<'a> Not for &'a BigInt

§

type Output = BigInt

The resulting type after applying the ! operator.
source§

fn not(self) -> BigInt

Performs the unary ! operation. Read more
source§

impl Not for BigInt

§

type Output = BigInt

The resulting type after applying the ! operator.
source§

fn not(self) -> BigInt

Performs the unary ! operation. Read more
source§

impl Num for BigInt

source§

fn from_str_radix(s: &str, radix: u32) -> Result<BigInt, ParseBigIntError>

Creates and initializes a BigInt.

§

type FromStrRadixErr = ParseBigIntError

source§

impl Octal for BigInt

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl One for BigInt

source§

fn one() -> BigInt

Returns the multiplicative identity element of Self, 1. Read more
source§

fn set_one(&mut self)

Sets self to the multiplicative identity element of Self, 1.
source§

fn is_one(&self) -> bool

Returns true if self is equal to the multiplicative identity. Read more
source§

impl Ord for BigInt

source§

fn cmp(&self, other: &BigInt) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized + PartialOrd,

Restrict a value to a certain interval. Read more
source§

impl PartialEq for BigInt

source§

fn eq(&self, other: &BigInt) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl PartialOrd for BigInt

source§

fn partial_cmp(&self, other: &BigInt) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · source§

fn lt(&self, other: &Rhs) -> bool

This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · source§

fn le(&self, other: &Rhs) -> bool

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · source§

fn gt(&self, other: &Rhs) -> bool

This method tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · source§

fn ge(&self, other: &Rhs) -> bool

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl<'a, 'b, T> Pow<&'b BigInt> for &'a Ratio<T>
where T: Clone + Integer, &'a T: Pow<&'b BigUint, Output = T>,

§

type Output = Ratio<T>

The result after applying the operator.
source§

fn pow(self, expon: &'b BigInt) -> Ratio<T>

Returns self to the power rhs. Read more
source§

impl<'b, T> Pow<&'b BigInt> for Ratio<T>
where T: Clone + Integer + Pow<&'b BigUint, Output = T>,

§

type Output = Ratio<T>

The result after applying the operator.
source§

fn pow(self, expon: &'b BigInt) -> Ratio<T>

Returns self to the power rhs. Read more
source§

impl<'a, 'b> Pow<&'b BigUint> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &BigUint) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'b> Pow<&'b BigUint> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &BigUint) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a, 'b> Pow<&'b u128> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &u128) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'b> Pow<&'b u128> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &u128) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a, 'b> Pow<&'b u16> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &u16) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'b> Pow<&'b u16> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &u16) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a, 'b> Pow<&'b u32> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &u32) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'b> Pow<&'b u32> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &u32) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a, 'b> Pow<&'b u64> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &u64) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'b> Pow<&'b u64> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &u64) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a, 'b> Pow<&'b u8> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &u8) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'b> Pow<&'b u8> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &u8) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a, 'b> Pow<&'b usize> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &usize) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'b> Pow<&'b usize> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: &usize) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a, T> Pow<BigInt> for &'a Ratio<T>
where T: Clone + Integer, &'a T: for<'b> Pow<&'b BigUint, Output = T>,

§

type Output = Ratio<T>

The result after applying the operator.
source§

fn pow(self, expon: BigInt) -> Ratio<T>

Returns self to the power rhs. Read more
source§

impl<T> Pow<BigInt> for Ratio<T>
where T: Clone + Integer + for<'b> Pow<&'b BigUint, Output = T>,

§

type Output = Ratio<T>

The result after applying the operator.
source§

fn pow(self, expon: BigInt) -> Ratio<T>

Returns self to the power rhs. Read more
source§

impl<'a> Pow<BigUint> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: BigUint) -> BigInt

Returns self to the power rhs. Read more
source§

impl Pow<BigUint> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: BigUint) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a> Pow<u128> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: u128) -> BigInt

Returns self to the power rhs. Read more
source§

impl Pow<u128> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: u128) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a> Pow<u16> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: u16) -> BigInt

Returns self to the power rhs. Read more
source§

impl Pow<u16> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: u16) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a> Pow<u32> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: u32) -> BigInt

Returns self to the power rhs. Read more
source§

impl Pow<u32> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: u32) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a> Pow<u64> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: u64) -> BigInt

Returns self to the power rhs. Read more
source§

impl Pow<u64> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: u64) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a> Pow<u8> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: u8) -> BigInt

Returns self to the power rhs. Read more
source§

impl Pow<u8> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: u8) -> BigInt

Returns self to the power rhs. Read more
source§

impl<'a> Pow<usize> for &'a BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: usize) -> BigInt

Returns self to the power rhs. Read more
source§

impl Pow<usize> for BigInt

§

type Output = BigInt

The result after applying the operator.
source§

fn pow(self, rhs: usize) -> BigInt

Returns self to the power rhs. Read more
source§

impl<T> Product<T> for BigInt
where BigInt: Mul<T, Output = BigInt>,

source§

fn product<I>(iter: I) -> BigInt
where I: Iterator<Item = T>,

Method which takes an iterator and generates Self from the elements by multiplying the items.
source§

impl<'a, 'b> Rem<&'b BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &BigInt) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a BigInt> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &BigInt) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &i128) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a i128> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &i128) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &i16) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a i16> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &i16) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &i32) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a i32> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &i32) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &i64) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a i64> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &i64) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &i8) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a i8> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &i8) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &isize) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a isize> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &isize) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &u128) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a u128> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &u128) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &u16) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a u16> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &u16) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &u32) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a u32> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &u32) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &u64) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a u64> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &u64) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &u8) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a u8> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &u8) -> BigInt

Performs the % operation. Read more
source§

impl<'a, 'b> Rem<&'b usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &usize) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<&'a usize> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: &usize) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: BigInt) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: i128) -> BigInt

Performs the % operation. Read more
source§

impl Rem<i128> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: i128) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: i16) -> BigInt

Performs the % operation. Read more
source§

impl Rem<i16> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: i16) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: i32) -> BigInt

Performs the % operation. Read more
source§

impl Rem<i32> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: i32) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: i64) -> BigInt

Performs the % operation. Read more
source§

impl Rem<i64> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: i64) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: i8) -> BigInt

Performs the % operation. Read more
source§

impl Rem<i8> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: i8) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: isize) -> BigInt

Performs the % operation. Read more
source§

impl Rem<isize> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: isize) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: u128) -> BigInt

Performs the % operation. Read more
source§

impl Rem<u128> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: u128) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: u16) -> BigInt

Performs the % operation. Read more
source§

impl Rem<u16> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: u16) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: u32) -> BigInt

Performs the % operation. Read more
source§

impl Rem<u32> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: u32) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: u64) -> BigInt

Performs the % operation. Read more
source§

impl Rem<u64> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: u64) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: u8) -> BigInt

Performs the % operation. Read more
source§

impl Rem<u8> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: u8) -> BigInt

Performs the % operation. Read more
source§

impl<'a> Rem<usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: usize) -> BigInt

Performs the % operation. Read more
source§

impl Rem<usize> for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: usize) -> BigInt

Performs the % operation. Read more
source§

impl Rem for BigInt

§

type Output = BigInt

The resulting type after applying the % operator.
source§

fn rem(self, other: BigInt) -> BigInt

Performs the % operation. Read more
source§

impl<'a> RemAssign<&'a BigInt> for BigInt

source§

fn rem_assign(&mut self, other: &BigInt)

Performs the %= operation. Read more
source§

impl RemAssign<i128> for BigInt

source§

fn rem_assign(&mut self, other: i128)

Performs the %= operation. Read more
source§

impl RemAssign<i16> for BigInt

source§

fn rem_assign(&mut self, other: i16)

Performs the %= operation. Read more
source§

impl RemAssign<i32> for BigInt

source§

fn rem_assign(&mut self, other: i32)

Performs the %= operation. Read more
source§

impl RemAssign<i64> for BigInt

source§

fn rem_assign(&mut self, other: i64)

Performs the %= operation. Read more
source§

impl RemAssign<i8> for BigInt

source§

fn rem_assign(&mut self, other: i8)

Performs the %= operation. Read more
source§

impl RemAssign<isize> for BigInt

source§

fn rem_assign(&mut self, other: isize)

Performs the %= operation. Read more
source§

impl RemAssign<u128> for BigInt

source§

fn rem_assign(&mut self, other: u128)

Performs the %= operation. Read more
source§

impl RemAssign<u16> for BigInt

source§

fn rem_assign(&mut self, other: u16)

Performs the %= operation. Read more
source§

impl RemAssign<u32> for BigInt

source§

fn rem_assign(&mut self, other: u32)

Performs the %= operation. Read more
source§

impl RemAssign<u64> for BigInt

source§

fn rem_assign(&mut self, other: u64)

Performs the %= operation. Read more
source§

impl RemAssign<u8> for BigInt

source§

fn rem_assign(&mut self, other: u8)

Performs the %= operation. Read more
source§

impl RemAssign<usize> for BigInt

source§

fn rem_assign(&mut self, other: usize)

Performs the %= operation. Read more
source§

impl RemAssign for BigInt

source§

fn rem_assign(&mut self, other: BigInt)

Performs the %= operation. Read more
source§

impl Roots for BigInt

source§

fn nth_root(&self, n: u32) -> BigInt

Returns the truncated principal nth root of an integer – if x >= 0 { ⌊ⁿ√x⌋ } else { ⌈ⁿ√x⌉ } Read more
source§

fn sqrt(&self) -> BigInt

Returns the truncated principal square root of an integer – ⌊√x⌋ Read more
source§

fn cbrt(&self) -> BigInt

Returns the truncated principal cube root of an integer – if x >= 0 { ⌊∛x⌋ } else { ⌈∛x⌉ } Read more
source§

impl SampleUniform for BigInt

§

type Sampler = UniformBigInt

The UniformSampler implementation supporting type X.
source§

impl<'a, 'b> Shl<&'b i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b i128) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b i128> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b i128) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b i16) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b i16> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b i16) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b i32) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b i32> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b i32) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b i64) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b i64> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b i64) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b i8) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b i8> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b i8) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b isize) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b isize> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b isize) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b u128) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b u128> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b u128) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b u16) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b u16> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b u16) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b u32) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b u32> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b u32) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b u64) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b u64> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b u64) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b u8) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b u8> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b u8) -> BigInt

Performs the << operation. Read more
source§

impl<'a, 'b> Shl<&'b usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b usize) -> BigInt

Performs the << operation. Read more
source§

impl<'b> Shl<&'b usize> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: &'b usize) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: i128) -> BigInt

Performs the << operation. Read more
source§

impl Shl<i128> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: i128) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: i16) -> BigInt

Performs the << operation. Read more
source§

impl Shl<i16> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: i16) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: i32) -> BigInt

Performs the << operation. Read more
source§

impl Shl<i32> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: i32) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: i64) -> BigInt

Performs the << operation. Read more
source§

impl Shl<i64> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: i64) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: i8) -> BigInt

Performs the << operation. Read more
source§

impl Shl<i8> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: i8) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: isize) -> BigInt

Performs the << operation. Read more
source§

impl Shl<isize> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: isize) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: u128) -> BigInt

Performs the << operation. Read more
source§

impl Shl<u128> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: u128) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: u16) -> BigInt

Performs the << operation. Read more
source§

impl Shl<u16> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: u16) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: u32) -> BigInt

Performs the << operation. Read more
source§

impl Shl<u32> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: u32) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: u64) -> BigInt

Performs the << operation. Read more
source§

impl Shl<u64> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: u64) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: u8) -> BigInt

Performs the << operation. Read more
source§

impl Shl<u8> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: u8) -> BigInt

Performs the << operation. Read more
source§

impl<'a> Shl<usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: usize) -> BigInt

Performs the << operation. Read more
source§

impl Shl<usize> for BigInt

§

type Output = BigInt

The resulting type after applying the << operator.
source§

fn shl(self, rhs: usize) -> BigInt

Performs the << operation. Read more
source§

impl<'b> ShlAssign<&'b i128> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b i128)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b i16> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b i16)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b i32> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b i32)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b i64> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b i64)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b i8> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b i8)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b isize> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b isize)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b u128> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b u128)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b u16> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b u16)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b u32> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b u32)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b u64> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b u64)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b u8> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b u8)

Performs the <<= operation. Read more
source§

impl<'b> ShlAssign<&'b usize> for BigInt

source§

fn shl_assign(&mut self, rhs: &'b usize)

Performs the <<= operation. Read more
source§

impl ShlAssign<i128> for BigInt

source§

fn shl_assign(&mut self, rhs: i128)

Performs the <<= operation. Read more
source§

impl ShlAssign<i16> for BigInt

source§

fn shl_assign(&mut self, rhs: i16)

Performs the <<= operation. Read more
source§

impl ShlAssign<i32> for BigInt

source§

fn shl_assign(&mut self, rhs: i32)

Performs the <<= operation. Read more
source§

impl ShlAssign<i64> for BigInt

source§

fn shl_assign(&mut self, rhs: i64)

Performs the <<= operation. Read more
source§

impl ShlAssign<i8> for BigInt

source§

fn shl_assign(&mut self, rhs: i8)

Performs the <<= operation. Read more
source§

impl ShlAssign<isize> for BigInt

source§

fn shl_assign(&mut self, rhs: isize)

Performs the <<= operation. Read more
source§

impl ShlAssign<u128> for BigInt

source§

fn shl_assign(&mut self, rhs: u128)

Performs the <<= operation. Read more
source§

impl ShlAssign<u16> for BigInt

source§

fn shl_assign(&mut self, rhs: u16)

Performs the <<= operation. Read more
source§

impl ShlAssign<u32> for BigInt

source§

fn shl_assign(&mut self, rhs: u32)

Performs the <<= operation. Read more
source§

impl ShlAssign<u64> for BigInt

source§

fn shl_assign(&mut self, rhs: u64)

Performs the <<= operation. Read more
source§

impl ShlAssign<u8> for BigInt

source§

fn shl_assign(&mut self, rhs: u8)

Performs the <<= operation. Read more
source§

impl ShlAssign<usize> for BigInt

source§

fn shl_assign(&mut self, rhs: usize)

Performs the <<= operation. Read more
source§

impl<'a, 'b> Shr<&'b i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b i128) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b i128> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b i128) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b i16) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b i16> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b i16) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b i32) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b i32> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b i32) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b i64) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b i64> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b i64) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b i8) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b i8> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b i8) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b isize) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b isize> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b isize) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b u128) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b u128> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b u128) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b u16) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b u16> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b u16) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b u32) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b u32> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b u32) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b u64) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b u64> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b u64) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b u8) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b u8> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b u8) -> BigInt

Performs the >> operation. Read more
source§

impl<'a, 'b> Shr<&'b usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b usize) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> Shr<&'b usize> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: &'b usize) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<i128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: i128) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<i128> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: i128) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<i16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: i16) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<i16> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: i16) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<i32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: i32) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<i32> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: i32) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<i64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: i64) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<i64> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: i64) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<i8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: i8) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<i8> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: i8) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<isize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: isize) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<isize> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: isize) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<u128> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: u128) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<u128> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: u128) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<u16> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: u16) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<u16> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: u16) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<u32> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: u32) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<u32> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: u32) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<u64> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: u64) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<u64> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: u64) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<u8> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: u8) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<u8> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: u8) -> BigInt

Performs the >> operation. Read more
source§

impl<'a> Shr<usize> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: usize) -> BigInt

Performs the >> operation. Read more
source§

impl Shr<usize> for BigInt

§

type Output = BigInt

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: usize) -> BigInt

Performs the >> operation. Read more
source§

impl<'b> ShrAssign<&'b i128> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b i128)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b i16> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b i16)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b i32> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b i32)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b i64> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b i64)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b i8> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b i8)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b isize> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b isize)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b u128> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b u128)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b u16> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b u16)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b u32> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b u32)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b u64> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b u64)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b u8> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b u8)

Performs the >>= operation. Read more
source§

impl<'b> ShrAssign<&'b usize> for BigInt

source§

fn shr_assign(&mut self, rhs: &'b usize)

Performs the >>= operation. Read more
source§

impl ShrAssign<i128> for BigInt

source§

fn shr_assign(&mut self, rhs: i128)

Performs the >>= operation. Read more
source§

impl ShrAssign<i16> for BigInt

source§

fn shr_assign(&mut self, rhs: i16)

Performs the >>= operation. Read more
source§

impl ShrAssign<i32> for BigInt

source§

fn shr_assign(&mut self, rhs: i32)

Performs the >>= operation. Read more
source§

impl ShrAssign<i64> for BigInt

source§

fn shr_assign(&mut self, rhs: i64)

Performs the >>= operation. Read more
source§

impl ShrAssign<i8> for BigInt

source§

fn shr_assign(&mut self, rhs: i8)

Performs the >>= operation. Read more
source§

impl ShrAssign<isize> for BigInt

source§

fn shr_assign(&mut self, rhs: isize)

Performs the >>= operation. Read more
source§

impl ShrAssign<u128> for BigInt

source§

fn shr_assign(&mut self, rhs: u128)

Performs the >>= operation. Read more
source§

impl ShrAssign<u16> for BigInt

source§

fn shr_assign(&mut self, rhs: u16)

Performs the >>= operation. Read more
source§

impl ShrAssign<u32> for BigInt

source§

fn shr_assign(&mut self, rhs: u32)

Performs the >>= operation. Read more
source§

impl ShrAssign<u64> for BigInt

source§

fn shr_assign(&mut self, rhs: u64)

Performs the >>= operation. Read more
source§

impl ShrAssign<u8> for BigInt

source§

fn shr_assign(&mut self, rhs: u8)

Performs the >>= operation. Read more
source§

impl ShrAssign<usize> for BigInt

source§

fn shr_assign(&mut self, rhs: usize)

Performs the >>= operation. Read more
source§

impl Signed for BigInt

source§

fn abs(&self) -> BigInt

Computes the absolute value. Read more
source§

fn abs_sub(&self, other: &BigInt) -> BigInt

The positive difference of two numbers. Read more
source§

fn signum(&self) -> BigInt

Returns the sign of the number. Read more
source§

fn is_positive(&self) -> bool

Returns true if the number is positive and false if the number is zero or negative.
source§

fn is_negative(&self) -> bool

Returns true if the number is negative and false if the number is zero or positive.
source§

impl<'a, 'b> Sub<&'b BigInt> for &'a BigInt

§

type Output = BigInt

The resulting type after applying the - operator.
source