// ************************************************************************** //
//                                                                            //
//    eses                   eses                                             //
//   eses                     eses                                            //
//  eses    eseses  esesese    eses   Embedded Systems Group                  //
//  ese    ese  ese ese         ese                                           //
//  ese    eseseses eseseses    ese   Department of Computer Science          //
//  eses   eses          ese   eses                                           //
//   eses   eseses  eseseses  eses    University of Kaiserslautern            //
//    eses                   eses                                             //
//                                                                            //
// ************************************************************************** //


nat a_0_0,a_0_1,a_0_2,a_1_0,a_1_1,a_1_2,a_2_0,a_2_1,a_2_2;
nat b_0_0,b_0_1,b_0_2,b_1_0,b_1_1,b_1_2,b_2_0,b_2_1,b_2_2;
nat c_0_0,c_0_1,c_0_2,c_1_0,c_1_1,c_1_2,c_2_0,c_2_1,c_2_2;
thread MatrixMult {
    nat t_1,t_2,t_3,t_4,t_5,t_6,t_7,t_8,t_9,t_10,t_11,t_12,t_13,t_14,t_15,t_16,t_17,t_18,t_19,t_20,t_21,t_22,t_23,t_24,t_25,t_26,t_27,t_28,t_29,t_30,t_31,t_32,t_33,t_34,t_35,t_36,t_37,t_38,t_39,t_40,t_41,t_42,t_43,t_44,t_45;
    t_1 = a_0_0 * b_0_0;
    t_2 = a_0_1 * b_1_0;
    t_3 = a_0_2 * b_2_0;
    t_4 = t_1 + t_2;
    t_5 = t_4 + t_3;
    t_6 = a_0_0 * b_0_1;
    t_7 = a_0_1 * b_1_1;
    t_8 = a_0_2 * b_2_1;
    t_9 = t_6 + t_7;
    t_10 = t_9 + t_8;
    t_11 = a_0_0 * b_0_2;
    t_12 = a_0_1 * b_1_2;
    t_13 = a_0_2 * b_2_2;
    t_14 = t_11 + t_12;
    t_15 = t_14 + t_13;
    t_16 = a_1_0 * b_0_0;
    t_17 = a_1_1 * b_1_0;
    t_18 = a_1_2 * b_2_0;
    t_19 = t_16 + t_17;
    t_20 = t_19 + t_18;
    t_21 = a_1_0 * b_0_1;
    t_22 = a_1_1 * b_1_1;
    t_23 = a_1_2 * b_2_1;
    t_24 = t_21 + t_22;
    t_25 = t_24 + t_23;
    t_26 = a_1_0 * b_0_2;
    t_27 = a_1_1 * b_1_2;
    t_28 = a_1_2 * b_2_2;
    t_29 = t_26 + t_27;
    t_30 = t_29 + t_28;
    t_31 = a_2_0 * b_0_0;
    t_32 = a_2_1 * b_1_0;
    t_33 = a_2_2 * b_2_0;
    t_34 = t_31 + t_32;
    t_35 = t_34 + t_33;
    t_36 = a_2_0 * b_0_1;
    t_37 = a_2_1 * b_1_1;
    t_38 = a_2_2 * b_2_1;
    t_39 = t_36 + t_37;
    t_40 = t_39 + t_38;
    t_41 = a_2_0 * b_0_2;
    t_42 = a_2_1 * b_1_2;
    t_43 = a_2_2 * b_2_2;
    t_44 = t_41 + t_42;
    t_45 = t_44 + t_43;
    c_0_0 = t_5;
    c_0_1 = t_10;
    c_0_2 = t_15;
    c_1_0 = t_20;
    c_1_1 = t_25;
    c_1_2 = t_30;
    c_2_0 = t_35;
    c_2_1 = t_40;
    c_2_2 = t_45;
}