當前位置: 首頁>>代碼示例>>Golang>>正文


Golang Int.SetBits方法代碼示例

本文整理匯總了Golang中math/big.Int.SetBits方法的典型用法代碼示例。如果您正苦於以下問題:Golang Int.SetBits方法的具體用法?Golang Int.SetBits怎麽用?Golang Int.SetBits使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在math/big.Int的用法示例。


在下文中一共展示了Int.SetBits方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: BigAbsCmp

func BigAbsCmp(x, y big.Int) int {
	// SetBits sets to |v|, thus giving an absolute comparison.
	var x0, y0 big.Int
	x0.SetBits(x.Bits())
	y0.SetBits(y.Bits())
	return x0.Cmp(&y0)
}
開發者ID:EricLagergren,項目名稱:decimal,代碼行數:7,代碼來源:abs.go

示例2: scalar2big

func scalar2big(out *big.Int, in *[4]C.ulonglong) {
	bits := make([]big.Word, 4)
	for i := range bits {
		bits[i] = big.Word(in[i])
	}
	out.SetBits(bits)
}
開發者ID:asimshankar,項目名稱:bn256,代碼行數:7,代碼來源:bn256_64.go

示例3: scalar2big

func scalar2big(out *big.Int, in *[4]C.ulonglong) {
	bits := make([]big.Word, 8)
	for i := 0; i < len(bits); i += 2 {
		bits[i] = big.Word(in[i>>1] & 0x00000000ffffffff)
		bits[i+1] = big.Word((in[i>>1] & 0xffffffff00000000) >> 32)
	}
	out.SetBits(bits)
}
開發者ID:asimshankar,項目名稱:bn256,代碼行數:8,代碼來源:bn256_32.go

示例4: NewBigInt

// Initialize a Flag that will Intersect with all flags with a value up to (length -1)
func NewBigInt(length int) Flag {
	n := (length + _WORDSIZE - 1) / _WORDSIZE

	wordTable := make([]big.Word, 0)
	for i := 0; i < n; i++ {
		wordTable = append(wordTable, _word1)
	}

	b := big.Int{}
	b.SetBits(wordTable)

	return Flag{N: b}
}
開發者ID:jloup,項目名稱:utils,代碼行數:14,代碼來源:flag.go

示例5: Mul

func (z fermat) Mul(x, y fermat) fermat {
	n := len(x) - 1
	if n < 30 {
		z = z[:2*n+2]
		basicMul(z, x, y)
		z = z[:2*n+1]
	} else {
		var xi, yi, zi big.Int
		xi.SetBits(x)
		yi.SetBits(y)
		zi.SetBits(z)
		zb := zi.Mul(&xi, &yi).Bits()
		if len(zb) <= n {
			// Short product.
			copy(z, zb)
			for i := len(zb); i < len(z); i++ {
				z[i] = 0
			}
			return z
		}
		z = zb
	}
	// len(z) is at most 2n+1.
	if len(z) > 2*n+1 {
		panic("len(z) > 2n+1")
	}
	i := len(z) - (n + 1) // i <= n
	c := subVV(z[1:i+1], z[1:i+1], z[n+1:])
	z = z[:n+1]
	z[n]++ // Add -1.
	subVW(z[i+1:], z[i+1:], c)
	// Add 1.
	if z[n] == 1 {
		z[n] = 0
	} else {
		addVW(z, z, 1)
	}
	z.norm()
	return z
}
開發者ID:remyoudompheng,項目名稱:bigfft,代碼行數:40,代碼來源:fermat.go

示例6: PreallocInt

// PreallocInt preallocates 128-bits of storage for an existing
// big.Int value. Will not perform the pre-allocation if the given
// pointer is nil, or if the storage has already been allocated.
//
// This function serves very little purpose as it provides no benefits
// whatsoever, and is only included for completeness.
func PreallocInt(i *big.Int) {
	var mem [pS]big.Word
	if i != nil && cap(i.Bits()) == 0 {
		i.SetBits(mem[0:0])
	}
}
開發者ID:cookieo9,項目名稱:go-misc,代碼行數:12,代碼來源:big128.go


注:本文中的math/big.Int.SetBits方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。