#define PRAGMA_SUB(x) _Pragma (#x)
#define DO_PRAGMA(x) PRAGMA_SUB(x)

#include <ap_int.h>
#include <hls_stream.h>

#define HO 16
#define WO 16
#define CI 8
#define CO 8
#define IW 4
#define WW 4
#define BF_LOG2 5
#define OW 13
#define PI 4
#define PO 4

#ifndef BUNDLE
#define BUNDLE
template <unsigned int N, typename T>
struct BundleT
{
    T data[N];
};
#endif

typedef ap_int<PI * IW> TIN;
typedef ap_int<PI * WW> TW;
typedef ap_int<PO * OW> TOUT;


void top(ap_int<IW> A[HO * WO][CI / PI][PI * 9], ap_int<WW> B[CI / PI][CO / PO][PI * PO * 9], ap_int<OW> C[HO * WO][CO]);
