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

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

#define HO 32
#define WO 32
#define CI 16
#define CO 16
#define IW 6
#define WW 6
#define BF_LOG2 5
#define OW 15
#define PI 4
#define PO 4

#define G 4
#define GW 2

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

typedef ap_int<2 * PI * IW> TIN2;
typedef ap_int<PI * IW> TIN;
typedef ap_int<PI * WW> TW;
typedef ap_int<2 * PO * OW> TOUT2;
typedef ap_int<PO * OW> TOUT;
typedef ap_int<PI * GW> TG;


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