// ==============================================================
// RTL generated by Vivado(TM) HLS - High-Level Synthesis from C, C++ and SystemC
// Version: 2018.3
// Copyright (C) 1986-2018 Xilinx, Inc. All Rights Reserved.
// 
// ===========================================================

#ifndef _VecDotDq_DSPx2_HH_
#define _VecDotDq_DSPx2_HH_

#include "systemc.h"
#include "AESL_pkg.h"

#include "MatrixMulx4_mul_mbkb.h"

namespace ap_rtl {

struct VecDotDq_DSPx2 : public sc_module {
    // Port declarations 11
    sc_in_clk ap_clk;
    sc_in< sc_logic > ap_rst;
    sc_in< sc_lv<24> > A_0_V;
    sc_in< sc_lv<24> > A_1_V;
    sc_in< sc_lv<24> > B_0_V;
    sc_in< sc_lv<24> > B_1_V;
    sc_in< sc_lv<8> > S_V;
    sc_out< sc_lv<15> > ap_return_0;
    sc_out< sc_lv<15> > ap_return_1;
    sc_out< sc_lv<15> > ap_return_2;
    sc_out< sc_lv<15> > ap_return_3;


    // Module declarations
    VecDotDq_DSPx2(sc_module_name name);
    SC_HAS_PROCESS(VecDotDq_DSPx2);

    ~VecDotDq_DSPx2();

    sc_trace_file* mVcdFile;

    MatrixMulx4_mul_mbkb<1,1,24,6,30>* MatrixMulx4_mul_mbkb_U1;
    MatrixMulx4_mul_mbkb<1,1,24,6,30>* MatrixMulx4_mul_mbkb_U2;
    MatrixMulx4_mul_mbkb<1,1,24,6,30>* MatrixMulx4_mul_mbkb_U3;
    MatrixMulx4_mul_mbkb<1,1,24,6,30>* MatrixMulx4_mul_mbkb_U4;
    MatrixMulx4_mul_mbkb<1,1,24,6,30>* MatrixMulx4_mul_mbkb_U5;
    MatrixMulx4_mul_mbkb<1,1,24,6,30>* MatrixMulx4_mul_mbkb_U6;
    MatrixMulx4_mul_mbkb<1,1,24,6,30>* MatrixMulx4_mul_mbkb_U7;
    MatrixMulx4_mul_mbkb<1,1,24,6,30>* MatrixMulx4_mul_mbkb_U8;
    sc_signal< sc_lv<2> > tmp_4_fu_98_p1;
    sc_signal< sc_lv<2> > tmp_4_reg_798;
    sc_signal< bool > ap_block_state1_pp0_stage0_iter0;
    sc_signal< bool > ap_block_state2_pp0_stage0_iter1;
    sc_signal< bool > ap_block_pp0_stage0_11001;
    sc_signal< sc_lv<30> > ret_V_5_fu_750_p2;
    sc_signal< sc_lv<30> > ret_V_5_reg_803;
    sc_signal< sc_lv<30> > ret_V_5_0_1_fu_756_p2;
    sc_signal< sc_lv<30> > ret_V_5_0_1_reg_809;
    sc_signal< sc_lv<2> > p_Result_2_1_reg_815;
    sc_signal< sc_lv<30> > ret_V_5_1_fu_762_p2;
    sc_signal< sc_lv<30> > ret_V_5_1_reg_820;
    sc_signal< sc_lv<30> > ret_V_5_1_1_fu_768_p2;
    sc_signal< sc_lv<30> > ret_V_5_1_1_reg_826;
    sc_signal< sc_lv<2> > p_Result_2_2_reg_832;
    sc_signal< sc_lv<30> > ret_V_5_2_fu_774_p2;
    sc_signal< sc_lv<30> > ret_V_5_2_reg_837;
    sc_signal< sc_lv<30> > ret_V_5_2_1_fu_780_p2;
    sc_signal< sc_lv<30> > ret_V_5_2_1_reg_843;
    sc_signal< sc_lv<2> > p_Result_2_3_reg_849;
    sc_signal< sc_lv<30> > ret_V_5_3_fu_786_p2;
    sc_signal< sc_lv<30> > ret_V_5_3_reg_854;
    sc_signal< sc_lv<30> > ret_V_5_3_1_fu_792_p2;
    sc_signal< sc_lv<30> > ret_V_5_3_1_reg_860;
    sc_signal< bool > ap_block_pp0_stage0;
    sc_signal< sc_lv<6> > tmp_2_fu_80_p1;
    sc_signal< sc_lv<6> > tmp_3_fu_84_p1;
    sc_signal< sc_lv<24> > tmp_fu_88_p4;
    sc_signal< sc_lv<6> > tmp_6_fu_106_p1;
    sc_signal< sc_lv<6> > tmp_8_fu_114_p1;
    sc_signal< sc_lv<6> > p_Result_s_fu_122_p4;
    sc_signal< sc_lv<6> > p_Result_1_1_fu_132_p4;
    sc_signal< sc_lv<24> > tmp_5_fu_142_p4;
    sc_signal< sc_lv<6> > p_Result_3_1_fu_166_p4;
    sc_signal< sc_lv<6> > p_Result_3_1_1_fu_180_p4;
    sc_signal< sc_lv<6> > p_Result_3_fu_194_p4;
    sc_signal< sc_lv<6> > p_Result_1_2_fu_204_p4;
    sc_signal< sc_lv<24> > tmp_s_fu_214_p4;
    sc_signal< sc_lv<6> > p_Result_3_2_fu_238_p4;
    sc_signal< sc_lv<6> > p_Result_3_2_1_fu_252_p4;
    sc_signal< sc_lv<6> > p_Result_4_fu_266_p4;
    sc_signal< sc_lv<6> > p_Result_1_3_fu_276_p4;
    sc_signal< sc_lv<24> > tmp_1_fu_286_p4;
    sc_signal< sc_lv<6> > p_Result_3_3_fu_310_p4;
    sc_signal< sc_lv<6> > p_Result_3_3_1_fu_324_p4;
    sc_signal< sc_lv<12> > p_Result_6_fu_341_p4;
    sc_signal< sc_lv<12> > tmp_cast_fu_338_p1;
    sc_signal< sc_lv<12> > r_V_1_fu_350_p2;
    sc_signal< sc_lv<12> > tmp_7_fu_360_p1;
    sc_signal< sc_lv<12> > r_V_1_0_0_1_fu_363_p2;
    sc_signal< sc_lv<12> > p_Result_4_0_1_fu_373_p4;
    sc_signal< sc_lv<12> > r_V_1_0_1_fu_382_p2;
    sc_signal< sc_lv<12> > tmp_9_fu_392_p1;
    sc_signal< sc_lv<12> > r_V_1_0_1_1_fu_395_p2;
    sc_signal< sc_lv<12> > p_Result_4_1_fu_408_p4;
    sc_signal< sc_lv<12> > tmp_1_cast_fu_405_p1;
    sc_signal< sc_lv<12> > r_V_1_1_fu_417_p2;
    sc_signal< sc_lv<12> > tmp_10_fu_427_p1;
    sc_signal< sc_lv<12> > r_V_1_1_0_1_fu_430_p2;
    sc_signal< sc_lv<12> > p_Result_4_1_1_fu_440_p4;
    sc_signal< sc_lv<12> > r_V_1_1_1_fu_449_p2;
    sc_signal< sc_lv<12> > tmp_11_fu_459_p1;
    sc_signal< sc_lv<12> > r_V_1_1_1_1_fu_462_p2;
    sc_signal< sc_lv<12> > p_Result_4_2_fu_475_p4;
    sc_signal< sc_lv<12> > tmp_2_cast_fu_472_p1;
    sc_signal< sc_lv<12> > r_V_1_2_fu_484_p2;
    sc_signal< sc_lv<12> > tmp_12_fu_494_p1;
    sc_signal< sc_lv<12> > r_V_1_2_0_1_fu_497_p2;
    sc_signal< sc_lv<12> > p_Result_4_2_1_fu_507_p4;
    sc_signal< sc_lv<12> > r_V_1_2_1_fu_516_p2;
    sc_signal< sc_lv<12> > tmp_13_fu_526_p1;
    sc_signal< sc_lv<12> > r_V_1_2_1_1_fu_529_p2;
    sc_signal< sc_lv<12> > p_Result_4_3_fu_542_p4;
    sc_signal< sc_lv<12> > tmp_3_cast_fu_539_p1;
    sc_signal< sc_lv<12> > r_V_1_3_fu_551_p2;
    sc_signal< sc_lv<13> > tmp_8_0_cast_fu_356_p1;
    sc_signal< sc_lv<13> > tmp_8_1_cast_fu_423_p1;
    sc_signal< sc_lv<13> > tmp1_fu_561_p2;
    sc_signal< sc_lv<13> > tmp_8_2_cast_fu_490_p1;
    sc_signal< sc_lv<13> > tmp_8_3_cast_fu_557_p1;
    sc_signal< sc_lv<13> > tmp2_fu_571_p2;
    sc_signal< sc_lv<14> > tmp2_cast_fu_577_p1;
    sc_signal< sc_lv<14> > tmp1_cast_fu_567_p1;
    sc_signal< sc_lv<14> > temp_0_V_write_assi_fu_581_p2;
    sc_signal< sc_lv<12> > tmp_14_fu_591_p1;
    sc_signal< sc_lv<12> > r_V_1_3_0_1_fu_594_p2;
    sc_signal< sc_lv<13> > tmp_8_0_0_1_cast_fu_369_p1;
    sc_signal< sc_lv<13> > tmp_8_1_0_1_cast_fu_436_p1;
    sc_signal< sc_lv<13> > tmp3_fu_604_p2;
    sc_signal< sc_lv<13> > tmp_8_2_0_1_cast_fu_503_p1;
    sc_signal< sc_lv<13> > tmp_8_3_0_1_cast_fu_600_p1;
    sc_signal< sc_lv<13> > tmp4_fu_614_p2;
    sc_signal< sc_lv<14> > tmp4_cast_fu_620_p1;
    sc_signal< sc_lv<14> > tmp3_cast_fu_610_p1;
    sc_signal< sc_lv<14> > temp_2_V_write_assi_fu_624_p2;
    sc_signal< sc_lv<12> > p_Result_4_3_1_fu_634_p4;
    sc_signal< sc_lv<12> > r_V_1_3_1_fu_643_p2;
    sc_signal< sc_lv<13> > tmp_8_0_1_cast_fu_388_p1;
    sc_signal< sc_lv<13> > tmp_8_1_1_cast_fu_455_p1;
    sc_signal< sc_lv<13> > tmp5_fu_653_p2;
    sc_signal< sc_lv<13> > tmp_8_2_1_cast_fu_522_p1;
    sc_signal< sc_lv<13> > tmp_8_3_1_cast_fu_649_p1;
    sc_signal< sc_lv<13> > tmp6_fu_663_p2;
    sc_signal< sc_lv<14> > tmp6_cast_fu_669_p1;
    sc_signal< sc_lv<14> > tmp5_cast_fu_659_p1;
    sc_signal< sc_lv<14> > temp_1_V_write_assi_fu_673_p2;
    sc_signal< sc_lv<12> > tmp_15_fu_683_p1;
    sc_signal< sc_lv<12> > r_V_1_3_1_1_fu_686_p2;
    sc_signal< sc_lv<13> > tmp_8_0_1_1_cast_fu_401_p1;
    sc_signal< sc_lv<13> > tmp_8_1_1_1_cast_fu_468_p1;
    sc_signal< sc_lv<13> > tmp7_fu_696_p2;
    sc_signal< sc_lv<13> > tmp_8_2_1_1_cast_fu_535_p1;
    sc_signal< sc_lv<13> > tmp_8_3_1_1_cast_fu_692_p1;
    sc_signal< sc_lv<13> > tmp8_fu_706_p2;
    sc_signal< sc_lv<14> > tmp8_cast_fu_712_p1;
    sc_signal< sc_lv<14> > tmp7_cast_fu_702_p1;
    sc_signal< sc_lv<14> > temp_3_V_write_assi_fu_716_p2;
    sc_signal< sc_lv<15> > temp_0_V_write_assi_1_fu_587_p1;
    sc_signal< sc_lv<15> > temp_1_V_write_assi_1_fu_679_p1;
    sc_signal< sc_lv<15> > temp_2_V_write_assi_1_fu_630_p1;
    sc_signal< sc_lv<15> > temp_3_V_write_assi_1_fu_722_p1;
    sc_signal< sc_lv<24> > ret_V_5_fu_750_p0;
    sc_signal< sc_lv<30> > rhs_V_cast_fu_102_p1;
    sc_signal< sc_lv<6> > ret_V_5_fu_750_p1;
    sc_signal< sc_lv<24> > ret_V_5_0_1_fu_756_p0;
    sc_signal< sc_lv<6> > ret_V_5_0_1_fu_756_p1;
    sc_signal< sc_lv<24> > ret_V_5_1_fu_762_p0;
    sc_signal< sc_lv<30> > rhs_V_1_cast_fu_162_p1;
    sc_signal< sc_lv<6> > ret_V_5_1_fu_762_p1;
    sc_signal< sc_lv<24> > ret_V_5_1_1_fu_768_p0;
    sc_signal< sc_lv<6> > ret_V_5_1_1_fu_768_p1;
    sc_signal< sc_lv<24> > ret_V_5_2_fu_774_p0;
    sc_signal< sc_lv<30> > rhs_V_2_cast_fu_234_p1;
    sc_signal< sc_lv<6> > ret_V_5_2_fu_774_p1;
    sc_signal< sc_lv<24> > ret_V_5_2_1_fu_780_p0;
    sc_signal< sc_lv<6> > ret_V_5_2_1_fu_780_p1;
    sc_signal< sc_lv<24> > ret_V_5_3_fu_786_p0;
    sc_signal< sc_lv<30> > rhs_V_3_cast_fu_306_p1;
    sc_signal< sc_lv<6> > ret_V_5_3_fu_786_p1;
    sc_signal< sc_lv<24> > ret_V_5_3_1_fu_792_p0;
    sc_signal< sc_lv<6> > ret_V_5_3_1_fu_792_p1;
    sc_signal< sc_lv<30> > ret_V_5_0_1_fu_756_p10;
    sc_signal< sc_lv<30> > ret_V_5_1_1_fu_768_p10;
    sc_signal< sc_lv<30> > ret_V_5_1_fu_762_p10;
    sc_signal< sc_lv<30> > ret_V_5_2_1_fu_780_p10;
    sc_signal< sc_lv<30> > ret_V_5_2_fu_774_p10;
    sc_signal< sc_lv<30> > ret_V_5_3_1_fu_792_p10;
    sc_signal< sc_lv<30> > ret_V_5_3_fu_786_p10;
    sc_signal< sc_lv<30> > ret_V_5_fu_750_p10;
    static const bool ap_const_boolean_1;
    static const bool ap_const_boolean_0;
    static const sc_lv<12> ap_const_lv12_0;
    static const sc_lv<32> ap_const_lv32_6;
    static const sc_lv<32> ap_const_lv32_B;
    static const sc_lv<32> ap_const_lv32_2;
    static const sc_lv<32> ap_const_lv32_3;
    static const sc_lv<32> ap_const_lv32_C;
    static const sc_lv<32> ap_const_lv32_11;
    static const sc_lv<32> ap_const_lv32_4;
    static const sc_lv<32> ap_const_lv32_5;
    static const sc_lv<32> ap_const_lv32_12;
    static const sc_lv<32> ap_const_lv32_17;
    static const sc_lv<32> ap_const_lv32_7;
    static const sc_lv<32> ap_const_lv32_1D;
    static const sc_logic ap_const_logic_1;
    static const sc_logic ap_const_logic_0;
    // Thread declarations
    void thread_ap_clk_no_reset_();
    void thread_ap_block_pp0_stage0();
    void thread_ap_block_pp0_stage0_11001();
    void thread_ap_block_state1_pp0_stage0_iter0();
    void thread_ap_block_state2_pp0_stage0_iter1();
    void thread_ap_return_0();
    void thread_ap_return_1();
    void thread_ap_return_2();
    void thread_ap_return_3();
    void thread_p_Result_1_1_fu_132_p4();
    void thread_p_Result_1_2_fu_204_p4();
    void thread_p_Result_1_3_fu_276_p4();
    void thread_p_Result_3_1_1_fu_180_p4();
    void thread_p_Result_3_1_fu_166_p4();
    void thread_p_Result_3_2_1_fu_252_p4();
    void thread_p_Result_3_2_fu_238_p4();
    void thread_p_Result_3_3_1_fu_324_p4();
    void thread_p_Result_3_3_fu_310_p4();
    void thread_p_Result_3_fu_194_p4();
    void thread_p_Result_4_0_1_fu_373_p4();
    void thread_p_Result_4_1_1_fu_440_p4();
    void thread_p_Result_4_1_fu_408_p4();
    void thread_p_Result_4_2_1_fu_507_p4();
    void thread_p_Result_4_2_fu_475_p4();
    void thread_p_Result_4_3_1_fu_634_p4();
    void thread_p_Result_4_3_fu_542_p4();
    void thread_p_Result_4_fu_266_p4();
    void thread_p_Result_6_fu_341_p4();
    void thread_p_Result_s_fu_122_p4();
    void thread_r_V_1_0_0_1_fu_363_p2();
    void thread_r_V_1_0_1_1_fu_395_p2();
    void thread_r_V_1_0_1_fu_382_p2();
    void thread_r_V_1_1_0_1_fu_430_p2();
    void thread_r_V_1_1_1_1_fu_462_p2();
    void thread_r_V_1_1_1_fu_449_p2();
    void thread_r_V_1_1_fu_417_p2();
    void thread_r_V_1_2_0_1_fu_497_p2();
    void thread_r_V_1_2_1_1_fu_529_p2();
    void thread_r_V_1_2_1_fu_516_p2();
    void thread_r_V_1_2_fu_484_p2();
    void thread_r_V_1_3_0_1_fu_594_p2();
    void thread_r_V_1_3_1_1_fu_686_p2();
    void thread_r_V_1_3_1_fu_643_p2();
    void thread_r_V_1_3_fu_551_p2();
    void thread_r_V_1_fu_350_p2();
    void thread_ret_V_5_0_1_fu_756_p0();
    void thread_ret_V_5_0_1_fu_756_p1();
    void thread_ret_V_5_0_1_fu_756_p10();
    void thread_ret_V_5_1_1_fu_768_p0();
    void thread_ret_V_5_1_1_fu_768_p1();
    void thread_ret_V_5_1_1_fu_768_p10();
    void thread_ret_V_5_1_fu_762_p0();
    void thread_ret_V_5_1_fu_762_p1();
    void thread_ret_V_5_1_fu_762_p10();
    void thread_ret_V_5_2_1_fu_780_p0();
    void thread_ret_V_5_2_1_fu_780_p1();
    void thread_ret_V_5_2_1_fu_780_p10();
    void thread_ret_V_5_2_fu_774_p0();
    void thread_ret_V_5_2_fu_774_p1();
    void thread_ret_V_5_2_fu_774_p10();
    void thread_ret_V_5_3_1_fu_792_p0();
    void thread_ret_V_5_3_1_fu_792_p1();
    void thread_ret_V_5_3_1_fu_792_p10();
    void thread_ret_V_5_3_fu_786_p0();
    void thread_ret_V_5_3_fu_786_p1();
    void thread_ret_V_5_3_fu_786_p10();
    void thread_ret_V_5_fu_750_p0();
    void thread_ret_V_5_fu_750_p1();
    void thread_ret_V_5_fu_750_p10();
    void thread_rhs_V_1_cast_fu_162_p1();
    void thread_rhs_V_2_cast_fu_234_p1();
    void thread_rhs_V_3_cast_fu_306_p1();
    void thread_rhs_V_cast_fu_102_p1();
    void thread_temp_0_V_write_assi_1_fu_587_p1();
    void thread_temp_0_V_write_assi_fu_581_p2();
    void thread_temp_1_V_write_assi_1_fu_679_p1();
    void thread_temp_1_V_write_assi_fu_673_p2();
    void thread_temp_2_V_write_assi_1_fu_630_p1();
    void thread_temp_2_V_write_assi_fu_624_p2();
    void thread_temp_3_V_write_assi_1_fu_722_p1();
    void thread_temp_3_V_write_assi_fu_716_p2();
    void thread_tmp1_cast_fu_567_p1();
    void thread_tmp1_fu_561_p2();
    void thread_tmp2_cast_fu_577_p1();
    void thread_tmp2_fu_571_p2();
    void thread_tmp3_cast_fu_610_p1();
    void thread_tmp3_fu_604_p2();
    void thread_tmp4_cast_fu_620_p1();
    void thread_tmp4_fu_614_p2();
    void thread_tmp5_cast_fu_659_p1();
    void thread_tmp5_fu_653_p2();
    void thread_tmp6_cast_fu_669_p1();
    void thread_tmp6_fu_663_p2();
    void thread_tmp7_cast_fu_702_p1();
    void thread_tmp7_fu_696_p2();
    void thread_tmp8_cast_fu_712_p1();
    void thread_tmp8_fu_706_p2();
    void thread_tmp_10_fu_427_p1();
    void thread_tmp_11_fu_459_p1();
    void thread_tmp_12_fu_494_p1();
    void thread_tmp_13_fu_526_p1();
    void thread_tmp_14_fu_591_p1();
    void thread_tmp_15_fu_683_p1();
    void thread_tmp_1_cast_fu_405_p1();
    void thread_tmp_1_fu_286_p4();
    void thread_tmp_2_cast_fu_472_p1();
    void thread_tmp_2_fu_80_p1();
    void thread_tmp_3_cast_fu_539_p1();
    void thread_tmp_3_fu_84_p1();
    void thread_tmp_4_fu_98_p1();
    void thread_tmp_5_fu_142_p4();
    void thread_tmp_6_fu_106_p1();
    void thread_tmp_7_fu_360_p1();
    void thread_tmp_8_0_0_1_cast_fu_369_p1();
    void thread_tmp_8_0_1_1_cast_fu_401_p1();
    void thread_tmp_8_0_1_cast_fu_388_p1();
    void thread_tmp_8_0_cast_fu_356_p1();
    void thread_tmp_8_1_0_1_cast_fu_436_p1();
    void thread_tmp_8_1_1_1_cast_fu_468_p1();
    void thread_tmp_8_1_1_cast_fu_455_p1();
    void thread_tmp_8_1_cast_fu_423_p1();
    void thread_tmp_8_2_0_1_cast_fu_503_p1();
    void thread_tmp_8_2_1_1_cast_fu_535_p1();
    void thread_tmp_8_2_1_cast_fu_522_p1();
    void thread_tmp_8_2_cast_fu_490_p1();
    void thread_tmp_8_3_0_1_cast_fu_600_p1();
    void thread_tmp_8_3_1_1_cast_fu_692_p1();
    void thread_tmp_8_3_1_cast_fu_649_p1();
    void thread_tmp_8_3_cast_fu_557_p1();
    void thread_tmp_8_fu_114_p1();
    void thread_tmp_9_fu_392_p1();
    void thread_tmp_cast_fu_338_p1();
    void thread_tmp_fu_88_p4();
    void thread_tmp_s_fu_214_p4();
};

}

using namespace ap_rtl;

#endif
