2016-11-02 14:43:15 +03:00
|
|
|
package math
|
|
|
|
|
|
|
|
import (
|
|
|
|
"math/big"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
|
|
)
|
|
|
|
|
|
|
|
// wordSize is the size number of bits in a big.Int Word.
|
2016-11-02 17:58:59 +03:00
|
|
|
const wordSize = 32 << (uint64(^big.Word(0)) >> 63)
|
2016-11-02 14:43:15 +03:00
|
|
|
|
|
|
|
// Exp implement exponentiation by squaring algorithm.
|
|
|
|
//
|
|
|
|
// Courtesy @karalabe and @chfast
|
|
|
|
func Exp(base, exponent *big.Int) *big.Int {
|
|
|
|
result := big.NewInt(1)
|
|
|
|
|
|
|
|
for _, word := range exponent.Bits() {
|
|
|
|
for i := 0; i < wordSize; i++ {
|
|
|
|
if word&1 == 1 {
|
|
|
|
common.U256(result.Mul(result, base))
|
|
|
|
}
|
|
|
|
common.U256(base.Mul(base, base))
|
|
|
|
word >>= 1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|