mirror of
https://github.com/logos-storage/plonky2.git
synced 2026-01-08 16:53:07 +00:00
Change ExtensionTarget::frobenius to use 4 constants instead of 1.
This commit is contained in:
parent
bdf8417c28
commit
2cd99ff84c
@ -19,15 +19,14 @@ impl<const D: usize> ExtensionTarget<D> {
|
||||
pub fn frobenius<F: Extendable<D>>(&self, builder: &mut CircuitBuilder<F, D>) -> Self {
|
||||
let arr = self.to_target_array();
|
||||
let k = (F::ORDER - 1) / (D as u64);
|
||||
let z0 = builder.constant(F::Extension::W.exp(k));
|
||||
let mut z = builder.one();
|
||||
let mut res = [builder.zero(); D];
|
||||
for i in 0..D {
|
||||
res[i] = builder.mul(arr[i], z);
|
||||
z = builder.mul(z, z0);
|
||||
let zs = (0..D as u64).map(|i| builder.constant(F::Extension::W.exp(k * i)));
|
||||
|
||||
let mut res = Vec::with_capacity(D);
|
||||
for (z, a) in zs.zip(arr) {
|
||||
res.push(builder.mul(z, a));
|
||||
}
|
||||
|
||||
Self(res)
|
||||
res.try_into().unwrap()
|
||||
}
|
||||
|
||||
pub fn from_range(gate: usize, range: Range<usize>) -> Self {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user