use crate::{
field::{
element::FieldElement,
traits::{IsFFTField, IsField, IsSubFieldOf, RootsConfig},
},
polynomial::Polynomial,
};
use lambdaworks_gpu::metal::abstractions::{errors::MetalError, state::MetalState};
use super::ops::*;
pub fn evaluate_fft_metal<F, E>(
coeffs: &[FieldElement<E>],
) -> Result<Vec<FieldElement<E>>, MetalError>
where
F: IsFFTField + IsSubFieldOf<E>,
E: IsField,
{
let state = MetalState::new(None)?;
let order = coeffs.len().trailing_zeros();
let twiddles = gen_twiddles::<F>(order.into(), RootsConfig::BitReverse, &state)?;
fft(coeffs, &twiddles, &state)
}
pub fn interpolate_fft_metal<F, E>(
fft_evals: &[FieldElement<E>],
) -> Result<Polynomial<FieldElement<E>>, MetalError>
where
F: IsFFTField + IsSubFieldOf<E>,
E: IsField,
{
let metal_state = MetalState::new(None)?;
let order = fft_evals.len().trailing_zeros();
let twiddles = gen_twiddles::<F>(order.into(), RootsConfig::BitReverseInversed, &metal_state)?;
let coeffs = fft(fft_evals, &twiddles, &metal_state)?;
let scale_factor = FieldElement::from(fft_evals.len() as u64).inv().unwrap();
Ok(Polynomial::new(&coeffs).scale_coeffs(&scale_factor))
}