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 LinearCombinationN1Coefs2 {}

impl LinearCombinationN1Coefs2 {
    #[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>(
        [linear_combination_n_1_coefs_2_input_limb_0, linear_combination_n_1_coefs_2_input_limb_1, linear_combination_n_1_coefs_2_input_limb_2, linear_combination_n_1_coefs_2_input_limb_3, linear_combination_n_1_coefs_2_input_limb_4, linear_combination_n_1_coefs_2_input_limb_5, linear_combination_n_1_coefs_2_input_limb_6, linear_combination_n_1_coefs_2_input_limb_7, linear_combination_n_1_coefs_2_input_limb_8, linear_combination_n_1_coefs_2_input_limb_9]: [E::F; 10],
        combination_limb_0_col0: E::F,
        combination_limb_1_col1: E::F,
        combination_limb_2_col2: E::F,
        combination_limb_3_col3: E::F,
        combination_limb_4_col4: E::F,
        combination_limb_5_col5: E::F,
        combination_limb_6_col6: E::F,
        combination_limb_7_col7: E::F,
        combination_limb_8_col8: E::F,
        combination_limb_9_col9: E::F,
        p_coef_col10: E::F,
        common_lookup_elements: &relations::CommonLookupElements,
        eval: &mut E,
    ) -> [E::F; 0] {
        let M31_136 = E::F::from(M31::from(136));
        let M31_16 = E::F::from(M31::from(16));
        let M31_2 = E::F::from(M31::from(2));
        let M31_256 = E::F::from(M31::from(256));

        let carry_0_tmp_13179_2 = eval.add_intermediate(
            ((((M31_2.clone() * linear_combination_n_1_coefs_2_input_limb_0.clone())
                - combination_limb_0_col0.clone())
                - p_coef_col10.clone())
                * M31_16.clone()),
        );
        let carry_1_tmp_13179_3 = eval.add_intermediate(
            (((carry_0_tmp_13179_2.clone()
                + (M31_2.clone() * linear_combination_n_1_coefs_2_input_limb_1.clone()))
                - combination_limb_1_col1.clone())
                * M31_16.clone()),
        );
        let carry_2_tmp_13179_4 = eval.add_intermediate(
            (((carry_1_tmp_13179_3.clone()
                + (M31_2.clone() * linear_combination_n_1_coefs_2_input_limb_2.clone()))
                - combination_limb_2_col2.clone())
                * M31_16.clone()),
        );
        let carry_3_tmp_13179_5 = eval.add_intermediate(
            (((carry_2_tmp_13179_4.clone()
                + (M31_2.clone() * linear_combination_n_1_coefs_2_input_limb_3.clone()))
                - combination_limb_3_col3.clone())
                * M31_16.clone()),
        );
        let carry_4_tmp_13179_6 = eval.add_intermediate(
            (((carry_3_tmp_13179_5.clone()
                + (M31_2.clone() * linear_combination_n_1_coefs_2_input_limb_4.clone()))
                - combination_limb_4_col4.clone())
                * M31_16.clone()),
        );
        let carry_5_tmp_13179_7 = eval.add_intermediate(
            (((carry_4_tmp_13179_6.clone()
                + (M31_2.clone() * linear_combination_n_1_coefs_2_input_limb_5.clone()))
                - combination_limb_5_col5.clone())
                * M31_16.clone()),
        );
        let carry_6_tmp_13179_8 = eval.add_intermediate(
            (((carry_5_tmp_13179_7.clone()
                + (M31_2.clone() * linear_combination_n_1_coefs_2_input_limb_6.clone()))
                - combination_limb_6_col6.clone())
                * M31_16.clone()),
        );
        let carry_7_tmp_13179_9 = eval.add_intermediate(
            ((((carry_6_tmp_13179_8.clone()
                + (M31_2.clone() * linear_combination_n_1_coefs_2_input_limb_7.clone()))
                - combination_limb_7_col7.clone())
                - (p_coef_col10.clone() * M31_136.clone()))
                * M31_16.clone()),
        );
        let carry_8_tmp_13179_10 = eval.add_intermediate(
            (((carry_7_tmp_13179_9.clone()
                + (M31_2.clone() * linear_combination_n_1_coefs_2_input_limb_8.clone()))
                - combination_limb_8_col8.clone())
                * M31_16.clone()),
        );
        // final limb constraint.
        eval.add_constraint(
            (((carry_8_tmp_13179_10.clone()
                + (M31_2.clone() * linear_combination_n_1_coefs_2_input_limb_9.clone()))
                - combination_limb_9_col9.clone())
                - (p_coef_col10.clone() * M31_256.clone())),
        );
        // carry constraint 0.
        eval.add_constraint(
            (((p_coef_col10.clone() * p_coef_col10.clone()) * p_coef_col10.clone())
                - p_coef_col10.clone()),
        );
        let biased_carry_1_tmp_13179_11 = eval.add_intermediate(carry_0_tmp_13179_2.clone());
        // carry constraint 1.
        eval.add_constraint(
            (((biased_carry_1_tmp_13179_11.clone() * biased_carry_1_tmp_13179_11.clone())
                * biased_carry_1_tmp_13179_11.clone())
                - biased_carry_1_tmp_13179_11.clone()),
        );
        let biased_carry_2_tmp_13179_12 = eval.add_intermediate(carry_1_tmp_13179_3.clone());
        // carry constraint 2.
        eval.add_constraint(
            (((biased_carry_2_tmp_13179_12.clone() * biased_carry_2_tmp_13179_12.clone())
                * biased_carry_2_tmp_13179_12.clone())
                - biased_carry_2_tmp_13179_12.clone()),
        );
        let biased_carry_3_tmp_13179_13 = eval.add_intermediate(carry_2_tmp_13179_4.clone());
        // carry constraint 3.
        eval.add_constraint(
            (((biased_carry_3_tmp_13179_13.clone() * biased_carry_3_tmp_13179_13.clone())
                * biased_carry_3_tmp_13179_13.clone())
                - biased_carry_3_tmp_13179_13.clone()),
        );
        let biased_carry_4_tmp_13179_14 = eval.add_intermediate(carry_3_tmp_13179_5.clone());
        // carry constraint 4.
        eval.add_constraint(
            (((biased_carry_4_tmp_13179_14.clone() * biased_carry_4_tmp_13179_14.clone())
                * biased_carry_4_tmp_13179_14.clone())
                - biased_carry_4_tmp_13179_14.clone()),
        );
        let biased_carry_5_tmp_13179_15 = eval.add_intermediate(carry_4_tmp_13179_6.clone());
        // carry constraint 5.
        eval.add_constraint(
            (((biased_carry_5_tmp_13179_15.clone() * biased_carry_5_tmp_13179_15.clone())
                * biased_carry_5_tmp_13179_15.clone())
                - biased_carry_5_tmp_13179_15.clone()),
        );
        let biased_carry_6_tmp_13179_16 = eval.add_intermediate(carry_5_tmp_13179_7.clone());
        // carry constraint 6.
        eval.add_constraint(
            (((biased_carry_6_tmp_13179_16.clone() * biased_carry_6_tmp_13179_16.clone())
                * biased_carry_6_tmp_13179_16.clone())
                - biased_carry_6_tmp_13179_16.clone()),
        );
        let biased_carry_7_tmp_13179_17 = eval.add_intermediate(carry_6_tmp_13179_8.clone());
        // carry constraint 7.
        eval.add_constraint(
            (((biased_carry_7_tmp_13179_17.clone() * biased_carry_7_tmp_13179_17.clone())
                * biased_carry_7_tmp_13179_17.clone())
                - biased_carry_7_tmp_13179_17.clone()),
        );
        let biased_carry_8_tmp_13179_18 = eval.add_intermediate(carry_7_tmp_13179_9.clone());
        // carry constraint 8.
        eval.add_constraint(
            (((biased_carry_8_tmp_13179_18.clone() * biased_carry_8_tmp_13179_18.clone())
                * biased_carry_8_tmp_13179_18.clone())
                - biased_carry_8_tmp_13179_18.clone()),
        );
        let biased_carry_9_tmp_13179_19 = eval.add_intermediate(carry_8_tmp_13179_10.clone());
        // carry constraint 9.
        eval.add_constraint(
            (((biased_carry_9_tmp_13179_19.clone() * biased_carry_9_tmp_13179_19.clone())
                * biased_carry_9_tmp_13179_19.clone())
                - biased_carry_9_tmp_13179_19.clone()),
        );
        []
    }
}