use crate::components::prelude::*;
use crate::components::subroutines::decode_instruction_472fe::DecodeInstruction472Fe;
use crate::components::subroutines::read_positive_num_bits_29::ReadPositiveNumBits29;
use crate::components::subroutines::read_u_32::ReadU32;
#[derive(Copy, Clone, Serialize, Deserialize, CairoSerialize)]
pub struct DecodeBlakeOpcode {}
impl DecodeBlakeOpcode {
#[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_blake_opcode_input_pc, decode_blake_opcode_input_ap, decode_blake_opcode_input_fp]: [E::F; 3],
offset0_col0: E::F,
offset1_col1: E::F,
offset2_col2: E::F,
dst_base_fp_col3: E::F,
op0_base_fp_col4: E::F,
op1_base_fp_col5: E::F,
ap_update_add_1_col6: E::F,
opcode_extension_col7: E::F,
mem0_base_col8: E::F,
op0_id_col9: E::F,
op0_limb_0_col10: E::F,
op0_limb_1_col11: E::F,
op0_limb_2_col12: E::F,
op0_limb_3_col13: E::F,
partial_limb_msb_col14: E::F,
mem1_base_col15: E::F,
op1_id_col16: E::F,
op1_limb_0_col17: E::F,
op1_limb_1_col18: E::F,
op1_limb_2_col19: E::F,
op1_limb_3_col20: E::F,
partial_limb_msb_col21: E::F,
ap_id_col22: E::F,
ap_limb_0_col23: E::F,
ap_limb_1_col24: E::F,
ap_limb_2_col25: E::F,
ap_limb_3_col26: E::F,
partial_limb_msb_col27: E::F,
mem_dst_base_col28: E::F,
low_16_bits_col29: E::F,
high_16_bits_col30: E::F,
low_7_ms_bits_col31: E::F,
high_14_ms_bits_col32: E::F,
high_5_ms_bits_col33: E::F,
dst_id_col34: E::F,
common_lookup_elements: &relations::CommonLookupElements,
eval: &mut E,
) -> [E::F; 4] {
let M31_1 = E::F::from(M31::from(1));
let M31_134217728 = E::F::from(M31::from(134217728));
let M31_2 = E::F::from(M31::from(2));
let M31_262144 = E::F::from(M31::from(262144));
let M31_512 = E::F::from(M31::from(512));
let [decode_instruction_472fe_output_tmp_47e62_9_offset0, decode_instruction_472fe_output_tmp_47e62_9_offset1, decode_instruction_472fe_output_tmp_47e62_9_offset2, decode_instruction_472fe_output_tmp_47e62_9_op1_base_ap] =
DecodeInstruction472Fe::evaluate(
[decode_blake_opcode_input_pc.clone()],
offset0_col0.clone(),
offset1_col1.clone(),
offset2_col2.clone(),
dst_base_fp_col3.clone(),
op0_base_fp_col4.clone(),
op1_base_fp_col5.clone(),
ap_update_add_1_col6.clone(),
opcode_extension_col7.clone(),
common_lookup_elements,
eval,
);
eval.add_constraint(
((opcode_extension_col7.clone() - M31_1.clone())
* (opcode_extension_col7.clone() - M31_2.clone())),
);
eval.add_constraint(
(mem0_base_col8.clone()
- ((op0_base_fp_col4.clone() * decode_blake_opcode_input_fp.clone())
+ ((M31_1.clone() - op0_base_fp_col4.clone())
* decode_blake_opcode_input_ap.clone()))),
);
ReadPositiveNumBits29::evaluate(
[(mem0_base_col8.clone()
+ decode_instruction_472fe_output_tmp_47e62_9_offset1.clone())],
op0_id_col9.clone(),
op0_limb_0_col10.clone(),
op0_limb_1_col11.clone(),
op0_limb_2_col12.clone(),
op0_limb_3_col13.clone(),
partial_limb_msb_col14.clone(),
common_lookup_elements,
eval,
);
eval.add_constraint(
(mem1_base_col15.clone()
- ((op1_base_fp_col5.clone() * decode_blake_opcode_input_fp.clone())
+ (decode_instruction_472fe_output_tmp_47e62_9_op1_base_ap.clone()
* decode_blake_opcode_input_ap.clone()))),
);
ReadPositiveNumBits29::evaluate(
[(mem1_base_col15.clone()
+ decode_instruction_472fe_output_tmp_47e62_9_offset2.clone())],
op1_id_col16.clone(),
op1_limb_0_col17.clone(),
op1_limb_1_col18.clone(),
op1_limb_2_col19.clone(),
op1_limb_3_col20.clone(),
partial_limb_msb_col21.clone(),
common_lookup_elements,
eval,
);
ReadPositiveNumBits29::evaluate(
[decode_blake_opcode_input_ap.clone()],
ap_id_col22.clone(),
ap_limb_0_col23.clone(),
ap_limb_1_col24.clone(),
ap_limb_2_col25.clone(),
ap_limb_3_col26.clone(),
partial_limb_msb_col27.clone(),
common_lookup_elements,
eval,
);
eval.add_constraint(
(mem_dst_base_col28.clone()
- ((dst_base_fp_col3.clone() * decode_blake_opcode_input_fp.clone())
+ ((M31_1.clone() - dst_base_fp_col3.clone())
* decode_blake_opcode_input_ap.clone()))),
);
ReadU32::evaluate(
[(mem_dst_base_col28.clone()
+ decode_instruction_472fe_output_tmp_47e62_9_offset0.clone())],
low_16_bits_col29.clone(),
high_16_bits_col30.clone(),
low_7_ms_bits_col31.clone(),
high_14_ms_bits_col32.clone(),
high_5_ms_bits_col33.clone(),
dst_id_col34.clone(),
common_lookup_elements,
eval,
);
[
(((op0_limb_0_col10.clone() + (op0_limb_1_col11.clone() * M31_512.clone()))
+ (op0_limb_2_col12.clone() * M31_262144.clone()))
+ (op0_limb_3_col13.clone() * M31_134217728.clone())),
(((op1_limb_0_col17.clone() + (op1_limb_1_col18.clone() * M31_512.clone()))
+ (op1_limb_2_col19.clone() * M31_262144.clone()))
+ (op1_limb_3_col20.clone() * M31_134217728.clone())),
(((ap_limb_0_col23.clone() + (ap_limb_1_col24.clone() * M31_512.clone()))
+ (ap_limb_2_col25.clone() * M31_262144.clone()))
+ (ap_limb_3_col26.clone() * M31_134217728.clone())),
(opcode_extension_col7.clone() - M31_1.clone()),
]
}
}