mirror of
https://github.com/status-im/eth2.0-specs.git
synced 2025-01-22 00:20:28 +00:00
update polynomial-commitments-sampling.md -- fix shift_polynomialcoeff
This commit is contained in:
parent
3644f360b8
commit
ac105f472a
@ -263,14 +263,14 @@ def divide_polynomialcoeff(a: PolynomialCoeff, b: PolynomialCoeff) -> Polynomial
|
|||||||
def shift_polynomialcoeff(polynomial_coeff: PolynomialCoeff, factor: BLSFieldElement) -> PolynomialCoeff:
|
def shift_polynomialcoeff(polynomial_coeff: PolynomialCoeff, factor: BLSFieldElement) -> PolynomialCoeff:
|
||||||
"""
|
"""
|
||||||
Shift the evaluation of a polynomial in coefficient form by factor.
|
Shift the evaluation of a polynomial in coefficient form by factor.
|
||||||
This results in a new polynomial g(x) = f(factor * x)
|
This returns a new polynomial g in coefficient form such that g(x) = f(factor * x).
|
||||||
|
In other words, each coefficient of f is scaled by a power of factor.
|
||||||
"""
|
"""
|
||||||
factor_power = 1
|
factor_power = 1
|
||||||
inv_factor = pow(int(factor), BLS_MODULUS - 2, BLS_MODULUS)
|
|
||||||
o = []
|
o = []
|
||||||
for p in polynomial_coeff:
|
for p in polynomial_coeff:
|
||||||
o.append(int(p) * factor_power % BLS_MODULUS)
|
o.append(int(p) * factor_power % BLS_MODULUS)
|
||||||
factor_power = factor_power * inv_factor % BLS_MODULUS
|
factor_power = factor_power * int(factor) % BLS_MODULUS
|
||||||
return o
|
return o
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user