// ==============================================================
// 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 _MatrixMulx4_HH_
#define _MatrixMulx4_HH_

#include "systemc.h"
#include "AESL_pkg.h"

#include "VecDotDq_DSPx2.h"
#include "MatrixMulx4_mux_1cud.h"
#include "MatrixMulx4_mux_4dEe.h"

namespace ap_rtl {

struct MatrixMulx4 : public sc_module {
    // Port declarations 591
    sc_in_clk ap_clk;
    sc_in< sc_logic > ap_rst;
    sc_in< sc_logic > ap_start;
    sc_out< sc_logic > ap_done;
    sc_out< sc_logic > ap_idle;
    sc_out< sc_logic > ap_ready;
    sc_in< sc_lv<48> > A_V_V_dout;
    sc_in< sc_logic > A_V_V_empty_n;
    sc_out< sc_logic > A_V_V_read;
    sc_in< sc_lv<24> > B_TW_0_0_0_V;
    sc_in< sc_lv<24> > B_TW_0_0_1_V;
    sc_in< sc_lv<24> > B_TW_0_0_2_V;
    sc_in< sc_lv<24> > B_TW_0_0_3_V;
    sc_in< sc_lv<24> > B_TW_0_0_4_V;
    sc_in< sc_lv<24> > B_TW_0_0_5_V;
    sc_in< sc_lv<24> > B_TW_0_0_6_V;
    sc_in< sc_lv<24> > B_TW_0_0_7_V;
    sc_in< sc_lv<24> > B_TW_0_0_8_V;
    sc_in< sc_lv<24> > B_TW_0_0_9_V;
    sc_in< sc_lv<24> > B_TW_0_0_10_V;
    sc_in< sc_lv<24> > B_TW_0_0_11_V;
    sc_in< sc_lv<24> > B_TW_0_0_12_V;
    sc_in< sc_lv<24> > B_TW_0_0_13_V;
    sc_in< sc_lv<24> > B_TW_0_0_14_V;
    sc_in< sc_lv<24> > B_TW_0_0_15_V;
    sc_in< sc_lv<24> > B_TW_0_0_16_V;
    sc_in< sc_lv<24> > B_TW_0_0_17_V;
    sc_in< sc_lv<24> > B_TW_0_0_18_V;
    sc_in< sc_lv<24> > B_TW_0_0_19_V;
    sc_in< sc_lv<24> > B_TW_0_0_20_V;
    sc_in< sc_lv<24> > B_TW_0_0_21_V;
    sc_in< sc_lv<24> > B_TW_0_0_22_V;
    sc_in< sc_lv<24> > B_TW_0_0_23_V;
    sc_in< sc_lv<24> > B_TW_0_0_24_V;
    sc_in< sc_lv<24> > B_TW_0_0_25_V;
    sc_in< sc_lv<24> > B_TW_0_0_26_V;
    sc_in< sc_lv<24> > B_TW_0_0_27_V;
    sc_in< sc_lv<24> > B_TW_0_0_28_V;
    sc_in< sc_lv<24> > B_TW_0_0_29_V;
    sc_in< sc_lv<24> > B_TW_0_0_30_V;
    sc_in< sc_lv<24> > B_TW_0_0_31_V;
    sc_in< sc_lv<24> > B_TW_0_0_32_V;
    sc_in< sc_lv<24> > B_TW_0_0_33_V;
    sc_in< sc_lv<24> > B_TW_0_0_34_V;
    sc_in< sc_lv<24> > B_TW_0_0_35_V;
    sc_in< sc_lv<24> > B_TW_0_1_0_V;
    sc_in< sc_lv<24> > B_TW_0_1_1_V;
    sc_in< sc_lv<24> > B_TW_0_1_2_V;
    sc_in< sc_lv<24> > B_TW_0_1_3_V;
    sc_in< sc_lv<24> > B_TW_0_1_4_V;
    sc_in< sc_lv<24> > B_TW_0_1_5_V;
    sc_in< sc_lv<24> > B_TW_0_1_6_V;
    sc_in< sc_lv<24> > B_TW_0_1_7_V;
    sc_in< sc_lv<24> > B_TW_0_1_8_V;
    sc_in< sc_lv<24> > B_TW_0_1_9_V;
    sc_in< sc_lv<24> > B_TW_0_1_10_V;
    sc_in< sc_lv<24> > B_TW_0_1_11_V;
    sc_in< sc_lv<24> > B_TW_0_1_12_V;
    sc_in< sc_lv<24> > B_TW_0_1_13_V;
    sc_in< sc_lv<24> > B_TW_0_1_14_V;
    sc_in< sc_lv<24> > B_TW_0_1_15_V;
    sc_in< sc_lv<24> > B_TW_0_1_16_V;
    sc_in< sc_lv<24> > B_TW_0_1_17_V;
    sc_in< sc_lv<24> > B_TW_0_1_18_V;
    sc_in< sc_lv<24> > B_TW_0_1_19_V;
    sc_in< sc_lv<24> > B_TW_0_1_20_V;
    sc_in< sc_lv<24> > B_TW_0_1_21_V;
    sc_in< sc_lv<24> > B_TW_0_1_22_V;
    sc_in< sc_lv<24> > B_TW_0_1_23_V;
    sc_in< sc_lv<24> > B_TW_0_1_24_V;
    sc_in< sc_lv<24> > B_TW_0_1_25_V;
    sc_in< sc_lv<24> > B_TW_0_1_26_V;
    sc_in< sc_lv<24> > B_TW_0_1_27_V;
    sc_in< sc_lv<24> > B_TW_0_1_28_V;
    sc_in< sc_lv<24> > B_TW_0_1_29_V;
    sc_in< sc_lv<24> > B_TW_0_1_30_V;
    sc_in< sc_lv<24> > B_TW_0_1_31_V;
    sc_in< sc_lv<24> > B_TW_0_1_32_V;
    sc_in< sc_lv<24> > B_TW_0_1_33_V;
    sc_in< sc_lv<24> > B_TW_0_1_34_V;
    sc_in< sc_lv<24> > B_TW_0_1_35_V;
    sc_in< sc_lv<24> > B_TW_0_2_0_V;
    sc_in< sc_lv<24> > B_TW_0_2_1_V;
    sc_in< sc_lv<24> > B_TW_0_2_2_V;
    sc_in< sc_lv<24> > B_TW_0_2_3_V;
    sc_in< sc_lv<24> > B_TW_0_2_4_V;
    sc_in< sc_lv<24> > B_TW_0_2_5_V;
    sc_in< sc_lv<24> > B_TW_0_2_6_V;
    sc_in< sc_lv<24> > B_TW_0_2_7_V;
    sc_in< sc_lv<24> > B_TW_0_2_8_V;
    sc_in< sc_lv<24> > B_TW_0_2_9_V;
    sc_in< sc_lv<24> > B_TW_0_2_10_V;
    sc_in< sc_lv<24> > B_TW_0_2_11_V;
    sc_in< sc_lv<24> > B_TW_0_2_12_V;
    sc_in< sc_lv<24> > B_TW_0_2_13_V;
    sc_in< sc_lv<24> > B_TW_0_2_14_V;
    sc_in< sc_lv<24> > B_TW_0_2_15_V;
    sc_in< sc_lv<24> > B_TW_0_2_16_V;
    sc_in< sc_lv<24> > B_TW_0_2_17_V;
    sc_in< sc_lv<24> > B_TW_0_2_18_V;
    sc_in< sc_lv<24> > B_TW_0_2_19_V;
    sc_in< sc_lv<24> > B_TW_0_2_20_V;
    sc_in< sc_lv<24> > B_TW_0_2_21_V;
    sc_in< sc_lv<24> > B_TW_0_2_22_V;
    sc_in< sc_lv<24> > B_TW_0_2_23_V;
    sc_in< sc_lv<24> > B_TW_0_2_24_V;
    sc_in< sc_lv<24> > B_TW_0_2_25_V;
    sc_in< sc_lv<24> > B_TW_0_2_26_V;
    sc_in< sc_lv<24> > B_TW_0_2_27_V;
    sc_in< sc_lv<24> > B_TW_0_2_28_V;
    sc_in< sc_lv<24> > B_TW_0_2_29_V;
    sc_in< sc_lv<24> > B_TW_0_2_30_V;
    sc_in< sc_lv<24> > B_TW_0_2_31_V;
    sc_in< sc_lv<24> > B_TW_0_2_32_V;
    sc_in< sc_lv<24> > B_TW_0_2_33_V;
    sc_in< sc_lv<24> > B_TW_0_2_34_V;
    sc_in< sc_lv<24> > B_TW_0_2_35_V;
    sc_in< sc_lv<24> > B_TW_0_3_0_V;
    sc_in< sc_lv<24> > B_TW_0_3_1_V;
    sc_in< sc_lv<24> > B_TW_0_3_2_V;
    sc_in< sc_lv<24> > B_TW_0_3_3_V;
    sc_in< sc_lv<24> > B_TW_0_3_4_V;
    sc_in< sc_lv<24> > B_TW_0_3_5_V;
    sc_in< sc_lv<24> > B_TW_0_3_6_V;
    sc_in< sc_lv<24> > B_TW_0_3_7_V;
    sc_in< sc_lv<24> > B_TW_0_3_8_V;
    sc_in< sc_lv<24> > B_TW_0_3_9_V;
    sc_in< sc_lv<24> > B_TW_0_3_10_V;
    sc_in< sc_lv<24> > B_TW_0_3_11_V;
    sc_in< sc_lv<24> > B_TW_0_3_12_V;
    sc_in< sc_lv<24> > B_TW_0_3_13_V;
    sc_in< sc_lv<24> > B_TW_0_3_14_V;
    sc_in< sc_lv<24> > B_TW_0_3_15_V;
    sc_in< sc_lv<24> > B_TW_0_3_16_V;
    sc_in< sc_lv<24> > B_TW_0_3_17_V;
    sc_in< sc_lv<24> > B_TW_0_3_18_V;
    sc_in< sc_lv<24> > B_TW_0_3_19_V;
    sc_in< sc_lv<24> > B_TW_0_3_20_V;
    sc_in< sc_lv<24> > B_TW_0_3_21_V;
    sc_in< sc_lv<24> > B_TW_0_3_22_V;
    sc_in< sc_lv<24> > B_TW_0_3_23_V;
    sc_in< sc_lv<24> > B_TW_0_3_24_V;
    sc_in< sc_lv<24> > B_TW_0_3_25_V;
    sc_in< sc_lv<24> > B_TW_0_3_26_V;
    sc_in< sc_lv<24> > B_TW_0_3_27_V;
    sc_in< sc_lv<24> > B_TW_0_3_28_V;
    sc_in< sc_lv<24> > B_TW_0_3_29_V;
    sc_in< sc_lv<24> > B_TW_0_3_30_V;
    sc_in< sc_lv<24> > B_TW_0_3_31_V;
    sc_in< sc_lv<24> > B_TW_0_3_32_V;
    sc_in< sc_lv<24> > B_TW_0_3_33_V;
    sc_in< sc_lv<24> > B_TW_0_3_34_V;
    sc_in< sc_lv<24> > B_TW_0_3_35_V;
    sc_in< sc_lv<24> > B_TW_1_0_0_V;
    sc_in< sc_lv<24> > B_TW_1_0_1_V;
    sc_in< sc_lv<24> > B_TW_1_0_2_V;
    sc_in< sc_lv<24> > B_TW_1_0_3_V;
    sc_in< sc_lv<24> > B_TW_1_0_4_V;
    sc_in< sc_lv<24> > B_TW_1_0_5_V;
    sc_in< sc_lv<24> > B_TW_1_0_6_V;
    sc_in< sc_lv<24> > B_TW_1_0_7_V;
    sc_in< sc_lv<24> > B_TW_1_0_8_V;
    sc_in< sc_lv<24> > B_TW_1_0_9_V;
    sc_in< sc_lv<24> > B_TW_1_0_10_V;
    sc_in< sc_lv<24> > B_TW_1_0_11_V;
    sc_in< sc_lv<24> > B_TW_1_0_12_V;
    sc_in< sc_lv<24> > B_TW_1_0_13_V;
    sc_in< sc_lv<24> > B_TW_1_0_14_V;
    sc_in< sc_lv<24> > B_TW_1_0_15_V;
    sc_in< sc_lv<24> > B_TW_1_0_16_V;
    sc_in< sc_lv<24> > B_TW_1_0_17_V;
    sc_in< sc_lv<24> > B_TW_1_0_18_V;
    sc_in< sc_lv<24> > B_TW_1_0_19_V;
    sc_in< sc_lv<24> > B_TW_1_0_20_V;
    sc_in< sc_lv<24> > B_TW_1_0_21_V;
    sc_in< sc_lv<24> > B_TW_1_0_22_V;
    sc_in< sc_lv<24> > B_TW_1_0_23_V;
    sc_in< sc_lv<24> > B_TW_1_0_24_V;
    sc_in< sc_lv<24> > B_TW_1_0_25_V;
    sc_in< sc_lv<24> > B_TW_1_0_26_V;
    sc_in< sc_lv<24> > B_TW_1_0_27_V;
    sc_in< sc_lv<24> > B_TW_1_0_28_V;
    sc_in< sc_lv<24> > B_TW_1_0_29_V;
    sc_in< sc_lv<24> > B_TW_1_0_30_V;
    sc_in< sc_lv<24> > B_TW_1_0_31_V;
    sc_in< sc_lv<24> > B_TW_1_0_32_V;
    sc_in< sc_lv<24> > B_TW_1_0_33_V;
    sc_in< sc_lv<24> > B_TW_1_0_34_V;
    sc_in< sc_lv<24> > B_TW_1_0_35_V;
    sc_in< sc_lv<24> > B_TW_1_1_0_V;
    sc_in< sc_lv<24> > B_TW_1_1_1_V;
    sc_in< sc_lv<24> > B_TW_1_1_2_V;
    sc_in< sc_lv<24> > B_TW_1_1_3_V;
    sc_in< sc_lv<24> > B_TW_1_1_4_V;
    sc_in< sc_lv<24> > B_TW_1_1_5_V;
    sc_in< sc_lv<24> > B_TW_1_1_6_V;
    sc_in< sc_lv<24> > B_TW_1_1_7_V;
    sc_in< sc_lv<24> > B_TW_1_1_8_V;
    sc_in< sc_lv<24> > B_TW_1_1_9_V;
    sc_in< sc_lv<24> > B_TW_1_1_10_V;
    sc_in< sc_lv<24> > B_TW_1_1_11_V;
    sc_in< sc_lv<24> > B_TW_1_1_12_V;
    sc_in< sc_lv<24> > B_TW_1_1_13_V;
    sc_in< sc_lv<24> > B_TW_1_1_14_V;
    sc_in< sc_lv<24> > B_TW_1_1_15_V;
    sc_in< sc_lv<24> > B_TW_1_1_16_V;
    sc_in< sc_lv<24> > B_TW_1_1_17_V;
    sc_in< sc_lv<24> > B_TW_1_1_18_V;
    sc_in< sc_lv<24> > B_TW_1_1_19_V;
    sc_in< sc_lv<24> > B_TW_1_1_20_V;
    sc_in< sc_lv<24> > B_TW_1_1_21_V;
    sc_in< sc_lv<24> > B_TW_1_1_22_V;
    sc_in< sc_lv<24> > B_TW_1_1_23_V;
    sc_in< sc_lv<24> > B_TW_1_1_24_V;
    sc_in< sc_lv<24> > B_TW_1_1_25_V;
    sc_in< sc_lv<24> > B_TW_1_1_26_V;
    sc_in< sc_lv<24> > B_TW_1_1_27_V;
    sc_in< sc_lv<24> > B_TW_1_1_28_V;
    sc_in< sc_lv<24> > B_TW_1_1_29_V;
    sc_in< sc_lv<24> > B_TW_1_1_30_V;
    sc_in< sc_lv<24> > B_TW_1_1_31_V;
    sc_in< sc_lv<24> > B_TW_1_1_32_V;
    sc_in< sc_lv<24> > B_TW_1_1_33_V;
    sc_in< sc_lv<24> > B_TW_1_1_34_V;
    sc_in< sc_lv<24> > B_TW_1_1_35_V;
    sc_in< sc_lv<24> > B_TW_1_2_0_V;
    sc_in< sc_lv<24> > B_TW_1_2_1_V;
    sc_in< sc_lv<24> > B_TW_1_2_2_V;
    sc_in< sc_lv<24> > B_TW_1_2_3_V;
    sc_in< sc_lv<24> > B_TW_1_2_4_V;
    sc_in< sc_lv<24> > B_TW_1_2_5_V;
    sc_in< sc_lv<24> > B_TW_1_2_6_V;
    sc_in< sc_lv<24> > B_TW_1_2_7_V;
    sc_in< sc_lv<24> > B_TW_1_2_8_V;
    sc_in< sc_lv<24> > B_TW_1_2_9_V;
    sc_in< sc_lv<24> > B_TW_1_2_10_V;
    sc_in< sc_lv<24> > B_TW_1_2_11_V;
    sc_in< sc_lv<24> > B_TW_1_2_12_V;
    sc_in< sc_lv<24> > B_TW_1_2_13_V;
    sc_in< sc_lv<24> > B_TW_1_2_14_V;
    sc_in< sc_lv<24> > B_TW_1_2_15_V;
    sc_in< sc_lv<24> > B_TW_1_2_16_V;
    sc_in< sc_lv<24> > B_TW_1_2_17_V;
    sc_in< sc_lv<24> > B_TW_1_2_18_V;
    sc_in< sc_lv<24> > B_TW_1_2_19_V;
    sc_in< sc_lv<24> > B_TW_1_2_20_V;
    sc_in< sc_lv<24> > B_TW_1_2_21_V;
    sc_in< sc_lv<24> > B_TW_1_2_22_V;
    sc_in< sc_lv<24> > B_TW_1_2_23_V;
    sc_in< sc_lv<24> > B_TW_1_2_24_V;
    sc_in< sc_lv<24> > B_TW_1_2_25_V;
    sc_in< sc_lv<24> > B_TW_1_2_26_V;
    sc_in< sc_lv<24> > B_TW_1_2_27_V;
    sc_in< sc_lv<24> > B_TW_1_2_28_V;
    sc_in< sc_lv<24> > B_TW_1_2_29_V;
    sc_in< sc_lv<24> > B_TW_1_2_30_V;
    sc_in< sc_lv<24> > B_TW_1_2_31_V;
    sc_in< sc_lv<24> > B_TW_1_2_32_V;
    sc_in< sc_lv<24> > B_TW_1_2_33_V;
    sc_in< sc_lv<24> > B_TW_1_2_34_V;
    sc_in< sc_lv<24> > B_TW_1_2_35_V;
    sc_in< sc_lv<24> > B_TW_1_3_0_V;
    sc_in< sc_lv<24> > B_TW_1_3_1_V;
    sc_in< sc_lv<24> > B_TW_1_3_2_V;
    sc_in< sc_lv<24> > B_TW_1_3_3_V;
    sc_in< sc_lv<24> > B_TW_1_3_4_V;
    sc_in< sc_lv<24> > B_TW_1_3_5_V;
    sc_in< sc_lv<24> > B_TW_1_3_6_V;
    sc_in< sc_lv<24> > B_TW_1_3_7_V;
    sc_in< sc_lv<24> > B_TW_1_3_8_V;
    sc_in< sc_lv<24> > B_TW_1_3_9_V;
    sc_in< sc_lv<24> > B_TW_1_3_10_V;
    sc_in< sc_lv<24> > B_TW_1_3_11_V;
    sc_in< sc_lv<24> > B_TW_1_3_12_V;
    sc_in< sc_lv<24> > B_TW_1_3_13_V;
    sc_in< sc_lv<24> > B_TW_1_3_14_V;
    sc_in< sc_lv<24> > B_TW_1_3_15_V;
    sc_in< sc_lv<24> > B_TW_1_3_16_V;
    sc_in< sc_lv<24> > B_TW_1_3_17_V;
    sc_in< sc_lv<24> > B_TW_1_3_18_V;
    sc_in< sc_lv<24> > B_TW_1_3_19_V;
    sc_in< sc_lv<24> > B_TW_1_3_20_V;
    sc_in< sc_lv<24> > B_TW_1_3_21_V;
    sc_in< sc_lv<24> > B_TW_1_3_22_V;
    sc_in< sc_lv<24> > B_TW_1_3_23_V;
    sc_in< sc_lv<24> > B_TW_1_3_24_V;
    sc_in< sc_lv<24> > B_TW_1_3_25_V;
    sc_in< sc_lv<24> > B_TW_1_3_26_V;
    sc_in< sc_lv<24> > B_TW_1_3_27_V;
    sc_in< sc_lv<24> > B_TW_1_3_28_V;
    sc_in< sc_lv<24> > B_TW_1_3_29_V;
    sc_in< sc_lv<24> > B_TW_1_3_30_V;
    sc_in< sc_lv<24> > B_TW_1_3_31_V;
    sc_in< sc_lv<24> > B_TW_1_3_32_V;
    sc_in< sc_lv<24> > B_TW_1_3_33_V;
    sc_in< sc_lv<24> > B_TW_1_3_34_V;
    sc_in< sc_lv<24> > B_TW_1_3_35_V;
    sc_in< sc_lv<24> > B_TW_2_0_0_V;
    sc_in< sc_lv<24> > B_TW_2_0_1_V;
    sc_in< sc_lv<24> > B_TW_2_0_2_V;
    sc_in< sc_lv<24> > B_TW_2_0_3_V;
    sc_in< sc_lv<24> > B_TW_2_0_4_V;
    sc_in< sc_lv<24> > B_TW_2_0_5_V;
    sc_in< sc_lv<24> > B_TW_2_0_6_V;
    sc_in< sc_lv<24> > B_TW_2_0_7_V;
    sc_in< sc_lv<24> > B_TW_2_0_8_V;
    sc_in< sc_lv<24> > B_TW_2_0_9_V;
    sc_in< sc_lv<24> > B_TW_2_0_10_V;
    sc_in< sc_lv<24> > B_TW_2_0_11_V;
    sc_in< sc_lv<24> > B_TW_2_0_12_V;
    sc_in< sc_lv<24> > B_TW_2_0_13_V;
    sc_in< sc_lv<24> > B_TW_2_0_14_V;
    sc_in< sc_lv<24> > B_TW_2_0_15_V;
    sc_in< sc_lv<24> > B_TW_2_0_16_V;
    sc_in< sc_lv<24> > B_TW_2_0_17_V;
    sc_in< sc_lv<24> > B_TW_2_0_18_V;
    sc_in< sc_lv<24> > B_TW_2_0_19_V;
    sc_in< sc_lv<24> > B_TW_2_0_20_V;
    sc_in< sc_lv<24> > B_TW_2_0_21_V;
    sc_in< sc_lv<24> > B_TW_2_0_22_V;
    sc_in< sc_lv<24> > B_TW_2_0_23_V;
    sc_in< sc_lv<24> > B_TW_2_0_24_V;
    sc_in< sc_lv<24> > B_TW_2_0_25_V;
    sc_in< sc_lv<24> > B_TW_2_0_26_V;
    sc_in< sc_lv<24> > B_TW_2_0_27_V;
    sc_in< sc_lv<24> > B_TW_2_0_28_V;
    sc_in< sc_lv<24> > B_TW_2_0_29_V;
    sc_in< sc_lv<24> > B_TW_2_0_30_V;
    sc_in< sc_lv<24> > B_TW_2_0_31_V;
    sc_in< sc_lv<24> > B_TW_2_0_32_V;
    sc_in< sc_lv<24> > B_TW_2_0_33_V;
    sc_in< sc_lv<24> > B_TW_2_0_34_V;
    sc_in< sc_lv<24> > B_TW_2_0_35_V;
    sc_in< sc_lv<24> > B_TW_2_1_0_V;
    sc_in< sc_lv<24> > B_TW_2_1_1_V;
    sc_in< sc_lv<24> > B_TW_2_1_2_V;
    sc_in< sc_lv<24> > B_TW_2_1_3_V;
    sc_in< sc_lv<24> > B_TW_2_1_4_V;
    sc_in< sc_lv<24> > B_TW_2_1_5_V;
    sc_in< sc_lv<24> > B_TW_2_1_6_V;
    sc_in< sc_lv<24> > B_TW_2_1_7_V;
    sc_in< sc_lv<24> > B_TW_2_1_8_V;
    sc_in< sc_lv<24> > B_TW_2_1_9_V;
    sc_in< sc_lv<24> > B_TW_2_1_10_V;
    sc_in< sc_lv<24> > B_TW_2_1_11_V;
    sc_in< sc_lv<24> > B_TW_2_1_12_V;
    sc_in< sc_lv<24> > B_TW_2_1_13_V;
    sc_in< sc_lv<24> > B_TW_2_1_14_V;
    sc_in< sc_lv<24> > B_TW_2_1_15_V;
    sc_in< sc_lv<24> > B_TW_2_1_16_V;
    sc_in< sc_lv<24> > B_TW_2_1_17_V;
    sc_in< sc_lv<24> > B_TW_2_1_18_V;
    sc_in< sc_lv<24> > B_TW_2_1_19_V;
    sc_in< sc_lv<24> > B_TW_2_1_20_V;
    sc_in< sc_lv<24> > B_TW_2_1_21_V;
    sc_in< sc_lv<24> > B_TW_2_1_22_V;
    sc_in< sc_lv<24> > B_TW_2_1_23_V;
    sc_in< sc_lv<24> > B_TW_2_1_24_V;
    sc_in< sc_lv<24> > B_TW_2_1_25_V;
    sc_in< sc_lv<24> > B_TW_2_1_26_V;
    sc_in< sc_lv<24> > B_TW_2_1_27_V;
    sc_in< sc_lv<24> > B_TW_2_1_28_V;
    sc_in< sc_lv<24> > B_TW_2_1_29_V;
    sc_in< sc_lv<24> > B_TW_2_1_30_V;
    sc_in< sc_lv<24> > B_TW_2_1_31_V;
    sc_in< sc_lv<24> > B_TW_2_1_32_V;
    sc_in< sc_lv<24> > B_TW_2_1_33_V;
    sc_in< sc_lv<24> > B_TW_2_1_34_V;
    sc_in< sc_lv<24> > B_TW_2_1_35_V;
    sc_in< sc_lv<24> > B_TW_2_2_0_V;
    sc_in< sc_lv<24> > B_TW_2_2_1_V;
    sc_in< sc_lv<24> > B_TW_2_2_2_V;
    sc_in< sc_lv<24> > B_TW_2_2_3_V;
    sc_in< sc_lv<24> > B_TW_2_2_4_V;
    sc_in< sc_lv<24> > B_TW_2_2_5_V;
    sc_in< sc_lv<24> > B_TW_2_2_6_V;
    sc_in< sc_lv<24> > B_TW_2_2_7_V;
    sc_in< sc_lv<24> > B_TW_2_2_8_V;
    sc_in< sc_lv<24> > B_TW_2_2_9_V;
    sc_in< sc_lv<24> > B_TW_2_2_10_V;
    sc_in< sc_lv<24> > B_TW_2_2_11_V;
    sc_in< sc_lv<24> > B_TW_2_2_12_V;
    sc_in< sc_lv<24> > B_TW_2_2_13_V;
    sc_in< sc_lv<24> > B_TW_2_2_14_V;
    sc_in< sc_lv<24> > B_TW_2_2_15_V;
    sc_in< sc_lv<24> > B_TW_2_2_16_V;
    sc_in< sc_lv<24> > B_TW_2_2_17_V;
    sc_in< sc_lv<24> > B_TW_2_2_18_V;
    sc_in< sc_lv<24> > B_TW_2_2_19_V;
    sc_in< sc_lv<24> > B_TW_2_2_20_V;
    sc_in< sc_lv<24> > B_TW_2_2_21_V;
    sc_in< sc_lv<24> > B_TW_2_2_22_V;
    sc_in< sc_lv<24> > B_TW_2_2_23_V;
    sc_in< sc_lv<24> > B_TW_2_2_24_V;
    sc_in< sc_lv<24> > B_TW_2_2_25_V;
    sc_in< sc_lv<24> > B_TW_2_2_26_V;
    sc_in< sc_lv<24> > B_TW_2_2_27_V;
    sc_in< sc_lv<24> > B_TW_2_2_28_V;
    sc_in< sc_lv<24> > B_TW_2_2_29_V;
    sc_in< sc_lv<24> > B_TW_2_2_30_V;
    sc_in< sc_lv<24> > B_TW_2_2_31_V;
    sc_in< sc_lv<24> > B_TW_2_2_32_V;
    sc_in< sc_lv<24> > B_TW_2_2_33_V;
    sc_in< sc_lv<24> > B_TW_2_2_34_V;
    sc_in< sc_lv<24> > B_TW_2_2_35_V;
    sc_in< sc_lv<24> > B_TW_2_3_0_V;
    sc_in< sc_lv<24> > B_TW_2_3_1_V;
    sc_in< sc_lv<24> > B_TW_2_3_2_V;
    sc_in< sc_lv<24> > B_TW_2_3_3_V;
    sc_in< sc_lv<24> > B_TW_2_3_4_V;
    sc_in< sc_lv<24> > B_TW_2_3_5_V;
    sc_in< sc_lv<24> > B_TW_2_3_6_V;
    sc_in< sc_lv<24> > B_TW_2_3_7_V;
    sc_in< sc_lv<24> > B_TW_2_3_8_V;
    sc_in< sc_lv<24> > B_TW_2_3_9_V;
    sc_in< sc_lv<24> > B_TW_2_3_10_V;
    sc_in< sc_lv<24> > B_TW_2_3_11_V;
    sc_in< sc_lv<24> > B_TW_2_3_12_V;
    sc_in< sc_lv<24> > B_TW_2_3_13_V;
    sc_in< sc_lv<24> > B_TW_2_3_14_V;
    sc_in< sc_lv<24> > B_TW_2_3_15_V;
    sc_in< sc_lv<24> > B_TW_2_3_16_V;
    sc_in< sc_lv<24> > B_TW_2_3_17_V;
    sc_in< sc_lv<24> > B_TW_2_3_18_V;
    sc_in< sc_lv<24> > B_TW_2_3_19_V;
    sc_in< sc_lv<24> > B_TW_2_3_20_V;
    sc_in< sc_lv<24> > B_TW_2_3_21_V;
    sc_in< sc_lv<24> > B_TW_2_3_22_V;
    sc_in< sc_lv<24> > B_TW_2_3_23_V;
    sc_in< sc_lv<24> > B_TW_2_3_24_V;
    sc_in< sc_lv<24> > B_TW_2_3_25_V;
    sc_in< sc_lv<24> > B_TW_2_3_26_V;
    sc_in< sc_lv<24> > B_TW_2_3_27_V;
    sc_in< sc_lv<24> > B_TW_2_3_28_V;
    sc_in< sc_lv<24> > B_TW_2_3_29_V;
    sc_in< sc_lv<24> > B_TW_2_3_30_V;
    sc_in< sc_lv<24> > B_TW_2_3_31_V;
    sc_in< sc_lv<24> > B_TW_2_3_32_V;
    sc_in< sc_lv<24> > B_TW_2_3_33_V;
    sc_in< sc_lv<24> > B_TW_2_3_34_V;
    sc_in< sc_lv<24> > B_TW_2_3_35_V;
    sc_in< sc_lv<24> > B_TW_3_0_0_V;
    sc_in< sc_lv<24> > B_TW_3_0_1_V;
    sc_in< sc_lv<24> > B_TW_3_0_2_V;
    sc_in< sc_lv<24> > B_TW_3_0_3_V;
    sc_in< sc_lv<24> > B_TW_3_0_4_V;
    sc_in< sc_lv<24> > B_TW_3_0_5_V;
    sc_in< sc_lv<24> > B_TW_3_0_6_V;
    sc_in< sc_lv<24> > B_TW_3_0_7_V;
    sc_in< sc_lv<24> > B_TW_3_0_8_V;
    sc_in< sc_lv<24> > B_TW_3_0_9_V;
    sc_in< sc_lv<24> > B_TW_3_0_10_V;
    sc_in< sc_lv<24> > B_TW_3_0_11_V;
    sc_in< sc_lv<24> > B_TW_3_0_12_V;
    sc_in< sc_lv<24> > B_TW_3_0_13_V;
    sc_in< sc_lv<24> > B_TW_3_0_14_V;
    sc_in< sc_lv<24> > B_TW_3_0_15_V;
    sc_in< sc_lv<24> > B_TW_3_0_16_V;
    sc_in< sc_lv<24> > B_TW_3_0_17_V;
    sc_in< sc_lv<24> > B_TW_3_0_18_V;
    sc_in< sc_lv<24> > B_TW_3_0_19_V;
    sc_in< sc_lv<24> > B_TW_3_0_20_V;
    sc_in< sc_lv<24> > B_TW_3_0_21_V;
    sc_in< sc_lv<24> > B_TW_3_0_22_V;
    sc_in< sc_lv<24> > B_TW_3_0_23_V;
    sc_in< sc_lv<24> > B_TW_3_0_24_V;
    sc_in< sc_lv<24> > B_TW_3_0_25_V;
    sc_in< sc_lv<24> > B_TW_3_0_26_V;
    sc_in< sc_lv<24> > B_TW_3_0_27_V;
    sc_in< sc_lv<24> > B_TW_3_0_28_V;
    sc_in< sc_lv<24> > B_TW_3_0_29_V;
    sc_in< sc_lv<24> > B_TW_3_0_30_V;
    sc_in< sc_lv<24> > B_TW_3_0_31_V;
    sc_in< sc_lv<24> > B_TW_3_0_32_V;
    sc_in< sc_lv<24> > B_TW_3_0_33_V;
    sc_in< sc_lv<24> > B_TW_3_0_34_V;
    sc_in< sc_lv<24> > B_TW_3_0_35_V;
    sc_in< sc_lv<24> > B_TW_3_1_0_V;
    sc_in< sc_lv<24> > B_TW_3_1_1_V;
    sc_in< sc_lv<24> > B_TW_3_1_2_V;
    sc_in< sc_lv<24> > B_TW_3_1_3_V;
    sc_in< sc_lv<24> > B_TW_3_1_4_V;
    sc_in< sc_lv<24> > B_TW_3_1_5_V;
    sc_in< sc_lv<24> > B_TW_3_1_6_V;
    sc_in< sc_lv<24> > B_TW_3_1_7_V;
    sc_in< sc_lv<24> > B_TW_3_1_8_V;
    sc_in< sc_lv<24> > B_TW_3_1_9_V;
    sc_in< sc_lv<24> > B_TW_3_1_10_V;
    sc_in< sc_lv<24> > B_TW_3_1_11_V;
    sc_in< sc_lv<24> > B_TW_3_1_12_V;
    sc_in< sc_lv<24> > B_TW_3_1_13_V;
    sc_in< sc_lv<24> > B_TW_3_1_14_V;
    sc_in< sc_lv<24> > B_TW_3_1_15_V;
    sc_in< sc_lv<24> > B_TW_3_1_16_V;
    sc_in< sc_lv<24> > B_TW_3_1_17_V;
    sc_in< sc_lv<24> > B_TW_3_1_18_V;
    sc_in< sc_lv<24> > B_TW_3_1_19_V;
    sc_in< sc_lv<24> > B_TW_3_1_20_V;
    sc_in< sc_lv<24> > B_TW_3_1_21_V;
    sc_in< sc_lv<24> > B_TW_3_1_22_V;
    sc_in< sc_lv<24> > B_TW_3_1_23_V;
    sc_in< sc_lv<24> > B_TW_3_1_24_V;
    sc_in< sc_lv<24> > B_TW_3_1_25_V;
    sc_in< sc_lv<24> > B_TW_3_1_26_V;
    sc_in< sc_lv<24> > B_TW_3_1_27_V;
    sc_in< sc_lv<24> > B_TW_3_1_28_V;
    sc_in< sc_lv<24> > B_TW_3_1_29_V;
    sc_in< sc_lv<24> > B_TW_3_1_30_V;
    sc_in< sc_lv<24> > B_TW_3_1_31_V;
    sc_in< sc_lv<24> > B_TW_3_1_32_V;
    sc_in< sc_lv<24> > B_TW_3_1_33_V;
    sc_in< sc_lv<24> > B_TW_3_1_34_V;
    sc_in< sc_lv<24> > B_TW_3_1_35_V;
    sc_in< sc_lv<24> > B_TW_3_2_0_V;
    sc_in< sc_lv<24> > B_TW_3_2_1_V;
    sc_in< sc_lv<24> > B_TW_3_2_2_V;
    sc_in< sc_lv<24> > B_TW_3_2_3_V;
    sc_in< sc_lv<24> > B_TW_3_2_4_V;
    sc_in< sc_lv<24> > B_TW_3_2_5_V;
    sc_in< sc_lv<24> > B_TW_3_2_6_V;
    sc_in< sc_lv<24> > B_TW_3_2_7_V;
    sc_in< sc_lv<24> > B_TW_3_2_8_V;
    sc_in< sc_lv<24> > B_TW_3_2_9_V;
    sc_in< sc_lv<24> > B_TW_3_2_10_V;
    sc_in< sc_lv<24> > B_TW_3_2_11_V;
    sc_in< sc_lv<24> > B_TW_3_2_12_V;
    sc_in< sc_lv<24> > B_TW_3_2_13_V;
    sc_in< sc_lv<24> > B_TW_3_2_14_V;
    sc_in< sc_lv<24> > B_TW_3_2_15_V;
    sc_in< sc_lv<24> > B_TW_3_2_16_V;
    sc_in< sc_lv<24> > B_TW_3_2_17_V;
    sc_in< sc_lv<24> > B_TW_3_2_18_V;
    sc_in< sc_lv<24> > B_TW_3_2_19_V;
    sc_in< sc_lv<24> > B_TW_3_2_20_V;
    sc_in< sc_lv<24> > B_TW_3_2_21_V;
    sc_in< sc_lv<24> > B_TW_3_2_22_V;
    sc_in< sc_lv<24> > B_TW_3_2_23_V;
    sc_in< sc_lv<24> > B_TW_3_2_24_V;
    sc_in< sc_lv<24> > B_TW_3_2_25_V;
    sc_in< sc_lv<24> > B_TW_3_2_26_V;
    sc_in< sc_lv<24> > B_TW_3_2_27_V;
    sc_in< sc_lv<24> > B_TW_3_2_28_V;
    sc_in< sc_lv<24> > B_TW_3_2_29_V;
    sc_in< sc_lv<24> > B_TW_3_2_30_V;
    sc_in< sc_lv<24> > B_TW_3_2_31_V;
    sc_in< sc_lv<24> > B_TW_3_2_32_V;
    sc_in< sc_lv<24> > B_TW_3_2_33_V;
    sc_in< sc_lv<24> > B_TW_3_2_34_V;
    sc_in< sc_lv<24> > B_TW_3_2_35_V;
    sc_in< sc_lv<24> > B_TW_3_3_0_V;
    sc_in< sc_lv<24> > B_TW_3_3_1_V;
    sc_in< sc_lv<24> > B_TW_3_3_2_V;
    sc_in< sc_lv<24> > B_TW_3_3_3_V;
    sc_in< sc_lv<24> > B_TW_3_3_4_V;
    sc_in< sc_lv<24> > B_TW_3_3_5_V;
    sc_in< sc_lv<24> > B_TW_3_3_6_V;
    sc_in< sc_lv<24> > B_TW_3_3_7_V;
    sc_in< sc_lv<24> > B_TW_3_3_8_V;
    sc_in< sc_lv<24> > B_TW_3_3_9_V;
    sc_in< sc_lv<24> > B_TW_3_3_10_V;
    sc_in< sc_lv<24> > B_TW_3_3_11_V;
    sc_in< sc_lv<24> > B_TW_3_3_12_V;
    sc_in< sc_lv<24> > B_TW_3_3_13_V;
    sc_in< sc_lv<24> > B_TW_3_3_14_V;
    sc_in< sc_lv<24> > B_TW_3_3_15_V;
    sc_in< sc_lv<24> > B_TW_3_3_16_V;
    sc_in< sc_lv<24> > B_TW_3_3_17_V;
    sc_in< sc_lv<24> > B_TW_3_3_18_V;
    sc_in< sc_lv<24> > B_TW_3_3_19_V;
    sc_in< sc_lv<24> > B_TW_3_3_20_V;
    sc_in< sc_lv<24> > B_TW_3_3_21_V;
    sc_in< sc_lv<24> > B_TW_3_3_22_V;
    sc_in< sc_lv<24> > B_TW_3_3_23_V;
    sc_in< sc_lv<24> > B_TW_3_3_24_V;
    sc_in< sc_lv<24> > B_TW_3_3_25_V;
    sc_in< sc_lv<24> > B_TW_3_3_26_V;
    sc_in< sc_lv<24> > B_TW_3_3_27_V;
    sc_in< sc_lv<24> > B_TW_3_3_28_V;
    sc_in< sc_lv<24> > B_TW_3_3_29_V;
    sc_in< sc_lv<24> > B_TW_3_3_30_V;
    sc_in< sc_lv<24> > B_TW_3_3_31_V;
    sc_in< sc_lv<24> > B_TW_3_3_32_V;
    sc_in< sc_lv<24> > B_TW_3_3_33_V;
    sc_in< sc_lv<24> > B_TW_3_3_34_V;
    sc_in< sc_lv<24> > B_TW_3_3_35_V;
    sc_out< sc_lv<2> > S_TW_V_address0;
    sc_out< sc_logic > S_TW_V_ce0;
    sc_in< sc_lv<8> > S_TW_V_q0;
    sc_out< sc_lv<120> > C_V_V_din;
    sc_in< sc_logic > C_V_V_full_n;
    sc_out< sc_logic > C_V_V_write;


    // Module declarations
    MatrixMulx4(sc_module_name name);
    SC_HAS_PROCESS(MatrixMulx4);

    ~MatrixMulx4();

    sc_trace_file* mVcdFile;

    ofstream mHdltvinHandle;
    ofstream mHdltvoutHandle;
    VecDotDq_DSPx2* grp_VecDotDq_DSPx2_fu_5137;
    VecDotDq_DSPx2* grp_VecDotDq_DSPx2_fu_5147;
    MatrixMulx4_mux_1cud<1,1,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,8,24>* MatrixMulx4_mux_1cud_U15;
    MatrixMulx4_mux_1cud<1,1,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,8,24>* MatrixMulx4_mux_1cud_U16;
    MatrixMulx4_mux_1cud<1,1,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,8,24>* MatrixMulx4_mux_1cud_U17;
    MatrixMulx4_mux_1cud<1,1,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,8,24>* MatrixMulx4_mux_1cud_U18;
    MatrixMulx4_mux_4dEe<1,1,48,48,48,48,2,48>* MatrixMulx4_mux_4dEe_U19;
    sc_signal< sc_lv<10> > ap_CS_fsm;
    sc_signal< sc_logic > ap_CS_fsm_state1;
    sc_signal< sc_logic > A_V_V_blk_n;
    sc_signal< sc_logic > ap_CS_fsm_state2;
    sc_signal< sc_lv<1> > exitcond4_fu_5157_p2;
    sc_signal< sc_logic > ap_CS_fsm_state3;
    sc_signal< sc_logic > ap_CS_fsm_state4;
    sc_signal< sc_logic > ap_CS_fsm_state5;
    sc_signal< sc_logic > C_V_V_blk_n;
    sc_signal< sc_logic > ap_CS_fsm_state12;
    sc_signal< sc_lv<15> > out_buffer_V_3_1_4_reg_5038;
    sc_signal< sc_lv<15> > out_buffer_V_3_0_4_reg_5049;
    sc_signal< sc_lv<15> > out_buffer_V_2_1_4_reg_5060;
    sc_signal< sc_lv<15> > out_buffer_V_2_0_4_reg_5071;
    sc_signal< sc_lv<15> > out_buffer_V_1_1_4_reg_5082;
    sc_signal< sc_lv<15> > out_buffer_V_1_0_4_reg_5093;
    sc_signal< sc_lv<15> > out_buffer_V_0_1_4_reg_5104;
    sc_signal< sc_lv<15> > out_buffer_V_0_0_4_reg_5115;
    sc_signal< sc_lv<3> > ic_block_1_reg_5126;
    sc_signal< sc_lv<10> > j_1_fu_5163_p2;
    sc_signal< sc_lv<10> > j_1_reg_6734;
    sc_signal< bool > ap_block_state2;
    sc_signal< sc_lv<48> > tmp_V_1_reg_6739;
    sc_signal< sc_lv<48> > tmp_V_2_reg_6744;
    sc_signal< sc_lv<48> > tmp_V_3_reg_6749;
    sc_signal< sc_lv<48> > tmp_V_4_reg_6754;
    sc_signal< sc_logic > ap_CS_fsm_state6;
    sc_signal< sc_lv<6> > oc_1_fu_5199_p2;
    sc_signal< sc_lv<6> > oc_1_reg_6802;
    sc_signal< sc_lv<1> > exitcond7_fu_5205_p2;
    sc_signal< sc_logic > ap_CS_fsm_state7;
    sc_signal< sc_lv<4> > po_1_fu_5211_p2;
    sc_signal< sc_lv<4> > po_1_reg_6811;
    sc_signal< sc_lv<15> > out_buffer_V_2_1_5_fu_5229_p3;
    sc_signal< sc_lv<2> > tmp_16_fu_5217_p1;
    sc_signal< sc_lv<15> > out_buffer_V_2_0_5_fu_5237_p3;
    sc_signal< sc_lv<15> > out_buffer_V_1_1_5_fu_5245_p3;
    sc_signal< sc_lv<15> > out_buffer_V_1_0_5_fu_5253_p3;
    sc_signal< sc_lv<15> > out_buffer_V_0_1_5_fu_5261_p3;
    sc_signal< sc_lv<15> > out_buffer_V_0_0_5_fu_5269_p3;
    sc_signal< sc_lv<15> > out_buffer_V_3_1_5_fu_5277_p3;
    sc_signal< sc_lv<15> > out_buffer_V_3_0_5_fu_5285_p3;
    sc_signal< sc_lv<8> > tmp_2_fu_5293_p1;
    sc_signal< sc_lv<8> > tmp_2_reg_6859;
    sc_signal< sc_lv<1> > exitcond8_fu_5297_p2;
    sc_signal< sc_lv<1> > exitcond8_reg_6864;
    sc_signal< sc_logic > ap_CS_fsm_pp0_stage0;
    sc_signal< bool > ap_block_state9_pp0_stage0_iter0;
    sc_signal< bool > ap_block_state10_pp0_stage0_iter1;
    sc_signal< bool > ap_block_state11_pp0_stage0_iter2;
    sc_signal< bool > ap_block_pp0_stage0_11001;
    sc_signal< sc_lv<1> > exitcond8_reg_6864_pp0_iter1_reg;
    sc_signal< sc_lv<3> > ic_block_fu_5303_p2;
    sc_signal< sc_logic > ap_enable_reg_pp0_iter0;
    sc_signal< sc_lv<2> > tmp_18_fu_5314_p1;
    sc_signal< sc_lv<2> > tmp_18_reg_6873;
    sc_signal< sc_lv<24> > tmp_1_fu_5339_p146;
    sc_signal< sc_lv<24> > tmp_1_reg_6883;
    sc_signal< sc_lv<24> > tmp_6_fu_5633_p146;
    sc_signal< sc_lv<24> > tmp_6_reg_6888;
    sc_signal< sc_lv<24> > tmp_8_fu_5927_p146;
    sc_signal< sc_lv<24> > tmp_8_reg_6893;
    sc_signal< sc_lv<24> > tmp_9_fu_6221_p146;
    sc_signal< sc_lv<24> > tmp_9_reg_6898;
    sc_signal< sc_lv<15> > out_buffer_0_0_V_fu_6558_p2;
    sc_signal< sc_logic > ap_enable_reg_pp0_iter2;
    sc_signal< sc_lv<15> > out_buffer_1_0_V_fu_6564_p2;
    sc_signal< sc_lv<15> > out_buffer_0_1_V_fu_6570_p2;
    sc_signal< sc_lv<15> > out_buffer_1_1_V_fu_6576_p2;
    sc_signal< sc_lv<15> > out_buffer_2_0_V_fu_6598_p2;
    sc_signal< sc_lv<15> > out_buffer_3_0_V_fu_6604_p2;
    sc_signal< sc_lv<15> > out_buffer_2_1_V_fu_6610_p2;
    sc_signal< sc_lv<15> > out_buffer_3_1_V_fu_6616_p2;
    sc_signal< bool > ap_block_pp0_stage0_subdone;
    sc_signal< sc_logic > ap_condition_pp0_exit_iter0_state9;
    sc_signal< sc_logic > ap_enable_reg_pp0_iter1;
    sc_signal< sc_lv<24> > grp_VecDotDq_DSPx2_fu_5137_A_1_V;
    sc_signal< sc_lv<15> > grp_VecDotDq_DSPx2_fu_5137_ap_return_0;
    sc_signal< sc_lv<15> > grp_VecDotDq_DSPx2_fu_5137_ap_return_1;
    sc_signal< sc_lv<15> > grp_VecDotDq_DSPx2_fu_5137_ap_return_2;
    sc_signal< sc_lv<15> > grp_VecDotDq_DSPx2_fu_5137_ap_return_3;
    sc_signal< sc_lv<24> > grp_VecDotDq_DSPx2_fu_5147_A_1_V;
    sc_signal< sc_lv<15> > grp_VecDotDq_DSPx2_fu_5147_ap_return_0;
    sc_signal< sc_lv<15> > grp_VecDotDq_DSPx2_fu_5147_ap_return_1;
    sc_signal< sc_lv<15> > grp_VecDotDq_DSPx2_fu_5147_ap_return_2;
    sc_signal< sc_lv<15> > grp_VecDotDq_DSPx2_fu_5147_ap_return_3;
    sc_signal< sc_lv<10> > j_reg_4780;
    sc_signal< sc_lv<1> > exitcond6_fu_5193_p2;
    sc_signal< sc_lv<6> > oc_reg_4791;
    sc_signal< sc_lv<15> > out_buffer_V_3_1_2_reg_4803;
    sc_signal< sc_logic > ap_CS_fsm_state8;
    sc_signal< sc_lv<15> > out_buffer_V_3_0_2_reg_4813;
    sc_signal< sc_lv<15> > out_buffer_V_2_1_2_reg_4823;
    sc_signal< sc_lv<15> > out_buffer_V_2_0_2_reg_4833;
    sc_signal< sc_lv<15> > out_buffer_V_1_1_2_reg_4843;
    sc_signal< sc_lv<15> > out_buffer_V_1_0_2_reg_4853;
    sc_signal< sc_lv<15> > out_buffer_V_0_1_2_reg_4863;
    sc_signal< sc_lv<15> > out_buffer_V_0_0_2_reg_4873;
    sc_signal< sc_lv<4> > po_reg_4883;
    sc_signal< sc_lv<15> > out_buffer_V_3_1_2_b_reg_4894;
    sc_signal< sc_lv<15> > out_buffer_V_3_0_2_b_reg_4912;
    sc_signal< sc_lv<15> > out_buffer_V_2_1_2_b_reg_4930;
    sc_signal< sc_lv<15> > out_buffer_V_2_0_2_b_reg_4948;
    sc_signal< sc_lv<15> > out_buffer_V_1_1_2_b_reg_4966;
    sc_signal< sc_lv<15> > out_buffer_V_1_0_2_b_reg_4984;
    sc_signal< sc_lv<15> > out_buffer_V_0_1_2_b_reg_5002;
    sc_signal< sc_lv<15> > out_buffer_V_0_0_2_b_reg_5020;
    sc_signal< sc_lv<24> > tmp_19_fu_6524_p1;
    sc_signal< bool > ap_block_pp0_stage0;
    sc_signal< sc_lv<64> > tmp_s_fu_5309_p1;
    sc_signal< sc_lv<15> > out_buffer_0_0_V_1_fu_1266;
    sc_signal< sc_lv<15> > out_buffer_0_1_V_1_fu_1270;
    sc_signal< sc_lv<15> > out_buffer_1_0_V_1_fu_1274;
    sc_signal< sc_lv<15> > out_buffer_1_1_V_1_fu_1278;
    sc_signal< sc_lv<15> > out_buffer_2_0_V_1_fu_1282;
    sc_signal< sc_lv<15> > out_buffer_2_1_V_1_fu_1286;
    sc_signal< sc_lv<15> > out_buffer_3_0_V_1_fu_1290;
    sc_signal< sc_lv<15> > out_buffer_3_1_V_1_fu_1294;
    sc_signal< sc_lv<1> > tmp_17_fu_5221_p3;
    sc_signal< sc_lv<7> > tmp_4_fu_5318_p5;
    sc_signal< sc_lv<8> > tmp_22_cast_fu_5330_p1;
    sc_signal< sc_lv<8> > tmp_5_fu_5334_p2;
    sc_signal< sc_lv<48> > tmp_7_fu_6515_p6;
    sc_signal< sc_lv<10> > ap_NS_fsm;
    sc_signal< sc_logic > ap_idle_pp0;
    sc_signal< sc_logic > ap_enable_pp0;
    static const sc_logic ap_const_logic_1;
    static const sc_logic ap_const_logic_0;
    static const sc_lv<10> ap_ST_fsm_state1;
    static const sc_lv<10> ap_ST_fsm_state2;
    static const sc_lv<10> ap_ST_fsm_state3;
    static const sc_lv<10> ap_ST_fsm_state4;
    static const sc_lv<10> ap_ST_fsm_state5;
    static const sc_lv<10> ap_ST_fsm_state6;
    static const sc_lv<10> ap_ST_fsm_state7;
    static const sc_lv<10> ap_ST_fsm_state8;
    static const sc_lv<10> ap_ST_fsm_pp0_stage0;
    static const sc_lv<10> ap_ST_fsm_state12;
    static const sc_lv<32> ap_const_lv32_0;
    static const bool ap_const_boolean_1;
    static const sc_lv<32> ap_const_lv32_1;
    static const sc_lv<1> ap_const_lv1_0;
    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_4;
    static const sc_lv<32> ap_const_lv32_9;
    static const sc_lv<32> ap_const_lv32_5;
    static const sc_lv<32> ap_const_lv32_6;
    static const sc_lv<2> ap_const_lv2_2;
    static const sc_lv<2> ap_const_lv2_1;
    static const sc_lv<2> ap_const_lv2_0;
    static const sc_lv<2> ap_const_lv2_3;
    static const sc_lv<1> ap_const_lv1_1;
    static const sc_lv<32> ap_const_lv32_8;
    static const bool ap_const_boolean_0;
    static const sc_lv<10> ap_const_lv10_0;
    static const sc_lv<6> ap_const_lv6_0;
    static const sc_lv<32> ap_const_lv32_7;
    static const sc_lv<4> ap_const_lv4_0;
    static const sc_lv<3> ap_const_lv3_0;
    static const sc_lv<10> ap_const_lv10_200;
    static const sc_lv<10> ap_const_lv10_1;
    static const sc_lv<6> ap_const_lv6_24;
    static const sc_lv<6> ap_const_lv6_1;
    static const sc_lv<4> ap_const_lv4_8;
    static const sc_lv<4> ap_const_lv4_1;
    static const sc_lv<15> ap_const_lv15_0;
    static const sc_lv<3> ap_const_lv3_4;
    static const sc_lv<3> ap_const_lv3_1;
    static const sc_lv<32> ap_const_lv32_18;
    static const sc_lv<32> ap_const_lv32_2F;
    // Thread declarations
    void thread_ap_clk_no_reset_();
    void thread_A_V_V_blk_n();
    void thread_A_V_V_read();
    void thread_C_V_V_blk_n();
    void thread_C_V_V_din();
    void thread_C_V_V_write();
    void thread_S_TW_V_address0();
    void thread_S_TW_V_ce0();
    void thread_ap_CS_fsm_pp0_stage0();
    void thread_ap_CS_fsm_state1();
    void thread_ap_CS_fsm_state12();
    void thread_ap_CS_fsm_state2();
    void thread_ap_CS_fsm_state3();
    void thread_ap_CS_fsm_state4();
    void thread_ap_CS_fsm_state5();
    void thread_ap_CS_fsm_state6();
    void thread_ap_CS_fsm_state7();
    void thread_ap_CS_fsm_state8();
    void thread_ap_block_pp0_stage0();
    void thread_ap_block_pp0_stage0_11001();
    void thread_ap_block_pp0_stage0_subdone();
    void thread_ap_block_state10_pp0_stage0_iter1();
    void thread_ap_block_state11_pp0_stage0_iter2();
    void thread_ap_block_state2();
    void thread_ap_block_state9_pp0_stage0_iter0();
    void thread_ap_condition_pp0_exit_iter0_state9();
    void thread_ap_done();
    void thread_ap_enable_pp0();
    void thread_ap_idle();
    void thread_ap_idle_pp0();
    void thread_ap_ready();
    void thread_exitcond4_fu_5157_p2();
    void thread_exitcond6_fu_5193_p2();
    void thread_exitcond7_fu_5205_p2();
    void thread_exitcond8_fu_5297_p2();
    void thread_grp_VecDotDq_DSPx2_fu_5137_A_1_V();
    void thread_grp_VecDotDq_DSPx2_fu_5147_A_1_V();
    void thread_ic_block_fu_5303_p2();
    void thread_j_1_fu_5163_p2();
    void thread_oc_1_fu_5199_p2();
    void thread_out_buffer_0_0_V_fu_6558_p2();
    void thread_out_buffer_0_1_V_fu_6570_p2();
    void thread_out_buffer_1_0_V_fu_6564_p2();
    void thread_out_buffer_1_1_V_fu_6576_p2();
    void thread_out_buffer_2_0_V_fu_6598_p2();
    void thread_out_buffer_2_1_V_fu_6610_p2();
    void thread_out_buffer_3_0_V_fu_6604_p2();
    void thread_out_buffer_3_1_V_fu_6616_p2();
    void thread_out_buffer_V_0_0_5_fu_5269_p3();
    void thread_out_buffer_V_0_1_5_fu_5261_p3();
    void thread_out_buffer_V_1_0_5_fu_5253_p3();
    void thread_out_buffer_V_1_1_5_fu_5245_p3();
    void thread_out_buffer_V_2_0_5_fu_5237_p3();
    void thread_out_buffer_V_2_1_5_fu_5229_p3();
    void thread_out_buffer_V_3_0_5_fu_5285_p3();
    void thread_out_buffer_V_3_1_5_fu_5277_p3();
    void thread_po_1_fu_5211_p2();
    void thread_tmp_16_fu_5217_p1();
    void thread_tmp_17_fu_5221_p3();
    void thread_tmp_18_fu_5314_p1();
    void thread_tmp_19_fu_6524_p1();
    void thread_tmp_22_cast_fu_5330_p1();
    void thread_tmp_2_fu_5293_p1();
    void thread_tmp_4_fu_5318_p5();
    void thread_tmp_5_fu_5334_p2();
    void thread_tmp_s_fu_5309_p1();
    void thread_ap_NS_fsm();
    void thread_hdltv_gen();
};

}

using namespace ap_rtl;

#endif
