slop-basefold-prover 6.2.4

BaseFold prover implementation with FRI integration
Documentation
use std::{convert::Infallible, sync::Arc};

use slop_algebra::TwoAdicField;
use slop_basefold::{FriConfig, RsCodeWord};
use slop_commit::Message;
use slop_dft::{p3::Radix2DitParallel, Dft, DftOrdering};
use slop_futures::OwnedBorrow;
use slop_multilinear::Mle;

#[derive(Debug, Clone)]
pub struct CpuDftEncoder<F> {
    pub config: FriConfig<F>,
    pub dft: Arc<Radix2DitParallel>,
}

impl<F: TwoAdicField> CpuDftEncoder<F> {
    #[inline]
    pub fn config(&self) -> FriConfig<F> {
        self.config
    }

    pub fn encode_batch<M>(&self, data: Message<M>) -> Result<Message<RsCodeWord<F>>, Infallible>
    where
        M: OwnedBorrow<Mle<F>>,
    {
        let dft = &self.dft;
        let log_blowup = self.config.log_blowup();
        let mut results = Vec::with_capacity(data.len());
        for data in data.iter() {
            let data = data.borrow().guts();
            assert_eq!(data.sizes().len(), 2, "Expected a 2D tensor");
            // Perform a DFT along the first axis of the tensor (assumed to be the long
            // dimension).
            let dft_result = dft.dft(data, log_blowup, DftOrdering::BitReversed, 0).unwrap();
            results.push(Arc::new(RsCodeWord { data: dft_result }));
        }
        Ok(Message::from(results))
    }
}