cairo-air 1.2.2

AIR (Algebraic Intermediate Representation) definitions for Cairo programs
Documentation
// This file was created by the AIR team.

use crate::components::prelude::*;

#[derive(Copy, Clone, Serialize, Deserialize, CairoSerialize)]
pub struct VerifyReduced252 {}

impl VerifyReduced252 {
    #[allow(unused_parens)]
    #[allow(clippy::double_parens)]
    #[allow(non_snake_case)]
    #[allow(clippy::unused_unit)]
    #[allow(unused_variables)]
    #[allow(clippy::too_many_arguments)]
    pub fn evaluate<E: EvalAtRow>(
        [verify_reduced_252_input_limb_0, verify_reduced_252_input_limb_1, verify_reduced_252_input_limb_2, verify_reduced_252_input_limb_3, verify_reduced_252_input_limb_4, verify_reduced_252_input_limb_5, verify_reduced_252_input_limb_6, verify_reduced_252_input_limb_7, verify_reduced_252_input_limb_8, verify_reduced_252_input_limb_9, verify_reduced_252_input_limb_10, verify_reduced_252_input_limb_11, verify_reduced_252_input_limb_12, verify_reduced_252_input_limb_13, verify_reduced_252_input_limb_14, verify_reduced_252_input_limb_15, verify_reduced_252_input_limb_16, verify_reduced_252_input_limb_17, verify_reduced_252_input_limb_18, verify_reduced_252_input_limb_19, verify_reduced_252_input_limb_20, verify_reduced_252_input_limb_21, verify_reduced_252_input_limb_22, verify_reduced_252_input_limb_23, verify_reduced_252_input_limb_24, verify_reduced_252_input_limb_25, verify_reduced_252_input_limb_26, verify_reduced_252_input_limb_27]: [E::F; 28],
        ms_limb_is_max_col0: E::F,
        ms_and_mid_limbs_are_max_col1: E::F,
        rc_input_col2: E::F,
        common_lookup_elements: &relations::CommonLookupElements,
        eval: &mut E,
    ) -> [E::F; 0] {
        let M31_1 = E::F::from(M31::from(1));
        let M31_120 = E::F::from(M31::from(120));
        let M31_1420243005 = E::F::from(M31::from(1420243005));

        // ms_max is bit.
        eval.add_constraint(
            (ms_limb_is_max_col0.clone() * (M31_1.clone() - ms_limb_is_max_col0.clone())),
        );
        // both_max is bit.
        eval.add_constraint(
            (ms_and_mid_limbs_are_max_col1.clone()
                * (M31_1.clone() - ms_and_mid_limbs_are_max_col1.clone())),
        );
        eval.add_to_relation(RelationEntry::new(
            common_lookup_elements,
            E::EF::from(M31_1.clone()),
            &[
                M31_1420243005.clone(),
                (verify_reduced_252_input_limb_27.clone() - ms_limb_is_max_col0.clone()),
            ],
        ));

        // If the MS limb is max, high limbs should be 0.
        eval.add_constraint(
            (ms_limb_is_max_col0.clone()
                * ((((verify_reduced_252_input_limb_22.clone()
                    + verify_reduced_252_input_limb_23.clone())
                    + verify_reduced_252_input_limb_24.clone())
                    + verify_reduced_252_input_limb_25.clone())
                    + verify_reduced_252_input_limb_26.clone())),
        );
        // rc_input.
        eval.add_constraint(
            (rc_input_col2.clone()
                - (ms_limb_is_max_col0.clone()
                    * ((M31_120.clone() + verify_reduced_252_input_limb_21.clone())
                        - ms_and_mid_limbs_are_max_col1.clone()))),
        );
        eval.add_to_relation(RelationEntry::new(
            common_lookup_elements,
            E::EF::from(M31_1.clone()),
            &[M31_1420243005.clone(), rc_input_col2.clone()],
        ));

        // If the MS and mid limbs are max, low limbs should be 0.
        eval.add_constraint(
            (ms_and_mid_limbs_are_max_col1.clone()
                * ((((((((((((((((((((verify_reduced_252_input_limb_0.clone()
                    + verify_reduced_252_input_limb_1.clone())
                    + verify_reduced_252_input_limb_2.clone())
                    + verify_reduced_252_input_limb_3.clone())
                    + verify_reduced_252_input_limb_4.clone())
                    + verify_reduced_252_input_limb_5.clone())
                    + verify_reduced_252_input_limb_6.clone())
                    + verify_reduced_252_input_limb_7.clone())
                    + verify_reduced_252_input_limb_8.clone())
                    + verify_reduced_252_input_limb_9.clone())
                    + verify_reduced_252_input_limb_10.clone())
                    + verify_reduced_252_input_limb_11.clone())
                    + verify_reduced_252_input_limb_12.clone())
                    + verify_reduced_252_input_limb_13.clone())
                    + verify_reduced_252_input_limb_14.clone())
                    + verify_reduced_252_input_limb_15.clone())
                    + verify_reduced_252_input_limb_16.clone())
                    + verify_reduced_252_input_limb_17.clone())
                    + verify_reduced_252_input_limb_18.clone())
                    + verify_reduced_252_input_limb_19.clone())
                    + verify_reduced_252_input_limb_20.clone())),
        );
        []
    }
}