Documentation ¶
Overview ¶
Package math provides integer math utilities.
Package math provides integer math utilities.
Index ¶
- Constants
- Variables
- func BigMax(x, y *big.Int) *big.Int
- func BigMin(x, y *big.Int) *big.Int
- func BigPow(a, b int64) *big.Int
- func Byte(bigint *big.Int, padlength, n int) byte
- func Exp(base, exponent *big.Int) *big.Int
- func FirstBitSet(v *big.Int) int
- func MustParseBig256(s string) *big.Int
- func MustParseUint256(s string) *uint256.Int
- func MustParseUint64(s string) uint64
- func PaddedBigBytes(bigint *big.Int, n int) []byte
- func ParseBig256(s string) (*big.Int, bool)
- func ParseUint256(s string) (*uint256.Int, bool)
- func ParseUint64(s string) (uint64, bool)
- func ReadBits(bigint *big.Int, buf []byte)
- func S256(x *big.Int) *big.Int
- func SafeAdd(x, y uint64) (uint64, bool)
- func SafeMul(x, y uint64) (uint64, bool)
- func SafeSub(x, y uint64) (uint64, bool)
- func U256(x *big.Int) *big.Int
- func U256Bytes(n *big.Int) []byte
- func Uint256Max(x, y *uint256.Int) *uint256.Int
- func Uint256Min(x, y *uint256.Int) *uint256.Int
- func Uint256Pow(a, b uint64) *uint256.Int
- type Decimal256
- type DecimalUint256
- type HexOrDecimal256
- type HexOrDecimal64
- type HexOrDecimalUint256
Constants ¶
const ( MaxInt8 = 1<<7 - 1 MinInt8 = -1 << 7 MaxInt16 = 1<<15 - 1 MinInt16 = -1 << 15 MaxInt32 = 1<<31 - 1 MinInt32 = -1 << 31 MaxInt64 = 1<<63 - 1 MinInt64 = -1 << 63 MaxUint8 = 1<<8 - 1 MaxUint16 = 1<<16 - 1 MaxUint32 = 1<<32 - 1 MaxUint64 = 1<<64 - 1 )
Integer limit values.
Variables ¶
var ( MaxBig256 = new(big.Int).Set(tt256m1) MaxBig63 = new(big.Int).Sub(tt63, big.NewInt(1)) )
Various big integer limit values.
Functions ¶
func Byte ¶
Byte returns the byte at position n, with the supplied padlength in Little-Endian encoding. n==0 returns the MSB Example: bigint '5', padlength 32, n=31 => 5
func Exp ¶
Exp implements exponentiation by squaring. Exp returns a newly-allocated big integer and does not change base or exponent. The result is truncated to 256 bits.
Courtesy @karalabe and @chfast
func FirstBitSet ¶
FirstBitSet returns the index of the first 1 bit in v, counting from LSB.
func MustParseBig256 ¶
MustParseBig256 parses s as a 256 bit big integer and panics if the string is invalid.
func MustParseUint256 ¶
MustParseUint256 parses s as a 256 bit big integer and panics if the string is invalid.
func MustParseUint64 ¶
MustParseUint64 parses s as an integer and panics if the string is invalid.
func PaddedBigBytes ¶
PaddedBigBytes encodes a big integer as a big-endian byte slice. The length of the slice is at least n bytes.
func ParseBig256 ¶
ParseBig256 parses s as a 256 bit integer in decimal or hexadecimal syntax. Leading zeros are accepted. The empty string parses as zero.
func ParseUint256 ¶
ParseUint256 parses s as a 256 bit integer in decimal or hexadecimal syntax. Leading zeros are accepted. The empty string parses as zero.
func ParseUint64 ¶
ParseUint64 parses s as an integer in decimal or hexadecimal syntax. Leading zeros are accepted. The empty string parses as zero.
func ReadBits ¶
ReadBits encodes the absolute value of bigint as big-endian bytes. Callers must ensure that buf has enough space. If buf is too short the result will be incomplete.
func S256 ¶
S256 interprets x as a two's complement number. x must not exceed 256 bits (the result is undefined if it does) and is not modified.
S256(0) = 0 S256(1) = 1 S256(2**255) = -2**255 S256(2**256-1) = -1
func U256Bytes ¶
U256Bytes converts a big Int into a 256bit EVM number. This operation is destructive.
func Uint256Max ¶
Uint256Max returns the larger of x or y.
func Uint256Min ¶
Uint256Min returns the smaller of x or y.
func Uint256Pow ¶
Uint256Pow returns a ** b as a big integer.
Types ¶
type Decimal256 ¶
Decimal256 unmarshals big.Int as a decimal string. When unmarshalling, it however accepts either "0x"-prefixed (hex encoded) or non-prefixed (decimal)
func (*Decimal256) MarshalText ¶
func (i *Decimal256) MarshalText() ([]byte, error)
MarshalText implements encoding.TextMarshaler.
func (*Decimal256) UnmarshalText ¶
func (i *Decimal256) UnmarshalText(input []byte) error
UnmarshalText implements encoding.TextUnmarshaler.
type DecimalUint256 ¶
DecimalUint256 unmarshals uint256.Int as a decimal string. When unmarshalling, it however accepts either "0x"-prefixed (hex encoded) or non-prefixed (decimal)
func NewDecimalUint256 ¶
func NewDecimalUint256(x uint64) *DecimalUint256
NewDecimalUint256 creates a new DecimalUint256
func (*DecimalUint256) MarshalText ¶
func (i *DecimalUint256) MarshalText() ([]byte, error)
MarshalText implements encoding.TextMarshaler.
func (*DecimalUint256) String ¶
func (i *DecimalUint256) String() string
String implements Stringer.
func (*DecimalUint256) UnmarshalText ¶
func (i *DecimalUint256) UnmarshalText(input []byte) error
UnmarshalText implements encoding.TextUnmarshaler.
type HexOrDecimal256 ¶
HexOrDecimal256 marshals big.Int as hex or decimal.
func NewHexOrDecimal256 ¶
func NewHexOrDecimal256(x int64) *HexOrDecimal256
NewHexOrDecimal256 creates a new HexOrDecimal256
func (*HexOrDecimal256) MarshalText ¶
func (i *HexOrDecimal256) MarshalText() ([]byte, error)
MarshalText implements encoding.TextMarshaler.
func (*HexOrDecimal256) ToInt ¶
func (i *HexOrDecimal256) ToInt() *big.Int
func (*HexOrDecimal256) UnmarshalJSON ¶
func (i *HexOrDecimal256) UnmarshalJSON(input []byte) error
UnmarshalJSON implements json.Unmarshaler.
It is similar to UnmarshalText, but allows parsing real decimals too, not just quoted decimal strings.
func (*HexOrDecimal256) UnmarshalText ¶
func (i *HexOrDecimal256) UnmarshalText(input []byte) error
UnmarshalText implements encoding.TextUnmarshaler.
type HexOrDecimal64 ¶
type HexOrDecimal64 uint64
HexOrDecimal64 marshals uint64 as hex or decimal.
func (HexOrDecimal64) MarshalText ¶
func (i HexOrDecimal64) MarshalText() ([]byte, error)
MarshalText implements encoding.TextMarshaler.
func (*HexOrDecimal64) UnmarshalJSON ¶
func (i *HexOrDecimal64) UnmarshalJSON(input []byte) error
UnmarshalJSON implements json.Unmarshaler.
It is similar to UnmarshalText, but allows parsing real decimals too, not just quoted decimal strings.
func (*HexOrDecimal64) UnmarshalText ¶
func (i *HexOrDecimal64) UnmarshalText(input []byte) error
UnmarshalText implements encoding.TextUnmarshaler.
type HexOrDecimalUint256 ¶
HexOrDecimalUint256 marshals uint256.Int as hex or decimal.
func NewHexOrDecimalUint256 ¶
func NewHexOrDecimalUint256(x uint64) *HexOrDecimalUint256
NewHexOrDecimalUint256 creates a new HexOrDecimalUint256
func (*HexOrDecimalUint256) MarshalText ¶
func (i *HexOrDecimalUint256) MarshalText() ([]byte, error)
MarshalText implements encoding.TextMarshaler.
func (*HexOrDecimalUint256) ToInt ¶
func (i *HexOrDecimalUint256) ToInt() *uint256.Int
func (*HexOrDecimalUint256) UnmarshalJSON ¶
func (i *HexOrDecimalUint256) UnmarshalJSON(input []byte) error
UnmarshalJSON implements json.Unmarshaler.
It is similar to UnmarshalText, but allows parsing real decimals too, not just quoted decimal strings.
func (*HexOrDecimalUint256) UnmarshalText ¶
func (i *HexOrDecimalUint256) UnmarshalText(input []byte) error
UnmarshalText implements encoding.TextUnmarshaler.