use crate::components::prelude::*;
#[derive(Copy, Clone, Serialize, Deserialize, CairoSerialize)]
pub struct DecodeInstructionB1597 {}
impl DecodeInstructionB1597 {
#[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>(
[decode_instruction_b1597_input_pc]: [E::F; 1],
offset2_col0: E::F,
op1_base_fp_col1: E::F,
ap_update_add_1_col2: E::F,
common_lookup_elements: &relations::CommonLookupElements,
eval: &mut E,
) -> [E::F; 2] {
let M31_1 = E::F::from(M31::from(1));
let M31_128 = E::F::from(M31::from(128));
let M31_1719106205 = E::F::from(M31::from(1719106205));
let M31_2 = E::F::from(M31::from(2));
let M31_24 = E::F::from(M31::from(24));
let M31_32 = E::F::from(M31::from(32));
let M31_32767 = E::F::from(M31::from(32767));
let M31_32768 = E::F::from(M31::from(32768));
let M31_64 = E::F::from(M31::from(64));
eval.add_constraint(
(op1_base_fp_col1.clone() * (M31_1.clone() - op1_base_fp_col1.clone())),
);
eval.add_constraint(
(ap_update_add_1_col2.clone() * (M31_1.clone() - ap_update_add_1_col2.clone())),
);
eval.add_to_relation(RelationEntry::new(
common_lookup_elements,
E::EF::from(M31_1.clone()),
&[
M31_1719106205.clone(),
decode_instruction_b1597_input_pc.clone(),
M31_32767.clone(),
M31_32767.clone(),
offset2_col0.clone(),
((M31_24.clone() + (op1_base_fp_col1.clone() * M31_64.clone()))
+ ((M31_1.clone() - op1_base_fp_col1.clone()) * M31_128.clone())),
(M31_2.clone() + (ap_update_add_1_col2.clone() * M31_32.clone())),
],
));
[
(offset2_col0.clone() - M31_32768.clone()),
(M31_1.clone() - op1_base_fp_col1.clone()),
]
}
}