#ifndef __VIVADO_SYNTH__
#include <fstream>
using namespace std;

  // Debug utility
  ofstream* global_debug_handle;

#endif //__VIVADO_SYNTH__
// compute file: jacdyn_16_opt_compute_units.h_merged_compute_units.h_merged_compute_units.h_merged_compute_units.h
#include "jacdyn_16_opt_compute_units.h_merged_compute_units.h_merged_compute_units.h_merged_compute_units.h"

struct in_in_1_merged1793_2256_to_in_in_ld1_merged1847_2240_cache {
	// RAM Box: {[15, 1327], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2257_to_in_in_ld1_merged1847_2241_cache {
	// RAM Box: {[14, 1326], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2258_to_in_in_ld1_merged1847_2242_cache {
	// RAM Box: {[13, 1325], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2259_to_in_in_ld1_merged1847_2243_cache {
	// RAM Box: {[12, 1324], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2260_to_in_in_ld1_merged1847_2244_cache {
	// RAM Box: {[11, 1323], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2261_to_in_in_ld1_merged1847_2245_cache {
	// RAM Box: {[10, 1322], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2262_to_in_in_ld1_merged1847_2246_cache {
	// RAM Box: {[9, 1321], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2263_to_in_in_ld1_merged1847_2247_cache {
	// RAM Box: {[8, 1320], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2264_to_in_in_ld1_merged1847_2248_cache {
	// RAM Box: {[7, 1319], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2265_to_in_in_ld1_merged1847_2249_cache {
	// RAM Box: {[6, 1318], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2266_to_in_in_ld1_merged1847_2250_cache {
	// RAM Box: {[5, 1317], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2267_to_in_in_ld1_merged1847_2251_cache {
	// RAM Box: {[4, 1316], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2268_to_in_in_ld1_merged1847_2252_cache {
	// RAM Box: {[3, 1315], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2269_to_in_in_ld1_merged1847_2253_cache {
	// RAM Box: {[2, 1314], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2270_to_in_in_ld1_merged1847_2254_cache {
	// RAM Box: {[1, 1313], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_in_1_merged1793_2271_to_in_in_ld1_merged1847_2255_cache {
	// RAM Box: {[0, 1312], [-15, 1934]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct in_cache {
  // Reader addrs...
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[15 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[14 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[13 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[12 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[11 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[10 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[9 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[8 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[7 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[6 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[5 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[4 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[3 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[2 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[1 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
    // { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // # of banks: 16
  in_in_1_merged1793_2256_to_in_in_ld1_merged1847_2240_cache in_in_1_merged1793_2256_to_in_in_ld1_merged1847_2240;
  in_in_1_merged1793_2257_to_in_in_ld1_merged1847_2241_cache in_in_1_merged1793_2257_to_in_in_ld1_merged1847_2241;
  in_in_1_merged1793_2258_to_in_in_ld1_merged1847_2242_cache in_in_1_merged1793_2258_to_in_in_ld1_merged1847_2242;
  in_in_1_merged1793_2259_to_in_in_ld1_merged1847_2243_cache in_in_1_merged1793_2259_to_in_in_ld1_merged1847_2243;
  in_in_1_merged1793_2260_to_in_in_ld1_merged1847_2244_cache in_in_1_merged1793_2260_to_in_in_ld1_merged1847_2244;
  in_in_1_merged1793_2261_to_in_in_ld1_merged1847_2245_cache in_in_1_merged1793_2261_to_in_in_ld1_merged1847_2245;
  in_in_1_merged1793_2262_to_in_in_ld1_merged1847_2246_cache in_in_1_merged1793_2262_to_in_in_ld1_merged1847_2246;
  in_in_1_merged1793_2263_to_in_in_ld1_merged1847_2247_cache in_in_1_merged1793_2263_to_in_in_ld1_merged1847_2247;
  in_in_1_merged1793_2264_to_in_in_ld1_merged1847_2248_cache in_in_1_merged1793_2264_to_in_in_ld1_merged1847_2248;
  in_in_1_merged1793_2265_to_in_in_ld1_merged1847_2249_cache in_in_1_merged1793_2265_to_in_in_ld1_merged1847_2249;
  in_in_1_merged1793_2266_to_in_in_ld1_merged1847_2250_cache in_in_1_merged1793_2266_to_in_in_ld1_merged1847_2250;
  in_in_1_merged1793_2267_to_in_in_ld1_merged1847_2251_cache in_in_1_merged1793_2267_to_in_in_ld1_merged1847_2251;
  in_in_1_merged1793_2268_to_in_in_ld1_merged1847_2252_cache in_in_1_merged1793_2268_to_in_in_ld1_merged1847_2252;
  in_in_1_merged1793_2269_to_in_in_ld1_merged1847_2253_cache in_in_1_merged1793_2269_to_in_in_ld1_merged1847_2253;
  in_in_1_merged1793_2270_to_in_in_ld1_merged1847_2254_cache in_in_1_merged1793_2270_to_in_in_ld1_merged1847_2254;
  in_in_1_merged1793_2271_to_in_in_ld1_merged1847_2255_cache in_in_1_merged1793_2271_to_in_in_ld1_merged1847_2255;
};



inline void in_in_1_merged1793_2256_write(hw_uint<16>& in_in_1_merged1793_2256, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2256_to_in_in_ld1_merged1847_2240.push(in_in_1_merged1793_2256);
}

inline void in_in_1_merged1793_2257_write(hw_uint<16>& in_in_1_merged1793_2257, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2257_to_in_in_ld1_merged1847_2241.push(in_in_1_merged1793_2257);
}

inline void in_in_1_merged1793_2258_write(hw_uint<16>& in_in_1_merged1793_2258, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2258_to_in_in_ld1_merged1847_2242.push(in_in_1_merged1793_2258);
}

inline void in_in_1_merged1793_2259_write(hw_uint<16>& in_in_1_merged1793_2259, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2259_to_in_in_ld1_merged1847_2243.push(in_in_1_merged1793_2259);
}

inline void in_in_1_merged1793_2260_write(hw_uint<16>& in_in_1_merged1793_2260, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2260_to_in_in_ld1_merged1847_2244.push(in_in_1_merged1793_2260);
}

inline void in_in_1_merged1793_2261_write(hw_uint<16>& in_in_1_merged1793_2261, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2261_to_in_in_ld1_merged1847_2245.push(in_in_1_merged1793_2261);
}

inline void in_in_1_merged1793_2262_write(hw_uint<16>& in_in_1_merged1793_2262, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2262_to_in_in_ld1_merged1847_2246.push(in_in_1_merged1793_2262);
}

inline void in_in_1_merged1793_2263_write(hw_uint<16>& in_in_1_merged1793_2263, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2263_to_in_in_ld1_merged1847_2247.push(in_in_1_merged1793_2263);
}

inline void in_in_1_merged1793_2264_write(hw_uint<16>& in_in_1_merged1793_2264, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2264_to_in_in_ld1_merged1847_2248.push(in_in_1_merged1793_2264);
}

inline void in_in_1_merged1793_2265_write(hw_uint<16>& in_in_1_merged1793_2265, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2265_to_in_in_ld1_merged1847_2249.push(in_in_1_merged1793_2265);
}

inline void in_in_1_merged1793_2266_write(hw_uint<16>& in_in_1_merged1793_2266, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2266_to_in_in_ld1_merged1847_2250.push(in_in_1_merged1793_2266);
}

inline void in_in_1_merged1793_2267_write(hw_uint<16>& in_in_1_merged1793_2267, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2267_to_in_in_ld1_merged1847_2251.push(in_in_1_merged1793_2267);
}

inline void in_in_1_merged1793_2268_write(hw_uint<16>& in_in_1_merged1793_2268, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2268_to_in_in_ld1_merged1847_2252.push(in_in_1_merged1793_2268);
}

inline void in_in_1_merged1793_2269_write(hw_uint<16>& in_in_1_merged1793_2269, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2269_to_in_in_ld1_merged1847_2253.push(in_in_1_merged1793_2269);
}

inline void in_in_1_merged1793_2270_write(hw_uint<16>& in_in_1_merged1793_2270, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2270_to_in_in_ld1_merged1847_2254.push(in_in_1_merged1793_2270);
}

inline void in_in_1_merged1793_2271_write(hw_uint<16>& in_in_1_merged1793_2271, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
  in.in_in_1_merged1793_2271_to_in_in_ld1_merged1847_2255.push(in_in_1_merged1793_2271);
}

inline hw_uint<16> in_in_ld1_merged1847_2240_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2240 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[15 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2256 = in.in_in_1_merged1793_2256_to_in_in_ld1_merged1847_2240.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2256;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2241_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2241 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[14 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2257 = in.in_in_1_merged1793_2257_to_in_in_ld1_merged1847_2241.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2257;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2242_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2242 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[13 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2258 = in.in_in_1_merged1793_2258_to_in_in_ld1_merged1847_2242.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2258;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2243_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2243 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[12 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2259 = in.in_in_1_merged1793_2259_to_in_in_ld1_merged1847_2243.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2259;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2244_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2244 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[11 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2260 = in.in_in_1_merged1793_2260_to_in_in_ld1_merged1847_2244.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2260;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2245_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2245 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[10 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2261 = in.in_in_1_merged1793_2261_to_in_in_ld1_merged1847_2245.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2261;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2246_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2246 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[9 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2262 = in.in_in_1_merged1793_2262_to_in_in_ld1_merged1847_2246.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2262;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2247_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2247 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[8 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2263 = in.in_in_1_merged1793_2263_to_in_in_ld1_merged1847_2247.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2263;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2248_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2248 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[7 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2264 = in.in_in_1_merged1793_2264_to_in_in_ld1_merged1847_2248.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2264;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2249_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2249 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[6 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2265 = in.in_in_1_merged1793_2265_to_in_in_ld1_merged1847_2249.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2265;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2250_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2250 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[5 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2266 = in.in_in_1_merged1793_2266_to_in_in_ld1_merged1847_2250.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2266;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2251_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2251 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[4 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2267 = in.in_in_1_merged1793_2267_to_in_in_ld1_merged1847_2251.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2267;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2252_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2252 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[3 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2268 = in.in_in_1_merged1793_2268_to_in_in_ld1_merged1847_2252.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2268;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2253_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2253 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[2 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2269 = in.in_in_1_merged1793_2269_to_in_in_ld1_merged1847_2253.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2269;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2254_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2254 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[1 + 16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2270 = in.in_in_1_merged1793_2270_to_in_in_ld1_merged1847_2254.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2270;
  return 0;
}

inline hw_uint<16> in_in_ld1_merged1847_2255_select(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_in_ld1_merged1847_2255 read pattern: { in_ld1_merged1847[root = 0, in_ld2, in_ld1] -> in[16in_ld1, -15 + in_ld2] : 0 <= in_ld2 <= 1949 and 0 <= in_ld1 <= 82 }
  // Read schedule : { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  // Write schedule: { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_in_1_merged1793_2271 = in.in_in_1_merged1793_2271_to_in_in_ld1_merged1847_2255.peek(/* one reader or all rams */ 0);
  return value_in_in_1_merged1793_2271;
  return 0;
}

// # of bundles = 2
// in_1_merged1793_write
//	in_in_1_merged1793_2256
//	in_in_1_merged1793_2257
//	in_in_1_merged1793_2258
//	in_in_1_merged1793_2259
//	in_in_1_merged1793_2260
//	in_in_1_merged1793_2261
//	in_in_1_merged1793_2262
//	in_in_1_merged1793_2263
//	in_in_1_merged1793_2264
//	in_in_1_merged1793_2265
//	in_in_1_merged1793_2266
//	in_in_1_merged1793_2267
//	in_in_1_merged1793_2268
//	in_in_1_merged1793_2269
//	in_in_1_merged1793_2270
//	in_in_1_merged1793_2271
inline void in_in_1_merged1793_write_bundle_write(hw_uint<256>& in_1_merged1793_write, in_cache& in, int root, int in_0, int in_1, int dynamic_address) {
	hw_uint<16> in_in_1_merged1793_2256_res = in_1_merged1793_write.extract<0, 15>();
	in_in_1_merged1793_2256_write(in_in_1_merged1793_2256_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2257_res = in_1_merged1793_write.extract<16, 31>();
	in_in_1_merged1793_2257_write(in_in_1_merged1793_2257_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2258_res = in_1_merged1793_write.extract<32, 47>();
	in_in_1_merged1793_2258_write(in_in_1_merged1793_2258_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2259_res = in_1_merged1793_write.extract<48, 63>();
	in_in_1_merged1793_2259_write(in_in_1_merged1793_2259_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2260_res = in_1_merged1793_write.extract<64, 79>();
	in_in_1_merged1793_2260_write(in_in_1_merged1793_2260_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2261_res = in_1_merged1793_write.extract<80, 95>();
	in_in_1_merged1793_2261_write(in_in_1_merged1793_2261_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2262_res = in_1_merged1793_write.extract<96, 111>();
	in_in_1_merged1793_2262_write(in_in_1_merged1793_2262_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2263_res = in_1_merged1793_write.extract<112, 127>();
	in_in_1_merged1793_2263_write(in_in_1_merged1793_2263_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2264_res = in_1_merged1793_write.extract<128, 143>();
	in_in_1_merged1793_2264_write(in_in_1_merged1793_2264_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2265_res = in_1_merged1793_write.extract<144, 159>();
	in_in_1_merged1793_2265_write(in_in_1_merged1793_2265_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2266_res = in_1_merged1793_write.extract<160, 175>();
	in_in_1_merged1793_2266_write(in_in_1_merged1793_2266_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2267_res = in_1_merged1793_write.extract<176, 191>();
	in_in_1_merged1793_2267_write(in_in_1_merged1793_2267_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2268_res = in_1_merged1793_write.extract<192, 207>();
	in_in_1_merged1793_2268_write(in_in_1_merged1793_2268_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2269_res = in_1_merged1793_write.extract<208, 223>();
	in_in_1_merged1793_2269_write(in_in_1_merged1793_2269_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2270_res = in_1_merged1793_write.extract<224, 239>();
	in_in_1_merged1793_2270_write(in_in_1_merged1793_2270_res, in, root, in_0, in_1, dynamic_address);
	hw_uint<16> in_in_1_merged1793_2271_res = in_1_merged1793_write.extract<240, 255>();
	in_in_1_merged1793_2271_write(in_in_1_merged1793_2271_res, in, root, in_0, in_1, dynamic_address);
}

// in_ld1_merged1847_read
//	in_in_ld1_merged1847_2240
//	in_in_ld1_merged1847_2241
//	in_in_ld1_merged1847_2242
//	in_in_ld1_merged1847_2243
//	in_in_ld1_merged1847_2244
//	in_in_ld1_merged1847_2245
//	in_in_ld1_merged1847_2246
//	in_in_ld1_merged1847_2247
//	in_in_ld1_merged1847_2248
//	in_in_ld1_merged1847_2249
//	in_in_ld1_merged1847_2250
//	in_in_ld1_merged1847_2251
//	in_in_ld1_merged1847_2252
//	in_in_ld1_merged1847_2253
//	in_in_ld1_merged1847_2254
//	in_in_ld1_merged1847_2255
inline hw_uint<256> in_in_ld1_merged1847_read_bundle_read(in_cache& in, int root, int in_ld2, int in_ld1, int dynamic_address) {
  // # of ports in bundle: 16
    // in_in_ld1_merged1847_2240
    // in_in_ld1_merged1847_2241
    // in_in_ld1_merged1847_2242
    // in_in_ld1_merged1847_2243
    // in_in_ld1_merged1847_2244
    // in_in_ld1_merged1847_2245
    // in_in_ld1_merged1847_2246
    // in_in_ld1_merged1847_2247
    // in_in_ld1_merged1847_2248
    // in_in_ld1_merged1847_2249
    // in_in_ld1_merged1847_2250
    // in_in_ld1_merged1847_2251
    // in_in_ld1_merged1847_2252
    // in_in_ld1_merged1847_2253
    // in_in_ld1_merged1847_2254
    // in_in_ld1_merged1847_2255

	hw_uint<256> result;
	hw_uint<16> in_in_ld1_merged1847_2240_res = in_in_ld1_merged1847_2240_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<0, 256>(result, in_in_ld1_merged1847_2240_res);
	hw_uint<16> in_in_ld1_merged1847_2241_res = in_in_ld1_merged1847_2241_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<16, 256>(result, in_in_ld1_merged1847_2241_res);
	hw_uint<16> in_in_ld1_merged1847_2242_res = in_in_ld1_merged1847_2242_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<32, 256>(result, in_in_ld1_merged1847_2242_res);
	hw_uint<16> in_in_ld1_merged1847_2243_res = in_in_ld1_merged1847_2243_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<48, 256>(result, in_in_ld1_merged1847_2243_res);
	hw_uint<16> in_in_ld1_merged1847_2244_res = in_in_ld1_merged1847_2244_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<64, 256>(result, in_in_ld1_merged1847_2244_res);
	hw_uint<16> in_in_ld1_merged1847_2245_res = in_in_ld1_merged1847_2245_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<80, 256>(result, in_in_ld1_merged1847_2245_res);
	hw_uint<16> in_in_ld1_merged1847_2246_res = in_in_ld1_merged1847_2246_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<96, 256>(result, in_in_ld1_merged1847_2246_res);
	hw_uint<16> in_in_ld1_merged1847_2247_res = in_in_ld1_merged1847_2247_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<112, 256>(result, in_in_ld1_merged1847_2247_res);
	hw_uint<16> in_in_ld1_merged1847_2248_res = in_in_ld1_merged1847_2248_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<128, 256>(result, in_in_ld1_merged1847_2248_res);
	hw_uint<16> in_in_ld1_merged1847_2249_res = in_in_ld1_merged1847_2249_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<144, 256>(result, in_in_ld1_merged1847_2249_res);
	hw_uint<16> in_in_ld1_merged1847_2250_res = in_in_ld1_merged1847_2250_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<160, 256>(result, in_in_ld1_merged1847_2250_res);
	hw_uint<16> in_in_ld1_merged1847_2251_res = in_in_ld1_merged1847_2251_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<176, 256>(result, in_in_ld1_merged1847_2251_res);
	hw_uint<16> in_in_ld1_merged1847_2252_res = in_in_ld1_merged1847_2252_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<192, 256>(result, in_in_ld1_merged1847_2252_res);
	hw_uint<16> in_in_ld1_merged1847_2253_res = in_in_ld1_merged1847_2253_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<208, 256>(result, in_in_ld1_merged1847_2253_res);
	hw_uint<16> in_in_ld1_merged1847_2254_res = in_in_ld1_merged1847_2254_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<224, 256>(result, in_in_ld1_merged1847_2254_res);
	hw_uint<16> in_in_ld1_merged1847_2255_res = in_in_ld1_merged1847_2255_select(in, root, in_ld2, in_ld1, dynamic_address);
	set_at<240, 256>(result, in_in_ld1_merged1847_2255_res);
	return result;
}

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_merged_banks_4_cache {
	// RAM Box: {[15, 1311], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_merged_banks_4_cache {
	// RAM Box: {[14, 1310], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_merged_banks_4_cache {
	// RAM Box: {[13, 1309], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_merged_banks_4_cache {
	// RAM Box: {[12, 1308], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_merged_banks_4_cache {
	// RAM Box: {[11, 1307], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_merged_banks_4_cache {
	// RAM Box: {[10, 1306], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_merged_banks_4_cache {
	// RAM Box: {[9, 1305], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_merged_banks_4_cache {
	// RAM Box: {[8, 1304], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_merged_banks_4_cache {
	// RAM Box: {[7, 1303], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_merged_banks_4_cache {
	// RAM Box: {[6, 1302], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_merged_banks_4_cache {
	// RAM Box: {[5, 1301], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_merged_banks_4_cache {
	// RAM Box: {[4, 1300], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_merged_banks_4_cache {
	// RAM Box: {[3, 1299], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_merged_banks_4_cache {
	// RAM Box: {[2, 1298], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_merged_banks_4_cache {
	// RAM Box: {[1, 1297], [-15, 1934]}
	// Capacity: 168
	// # of read delays: 4
  // 0, 1, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 82> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 82> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_83() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_84() {
		return f4;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_167() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_merged_banks_4_cache {
	// RAM Box: {[0, 1312], [-15, 1933]}
	// Capacity: 168
	// # of read delays: 5
  // 0, 1, 83, 84, 167
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 82> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_84() {
		return f6;
	}

	inline hw_uint<16> peek_166() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_167() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 82
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 82 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct in_FIFO_buf64_cache {
  // Reader addrs...
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[15 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[15 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[16 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[15 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[14 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[14 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[15 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[14 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[13 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[13 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[14 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[13 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[12 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[12 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[13 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[12 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[11 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[11 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[12 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[11 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[10 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[10 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[11 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[10 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[9 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[9 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[10 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[9 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[8 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[8 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[9 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[8 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[7 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[7 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[8 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[7 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[6 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[6 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[7 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[6 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[5 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[5 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[6 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[5 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[4 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[4 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[5 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[4 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[3 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[3 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[4 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[3 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[2 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[2 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[3 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[2 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[1 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[1 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[2 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[1 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[1 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
    // { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // # of banks: 16
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_merged_banks_4;
  in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_merged_banks_4_cache in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_merged_banks_4;
};



inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206);
}

inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_write(hw_uint<16>& in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
  in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_merged_banks_4.push(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207);
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2096_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2096 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[15 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2097_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2097 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[15 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2098_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2098 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[16 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_merged_banks_4.peek_83();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2099_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2099 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[15 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2100_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2100 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[14 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2101_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2101 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[14 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2102_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2102 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[15 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2103_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2103 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[14 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2104_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2104 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[13 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2105_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2105 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[13 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2106_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2106 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[14 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2107_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2107 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[13 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2108_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2108 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[12 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2109_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2109 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[12 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2110_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2110 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[13 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2111_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2111 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[12 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2112_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2112 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[11 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2113_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2113 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[11 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2114_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2114 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[12 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2115_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2115 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[11 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2116_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2116 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[10 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2117_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2117 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[10 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2118_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2118 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[11 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2119_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2119 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[10 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2120_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2120 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[9 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2121_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2121 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[9 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2122_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2122 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[10 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2123_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2123 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[9 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2124_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2124 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[8 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2125_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2125 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[8 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2126_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2126 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[9 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2127_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2127 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[8 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2128_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2128 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[7 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2129_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2129 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[7 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2130_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2130 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[8 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2131_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2131 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[7 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2132_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2132 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[6 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2133_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2133 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[6 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2134_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2134 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[7 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2135_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2135 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[6 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2136_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2136 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[5 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2137_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2137 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[5 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2138_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2138 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[6 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2139_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2139 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[5 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2140_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2140 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[4 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2141_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2141 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[4 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2142_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2142 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[5 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2143_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2143 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[4 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2144_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2144 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[3 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2145_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2145 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[3 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2146_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2146 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[4 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2147_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2147 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[3 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2148_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2148 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[2 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2149_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2149 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[2 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2150_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2150 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[3 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2151_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2151 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[2 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2152_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2152 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[1 + 16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2153_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2153 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[1 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2154_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2154 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[2 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2155_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2155 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[1 + 16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2156_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2156 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[16stg0_1, -15 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_merged_banks_4.peek_167();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2157_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2157 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2158_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2158 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[1 + 16stg0_1, -14 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_merged_banks_4.peek_84();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206;
  return 0;
}

inline hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2159_select(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // in_FIFO_buf64_stg0_1_merged1796_2159 read pattern: { stg0_1_merged1796[root = 0, stg0_0, stg0_1] -> in_FIFO_buf64[16stg0_1, -13 + stg0_0] : 0 <= stg0_0 <= 1947 and 0 <= stg0_1 <= 81 }
  // Read schedule : { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
  auto value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207 = in_FIFO_buf64.in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_merged_banks_4.peek_1();
  return value_in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207;
  return 0;
}

// # of bundles = 2
// in_to_gp_20_ld65_merged1774_write
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206
//	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207
inline void in_FIFO_buf64_in_to_gp_20_ld65_merged1774_write_bundle_write(hw_uint<256>& in_to_gp_20_ld65_merged1774_write, in_FIFO_buf64_cache& in_FIFO_buf64, int root, int in_to_gp_20_ld66, int in_to_gp_20_ld65, int dynamic_address) {
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_res = in_to_gp_20_ld65_merged1774_write.extract<0, 15>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2192_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_res = in_to_gp_20_ld65_merged1774_write.extract<16, 31>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2193_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_res = in_to_gp_20_ld65_merged1774_write.extract<32, 47>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2194_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_res = in_to_gp_20_ld65_merged1774_write.extract<48, 63>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2195_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_res = in_to_gp_20_ld65_merged1774_write.extract<64, 79>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2196_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_res = in_to_gp_20_ld65_merged1774_write.extract<80, 95>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2197_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_res = in_to_gp_20_ld65_merged1774_write.extract<96, 111>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2198_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_res = in_to_gp_20_ld65_merged1774_write.extract<112, 127>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2199_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_res = in_to_gp_20_ld65_merged1774_write.extract<128, 143>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2200_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_res = in_to_gp_20_ld65_merged1774_write.extract<144, 159>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2201_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_res = in_to_gp_20_ld65_merged1774_write.extract<160, 175>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2202_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_res = in_to_gp_20_ld65_merged1774_write.extract<176, 191>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2203_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_res = in_to_gp_20_ld65_merged1774_write.extract<192, 207>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2204_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_res = in_to_gp_20_ld65_merged1774_write.extract<208, 223>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2205_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_res = in_to_gp_20_ld65_merged1774_write.extract<224, 239>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2206_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
	hw_uint<16> in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_res = in_to_gp_20_ld65_merged1774_write.extract<240, 255>();
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_write(in_FIFO_buf64_in_to_gp_20_ld65_merged1774_2207_res, in_FIFO_buf64, root, in_to_gp_20_ld66, in_to_gp_20_ld65, dynamic_address);
}

// stg0_1_merged1796_read
//	in_FIFO_buf64_stg0_1_merged1796_2096
//	in_FIFO_buf64_stg0_1_merged1796_2097
//	in_FIFO_buf64_stg0_1_merged1796_2098
//	in_FIFO_buf64_stg0_1_merged1796_2099
//	in_FIFO_buf64_stg0_1_merged1796_2100
//	in_FIFO_buf64_stg0_1_merged1796_2101
//	in_FIFO_buf64_stg0_1_merged1796_2102
//	in_FIFO_buf64_stg0_1_merged1796_2103
//	in_FIFO_buf64_stg0_1_merged1796_2104
//	in_FIFO_buf64_stg0_1_merged1796_2105
//	in_FIFO_buf64_stg0_1_merged1796_2106
//	in_FIFO_buf64_stg0_1_merged1796_2107
//	in_FIFO_buf64_stg0_1_merged1796_2108
//	in_FIFO_buf64_stg0_1_merged1796_2109
//	in_FIFO_buf64_stg0_1_merged1796_2110
//	in_FIFO_buf64_stg0_1_merged1796_2111
//	in_FIFO_buf64_stg0_1_merged1796_2112
//	in_FIFO_buf64_stg0_1_merged1796_2113
//	in_FIFO_buf64_stg0_1_merged1796_2114
//	in_FIFO_buf64_stg0_1_merged1796_2115
//	in_FIFO_buf64_stg0_1_merged1796_2116
//	in_FIFO_buf64_stg0_1_merged1796_2117
//	in_FIFO_buf64_stg0_1_merged1796_2118
//	in_FIFO_buf64_stg0_1_merged1796_2119
//	in_FIFO_buf64_stg0_1_merged1796_2120
//	in_FIFO_buf64_stg0_1_merged1796_2121
//	in_FIFO_buf64_stg0_1_merged1796_2122
//	in_FIFO_buf64_stg0_1_merged1796_2123
//	in_FIFO_buf64_stg0_1_merged1796_2124
//	in_FIFO_buf64_stg0_1_merged1796_2125
//	in_FIFO_buf64_stg0_1_merged1796_2126
//	in_FIFO_buf64_stg0_1_merged1796_2127
//	in_FIFO_buf64_stg0_1_merged1796_2128
//	in_FIFO_buf64_stg0_1_merged1796_2129
//	in_FIFO_buf64_stg0_1_merged1796_2130
//	in_FIFO_buf64_stg0_1_merged1796_2131
//	in_FIFO_buf64_stg0_1_merged1796_2132
//	in_FIFO_buf64_stg0_1_merged1796_2133
//	in_FIFO_buf64_stg0_1_merged1796_2134
//	in_FIFO_buf64_stg0_1_merged1796_2135
//	in_FIFO_buf64_stg0_1_merged1796_2136
//	in_FIFO_buf64_stg0_1_merged1796_2137
//	in_FIFO_buf64_stg0_1_merged1796_2138
//	in_FIFO_buf64_stg0_1_merged1796_2139
//	in_FIFO_buf64_stg0_1_merged1796_2140
//	in_FIFO_buf64_stg0_1_merged1796_2141
//	in_FIFO_buf64_stg0_1_merged1796_2142
//	in_FIFO_buf64_stg0_1_merged1796_2143
//	in_FIFO_buf64_stg0_1_merged1796_2144
//	in_FIFO_buf64_stg0_1_merged1796_2145
//	in_FIFO_buf64_stg0_1_merged1796_2146
//	in_FIFO_buf64_stg0_1_merged1796_2147
//	in_FIFO_buf64_stg0_1_merged1796_2148
//	in_FIFO_buf64_stg0_1_merged1796_2149
//	in_FIFO_buf64_stg0_1_merged1796_2150
//	in_FIFO_buf64_stg0_1_merged1796_2151
//	in_FIFO_buf64_stg0_1_merged1796_2152
//	in_FIFO_buf64_stg0_1_merged1796_2153
//	in_FIFO_buf64_stg0_1_merged1796_2154
//	in_FIFO_buf64_stg0_1_merged1796_2155
//	in_FIFO_buf64_stg0_1_merged1796_2156
//	in_FIFO_buf64_stg0_1_merged1796_2157
//	in_FIFO_buf64_stg0_1_merged1796_2158
//	in_FIFO_buf64_stg0_1_merged1796_2159
inline hw_uint<1024> in_FIFO_buf64_stg0_1_merged1796_read_bundle_read(in_FIFO_buf64_cache& in_FIFO_buf64, int root, int stg0_0, int stg0_1, int dynamic_address) {
  // # of ports in bundle: 64
    // in_FIFO_buf64_stg0_1_merged1796_2096
    // in_FIFO_buf64_stg0_1_merged1796_2097
    // in_FIFO_buf64_stg0_1_merged1796_2098
    // in_FIFO_buf64_stg0_1_merged1796_2099
    // in_FIFO_buf64_stg0_1_merged1796_2100
    // in_FIFO_buf64_stg0_1_merged1796_2101
    // in_FIFO_buf64_stg0_1_merged1796_2102
    // in_FIFO_buf64_stg0_1_merged1796_2103
    // in_FIFO_buf64_stg0_1_merged1796_2104
    // in_FIFO_buf64_stg0_1_merged1796_2105
    // in_FIFO_buf64_stg0_1_merged1796_2106
    // in_FIFO_buf64_stg0_1_merged1796_2107
    // in_FIFO_buf64_stg0_1_merged1796_2108
    // in_FIFO_buf64_stg0_1_merged1796_2109
    // in_FIFO_buf64_stg0_1_merged1796_2110
    // in_FIFO_buf64_stg0_1_merged1796_2111
    // in_FIFO_buf64_stg0_1_merged1796_2112
    // in_FIFO_buf64_stg0_1_merged1796_2113
    // in_FIFO_buf64_stg0_1_merged1796_2114
    // in_FIFO_buf64_stg0_1_merged1796_2115
    // in_FIFO_buf64_stg0_1_merged1796_2116
    // in_FIFO_buf64_stg0_1_merged1796_2117
    // in_FIFO_buf64_stg0_1_merged1796_2118
    // in_FIFO_buf64_stg0_1_merged1796_2119
    // in_FIFO_buf64_stg0_1_merged1796_2120
    // in_FIFO_buf64_stg0_1_merged1796_2121
    // in_FIFO_buf64_stg0_1_merged1796_2122
    // in_FIFO_buf64_stg0_1_merged1796_2123
    // in_FIFO_buf64_stg0_1_merged1796_2124
    // in_FIFO_buf64_stg0_1_merged1796_2125
    // in_FIFO_buf64_stg0_1_merged1796_2126
    // in_FIFO_buf64_stg0_1_merged1796_2127
    // in_FIFO_buf64_stg0_1_merged1796_2128
    // in_FIFO_buf64_stg0_1_merged1796_2129
    // in_FIFO_buf64_stg0_1_merged1796_2130
    // in_FIFO_buf64_stg0_1_merged1796_2131
    // in_FIFO_buf64_stg0_1_merged1796_2132
    // in_FIFO_buf64_stg0_1_merged1796_2133
    // in_FIFO_buf64_stg0_1_merged1796_2134
    // in_FIFO_buf64_stg0_1_merged1796_2135
    // in_FIFO_buf64_stg0_1_merged1796_2136
    // in_FIFO_buf64_stg0_1_merged1796_2137
    // in_FIFO_buf64_stg0_1_merged1796_2138
    // in_FIFO_buf64_stg0_1_merged1796_2139
    // in_FIFO_buf64_stg0_1_merged1796_2140
    // in_FIFO_buf64_stg0_1_merged1796_2141
    // in_FIFO_buf64_stg0_1_merged1796_2142
    // in_FIFO_buf64_stg0_1_merged1796_2143
    // in_FIFO_buf64_stg0_1_merged1796_2144
    // in_FIFO_buf64_stg0_1_merged1796_2145
    // in_FIFO_buf64_stg0_1_merged1796_2146
    // in_FIFO_buf64_stg0_1_merged1796_2147
    // in_FIFO_buf64_stg0_1_merged1796_2148
    // in_FIFO_buf64_stg0_1_merged1796_2149
    // in_FIFO_buf64_stg0_1_merged1796_2150
    // in_FIFO_buf64_stg0_1_merged1796_2151
    // in_FIFO_buf64_stg0_1_merged1796_2152
    // in_FIFO_buf64_stg0_1_merged1796_2153
    // in_FIFO_buf64_stg0_1_merged1796_2154
    // in_FIFO_buf64_stg0_1_merged1796_2155
    // in_FIFO_buf64_stg0_1_merged1796_2156
    // in_FIFO_buf64_stg0_1_merged1796_2157
    // in_FIFO_buf64_stg0_1_merged1796_2158
    // in_FIFO_buf64_stg0_1_merged1796_2159

	hw_uint<1024> result;
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2096_res = in_FIFO_buf64_stg0_1_merged1796_2096_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<0, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2096_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2097_res = in_FIFO_buf64_stg0_1_merged1796_2097_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<16, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2097_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2098_res = in_FIFO_buf64_stg0_1_merged1796_2098_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<32, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2098_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2099_res = in_FIFO_buf64_stg0_1_merged1796_2099_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<48, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2099_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2100_res = in_FIFO_buf64_stg0_1_merged1796_2100_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<64, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2100_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2101_res = in_FIFO_buf64_stg0_1_merged1796_2101_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<80, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2101_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2102_res = in_FIFO_buf64_stg0_1_merged1796_2102_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<96, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2102_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2103_res = in_FIFO_buf64_stg0_1_merged1796_2103_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<112, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2103_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2104_res = in_FIFO_buf64_stg0_1_merged1796_2104_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<128, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2104_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2105_res = in_FIFO_buf64_stg0_1_merged1796_2105_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<144, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2105_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2106_res = in_FIFO_buf64_stg0_1_merged1796_2106_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<160, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2106_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2107_res = in_FIFO_buf64_stg0_1_merged1796_2107_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<176, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2107_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2108_res = in_FIFO_buf64_stg0_1_merged1796_2108_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<192, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2108_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2109_res = in_FIFO_buf64_stg0_1_merged1796_2109_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<208, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2109_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2110_res = in_FIFO_buf64_stg0_1_merged1796_2110_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<224, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2110_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2111_res = in_FIFO_buf64_stg0_1_merged1796_2111_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<240, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2111_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2112_res = in_FIFO_buf64_stg0_1_merged1796_2112_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<256, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2112_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2113_res = in_FIFO_buf64_stg0_1_merged1796_2113_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<272, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2113_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2114_res = in_FIFO_buf64_stg0_1_merged1796_2114_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<288, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2114_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2115_res = in_FIFO_buf64_stg0_1_merged1796_2115_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<304, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2115_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2116_res = in_FIFO_buf64_stg0_1_merged1796_2116_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<320, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2116_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2117_res = in_FIFO_buf64_stg0_1_merged1796_2117_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<336, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2117_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2118_res = in_FIFO_buf64_stg0_1_merged1796_2118_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<352, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2118_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2119_res = in_FIFO_buf64_stg0_1_merged1796_2119_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<368, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2119_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2120_res = in_FIFO_buf64_stg0_1_merged1796_2120_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<384, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2120_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2121_res = in_FIFO_buf64_stg0_1_merged1796_2121_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<400, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2121_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2122_res = in_FIFO_buf64_stg0_1_merged1796_2122_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<416, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2122_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2123_res = in_FIFO_buf64_stg0_1_merged1796_2123_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<432, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2123_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2124_res = in_FIFO_buf64_stg0_1_merged1796_2124_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<448, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2124_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2125_res = in_FIFO_buf64_stg0_1_merged1796_2125_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<464, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2125_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2126_res = in_FIFO_buf64_stg0_1_merged1796_2126_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<480, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2126_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2127_res = in_FIFO_buf64_stg0_1_merged1796_2127_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<496, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2127_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2128_res = in_FIFO_buf64_stg0_1_merged1796_2128_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<512, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2128_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2129_res = in_FIFO_buf64_stg0_1_merged1796_2129_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<528, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2129_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2130_res = in_FIFO_buf64_stg0_1_merged1796_2130_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<544, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2130_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2131_res = in_FIFO_buf64_stg0_1_merged1796_2131_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<560, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2131_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2132_res = in_FIFO_buf64_stg0_1_merged1796_2132_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<576, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2132_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2133_res = in_FIFO_buf64_stg0_1_merged1796_2133_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<592, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2133_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2134_res = in_FIFO_buf64_stg0_1_merged1796_2134_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<608, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2134_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2135_res = in_FIFO_buf64_stg0_1_merged1796_2135_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<624, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2135_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2136_res = in_FIFO_buf64_stg0_1_merged1796_2136_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<640, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2136_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2137_res = in_FIFO_buf64_stg0_1_merged1796_2137_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<656, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2137_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2138_res = in_FIFO_buf64_stg0_1_merged1796_2138_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<672, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2138_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2139_res = in_FIFO_buf64_stg0_1_merged1796_2139_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<688, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2139_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2140_res = in_FIFO_buf64_stg0_1_merged1796_2140_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<704, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2140_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2141_res = in_FIFO_buf64_stg0_1_merged1796_2141_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<720, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2141_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2142_res = in_FIFO_buf64_stg0_1_merged1796_2142_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<736, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2142_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2143_res = in_FIFO_buf64_stg0_1_merged1796_2143_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<752, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2143_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2144_res = in_FIFO_buf64_stg0_1_merged1796_2144_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<768, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2144_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2145_res = in_FIFO_buf64_stg0_1_merged1796_2145_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<784, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2145_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2146_res = in_FIFO_buf64_stg0_1_merged1796_2146_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<800, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2146_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2147_res = in_FIFO_buf64_stg0_1_merged1796_2147_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<816, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2147_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2148_res = in_FIFO_buf64_stg0_1_merged1796_2148_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<832, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2148_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2149_res = in_FIFO_buf64_stg0_1_merged1796_2149_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<848, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2149_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2150_res = in_FIFO_buf64_stg0_1_merged1796_2150_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<864, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2150_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2151_res = in_FIFO_buf64_stg0_1_merged1796_2151_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<880, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2151_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2152_res = in_FIFO_buf64_stg0_1_merged1796_2152_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<896, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2152_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2153_res = in_FIFO_buf64_stg0_1_merged1796_2153_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<912, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2153_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2154_res = in_FIFO_buf64_stg0_1_merged1796_2154_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<928, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2154_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2155_res = in_FIFO_buf64_stg0_1_merged1796_2155_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<944, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2155_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2156_res = in_FIFO_buf64_stg0_1_merged1796_2156_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<960, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2156_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2157_res = in_FIFO_buf64_stg0_1_merged1796_2157_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<976, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2157_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2158_res = in_FIFO_buf64_stg0_1_merged1796_2158_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<992, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2158_res);
	hw_uint<16> in_FIFO_buf64_stg0_1_merged1796_2159_res = in_FIFO_buf64_stg0_1_merged1796_2159_select(in_FIFO_buf64, root, stg0_0, stg0_1, dynamic_address);
	set_at<1008, 1024>(result, in_FIFO_buf64_stg0_1_merged1796_2159_res);
	return result;
}

struct stg0_stg0_1_merged1796_2080_to_stg0_stg0_ld5_merged1857_2064_cache {
	// RAM Box: {[15, 1311], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2081_to_stg0_stg0_ld5_merged1857_2065_cache {
	// RAM Box: {[14, 1310], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2082_to_stg0_stg0_ld5_merged1857_2066_cache {
	// RAM Box: {[13, 1309], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2083_to_stg0_stg0_ld5_merged1857_2067_cache {
	// RAM Box: {[12, 1308], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2084_to_stg0_stg0_ld5_merged1857_2068_cache {
	// RAM Box: {[11, 1307], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2085_to_stg0_stg0_ld5_merged1857_2069_cache {
	// RAM Box: {[10, 1306], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2086_to_stg0_stg0_ld5_merged1857_2070_cache {
	// RAM Box: {[9, 1305], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2087_to_stg0_stg0_ld5_merged1857_2071_cache {
	// RAM Box: {[8, 1304], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2088_to_stg0_stg0_ld5_merged1857_2072_cache {
	// RAM Box: {[7, 1303], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2089_to_stg0_stg0_ld5_merged1857_2073_cache {
	// RAM Box: {[6, 1302], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2090_to_stg0_stg0_ld5_merged1857_2074_cache {
	// RAM Box: {[5, 1301], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2091_to_stg0_stg0_ld5_merged1857_2075_cache {
	// RAM Box: {[4, 1300], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2092_to_stg0_stg0_ld5_merged1857_2076_cache {
	// RAM Box: {[3, 1299], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2093_to_stg0_stg0_ld5_merged1857_2077_cache {
	// RAM Box: {[2, 1298], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2094_to_stg0_stg0_ld5_merged1857_2078_cache {
	// RAM Box: {[1, 1297], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_stg0_1_merged1796_2095_to_stg0_stg0_ld5_merged1857_2079_cache {
	// RAM Box: {[0, 1296], [-14, 1933]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg0_cache {
  // Reader addrs...
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[15 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[14 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[13 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[12 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[11 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[10 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[9 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[8 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[7 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[6 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[5 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[4 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[3 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[2 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[1 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
    // { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // # of banks: 16
  stg0_stg0_1_merged1796_2080_to_stg0_stg0_ld5_merged1857_2064_cache stg0_stg0_1_merged1796_2080_to_stg0_stg0_ld5_merged1857_2064;
  stg0_stg0_1_merged1796_2081_to_stg0_stg0_ld5_merged1857_2065_cache stg0_stg0_1_merged1796_2081_to_stg0_stg0_ld5_merged1857_2065;
  stg0_stg0_1_merged1796_2082_to_stg0_stg0_ld5_merged1857_2066_cache stg0_stg0_1_merged1796_2082_to_stg0_stg0_ld5_merged1857_2066;
  stg0_stg0_1_merged1796_2083_to_stg0_stg0_ld5_merged1857_2067_cache stg0_stg0_1_merged1796_2083_to_stg0_stg0_ld5_merged1857_2067;
  stg0_stg0_1_merged1796_2084_to_stg0_stg0_ld5_merged1857_2068_cache stg0_stg0_1_merged1796_2084_to_stg0_stg0_ld5_merged1857_2068;
  stg0_stg0_1_merged1796_2085_to_stg0_stg0_ld5_merged1857_2069_cache stg0_stg0_1_merged1796_2085_to_stg0_stg0_ld5_merged1857_2069;
  stg0_stg0_1_merged1796_2086_to_stg0_stg0_ld5_merged1857_2070_cache stg0_stg0_1_merged1796_2086_to_stg0_stg0_ld5_merged1857_2070;
  stg0_stg0_1_merged1796_2087_to_stg0_stg0_ld5_merged1857_2071_cache stg0_stg0_1_merged1796_2087_to_stg0_stg0_ld5_merged1857_2071;
  stg0_stg0_1_merged1796_2088_to_stg0_stg0_ld5_merged1857_2072_cache stg0_stg0_1_merged1796_2088_to_stg0_stg0_ld5_merged1857_2072;
  stg0_stg0_1_merged1796_2089_to_stg0_stg0_ld5_merged1857_2073_cache stg0_stg0_1_merged1796_2089_to_stg0_stg0_ld5_merged1857_2073;
  stg0_stg0_1_merged1796_2090_to_stg0_stg0_ld5_merged1857_2074_cache stg0_stg0_1_merged1796_2090_to_stg0_stg0_ld5_merged1857_2074;
  stg0_stg0_1_merged1796_2091_to_stg0_stg0_ld5_merged1857_2075_cache stg0_stg0_1_merged1796_2091_to_stg0_stg0_ld5_merged1857_2075;
  stg0_stg0_1_merged1796_2092_to_stg0_stg0_ld5_merged1857_2076_cache stg0_stg0_1_merged1796_2092_to_stg0_stg0_ld5_merged1857_2076;
  stg0_stg0_1_merged1796_2093_to_stg0_stg0_ld5_merged1857_2077_cache stg0_stg0_1_merged1796_2093_to_stg0_stg0_ld5_merged1857_2077;
  stg0_stg0_1_merged1796_2094_to_stg0_stg0_ld5_merged1857_2078_cache stg0_stg0_1_merged1796_2094_to_stg0_stg0_ld5_merged1857_2078;
  stg0_stg0_1_merged1796_2095_to_stg0_stg0_ld5_merged1857_2079_cache stg0_stg0_1_merged1796_2095_to_stg0_stg0_ld5_merged1857_2079;
};



inline void stg0_stg0_1_merged1796_2080_write(hw_uint<16>& stg0_stg0_1_merged1796_2080, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2080_to_stg0_stg0_ld5_merged1857_2064.push(stg0_stg0_1_merged1796_2080);
}

inline void stg0_stg0_1_merged1796_2081_write(hw_uint<16>& stg0_stg0_1_merged1796_2081, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2081_to_stg0_stg0_ld5_merged1857_2065.push(stg0_stg0_1_merged1796_2081);
}

inline void stg0_stg0_1_merged1796_2082_write(hw_uint<16>& stg0_stg0_1_merged1796_2082, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2082_to_stg0_stg0_ld5_merged1857_2066.push(stg0_stg0_1_merged1796_2082);
}

inline void stg0_stg0_1_merged1796_2083_write(hw_uint<16>& stg0_stg0_1_merged1796_2083, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2083_to_stg0_stg0_ld5_merged1857_2067.push(stg0_stg0_1_merged1796_2083);
}

inline void stg0_stg0_1_merged1796_2084_write(hw_uint<16>& stg0_stg0_1_merged1796_2084, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2084_to_stg0_stg0_ld5_merged1857_2068.push(stg0_stg0_1_merged1796_2084);
}

inline void stg0_stg0_1_merged1796_2085_write(hw_uint<16>& stg0_stg0_1_merged1796_2085, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2085_to_stg0_stg0_ld5_merged1857_2069.push(stg0_stg0_1_merged1796_2085);
}

inline void stg0_stg0_1_merged1796_2086_write(hw_uint<16>& stg0_stg0_1_merged1796_2086, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2086_to_stg0_stg0_ld5_merged1857_2070.push(stg0_stg0_1_merged1796_2086);
}

inline void stg0_stg0_1_merged1796_2087_write(hw_uint<16>& stg0_stg0_1_merged1796_2087, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2087_to_stg0_stg0_ld5_merged1857_2071.push(stg0_stg0_1_merged1796_2087);
}

inline void stg0_stg0_1_merged1796_2088_write(hw_uint<16>& stg0_stg0_1_merged1796_2088, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2088_to_stg0_stg0_ld5_merged1857_2072.push(stg0_stg0_1_merged1796_2088);
}

inline void stg0_stg0_1_merged1796_2089_write(hw_uint<16>& stg0_stg0_1_merged1796_2089, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2089_to_stg0_stg0_ld5_merged1857_2073.push(stg0_stg0_1_merged1796_2089);
}

inline void stg0_stg0_1_merged1796_2090_write(hw_uint<16>& stg0_stg0_1_merged1796_2090, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2090_to_stg0_stg0_ld5_merged1857_2074.push(stg0_stg0_1_merged1796_2090);
}

inline void stg0_stg0_1_merged1796_2091_write(hw_uint<16>& stg0_stg0_1_merged1796_2091, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2091_to_stg0_stg0_ld5_merged1857_2075.push(stg0_stg0_1_merged1796_2091);
}

inline void stg0_stg0_1_merged1796_2092_write(hw_uint<16>& stg0_stg0_1_merged1796_2092, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2092_to_stg0_stg0_ld5_merged1857_2076.push(stg0_stg0_1_merged1796_2092);
}

inline void stg0_stg0_1_merged1796_2093_write(hw_uint<16>& stg0_stg0_1_merged1796_2093, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2093_to_stg0_stg0_ld5_merged1857_2077.push(stg0_stg0_1_merged1796_2093);
}

inline void stg0_stg0_1_merged1796_2094_write(hw_uint<16>& stg0_stg0_1_merged1796_2094, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2094_to_stg0_stg0_ld5_merged1857_2078.push(stg0_stg0_1_merged1796_2094);
}

inline void stg0_stg0_1_merged1796_2095_write(hw_uint<16>& stg0_stg0_1_merged1796_2095, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
  stg0.stg0_stg0_1_merged1796_2095_to_stg0_stg0_ld5_merged1857_2079.push(stg0_stg0_1_merged1796_2095);
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2064_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2064 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[15 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2080 = stg0.stg0_stg0_1_merged1796_2080_to_stg0_stg0_ld5_merged1857_2064.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2080;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2065_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2065 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[14 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2081 = stg0.stg0_stg0_1_merged1796_2081_to_stg0_stg0_ld5_merged1857_2065.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2081;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2066_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2066 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[13 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2082 = stg0.stg0_stg0_1_merged1796_2082_to_stg0_stg0_ld5_merged1857_2066.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2082;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2067_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2067 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[12 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2083 = stg0.stg0_stg0_1_merged1796_2083_to_stg0_stg0_ld5_merged1857_2067.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2083;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2068_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2068 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[11 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2084 = stg0.stg0_stg0_1_merged1796_2084_to_stg0_stg0_ld5_merged1857_2068.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2084;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2069_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2069 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[10 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2085 = stg0.stg0_stg0_1_merged1796_2085_to_stg0_stg0_ld5_merged1857_2069.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2085;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2070_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2070 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[9 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2086 = stg0.stg0_stg0_1_merged1796_2086_to_stg0_stg0_ld5_merged1857_2070.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2086;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2071_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2071 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[8 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2087 = stg0.stg0_stg0_1_merged1796_2087_to_stg0_stg0_ld5_merged1857_2071.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2087;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2072_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2072 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[7 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2088 = stg0.stg0_stg0_1_merged1796_2088_to_stg0_stg0_ld5_merged1857_2072.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2088;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2073_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2073 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[6 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2089 = stg0.stg0_stg0_1_merged1796_2089_to_stg0_stg0_ld5_merged1857_2073.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2089;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2074_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2074 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[5 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2090 = stg0.stg0_stg0_1_merged1796_2090_to_stg0_stg0_ld5_merged1857_2074.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2090;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2075_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2075 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[4 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2091 = stg0.stg0_stg0_1_merged1796_2091_to_stg0_stg0_ld5_merged1857_2075.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2091;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2076_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2076 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[3 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2092 = stg0.stg0_stg0_1_merged1796_2092_to_stg0_stg0_ld5_merged1857_2076.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2092;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2077_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2077 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[2 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2093 = stg0.stg0_stg0_1_merged1796_2093_to_stg0_stg0_ld5_merged1857_2077.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2093;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2078_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2078 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[1 + 16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2094 = stg0.stg0_stg0_1_merged1796_2094_to_stg0_stg0_ld5_merged1857_2078.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2094;
  return 0;
}

inline hw_uint<16> stg0_stg0_ld5_merged1857_2079_select(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_stg0_ld5_merged1857_2079 read pattern: { stg0_ld5_merged1857[root = 0, stg0_ld6, stg0_ld5] -> stg0[16stg0_ld5, -14 + stg0_ld6] : 0 <= stg0_ld6 <= 1947 and 0 <= stg0_ld5 <= 81 }
  // Read schedule : { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  // Write schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_stg0_1_merged1796_2095 = stg0.stg0_stg0_1_merged1796_2095_to_stg0_stg0_ld5_merged1857_2079.peek(/* one reader or all rams */ 0);
  return value_stg0_stg0_1_merged1796_2095;
  return 0;
}

// # of bundles = 2
// stg0_1_merged1796_write
//	stg0_stg0_1_merged1796_2080
//	stg0_stg0_1_merged1796_2081
//	stg0_stg0_1_merged1796_2082
//	stg0_stg0_1_merged1796_2083
//	stg0_stg0_1_merged1796_2084
//	stg0_stg0_1_merged1796_2085
//	stg0_stg0_1_merged1796_2086
//	stg0_stg0_1_merged1796_2087
//	stg0_stg0_1_merged1796_2088
//	stg0_stg0_1_merged1796_2089
//	stg0_stg0_1_merged1796_2090
//	stg0_stg0_1_merged1796_2091
//	stg0_stg0_1_merged1796_2092
//	stg0_stg0_1_merged1796_2093
//	stg0_stg0_1_merged1796_2094
//	stg0_stg0_1_merged1796_2095
inline void stg0_stg0_1_merged1796_write_bundle_write(hw_uint<256>& stg0_1_merged1796_write, stg0_cache& stg0, int root, int stg0_0, int stg0_1, int dynamic_address) {
	hw_uint<16> stg0_stg0_1_merged1796_2080_res = stg0_1_merged1796_write.extract<0, 15>();
	stg0_stg0_1_merged1796_2080_write(stg0_stg0_1_merged1796_2080_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2081_res = stg0_1_merged1796_write.extract<16, 31>();
	stg0_stg0_1_merged1796_2081_write(stg0_stg0_1_merged1796_2081_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2082_res = stg0_1_merged1796_write.extract<32, 47>();
	stg0_stg0_1_merged1796_2082_write(stg0_stg0_1_merged1796_2082_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2083_res = stg0_1_merged1796_write.extract<48, 63>();
	stg0_stg0_1_merged1796_2083_write(stg0_stg0_1_merged1796_2083_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2084_res = stg0_1_merged1796_write.extract<64, 79>();
	stg0_stg0_1_merged1796_2084_write(stg0_stg0_1_merged1796_2084_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2085_res = stg0_1_merged1796_write.extract<80, 95>();
	stg0_stg0_1_merged1796_2085_write(stg0_stg0_1_merged1796_2085_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2086_res = stg0_1_merged1796_write.extract<96, 111>();
	stg0_stg0_1_merged1796_2086_write(stg0_stg0_1_merged1796_2086_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2087_res = stg0_1_merged1796_write.extract<112, 127>();
	stg0_stg0_1_merged1796_2087_write(stg0_stg0_1_merged1796_2087_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2088_res = stg0_1_merged1796_write.extract<128, 143>();
	stg0_stg0_1_merged1796_2088_write(stg0_stg0_1_merged1796_2088_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2089_res = stg0_1_merged1796_write.extract<144, 159>();
	stg0_stg0_1_merged1796_2089_write(stg0_stg0_1_merged1796_2089_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2090_res = stg0_1_merged1796_write.extract<160, 175>();
	stg0_stg0_1_merged1796_2090_write(stg0_stg0_1_merged1796_2090_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2091_res = stg0_1_merged1796_write.extract<176, 191>();
	stg0_stg0_1_merged1796_2091_write(stg0_stg0_1_merged1796_2091_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2092_res = stg0_1_merged1796_write.extract<192, 207>();
	stg0_stg0_1_merged1796_2092_write(stg0_stg0_1_merged1796_2092_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2093_res = stg0_1_merged1796_write.extract<208, 223>();
	stg0_stg0_1_merged1796_2093_write(stg0_stg0_1_merged1796_2093_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2094_res = stg0_1_merged1796_write.extract<224, 239>();
	stg0_stg0_1_merged1796_2094_write(stg0_stg0_1_merged1796_2094_res, stg0, root, stg0_0, stg0_1, dynamic_address);
	hw_uint<16> stg0_stg0_1_merged1796_2095_res = stg0_1_merged1796_write.extract<240, 255>();
	stg0_stg0_1_merged1796_2095_write(stg0_stg0_1_merged1796_2095_res, stg0, root, stg0_0, stg0_1, dynamic_address);
}

// stg0_ld5_merged1857_read
//	stg0_stg0_ld5_merged1857_2064
//	stg0_stg0_ld5_merged1857_2065
//	stg0_stg0_ld5_merged1857_2066
//	stg0_stg0_ld5_merged1857_2067
//	stg0_stg0_ld5_merged1857_2068
//	stg0_stg0_ld5_merged1857_2069
//	stg0_stg0_ld5_merged1857_2070
//	stg0_stg0_ld5_merged1857_2071
//	stg0_stg0_ld5_merged1857_2072
//	stg0_stg0_ld5_merged1857_2073
//	stg0_stg0_ld5_merged1857_2074
//	stg0_stg0_ld5_merged1857_2075
//	stg0_stg0_ld5_merged1857_2076
//	stg0_stg0_ld5_merged1857_2077
//	stg0_stg0_ld5_merged1857_2078
//	stg0_stg0_ld5_merged1857_2079
inline hw_uint<256> stg0_stg0_ld5_merged1857_read_bundle_read(stg0_cache& stg0, int root, int stg0_ld6, int stg0_ld5, int dynamic_address) {
  // # of ports in bundle: 16
    // stg0_stg0_ld5_merged1857_2064
    // stg0_stg0_ld5_merged1857_2065
    // stg0_stg0_ld5_merged1857_2066
    // stg0_stg0_ld5_merged1857_2067
    // stg0_stg0_ld5_merged1857_2068
    // stg0_stg0_ld5_merged1857_2069
    // stg0_stg0_ld5_merged1857_2070
    // stg0_stg0_ld5_merged1857_2071
    // stg0_stg0_ld5_merged1857_2072
    // stg0_stg0_ld5_merged1857_2073
    // stg0_stg0_ld5_merged1857_2074
    // stg0_stg0_ld5_merged1857_2075
    // stg0_stg0_ld5_merged1857_2076
    // stg0_stg0_ld5_merged1857_2077
    // stg0_stg0_ld5_merged1857_2078
    // stg0_stg0_ld5_merged1857_2079

	hw_uint<256> result;
	hw_uint<16> stg0_stg0_ld5_merged1857_2064_res = stg0_stg0_ld5_merged1857_2064_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<0, 256>(result, stg0_stg0_ld5_merged1857_2064_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2065_res = stg0_stg0_ld5_merged1857_2065_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<16, 256>(result, stg0_stg0_ld5_merged1857_2065_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2066_res = stg0_stg0_ld5_merged1857_2066_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<32, 256>(result, stg0_stg0_ld5_merged1857_2066_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2067_res = stg0_stg0_ld5_merged1857_2067_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<48, 256>(result, stg0_stg0_ld5_merged1857_2067_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2068_res = stg0_stg0_ld5_merged1857_2068_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<64, 256>(result, stg0_stg0_ld5_merged1857_2068_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2069_res = stg0_stg0_ld5_merged1857_2069_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<80, 256>(result, stg0_stg0_ld5_merged1857_2069_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2070_res = stg0_stg0_ld5_merged1857_2070_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<96, 256>(result, stg0_stg0_ld5_merged1857_2070_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2071_res = stg0_stg0_ld5_merged1857_2071_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<112, 256>(result, stg0_stg0_ld5_merged1857_2071_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2072_res = stg0_stg0_ld5_merged1857_2072_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<128, 256>(result, stg0_stg0_ld5_merged1857_2072_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2073_res = stg0_stg0_ld5_merged1857_2073_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<144, 256>(result, stg0_stg0_ld5_merged1857_2073_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2074_res = stg0_stg0_ld5_merged1857_2074_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<160, 256>(result, stg0_stg0_ld5_merged1857_2074_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2075_res = stg0_stg0_ld5_merged1857_2075_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<176, 256>(result, stg0_stg0_ld5_merged1857_2075_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2076_res = stg0_stg0_ld5_merged1857_2076_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<192, 256>(result, stg0_stg0_ld5_merged1857_2076_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2077_res = stg0_stg0_ld5_merged1857_2077_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<208, 256>(result, stg0_stg0_ld5_merged1857_2077_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2078_res = stg0_stg0_ld5_merged1857_2078_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<224, 256>(result, stg0_stg0_ld5_merged1857_2078_res);
	hw_uint<16> stg0_stg0_ld5_merged1857_2079_res = stg0_stg0_ld5_merged1857_2079_select(stg0, root, stg0_ld6, stg0_ld5, dynamic_address);
	set_at<240, 256>(result, stg0_stg0_ld5_merged1857_2079_res);
	return result;
}

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_merged_banks_4_cache {
	// RAM Box: {[15, 1295], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_merged_banks_4_cache {
	// RAM Box: {[14, 1294], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_merged_banks_4_cache {
	// RAM Box: {[13, 1293], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_merged_banks_4_cache {
	// RAM Box: {[12, 1292], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_merged_banks_4_cache {
	// RAM Box: {[11, 1291], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_merged_banks_4_cache {
	// RAM Box: {[10, 1290], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_merged_banks_4_cache {
	// RAM Box: {[9, 1289], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_merged_banks_4_cache {
	// RAM Box: {[8, 1288], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_merged_banks_4_cache {
	// RAM Box: {[7, 1287], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_merged_banks_4_cache {
	// RAM Box: {[6, 1286], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_merged_banks_4_cache {
	// RAM Box: {[5, 1285], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_merged_banks_4_cache {
	// RAM Box: {[4, 1284], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_merged_banks_4_cache {
	// RAM Box: {[3, 1283], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_merged_banks_4_cache {
	// RAM Box: {[2, 1282], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_merged_banks_4_cache {
	// RAM Box: {[1, 1281], [-14, 1933]}
	// Capacity: 166
	// # of read delays: 4
  // 0, 1, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 81> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 81> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_82() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_83() {
		return f4;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_165() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_merged_banks_4_cache {
	// RAM Box: {[0, 1296], [-14, 1932]}
	// Capacity: 166
	// # of read delays: 5
  // 0, 1, 82, 83, 165
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 81> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_83() {
		return f6;
	}

	inline hw_uint<16> peek_164() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_165() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 81
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 81 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg0_FIFO_buf68_cache {
  // Reader addrs...
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[15 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[15 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[16 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[15 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[14 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[14 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[15 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[14 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[13 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[13 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[14 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[13 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[12 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[12 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[13 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[12 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[11 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[11 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[12 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[11 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[10 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[10 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[11 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[10 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[9 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[9 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[10 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[9 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[8 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[8 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[9 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[8 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[7 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[7 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[8 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[7 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[6 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[6 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[7 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[6 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[5 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[5 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[6 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[5 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[4 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[4 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[5 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[4 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[3 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[3 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[4 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[3 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[2 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[2 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[3 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[2 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[1 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[1 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[2 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[1 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[1 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
    // { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // # of banks: 16
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_merged_banks_4;
  stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_merged_banks_4_cache stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_merged_banks_4;
};



inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030);
}

inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_write(hw_uint<16>& stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
  stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_merged_banks_4.push(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031);
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1232_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1232 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[15 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1233_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1233 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[15 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1234_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1234 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[16 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_merged_banks_4.peek_82();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1235_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1235 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[15 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1236_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1236 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[14 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1237_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1237 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[14 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1238_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1238 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[15 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1239_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1239 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[14 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1240_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1240 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[13 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1241_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1241 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[13 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1242_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1242 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[14 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1243_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1243 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[13 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1244_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1244 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[12 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1245_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1245 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[12 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1246_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1246 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[13 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1247_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1247 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[12 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1248_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1248 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[11 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1249_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1249 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[11 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1250_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1250 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[12 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1251_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1251 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[11 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1252_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1252 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[10 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1253_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1253 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[10 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1254_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1254 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[11 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1255_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1255 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[10 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1256_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1256 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[9 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1257_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1257 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[9 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1258_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1258 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[10 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1259_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1259 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[9 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1260_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1260 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[8 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1261_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1261 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[8 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1262_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1262 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[9 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1263_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1263 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[8 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1264_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1264 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[7 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1265_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1265 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[7 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1266_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1266 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[8 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1267_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1267 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[7 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1268_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1268 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[6 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1269_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1269 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[6 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1270_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1270 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[7 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1271_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1271 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[6 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1272_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1272 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[5 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1273_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1273 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[5 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1274_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1274 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[6 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1275_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1275 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[5 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1276_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1276 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[4 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1277_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1277 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[4 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1278_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1278 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[5 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1279_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1279 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[4 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1280_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1280 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[3 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1281_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1281 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[3 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1282_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1282 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[4 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1283_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1283 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[3 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1284_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1284 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[2 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1285_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1285 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[2 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1286_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1286 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[3 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1287_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1287 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[2 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1288_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1288 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[1 + 16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1289_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1289 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[1 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1290_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1290 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[2 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1291_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1291 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[1 + 16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1292_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1292 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[16stg1_1, -14 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_merged_banks_4.peek_165();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1293_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1293 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1294_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1294 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[1 + 16stg1_1, -13 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_merged_banks_4.peek_83();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030;
  return 0;
}

inline hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1295_select(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg0_FIFO_buf68_stg1_1_merged1799_1295 read pattern: { stg1_1_merged1799[root = 0, stg1_0, stg1_1] -> stg0_FIFO_buf68[16stg1_1, -12 + stg1_0] : 0 <= stg1_0 <= 1945 and 0 <= stg1_1 <= 80 }
  // Read schedule : { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
  auto value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031 = stg0_FIFO_buf68.stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_merged_banks_4.peek_1();
  return value_stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031;
  return 0;
}

// # of bundles = 2
// stg0_to_gp_84_ld69_merged1782_write
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030
//	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031
inline void stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_write_bundle_write(hw_uint<256>& stg0_to_gp_84_ld69_merged1782_write, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg0_to_gp_84_ld70, int stg0_to_gp_84_ld69, int dynamic_address) {
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_res = stg0_to_gp_84_ld69_merged1782_write.extract<0, 15>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2016_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_res = stg0_to_gp_84_ld69_merged1782_write.extract<16, 31>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2017_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_res = stg0_to_gp_84_ld69_merged1782_write.extract<32, 47>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2018_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_res = stg0_to_gp_84_ld69_merged1782_write.extract<48, 63>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2019_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_res = stg0_to_gp_84_ld69_merged1782_write.extract<64, 79>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2020_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_res = stg0_to_gp_84_ld69_merged1782_write.extract<80, 95>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2021_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_res = stg0_to_gp_84_ld69_merged1782_write.extract<96, 111>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2022_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_res = stg0_to_gp_84_ld69_merged1782_write.extract<112, 127>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2023_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_res = stg0_to_gp_84_ld69_merged1782_write.extract<128, 143>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2024_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_res = stg0_to_gp_84_ld69_merged1782_write.extract<144, 159>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2025_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_res = stg0_to_gp_84_ld69_merged1782_write.extract<160, 175>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2026_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_res = stg0_to_gp_84_ld69_merged1782_write.extract<176, 191>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2027_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_res = stg0_to_gp_84_ld69_merged1782_write.extract<192, 207>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2028_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_res = stg0_to_gp_84_ld69_merged1782_write.extract<208, 223>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2029_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_res = stg0_to_gp_84_ld69_merged1782_write.extract<224, 239>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2030_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
	hw_uint<16> stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_res = stg0_to_gp_84_ld69_merged1782_write.extract<240, 255>();
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_write(stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_2031_res, stg0_FIFO_buf68, root, stg0_to_gp_84_ld70, stg0_to_gp_84_ld69, dynamic_address);
}

// stg1_1_merged1799_read
//	stg0_FIFO_buf68_stg1_1_merged1799_1232
//	stg0_FIFO_buf68_stg1_1_merged1799_1233
//	stg0_FIFO_buf68_stg1_1_merged1799_1234
//	stg0_FIFO_buf68_stg1_1_merged1799_1235
//	stg0_FIFO_buf68_stg1_1_merged1799_1236
//	stg0_FIFO_buf68_stg1_1_merged1799_1237
//	stg0_FIFO_buf68_stg1_1_merged1799_1238
//	stg0_FIFO_buf68_stg1_1_merged1799_1239
//	stg0_FIFO_buf68_stg1_1_merged1799_1240
//	stg0_FIFO_buf68_stg1_1_merged1799_1241
//	stg0_FIFO_buf68_stg1_1_merged1799_1242
//	stg0_FIFO_buf68_stg1_1_merged1799_1243
//	stg0_FIFO_buf68_stg1_1_merged1799_1244
//	stg0_FIFO_buf68_stg1_1_merged1799_1245
//	stg0_FIFO_buf68_stg1_1_merged1799_1246
//	stg0_FIFO_buf68_stg1_1_merged1799_1247
//	stg0_FIFO_buf68_stg1_1_merged1799_1248
//	stg0_FIFO_buf68_stg1_1_merged1799_1249
//	stg0_FIFO_buf68_stg1_1_merged1799_1250
//	stg0_FIFO_buf68_stg1_1_merged1799_1251
//	stg0_FIFO_buf68_stg1_1_merged1799_1252
//	stg0_FIFO_buf68_stg1_1_merged1799_1253
//	stg0_FIFO_buf68_stg1_1_merged1799_1254
//	stg0_FIFO_buf68_stg1_1_merged1799_1255
//	stg0_FIFO_buf68_stg1_1_merged1799_1256
//	stg0_FIFO_buf68_stg1_1_merged1799_1257
//	stg0_FIFO_buf68_stg1_1_merged1799_1258
//	stg0_FIFO_buf68_stg1_1_merged1799_1259
//	stg0_FIFO_buf68_stg1_1_merged1799_1260
//	stg0_FIFO_buf68_stg1_1_merged1799_1261
//	stg0_FIFO_buf68_stg1_1_merged1799_1262
//	stg0_FIFO_buf68_stg1_1_merged1799_1263
//	stg0_FIFO_buf68_stg1_1_merged1799_1264
//	stg0_FIFO_buf68_stg1_1_merged1799_1265
//	stg0_FIFO_buf68_stg1_1_merged1799_1266
//	stg0_FIFO_buf68_stg1_1_merged1799_1267
//	stg0_FIFO_buf68_stg1_1_merged1799_1268
//	stg0_FIFO_buf68_stg1_1_merged1799_1269
//	stg0_FIFO_buf68_stg1_1_merged1799_1270
//	stg0_FIFO_buf68_stg1_1_merged1799_1271
//	stg0_FIFO_buf68_stg1_1_merged1799_1272
//	stg0_FIFO_buf68_stg1_1_merged1799_1273
//	stg0_FIFO_buf68_stg1_1_merged1799_1274
//	stg0_FIFO_buf68_stg1_1_merged1799_1275
//	stg0_FIFO_buf68_stg1_1_merged1799_1276
//	stg0_FIFO_buf68_stg1_1_merged1799_1277
//	stg0_FIFO_buf68_stg1_1_merged1799_1278
//	stg0_FIFO_buf68_stg1_1_merged1799_1279
//	stg0_FIFO_buf68_stg1_1_merged1799_1280
//	stg0_FIFO_buf68_stg1_1_merged1799_1281
//	stg0_FIFO_buf68_stg1_1_merged1799_1282
//	stg0_FIFO_buf68_stg1_1_merged1799_1283
//	stg0_FIFO_buf68_stg1_1_merged1799_1284
//	stg0_FIFO_buf68_stg1_1_merged1799_1285
//	stg0_FIFO_buf68_stg1_1_merged1799_1286
//	stg0_FIFO_buf68_stg1_1_merged1799_1287
//	stg0_FIFO_buf68_stg1_1_merged1799_1288
//	stg0_FIFO_buf68_stg1_1_merged1799_1289
//	stg0_FIFO_buf68_stg1_1_merged1799_1290
//	stg0_FIFO_buf68_stg1_1_merged1799_1291
//	stg0_FIFO_buf68_stg1_1_merged1799_1292
//	stg0_FIFO_buf68_stg1_1_merged1799_1293
//	stg0_FIFO_buf68_stg1_1_merged1799_1294
//	stg0_FIFO_buf68_stg1_1_merged1799_1295
inline hw_uint<1024> stg0_FIFO_buf68_stg1_1_merged1799_read_bundle_read(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int root, int stg1_0, int stg1_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg0_FIFO_buf68_stg1_1_merged1799_1232
    // stg0_FIFO_buf68_stg1_1_merged1799_1233
    // stg0_FIFO_buf68_stg1_1_merged1799_1234
    // stg0_FIFO_buf68_stg1_1_merged1799_1235
    // stg0_FIFO_buf68_stg1_1_merged1799_1236
    // stg0_FIFO_buf68_stg1_1_merged1799_1237
    // stg0_FIFO_buf68_stg1_1_merged1799_1238
    // stg0_FIFO_buf68_stg1_1_merged1799_1239
    // stg0_FIFO_buf68_stg1_1_merged1799_1240
    // stg0_FIFO_buf68_stg1_1_merged1799_1241
    // stg0_FIFO_buf68_stg1_1_merged1799_1242
    // stg0_FIFO_buf68_stg1_1_merged1799_1243
    // stg0_FIFO_buf68_stg1_1_merged1799_1244
    // stg0_FIFO_buf68_stg1_1_merged1799_1245
    // stg0_FIFO_buf68_stg1_1_merged1799_1246
    // stg0_FIFO_buf68_stg1_1_merged1799_1247
    // stg0_FIFO_buf68_stg1_1_merged1799_1248
    // stg0_FIFO_buf68_stg1_1_merged1799_1249
    // stg0_FIFO_buf68_stg1_1_merged1799_1250
    // stg0_FIFO_buf68_stg1_1_merged1799_1251
    // stg0_FIFO_buf68_stg1_1_merged1799_1252
    // stg0_FIFO_buf68_stg1_1_merged1799_1253
    // stg0_FIFO_buf68_stg1_1_merged1799_1254
    // stg0_FIFO_buf68_stg1_1_merged1799_1255
    // stg0_FIFO_buf68_stg1_1_merged1799_1256
    // stg0_FIFO_buf68_stg1_1_merged1799_1257
    // stg0_FIFO_buf68_stg1_1_merged1799_1258
    // stg0_FIFO_buf68_stg1_1_merged1799_1259
    // stg0_FIFO_buf68_stg1_1_merged1799_1260
    // stg0_FIFO_buf68_stg1_1_merged1799_1261
    // stg0_FIFO_buf68_stg1_1_merged1799_1262
    // stg0_FIFO_buf68_stg1_1_merged1799_1263
    // stg0_FIFO_buf68_stg1_1_merged1799_1264
    // stg0_FIFO_buf68_stg1_1_merged1799_1265
    // stg0_FIFO_buf68_stg1_1_merged1799_1266
    // stg0_FIFO_buf68_stg1_1_merged1799_1267
    // stg0_FIFO_buf68_stg1_1_merged1799_1268
    // stg0_FIFO_buf68_stg1_1_merged1799_1269
    // stg0_FIFO_buf68_stg1_1_merged1799_1270
    // stg0_FIFO_buf68_stg1_1_merged1799_1271
    // stg0_FIFO_buf68_stg1_1_merged1799_1272
    // stg0_FIFO_buf68_stg1_1_merged1799_1273
    // stg0_FIFO_buf68_stg1_1_merged1799_1274
    // stg0_FIFO_buf68_stg1_1_merged1799_1275
    // stg0_FIFO_buf68_stg1_1_merged1799_1276
    // stg0_FIFO_buf68_stg1_1_merged1799_1277
    // stg0_FIFO_buf68_stg1_1_merged1799_1278
    // stg0_FIFO_buf68_stg1_1_merged1799_1279
    // stg0_FIFO_buf68_stg1_1_merged1799_1280
    // stg0_FIFO_buf68_stg1_1_merged1799_1281
    // stg0_FIFO_buf68_stg1_1_merged1799_1282
    // stg0_FIFO_buf68_stg1_1_merged1799_1283
    // stg0_FIFO_buf68_stg1_1_merged1799_1284
    // stg0_FIFO_buf68_stg1_1_merged1799_1285
    // stg0_FIFO_buf68_stg1_1_merged1799_1286
    // stg0_FIFO_buf68_stg1_1_merged1799_1287
    // stg0_FIFO_buf68_stg1_1_merged1799_1288
    // stg0_FIFO_buf68_stg1_1_merged1799_1289
    // stg0_FIFO_buf68_stg1_1_merged1799_1290
    // stg0_FIFO_buf68_stg1_1_merged1799_1291
    // stg0_FIFO_buf68_stg1_1_merged1799_1292
    // stg0_FIFO_buf68_stg1_1_merged1799_1293
    // stg0_FIFO_buf68_stg1_1_merged1799_1294
    // stg0_FIFO_buf68_stg1_1_merged1799_1295

	hw_uint<1024> result;
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1232_res = stg0_FIFO_buf68_stg1_1_merged1799_1232_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<0, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1232_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1233_res = stg0_FIFO_buf68_stg1_1_merged1799_1233_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<16, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1233_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1234_res = stg0_FIFO_buf68_stg1_1_merged1799_1234_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<32, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1234_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1235_res = stg0_FIFO_buf68_stg1_1_merged1799_1235_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<48, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1235_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1236_res = stg0_FIFO_buf68_stg1_1_merged1799_1236_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<64, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1236_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1237_res = stg0_FIFO_buf68_stg1_1_merged1799_1237_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<80, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1237_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1238_res = stg0_FIFO_buf68_stg1_1_merged1799_1238_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<96, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1238_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1239_res = stg0_FIFO_buf68_stg1_1_merged1799_1239_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<112, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1239_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1240_res = stg0_FIFO_buf68_stg1_1_merged1799_1240_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<128, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1240_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1241_res = stg0_FIFO_buf68_stg1_1_merged1799_1241_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<144, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1241_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1242_res = stg0_FIFO_buf68_stg1_1_merged1799_1242_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<160, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1242_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1243_res = stg0_FIFO_buf68_stg1_1_merged1799_1243_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<176, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1243_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1244_res = stg0_FIFO_buf68_stg1_1_merged1799_1244_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<192, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1244_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1245_res = stg0_FIFO_buf68_stg1_1_merged1799_1245_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<208, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1245_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1246_res = stg0_FIFO_buf68_stg1_1_merged1799_1246_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<224, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1246_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1247_res = stg0_FIFO_buf68_stg1_1_merged1799_1247_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<240, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1247_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1248_res = stg0_FIFO_buf68_stg1_1_merged1799_1248_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<256, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1248_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1249_res = stg0_FIFO_buf68_stg1_1_merged1799_1249_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<272, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1249_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1250_res = stg0_FIFO_buf68_stg1_1_merged1799_1250_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<288, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1250_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1251_res = stg0_FIFO_buf68_stg1_1_merged1799_1251_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<304, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1251_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1252_res = stg0_FIFO_buf68_stg1_1_merged1799_1252_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<320, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1252_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1253_res = stg0_FIFO_buf68_stg1_1_merged1799_1253_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<336, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1253_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1254_res = stg0_FIFO_buf68_stg1_1_merged1799_1254_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<352, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1254_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1255_res = stg0_FIFO_buf68_stg1_1_merged1799_1255_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<368, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1255_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1256_res = stg0_FIFO_buf68_stg1_1_merged1799_1256_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<384, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1256_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1257_res = stg0_FIFO_buf68_stg1_1_merged1799_1257_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<400, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1257_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1258_res = stg0_FIFO_buf68_stg1_1_merged1799_1258_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<416, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1258_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1259_res = stg0_FIFO_buf68_stg1_1_merged1799_1259_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<432, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1259_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1260_res = stg0_FIFO_buf68_stg1_1_merged1799_1260_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<448, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1260_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1261_res = stg0_FIFO_buf68_stg1_1_merged1799_1261_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<464, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1261_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1262_res = stg0_FIFO_buf68_stg1_1_merged1799_1262_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<480, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1262_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1263_res = stg0_FIFO_buf68_stg1_1_merged1799_1263_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<496, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1263_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1264_res = stg0_FIFO_buf68_stg1_1_merged1799_1264_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<512, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1264_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1265_res = stg0_FIFO_buf68_stg1_1_merged1799_1265_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<528, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1265_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1266_res = stg0_FIFO_buf68_stg1_1_merged1799_1266_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<544, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1266_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1267_res = stg0_FIFO_buf68_stg1_1_merged1799_1267_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<560, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1267_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1268_res = stg0_FIFO_buf68_stg1_1_merged1799_1268_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<576, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1268_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1269_res = stg0_FIFO_buf68_stg1_1_merged1799_1269_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<592, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1269_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1270_res = stg0_FIFO_buf68_stg1_1_merged1799_1270_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<608, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1270_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1271_res = stg0_FIFO_buf68_stg1_1_merged1799_1271_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<624, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1271_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1272_res = stg0_FIFO_buf68_stg1_1_merged1799_1272_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<640, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1272_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1273_res = stg0_FIFO_buf68_stg1_1_merged1799_1273_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<656, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1273_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1274_res = stg0_FIFO_buf68_stg1_1_merged1799_1274_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<672, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1274_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1275_res = stg0_FIFO_buf68_stg1_1_merged1799_1275_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<688, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1275_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1276_res = stg0_FIFO_buf68_stg1_1_merged1799_1276_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<704, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1276_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1277_res = stg0_FIFO_buf68_stg1_1_merged1799_1277_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<720, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1277_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1278_res = stg0_FIFO_buf68_stg1_1_merged1799_1278_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<736, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1278_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1279_res = stg0_FIFO_buf68_stg1_1_merged1799_1279_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<752, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1279_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1280_res = stg0_FIFO_buf68_stg1_1_merged1799_1280_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<768, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1280_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1281_res = stg0_FIFO_buf68_stg1_1_merged1799_1281_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<784, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1281_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1282_res = stg0_FIFO_buf68_stg1_1_merged1799_1282_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<800, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1282_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1283_res = stg0_FIFO_buf68_stg1_1_merged1799_1283_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<816, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1283_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1284_res = stg0_FIFO_buf68_stg1_1_merged1799_1284_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<832, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1284_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1285_res = stg0_FIFO_buf68_stg1_1_merged1799_1285_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<848, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1285_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1286_res = stg0_FIFO_buf68_stg1_1_merged1799_1286_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<864, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1286_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1287_res = stg0_FIFO_buf68_stg1_1_merged1799_1287_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<880, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1287_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1288_res = stg0_FIFO_buf68_stg1_1_merged1799_1288_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<896, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1288_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1289_res = stg0_FIFO_buf68_stg1_1_merged1799_1289_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<912, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1289_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1290_res = stg0_FIFO_buf68_stg1_1_merged1799_1290_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<928, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1290_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1291_res = stg0_FIFO_buf68_stg1_1_merged1799_1291_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<944, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1291_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1292_res = stg0_FIFO_buf68_stg1_1_merged1799_1292_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<960, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1292_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1293_res = stg0_FIFO_buf68_stg1_1_merged1799_1293_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<976, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1293_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1294_res = stg0_FIFO_buf68_stg1_1_merged1799_1294_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<992, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1294_res);
	hw_uint<16> stg0_FIFO_buf68_stg1_1_merged1799_1295_res = stg0_FIFO_buf68_stg1_1_merged1799_1295_select(stg0_FIFO_buf68, root, stg1_0, stg1_1, dynamic_address);
	set_at<1008, 1024>(result, stg0_FIFO_buf68_stg1_1_merged1799_1295_res);
	return result;
}

struct stg1_stg1_1_merged1799_1216_to_stg1_stg1_ld9_merged1843_1200_cache {
	// RAM Box: {[15, 1295], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1217_to_stg1_stg1_ld9_merged1843_1201_cache {
	// RAM Box: {[14, 1294], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1218_to_stg1_stg1_ld9_merged1843_1202_cache {
	// RAM Box: {[13, 1293], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1219_to_stg1_stg1_ld9_merged1843_1203_cache {
	// RAM Box: {[12, 1292], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1220_to_stg1_stg1_ld9_merged1843_1204_cache {
	// RAM Box: {[11, 1291], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1221_to_stg1_stg1_ld9_merged1843_1205_cache {
	// RAM Box: {[10, 1290], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1222_to_stg1_stg1_ld9_merged1843_1206_cache {
	// RAM Box: {[9, 1289], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1223_to_stg1_stg1_ld9_merged1843_1207_cache {
	// RAM Box: {[8, 1288], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1224_to_stg1_stg1_ld9_merged1843_1208_cache {
	// RAM Box: {[7, 1287], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1225_to_stg1_stg1_ld9_merged1843_1209_cache {
	// RAM Box: {[6, 1286], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1226_to_stg1_stg1_ld9_merged1843_1210_cache {
	// RAM Box: {[5, 1285], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1227_to_stg1_stg1_ld9_merged1843_1211_cache {
	// RAM Box: {[4, 1284], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1228_to_stg1_stg1_ld9_merged1843_1212_cache {
	// RAM Box: {[3, 1283], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1229_to_stg1_stg1_ld9_merged1843_1213_cache {
	// RAM Box: {[2, 1282], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1230_to_stg1_stg1_ld9_merged1843_1214_cache {
	// RAM Box: {[1, 1281], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_stg1_1_merged1799_1231_to_stg1_stg1_ld9_merged1843_1215_cache {
	// RAM Box: {[0, 1280], [-13, 1932]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg1_cache {
  // Reader addrs...
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[15 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[14 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[13 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[12 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[11 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[10 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[9 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[8 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[7 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[6 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[5 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[4 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[3 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[2 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[1 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
    // { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // # of banks: 16
  stg1_stg1_1_merged1799_1216_to_stg1_stg1_ld9_merged1843_1200_cache stg1_stg1_1_merged1799_1216_to_stg1_stg1_ld9_merged1843_1200;
  stg1_stg1_1_merged1799_1217_to_stg1_stg1_ld9_merged1843_1201_cache stg1_stg1_1_merged1799_1217_to_stg1_stg1_ld9_merged1843_1201;
  stg1_stg1_1_merged1799_1218_to_stg1_stg1_ld9_merged1843_1202_cache stg1_stg1_1_merged1799_1218_to_stg1_stg1_ld9_merged1843_1202;
  stg1_stg1_1_merged1799_1219_to_stg1_stg1_ld9_merged1843_1203_cache stg1_stg1_1_merged1799_1219_to_stg1_stg1_ld9_merged1843_1203;
  stg1_stg1_1_merged1799_1220_to_stg1_stg1_ld9_merged1843_1204_cache stg1_stg1_1_merged1799_1220_to_stg1_stg1_ld9_merged1843_1204;
  stg1_stg1_1_merged1799_1221_to_stg1_stg1_ld9_merged1843_1205_cache stg1_stg1_1_merged1799_1221_to_stg1_stg1_ld9_merged1843_1205;
  stg1_stg1_1_merged1799_1222_to_stg1_stg1_ld9_merged1843_1206_cache stg1_stg1_1_merged1799_1222_to_stg1_stg1_ld9_merged1843_1206;
  stg1_stg1_1_merged1799_1223_to_stg1_stg1_ld9_merged1843_1207_cache stg1_stg1_1_merged1799_1223_to_stg1_stg1_ld9_merged1843_1207;
  stg1_stg1_1_merged1799_1224_to_stg1_stg1_ld9_merged1843_1208_cache stg1_stg1_1_merged1799_1224_to_stg1_stg1_ld9_merged1843_1208;
  stg1_stg1_1_merged1799_1225_to_stg1_stg1_ld9_merged1843_1209_cache stg1_stg1_1_merged1799_1225_to_stg1_stg1_ld9_merged1843_1209;
  stg1_stg1_1_merged1799_1226_to_stg1_stg1_ld9_merged1843_1210_cache stg1_stg1_1_merged1799_1226_to_stg1_stg1_ld9_merged1843_1210;
  stg1_stg1_1_merged1799_1227_to_stg1_stg1_ld9_merged1843_1211_cache stg1_stg1_1_merged1799_1227_to_stg1_stg1_ld9_merged1843_1211;
  stg1_stg1_1_merged1799_1228_to_stg1_stg1_ld9_merged1843_1212_cache stg1_stg1_1_merged1799_1228_to_stg1_stg1_ld9_merged1843_1212;
  stg1_stg1_1_merged1799_1229_to_stg1_stg1_ld9_merged1843_1213_cache stg1_stg1_1_merged1799_1229_to_stg1_stg1_ld9_merged1843_1213;
  stg1_stg1_1_merged1799_1230_to_stg1_stg1_ld9_merged1843_1214_cache stg1_stg1_1_merged1799_1230_to_stg1_stg1_ld9_merged1843_1214;
  stg1_stg1_1_merged1799_1231_to_stg1_stg1_ld9_merged1843_1215_cache stg1_stg1_1_merged1799_1231_to_stg1_stg1_ld9_merged1843_1215;
};



inline void stg1_stg1_1_merged1799_1216_write(hw_uint<16>& stg1_stg1_1_merged1799_1216, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1216_to_stg1_stg1_ld9_merged1843_1200.push(stg1_stg1_1_merged1799_1216);
}

inline void stg1_stg1_1_merged1799_1217_write(hw_uint<16>& stg1_stg1_1_merged1799_1217, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1217_to_stg1_stg1_ld9_merged1843_1201.push(stg1_stg1_1_merged1799_1217);
}

inline void stg1_stg1_1_merged1799_1218_write(hw_uint<16>& stg1_stg1_1_merged1799_1218, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1218_to_stg1_stg1_ld9_merged1843_1202.push(stg1_stg1_1_merged1799_1218);
}

inline void stg1_stg1_1_merged1799_1219_write(hw_uint<16>& stg1_stg1_1_merged1799_1219, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1219_to_stg1_stg1_ld9_merged1843_1203.push(stg1_stg1_1_merged1799_1219);
}

inline void stg1_stg1_1_merged1799_1220_write(hw_uint<16>& stg1_stg1_1_merged1799_1220, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1220_to_stg1_stg1_ld9_merged1843_1204.push(stg1_stg1_1_merged1799_1220);
}

inline void stg1_stg1_1_merged1799_1221_write(hw_uint<16>& stg1_stg1_1_merged1799_1221, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1221_to_stg1_stg1_ld9_merged1843_1205.push(stg1_stg1_1_merged1799_1221);
}

inline void stg1_stg1_1_merged1799_1222_write(hw_uint<16>& stg1_stg1_1_merged1799_1222, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1222_to_stg1_stg1_ld9_merged1843_1206.push(stg1_stg1_1_merged1799_1222);
}

inline void stg1_stg1_1_merged1799_1223_write(hw_uint<16>& stg1_stg1_1_merged1799_1223, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1223_to_stg1_stg1_ld9_merged1843_1207.push(stg1_stg1_1_merged1799_1223);
}

inline void stg1_stg1_1_merged1799_1224_write(hw_uint<16>& stg1_stg1_1_merged1799_1224, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1224_to_stg1_stg1_ld9_merged1843_1208.push(stg1_stg1_1_merged1799_1224);
}

inline void stg1_stg1_1_merged1799_1225_write(hw_uint<16>& stg1_stg1_1_merged1799_1225, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1225_to_stg1_stg1_ld9_merged1843_1209.push(stg1_stg1_1_merged1799_1225);
}

inline void stg1_stg1_1_merged1799_1226_write(hw_uint<16>& stg1_stg1_1_merged1799_1226, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1226_to_stg1_stg1_ld9_merged1843_1210.push(stg1_stg1_1_merged1799_1226);
}

inline void stg1_stg1_1_merged1799_1227_write(hw_uint<16>& stg1_stg1_1_merged1799_1227, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1227_to_stg1_stg1_ld9_merged1843_1211.push(stg1_stg1_1_merged1799_1227);
}

inline void stg1_stg1_1_merged1799_1228_write(hw_uint<16>& stg1_stg1_1_merged1799_1228, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1228_to_stg1_stg1_ld9_merged1843_1212.push(stg1_stg1_1_merged1799_1228);
}

inline void stg1_stg1_1_merged1799_1229_write(hw_uint<16>& stg1_stg1_1_merged1799_1229, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1229_to_stg1_stg1_ld9_merged1843_1213.push(stg1_stg1_1_merged1799_1229);
}

inline void stg1_stg1_1_merged1799_1230_write(hw_uint<16>& stg1_stg1_1_merged1799_1230, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1230_to_stg1_stg1_ld9_merged1843_1214.push(stg1_stg1_1_merged1799_1230);
}

inline void stg1_stg1_1_merged1799_1231_write(hw_uint<16>& stg1_stg1_1_merged1799_1231, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
  stg1.stg1_stg1_1_merged1799_1231_to_stg1_stg1_ld9_merged1843_1215.push(stg1_stg1_1_merged1799_1231);
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1200_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1200 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[15 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1216 = stg1.stg1_stg1_1_merged1799_1216_to_stg1_stg1_ld9_merged1843_1200.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1216;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1201_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1201 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[14 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1217 = stg1.stg1_stg1_1_merged1799_1217_to_stg1_stg1_ld9_merged1843_1201.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1217;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1202_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1202 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[13 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1218 = stg1.stg1_stg1_1_merged1799_1218_to_stg1_stg1_ld9_merged1843_1202.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1218;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1203_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1203 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[12 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1219 = stg1.stg1_stg1_1_merged1799_1219_to_stg1_stg1_ld9_merged1843_1203.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1219;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1204_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1204 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[11 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1220 = stg1.stg1_stg1_1_merged1799_1220_to_stg1_stg1_ld9_merged1843_1204.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1220;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1205_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1205 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[10 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1221 = stg1.stg1_stg1_1_merged1799_1221_to_stg1_stg1_ld9_merged1843_1205.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1221;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1206_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1206 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[9 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1222 = stg1.stg1_stg1_1_merged1799_1222_to_stg1_stg1_ld9_merged1843_1206.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1222;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1207_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1207 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[8 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1223 = stg1.stg1_stg1_1_merged1799_1223_to_stg1_stg1_ld9_merged1843_1207.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1223;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1208_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1208 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[7 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1224 = stg1.stg1_stg1_1_merged1799_1224_to_stg1_stg1_ld9_merged1843_1208.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1224;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1209_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1209 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[6 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1225 = stg1.stg1_stg1_1_merged1799_1225_to_stg1_stg1_ld9_merged1843_1209.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1225;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1210_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1210 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[5 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1226 = stg1.stg1_stg1_1_merged1799_1226_to_stg1_stg1_ld9_merged1843_1210.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1226;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1211_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1211 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[4 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1227 = stg1.stg1_stg1_1_merged1799_1227_to_stg1_stg1_ld9_merged1843_1211.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1227;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1212_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1212 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[3 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1228 = stg1.stg1_stg1_1_merged1799_1228_to_stg1_stg1_ld9_merged1843_1212.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1228;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1213_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1213 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[2 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1229 = stg1.stg1_stg1_1_merged1799_1229_to_stg1_stg1_ld9_merged1843_1213.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1229;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1214_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1214 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[1 + 16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1230 = stg1.stg1_stg1_1_merged1799_1230_to_stg1_stg1_ld9_merged1843_1214.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1230;
  return 0;
}

inline hw_uint<16> stg1_stg1_ld9_merged1843_1215_select(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_stg1_ld9_merged1843_1215 read pattern: { stg1_ld9_merged1843[root = 0, stg1_ld10, stg1_ld9] -> stg1[16stg1_ld9, -13 + stg1_ld10] : 0 <= stg1_ld10 <= 1945 and 0 <= stg1_ld9 <= 80 }
  // Read schedule : { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  // Write schedule: { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_stg1_1_merged1799_1231 = stg1.stg1_stg1_1_merged1799_1231_to_stg1_stg1_ld9_merged1843_1215.peek(/* one reader or all rams */ 0);
  return value_stg1_stg1_1_merged1799_1231;
  return 0;
}

// # of bundles = 2
// stg1_1_merged1799_write
//	stg1_stg1_1_merged1799_1216
//	stg1_stg1_1_merged1799_1217
//	stg1_stg1_1_merged1799_1218
//	stg1_stg1_1_merged1799_1219
//	stg1_stg1_1_merged1799_1220
//	stg1_stg1_1_merged1799_1221
//	stg1_stg1_1_merged1799_1222
//	stg1_stg1_1_merged1799_1223
//	stg1_stg1_1_merged1799_1224
//	stg1_stg1_1_merged1799_1225
//	stg1_stg1_1_merged1799_1226
//	stg1_stg1_1_merged1799_1227
//	stg1_stg1_1_merged1799_1228
//	stg1_stg1_1_merged1799_1229
//	stg1_stg1_1_merged1799_1230
//	stg1_stg1_1_merged1799_1231
inline void stg1_stg1_1_merged1799_write_bundle_write(hw_uint<256>& stg1_1_merged1799_write, stg1_cache& stg1, int root, int stg1_0, int stg1_1, int dynamic_address) {
	hw_uint<16> stg1_stg1_1_merged1799_1216_res = stg1_1_merged1799_write.extract<0, 15>();
	stg1_stg1_1_merged1799_1216_write(stg1_stg1_1_merged1799_1216_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1217_res = stg1_1_merged1799_write.extract<16, 31>();
	stg1_stg1_1_merged1799_1217_write(stg1_stg1_1_merged1799_1217_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1218_res = stg1_1_merged1799_write.extract<32, 47>();
	stg1_stg1_1_merged1799_1218_write(stg1_stg1_1_merged1799_1218_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1219_res = stg1_1_merged1799_write.extract<48, 63>();
	stg1_stg1_1_merged1799_1219_write(stg1_stg1_1_merged1799_1219_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1220_res = stg1_1_merged1799_write.extract<64, 79>();
	stg1_stg1_1_merged1799_1220_write(stg1_stg1_1_merged1799_1220_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1221_res = stg1_1_merged1799_write.extract<80, 95>();
	stg1_stg1_1_merged1799_1221_write(stg1_stg1_1_merged1799_1221_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1222_res = stg1_1_merged1799_write.extract<96, 111>();
	stg1_stg1_1_merged1799_1222_write(stg1_stg1_1_merged1799_1222_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1223_res = stg1_1_merged1799_write.extract<112, 127>();
	stg1_stg1_1_merged1799_1223_write(stg1_stg1_1_merged1799_1223_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1224_res = stg1_1_merged1799_write.extract<128, 143>();
	stg1_stg1_1_merged1799_1224_write(stg1_stg1_1_merged1799_1224_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1225_res = stg1_1_merged1799_write.extract<144, 159>();
	stg1_stg1_1_merged1799_1225_write(stg1_stg1_1_merged1799_1225_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1226_res = stg1_1_merged1799_write.extract<160, 175>();
	stg1_stg1_1_merged1799_1226_write(stg1_stg1_1_merged1799_1226_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1227_res = stg1_1_merged1799_write.extract<176, 191>();
	stg1_stg1_1_merged1799_1227_write(stg1_stg1_1_merged1799_1227_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1228_res = stg1_1_merged1799_write.extract<192, 207>();
	stg1_stg1_1_merged1799_1228_write(stg1_stg1_1_merged1799_1228_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1229_res = stg1_1_merged1799_write.extract<208, 223>();
	stg1_stg1_1_merged1799_1229_write(stg1_stg1_1_merged1799_1229_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1230_res = stg1_1_merged1799_write.extract<224, 239>();
	stg1_stg1_1_merged1799_1230_write(stg1_stg1_1_merged1799_1230_res, stg1, root, stg1_0, stg1_1, dynamic_address);
	hw_uint<16> stg1_stg1_1_merged1799_1231_res = stg1_1_merged1799_write.extract<240, 255>();
	stg1_stg1_1_merged1799_1231_write(stg1_stg1_1_merged1799_1231_res, stg1, root, stg1_0, stg1_1, dynamic_address);
}

// stg1_ld9_merged1843_read
//	stg1_stg1_ld9_merged1843_1200
//	stg1_stg1_ld9_merged1843_1201
//	stg1_stg1_ld9_merged1843_1202
//	stg1_stg1_ld9_merged1843_1203
//	stg1_stg1_ld9_merged1843_1204
//	stg1_stg1_ld9_merged1843_1205
//	stg1_stg1_ld9_merged1843_1206
//	stg1_stg1_ld9_merged1843_1207
//	stg1_stg1_ld9_merged1843_1208
//	stg1_stg1_ld9_merged1843_1209
//	stg1_stg1_ld9_merged1843_1210
//	stg1_stg1_ld9_merged1843_1211
//	stg1_stg1_ld9_merged1843_1212
//	stg1_stg1_ld9_merged1843_1213
//	stg1_stg1_ld9_merged1843_1214
//	stg1_stg1_ld9_merged1843_1215
inline hw_uint<256> stg1_stg1_ld9_merged1843_read_bundle_read(stg1_cache& stg1, int root, int stg1_ld10, int stg1_ld9, int dynamic_address) {
  // # of ports in bundle: 16
    // stg1_stg1_ld9_merged1843_1200
    // stg1_stg1_ld9_merged1843_1201
    // stg1_stg1_ld9_merged1843_1202
    // stg1_stg1_ld9_merged1843_1203
    // stg1_stg1_ld9_merged1843_1204
    // stg1_stg1_ld9_merged1843_1205
    // stg1_stg1_ld9_merged1843_1206
    // stg1_stg1_ld9_merged1843_1207
    // stg1_stg1_ld9_merged1843_1208
    // stg1_stg1_ld9_merged1843_1209
    // stg1_stg1_ld9_merged1843_1210
    // stg1_stg1_ld9_merged1843_1211
    // stg1_stg1_ld9_merged1843_1212
    // stg1_stg1_ld9_merged1843_1213
    // stg1_stg1_ld9_merged1843_1214
    // stg1_stg1_ld9_merged1843_1215

	hw_uint<256> result;
	hw_uint<16> stg1_stg1_ld9_merged1843_1200_res = stg1_stg1_ld9_merged1843_1200_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<0, 256>(result, stg1_stg1_ld9_merged1843_1200_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1201_res = stg1_stg1_ld9_merged1843_1201_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<16, 256>(result, stg1_stg1_ld9_merged1843_1201_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1202_res = stg1_stg1_ld9_merged1843_1202_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<32, 256>(result, stg1_stg1_ld9_merged1843_1202_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1203_res = stg1_stg1_ld9_merged1843_1203_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<48, 256>(result, stg1_stg1_ld9_merged1843_1203_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1204_res = stg1_stg1_ld9_merged1843_1204_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<64, 256>(result, stg1_stg1_ld9_merged1843_1204_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1205_res = stg1_stg1_ld9_merged1843_1205_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<80, 256>(result, stg1_stg1_ld9_merged1843_1205_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1206_res = stg1_stg1_ld9_merged1843_1206_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<96, 256>(result, stg1_stg1_ld9_merged1843_1206_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1207_res = stg1_stg1_ld9_merged1843_1207_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<112, 256>(result, stg1_stg1_ld9_merged1843_1207_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1208_res = stg1_stg1_ld9_merged1843_1208_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<128, 256>(result, stg1_stg1_ld9_merged1843_1208_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1209_res = stg1_stg1_ld9_merged1843_1209_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<144, 256>(result, stg1_stg1_ld9_merged1843_1209_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1210_res = stg1_stg1_ld9_merged1843_1210_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<160, 256>(result, stg1_stg1_ld9_merged1843_1210_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1211_res = stg1_stg1_ld9_merged1843_1211_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<176, 256>(result, stg1_stg1_ld9_merged1843_1211_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1212_res = stg1_stg1_ld9_merged1843_1212_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<192, 256>(result, stg1_stg1_ld9_merged1843_1212_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1213_res = stg1_stg1_ld9_merged1843_1213_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<208, 256>(result, stg1_stg1_ld9_merged1843_1213_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1214_res = stg1_stg1_ld9_merged1843_1214_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<224, 256>(result, stg1_stg1_ld9_merged1843_1214_res);
	hw_uint<16> stg1_stg1_ld9_merged1843_1215_res = stg1_stg1_ld9_merged1843_1215_select(stg1, root, stg1_ld10, stg1_ld9, dynamic_address);
	set_at<240, 256>(result, stg1_stg1_ld9_merged1843_1215_res);
	return result;
}

struct stg10_stg10_1_merged1826_1936_to_stg10_stg10_ld13_merged1849_1920_cache {
	// RAM Box: {[15, 1151], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1937_to_stg10_stg10_ld13_merged1849_1921_cache {
	// RAM Box: {[14, 1150], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1938_to_stg10_stg10_ld13_merged1849_1922_cache {
	// RAM Box: {[13, 1149], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1939_to_stg10_stg10_ld13_merged1849_1923_cache {
	// RAM Box: {[12, 1148], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1940_to_stg10_stg10_ld13_merged1849_1924_cache {
	// RAM Box: {[11, 1147], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1941_to_stg10_stg10_ld13_merged1849_1925_cache {
	// RAM Box: {[10, 1146], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1942_to_stg10_stg10_ld13_merged1849_1926_cache {
	// RAM Box: {[9, 1145], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1943_to_stg10_stg10_ld13_merged1849_1927_cache {
	// RAM Box: {[8, 1144], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1944_to_stg10_stg10_ld13_merged1849_1928_cache {
	// RAM Box: {[7, 1143], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1945_to_stg10_stg10_ld13_merged1849_1929_cache {
	// RAM Box: {[6, 1142], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1946_to_stg10_stg10_ld13_merged1849_1930_cache {
	// RAM Box: {[5, 1141], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1947_to_stg10_stg10_ld13_merged1849_1931_cache {
	// RAM Box: {[4, 1140], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1948_to_stg10_stg10_ld13_merged1849_1932_cache {
	// RAM Box: {[3, 1139], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1949_to_stg10_stg10_ld13_merged1849_1933_cache {
	// RAM Box: {[2, 1138], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1950_to_stg10_stg10_ld13_merged1849_1934_cache {
	// RAM Box: {[1, 1137], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_stg10_1_merged1826_1951_to_stg10_stg10_ld13_merged1849_1935_cache {
	// RAM Box: {[0, 1136], [-4, 1923]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg10_cache {
  // Reader addrs...
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[15 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[14 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[13 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[12 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[11 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[10 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[9 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[8 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[7 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[6 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[5 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[4 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[3 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[2 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[1 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
    // { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // # of banks: 16
  stg10_stg10_1_merged1826_1936_to_stg10_stg10_ld13_merged1849_1920_cache stg10_stg10_1_merged1826_1936_to_stg10_stg10_ld13_merged1849_1920;
  stg10_stg10_1_merged1826_1937_to_stg10_stg10_ld13_merged1849_1921_cache stg10_stg10_1_merged1826_1937_to_stg10_stg10_ld13_merged1849_1921;
  stg10_stg10_1_merged1826_1938_to_stg10_stg10_ld13_merged1849_1922_cache stg10_stg10_1_merged1826_1938_to_stg10_stg10_ld13_merged1849_1922;
  stg10_stg10_1_merged1826_1939_to_stg10_stg10_ld13_merged1849_1923_cache stg10_stg10_1_merged1826_1939_to_stg10_stg10_ld13_merged1849_1923;
  stg10_stg10_1_merged1826_1940_to_stg10_stg10_ld13_merged1849_1924_cache stg10_stg10_1_merged1826_1940_to_stg10_stg10_ld13_merged1849_1924;
  stg10_stg10_1_merged1826_1941_to_stg10_stg10_ld13_merged1849_1925_cache stg10_stg10_1_merged1826_1941_to_stg10_stg10_ld13_merged1849_1925;
  stg10_stg10_1_merged1826_1942_to_stg10_stg10_ld13_merged1849_1926_cache stg10_stg10_1_merged1826_1942_to_stg10_stg10_ld13_merged1849_1926;
  stg10_stg10_1_merged1826_1943_to_stg10_stg10_ld13_merged1849_1927_cache stg10_stg10_1_merged1826_1943_to_stg10_stg10_ld13_merged1849_1927;
  stg10_stg10_1_merged1826_1944_to_stg10_stg10_ld13_merged1849_1928_cache stg10_stg10_1_merged1826_1944_to_stg10_stg10_ld13_merged1849_1928;
  stg10_stg10_1_merged1826_1945_to_stg10_stg10_ld13_merged1849_1929_cache stg10_stg10_1_merged1826_1945_to_stg10_stg10_ld13_merged1849_1929;
  stg10_stg10_1_merged1826_1946_to_stg10_stg10_ld13_merged1849_1930_cache stg10_stg10_1_merged1826_1946_to_stg10_stg10_ld13_merged1849_1930;
  stg10_stg10_1_merged1826_1947_to_stg10_stg10_ld13_merged1849_1931_cache stg10_stg10_1_merged1826_1947_to_stg10_stg10_ld13_merged1849_1931;
  stg10_stg10_1_merged1826_1948_to_stg10_stg10_ld13_merged1849_1932_cache stg10_stg10_1_merged1826_1948_to_stg10_stg10_ld13_merged1849_1932;
  stg10_stg10_1_merged1826_1949_to_stg10_stg10_ld13_merged1849_1933_cache stg10_stg10_1_merged1826_1949_to_stg10_stg10_ld13_merged1849_1933;
  stg10_stg10_1_merged1826_1950_to_stg10_stg10_ld13_merged1849_1934_cache stg10_stg10_1_merged1826_1950_to_stg10_stg10_ld13_merged1849_1934;
  stg10_stg10_1_merged1826_1951_to_stg10_stg10_ld13_merged1849_1935_cache stg10_stg10_1_merged1826_1951_to_stg10_stg10_ld13_merged1849_1935;
};



inline void stg10_stg10_1_merged1826_1936_write(hw_uint<16>& stg10_stg10_1_merged1826_1936, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1936_to_stg10_stg10_ld13_merged1849_1920.push(stg10_stg10_1_merged1826_1936);
}

inline void stg10_stg10_1_merged1826_1937_write(hw_uint<16>& stg10_stg10_1_merged1826_1937, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1937_to_stg10_stg10_ld13_merged1849_1921.push(stg10_stg10_1_merged1826_1937);
}

inline void stg10_stg10_1_merged1826_1938_write(hw_uint<16>& stg10_stg10_1_merged1826_1938, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1938_to_stg10_stg10_ld13_merged1849_1922.push(stg10_stg10_1_merged1826_1938);
}

inline void stg10_stg10_1_merged1826_1939_write(hw_uint<16>& stg10_stg10_1_merged1826_1939, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1939_to_stg10_stg10_ld13_merged1849_1923.push(stg10_stg10_1_merged1826_1939);
}

inline void stg10_stg10_1_merged1826_1940_write(hw_uint<16>& stg10_stg10_1_merged1826_1940, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1940_to_stg10_stg10_ld13_merged1849_1924.push(stg10_stg10_1_merged1826_1940);
}

inline void stg10_stg10_1_merged1826_1941_write(hw_uint<16>& stg10_stg10_1_merged1826_1941, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1941_to_stg10_stg10_ld13_merged1849_1925.push(stg10_stg10_1_merged1826_1941);
}

inline void stg10_stg10_1_merged1826_1942_write(hw_uint<16>& stg10_stg10_1_merged1826_1942, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1942_to_stg10_stg10_ld13_merged1849_1926.push(stg10_stg10_1_merged1826_1942);
}

inline void stg10_stg10_1_merged1826_1943_write(hw_uint<16>& stg10_stg10_1_merged1826_1943, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1943_to_stg10_stg10_ld13_merged1849_1927.push(stg10_stg10_1_merged1826_1943);
}

inline void stg10_stg10_1_merged1826_1944_write(hw_uint<16>& stg10_stg10_1_merged1826_1944, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1944_to_stg10_stg10_ld13_merged1849_1928.push(stg10_stg10_1_merged1826_1944);
}

inline void stg10_stg10_1_merged1826_1945_write(hw_uint<16>& stg10_stg10_1_merged1826_1945, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1945_to_stg10_stg10_ld13_merged1849_1929.push(stg10_stg10_1_merged1826_1945);
}

inline void stg10_stg10_1_merged1826_1946_write(hw_uint<16>& stg10_stg10_1_merged1826_1946, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1946_to_stg10_stg10_ld13_merged1849_1930.push(stg10_stg10_1_merged1826_1946);
}

inline void stg10_stg10_1_merged1826_1947_write(hw_uint<16>& stg10_stg10_1_merged1826_1947, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1947_to_stg10_stg10_ld13_merged1849_1931.push(stg10_stg10_1_merged1826_1947);
}

inline void stg10_stg10_1_merged1826_1948_write(hw_uint<16>& stg10_stg10_1_merged1826_1948, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1948_to_stg10_stg10_ld13_merged1849_1932.push(stg10_stg10_1_merged1826_1948);
}

inline void stg10_stg10_1_merged1826_1949_write(hw_uint<16>& stg10_stg10_1_merged1826_1949, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1949_to_stg10_stg10_ld13_merged1849_1933.push(stg10_stg10_1_merged1826_1949);
}

inline void stg10_stg10_1_merged1826_1950_write(hw_uint<16>& stg10_stg10_1_merged1826_1950, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1950_to_stg10_stg10_ld13_merged1849_1934.push(stg10_stg10_1_merged1826_1950);
}

inline void stg10_stg10_1_merged1826_1951_write(hw_uint<16>& stg10_stg10_1_merged1826_1951, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
  stg10.stg10_stg10_1_merged1826_1951_to_stg10_stg10_ld13_merged1849_1935.push(stg10_stg10_1_merged1826_1951);
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1920_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1920 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[15 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1936 = stg10.stg10_stg10_1_merged1826_1936_to_stg10_stg10_ld13_merged1849_1920.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1936;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1921_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1921 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[14 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1937 = stg10.stg10_stg10_1_merged1826_1937_to_stg10_stg10_ld13_merged1849_1921.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1937;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1922_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1922 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[13 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1938 = stg10.stg10_stg10_1_merged1826_1938_to_stg10_stg10_ld13_merged1849_1922.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1938;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1923_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1923 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[12 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1939 = stg10.stg10_stg10_1_merged1826_1939_to_stg10_stg10_ld13_merged1849_1923.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1939;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1924_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1924 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[11 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1940 = stg10.stg10_stg10_1_merged1826_1940_to_stg10_stg10_ld13_merged1849_1924.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1940;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1925_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1925 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[10 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1941 = stg10.stg10_stg10_1_merged1826_1941_to_stg10_stg10_ld13_merged1849_1925.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1941;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1926_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1926 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[9 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1942 = stg10.stg10_stg10_1_merged1826_1942_to_stg10_stg10_ld13_merged1849_1926.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1942;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1927_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1927 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[8 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1943 = stg10.stg10_stg10_1_merged1826_1943_to_stg10_stg10_ld13_merged1849_1927.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1943;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1928_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1928 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[7 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1944 = stg10.stg10_stg10_1_merged1826_1944_to_stg10_stg10_ld13_merged1849_1928.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1944;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1929_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1929 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[6 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1945 = stg10.stg10_stg10_1_merged1826_1945_to_stg10_stg10_ld13_merged1849_1929.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1945;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1930_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1930 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[5 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1946 = stg10.stg10_stg10_1_merged1826_1946_to_stg10_stg10_ld13_merged1849_1930.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1946;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1931_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1931 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[4 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1947 = stg10.stg10_stg10_1_merged1826_1947_to_stg10_stg10_ld13_merged1849_1931.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1947;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1932_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1932 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[3 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1948 = stg10.stg10_stg10_1_merged1826_1948_to_stg10_stg10_ld13_merged1849_1932.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1948;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1933_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1933 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[2 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1949 = stg10.stg10_stg10_1_merged1826_1949_to_stg10_stg10_ld13_merged1849_1933.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1949;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1934_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1934 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[1 + 16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1950 = stg10.stg10_stg10_1_merged1826_1950_to_stg10_stg10_ld13_merged1849_1934.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1950;
  return 0;
}

inline hw_uint<16> stg10_stg10_ld13_merged1849_1935_select(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_stg10_ld13_merged1849_1935 read pattern: { stg10_ld13_merged1849[root = 0, stg10_ld14, stg10_ld13] -> stg10[16stg10_ld13, -4 + stg10_ld14] : 0 <= stg10_ld14 <= 1927 and 0 <= stg10_ld13 <= 71 }
  // Read schedule : { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_stg10_1_merged1826_1951 = stg10.stg10_stg10_1_merged1826_1951_to_stg10_stg10_ld13_merged1849_1935.peek(/* one reader or all rams */ 0);
  return value_stg10_stg10_1_merged1826_1951;
  return 0;
}

// # of bundles = 2
// stg10_1_merged1826_write
//	stg10_stg10_1_merged1826_1936
//	stg10_stg10_1_merged1826_1937
//	stg10_stg10_1_merged1826_1938
//	stg10_stg10_1_merged1826_1939
//	stg10_stg10_1_merged1826_1940
//	stg10_stg10_1_merged1826_1941
//	stg10_stg10_1_merged1826_1942
//	stg10_stg10_1_merged1826_1943
//	stg10_stg10_1_merged1826_1944
//	stg10_stg10_1_merged1826_1945
//	stg10_stg10_1_merged1826_1946
//	stg10_stg10_1_merged1826_1947
//	stg10_stg10_1_merged1826_1948
//	stg10_stg10_1_merged1826_1949
//	stg10_stg10_1_merged1826_1950
//	stg10_stg10_1_merged1826_1951
inline void stg10_stg10_1_merged1826_write_bundle_write(hw_uint<256>& stg10_1_merged1826_write, stg10_cache& stg10, int root, int stg10_0, int stg10_1, int dynamic_address) {
	hw_uint<16> stg10_stg10_1_merged1826_1936_res = stg10_1_merged1826_write.extract<0, 15>();
	stg10_stg10_1_merged1826_1936_write(stg10_stg10_1_merged1826_1936_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1937_res = stg10_1_merged1826_write.extract<16, 31>();
	stg10_stg10_1_merged1826_1937_write(stg10_stg10_1_merged1826_1937_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1938_res = stg10_1_merged1826_write.extract<32, 47>();
	stg10_stg10_1_merged1826_1938_write(stg10_stg10_1_merged1826_1938_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1939_res = stg10_1_merged1826_write.extract<48, 63>();
	stg10_stg10_1_merged1826_1939_write(stg10_stg10_1_merged1826_1939_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1940_res = stg10_1_merged1826_write.extract<64, 79>();
	stg10_stg10_1_merged1826_1940_write(stg10_stg10_1_merged1826_1940_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1941_res = stg10_1_merged1826_write.extract<80, 95>();
	stg10_stg10_1_merged1826_1941_write(stg10_stg10_1_merged1826_1941_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1942_res = stg10_1_merged1826_write.extract<96, 111>();
	stg10_stg10_1_merged1826_1942_write(stg10_stg10_1_merged1826_1942_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1943_res = stg10_1_merged1826_write.extract<112, 127>();
	stg10_stg10_1_merged1826_1943_write(stg10_stg10_1_merged1826_1943_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1944_res = stg10_1_merged1826_write.extract<128, 143>();
	stg10_stg10_1_merged1826_1944_write(stg10_stg10_1_merged1826_1944_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1945_res = stg10_1_merged1826_write.extract<144, 159>();
	stg10_stg10_1_merged1826_1945_write(stg10_stg10_1_merged1826_1945_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1946_res = stg10_1_merged1826_write.extract<160, 175>();
	stg10_stg10_1_merged1826_1946_write(stg10_stg10_1_merged1826_1946_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1947_res = stg10_1_merged1826_write.extract<176, 191>();
	stg10_stg10_1_merged1826_1947_write(stg10_stg10_1_merged1826_1947_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1948_res = stg10_1_merged1826_write.extract<192, 207>();
	stg10_stg10_1_merged1826_1948_write(stg10_stg10_1_merged1826_1948_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1949_res = stg10_1_merged1826_write.extract<208, 223>();
	stg10_stg10_1_merged1826_1949_write(stg10_stg10_1_merged1826_1949_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1950_res = stg10_1_merged1826_write.extract<224, 239>();
	stg10_stg10_1_merged1826_1950_write(stg10_stg10_1_merged1826_1950_res, stg10, root, stg10_0, stg10_1, dynamic_address);
	hw_uint<16> stg10_stg10_1_merged1826_1951_res = stg10_1_merged1826_write.extract<240, 255>();
	stg10_stg10_1_merged1826_1951_write(stg10_stg10_1_merged1826_1951_res, stg10, root, stg10_0, stg10_1, dynamic_address);
}

// stg10_ld13_merged1849_read
//	stg10_stg10_ld13_merged1849_1920
//	stg10_stg10_ld13_merged1849_1921
//	stg10_stg10_ld13_merged1849_1922
//	stg10_stg10_ld13_merged1849_1923
//	stg10_stg10_ld13_merged1849_1924
//	stg10_stg10_ld13_merged1849_1925
//	stg10_stg10_ld13_merged1849_1926
//	stg10_stg10_ld13_merged1849_1927
//	stg10_stg10_ld13_merged1849_1928
//	stg10_stg10_ld13_merged1849_1929
//	stg10_stg10_ld13_merged1849_1930
//	stg10_stg10_ld13_merged1849_1931
//	stg10_stg10_ld13_merged1849_1932
//	stg10_stg10_ld13_merged1849_1933
//	stg10_stg10_ld13_merged1849_1934
//	stg10_stg10_ld13_merged1849_1935
inline hw_uint<256> stg10_stg10_ld13_merged1849_read_bundle_read(stg10_cache& stg10, int root, int stg10_ld14, int stg10_ld13, int dynamic_address) {
  // # of ports in bundle: 16
    // stg10_stg10_ld13_merged1849_1920
    // stg10_stg10_ld13_merged1849_1921
    // stg10_stg10_ld13_merged1849_1922
    // stg10_stg10_ld13_merged1849_1923
    // stg10_stg10_ld13_merged1849_1924
    // stg10_stg10_ld13_merged1849_1925
    // stg10_stg10_ld13_merged1849_1926
    // stg10_stg10_ld13_merged1849_1927
    // stg10_stg10_ld13_merged1849_1928
    // stg10_stg10_ld13_merged1849_1929
    // stg10_stg10_ld13_merged1849_1930
    // stg10_stg10_ld13_merged1849_1931
    // stg10_stg10_ld13_merged1849_1932
    // stg10_stg10_ld13_merged1849_1933
    // stg10_stg10_ld13_merged1849_1934
    // stg10_stg10_ld13_merged1849_1935

	hw_uint<256> result;
	hw_uint<16> stg10_stg10_ld13_merged1849_1920_res = stg10_stg10_ld13_merged1849_1920_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<0, 256>(result, stg10_stg10_ld13_merged1849_1920_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1921_res = stg10_stg10_ld13_merged1849_1921_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<16, 256>(result, stg10_stg10_ld13_merged1849_1921_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1922_res = stg10_stg10_ld13_merged1849_1922_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<32, 256>(result, stg10_stg10_ld13_merged1849_1922_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1923_res = stg10_stg10_ld13_merged1849_1923_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<48, 256>(result, stg10_stg10_ld13_merged1849_1923_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1924_res = stg10_stg10_ld13_merged1849_1924_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<64, 256>(result, stg10_stg10_ld13_merged1849_1924_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1925_res = stg10_stg10_ld13_merged1849_1925_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<80, 256>(result, stg10_stg10_ld13_merged1849_1925_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1926_res = stg10_stg10_ld13_merged1849_1926_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<96, 256>(result, stg10_stg10_ld13_merged1849_1926_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1927_res = stg10_stg10_ld13_merged1849_1927_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<112, 256>(result, stg10_stg10_ld13_merged1849_1927_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1928_res = stg10_stg10_ld13_merged1849_1928_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<128, 256>(result, stg10_stg10_ld13_merged1849_1928_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1929_res = stg10_stg10_ld13_merged1849_1929_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<144, 256>(result, stg10_stg10_ld13_merged1849_1929_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1930_res = stg10_stg10_ld13_merged1849_1930_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<160, 256>(result, stg10_stg10_ld13_merged1849_1930_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1931_res = stg10_stg10_ld13_merged1849_1931_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<176, 256>(result, stg10_stg10_ld13_merged1849_1931_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1932_res = stg10_stg10_ld13_merged1849_1932_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<192, 256>(result, stg10_stg10_ld13_merged1849_1932_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1933_res = stg10_stg10_ld13_merged1849_1933_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<208, 256>(result, stg10_stg10_ld13_merged1849_1933_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1934_res = stg10_stg10_ld13_merged1849_1934_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<224, 256>(result, stg10_stg10_ld13_merged1849_1934_res);
	hw_uint<16> stg10_stg10_ld13_merged1849_1935_res = stg10_stg10_ld13_merged1849_1935_select(stg10, root, stg10_ld14, stg10_ld13, dynamic_address);
	set_at<240, 256>(result, stg10_stg10_ld13_merged1849_1935_res);
	return result;
}

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_merged_banks_4_cache {
	// RAM Box: {[15, 1135], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_merged_banks_4_cache {
	// RAM Box: {[14, 1134], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_merged_banks_4_cache {
	// RAM Box: {[13, 1133], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_merged_banks_4_cache {
	// RAM Box: {[12, 1132], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_merged_banks_4_cache {
	// RAM Box: {[11, 1131], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_merged_banks_4_cache {
	// RAM Box: {[10, 1130], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_merged_banks_4_cache {
	// RAM Box: {[9, 1129], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_merged_banks_4_cache {
	// RAM Box: {[8, 1128], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_merged_banks_4_cache {
	// RAM Box: {[7, 1127], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_merged_banks_4_cache {
	// RAM Box: {[6, 1126], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_merged_banks_4_cache {
	// RAM Box: {[5, 1125], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_merged_banks_4_cache {
	// RAM Box: {[4, 1124], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_merged_banks_4_cache {
	// RAM Box: {[3, 1123], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_merged_banks_4_cache {
	// RAM Box: {[2, 1122], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_merged_banks_4_cache {
	// RAM Box: {[1, 1121], [-4, 1923]}
	// Capacity: 146
	// # of read delays: 4
  // 0, 1, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 71> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_145() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_merged_banks_4_cache {
	// RAM Box: {[0, 1136], [-4, 1922]}
	// Capacity: 146
	// # of read delays: 5
  // 0, 1, 72, 73, 145
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 71> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_73() {
		return f6;
	}

	inline hw_uint<16> peek_144() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_145() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg10_FIFO_buf76_cache {
  // Reader addrs...
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[15 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[15 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[16 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[15 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[14 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[14 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[15 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[14 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[13 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[13 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[14 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[13 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[12 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[12 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[13 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[12 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[11 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[11 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[12 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[11 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[10 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[10 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[11 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[10 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[9 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[9 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[10 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[9 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[8 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[8 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[9 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[8 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[7 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[7 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[8 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[7 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[6 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[6 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[7 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[6 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[5 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[5 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[6 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[5 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[4 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[4 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[5 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[4 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[3 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[3 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[4 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[3 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[2 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[2 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[3 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[2 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[1 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[1 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[2 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[1 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[1 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
    // { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // # of banks: 16
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_merged_banks_4;
  stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_merged_banks_4_cache stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_merged_banks_4;
};



inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886);
}

inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_write(hw_uint<16>& stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
  stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_merged_banks_4.push(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887);
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1808_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1808 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[15 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1809_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1809 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[15 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1810_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1810 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[16 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_merged_banks_4.peek_72();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1811_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1811 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[15 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1812_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1812 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[14 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1813_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1813 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[14 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1814_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1814 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[15 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1815_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1815 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[14 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1816_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1816 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[13 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1817_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1817 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[13 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1818_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1818 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[14 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1819_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1819 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[13 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1820_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1820 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[12 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1821_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1821 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[12 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1822_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1822 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[13 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1823_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1823 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[12 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1824_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1824 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[11 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1825_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1825 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[11 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1826_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1826 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[12 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1827_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1827 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[11 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1828_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1828 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[10 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1829_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1829 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[10 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1830_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1830 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[11 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1831_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1831 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[10 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1832_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1832 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[9 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1833_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1833 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[9 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1834_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1834 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[10 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1835_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1835 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[9 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1836_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1836 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[8 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1837_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1837 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[8 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1838_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1838 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[9 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1839_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1839 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[8 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1840_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1840 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[7 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1841_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1841 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[7 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1842_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1842 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[8 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1843_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1843 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[7 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1844_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1844 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[6 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1845_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1845 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[6 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1846_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1846 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[7 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1847_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1847 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[6 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1848_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1848 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[5 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1849_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1849 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[5 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1850_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1850 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[6 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1851_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1851 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[5 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1852_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1852 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[4 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1853_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1853 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[4 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1854_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1854 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[5 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1855_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1855 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[4 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1856_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1856 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[3 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1857_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1857 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[3 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1858_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1858 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[4 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1859_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1859 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[3 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1860_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1860 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[2 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1861_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1861 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[2 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1862_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1862 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[3 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1863_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1863 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[2 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1864_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1864 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[1 + 16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1865_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1865 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[1 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1866_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1866 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[2 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1867_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1867 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[1 + 16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1868_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1868 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[16stg11_1, -4 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_merged_banks_4.peek_145();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1869_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1869 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1870_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1870 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[1 + 16stg11_1, -3 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_merged_banks_4.peek_73();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886;
  return 0;
}

inline hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1871_select(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg10_FIFO_buf76_stg11_1_merged1829_1871 read pattern: { stg11_1_merged1829[root = 0, stg11_0, stg11_1] -> stg10_FIFO_buf76[16stg11_1, -2 + stg11_0] : 0 <= stg11_0 <= 1925 and 0 <= stg11_1 <= 70 }
  // Read schedule : { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  auto value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887 = stg10_FIFO_buf76.stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_merged_banks_4.peek_1();
  return value_stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887;
  return 0;
}

// # of bundles = 2
// stg10_to_gp_412_ld77_merged1768_write
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886
//	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887
inline void stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_write_bundle_write(hw_uint<256>& stg10_to_gp_412_ld77_merged1768_write, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg10_to_gp_412_ld78, int stg10_to_gp_412_ld77, int dynamic_address) {
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_res = stg10_to_gp_412_ld77_merged1768_write.extract<0, 15>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1872_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_res = stg10_to_gp_412_ld77_merged1768_write.extract<16, 31>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1873_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_res = stg10_to_gp_412_ld77_merged1768_write.extract<32, 47>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1874_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_res = stg10_to_gp_412_ld77_merged1768_write.extract<48, 63>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1875_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_res = stg10_to_gp_412_ld77_merged1768_write.extract<64, 79>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1876_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_res = stg10_to_gp_412_ld77_merged1768_write.extract<80, 95>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1877_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_res = stg10_to_gp_412_ld77_merged1768_write.extract<96, 111>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1878_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_res = stg10_to_gp_412_ld77_merged1768_write.extract<112, 127>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1879_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_res = stg10_to_gp_412_ld77_merged1768_write.extract<128, 143>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1880_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_res = stg10_to_gp_412_ld77_merged1768_write.extract<144, 159>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1881_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_res = stg10_to_gp_412_ld77_merged1768_write.extract<160, 175>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1882_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_res = stg10_to_gp_412_ld77_merged1768_write.extract<176, 191>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1883_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_res = stg10_to_gp_412_ld77_merged1768_write.extract<192, 207>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1884_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_res = stg10_to_gp_412_ld77_merged1768_write.extract<208, 223>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1885_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_res = stg10_to_gp_412_ld77_merged1768_write.extract<224, 239>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1886_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
	hw_uint<16> stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_res = stg10_to_gp_412_ld77_merged1768_write.extract<240, 255>();
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_write(stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_1887_res, stg10_FIFO_buf76, root, stg10_to_gp_412_ld78, stg10_to_gp_412_ld77, dynamic_address);
}

// stg11_1_merged1829_read
//	stg10_FIFO_buf76_stg11_1_merged1829_1808
//	stg10_FIFO_buf76_stg11_1_merged1829_1809
//	stg10_FIFO_buf76_stg11_1_merged1829_1810
//	stg10_FIFO_buf76_stg11_1_merged1829_1811
//	stg10_FIFO_buf76_stg11_1_merged1829_1812
//	stg10_FIFO_buf76_stg11_1_merged1829_1813
//	stg10_FIFO_buf76_stg11_1_merged1829_1814
//	stg10_FIFO_buf76_stg11_1_merged1829_1815
//	stg10_FIFO_buf76_stg11_1_merged1829_1816
//	stg10_FIFO_buf76_stg11_1_merged1829_1817
//	stg10_FIFO_buf76_stg11_1_merged1829_1818
//	stg10_FIFO_buf76_stg11_1_merged1829_1819
//	stg10_FIFO_buf76_stg11_1_merged1829_1820
//	stg10_FIFO_buf76_stg11_1_merged1829_1821
//	stg10_FIFO_buf76_stg11_1_merged1829_1822
//	stg10_FIFO_buf76_stg11_1_merged1829_1823
//	stg10_FIFO_buf76_stg11_1_merged1829_1824
//	stg10_FIFO_buf76_stg11_1_merged1829_1825
//	stg10_FIFO_buf76_stg11_1_merged1829_1826
//	stg10_FIFO_buf76_stg11_1_merged1829_1827
//	stg10_FIFO_buf76_stg11_1_merged1829_1828
//	stg10_FIFO_buf76_stg11_1_merged1829_1829
//	stg10_FIFO_buf76_stg11_1_merged1829_1830
//	stg10_FIFO_buf76_stg11_1_merged1829_1831
//	stg10_FIFO_buf76_stg11_1_merged1829_1832
//	stg10_FIFO_buf76_stg11_1_merged1829_1833
//	stg10_FIFO_buf76_stg11_1_merged1829_1834
//	stg10_FIFO_buf76_stg11_1_merged1829_1835
//	stg10_FIFO_buf76_stg11_1_merged1829_1836
//	stg10_FIFO_buf76_stg11_1_merged1829_1837
//	stg10_FIFO_buf76_stg11_1_merged1829_1838
//	stg10_FIFO_buf76_stg11_1_merged1829_1839
//	stg10_FIFO_buf76_stg11_1_merged1829_1840
//	stg10_FIFO_buf76_stg11_1_merged1829_1841
//	stg10_FIFO_buf76_stg11_1_merged1829_1842
//	stg10_FIFO_buf76_stg11_1_merged1829_1843
//	stg10_FIFO_buf76_stg11_1_merged1829_1844
//	stg10_FIFO_buf76_stg11_1_merged1829_1845
//	stg10_FIFO_buf76_stg11_1_merged1829_1846
//	stg10_FIFO_buf76_stg11_1_merged1829_1847
//	stg10_FIFO_buf76_stg11_1_merged1829_1848
//	stg10_FIFO_buf76_stg11_1_merged1829_1849
//	stg10_FIFO_buf76_stg11_1_merged1829_1850
//	stg10_FIFO_buf76_stg11_1_merged1829_1851
//	stg10_FIFO_buf76_stg11_1_merged1829_1852
//	stg10_FIFO_buf76_stg11_1_merged1829_1853
//	stg10_FIFO_buf76_stg11_1_merged1829_1854
//	stg10_FIFO_buf76_stg11_1_merged1829_1855
//	stg10_FIFO_buf76_stg11_1_merged1829_1856
//	stg10_FIFO_buf76_stg11_1_merged1829_1857
//	stg10_FIFO_buf76_stg11_1_merged1829_1858
//	stg10_FIFO_buf76_stg11_1_merged1829_1859
//	stg10_FIFO_buf76_stg11_1_merged1829_1860
//	stg10_FIFO_buf76_stg11_1_merged1829_1861
//	stg10_FIFO_buf76_stg11_1_merged1829_1862
//	stg10_FIFO_buf76_stg11_1_merged1829_1863
//	stg10_FIFO_buf76_stg11_1_merged1829_1864
//	stg10_FIFO_buf76_stg11_1_merged1829_1865
//	stg10_FIFO_buf76_stg11_1_merged1829_1866
//	stg10_FIFO_buf76_stg11_1_merged1829_1867
//	stg10_FIFO_buf76_stg11_1_merged1829_1868
//	stg10_FIFO_buf76_stg11_1_merged1829_1869
//	stg10_FIFO_buf76_stg11_1_merged1829_1870
//	stg10_FIFO_buf76_stg11_1_merged1829_1871
inline hw_uint<1024> stg10_FIFO_buf76_stg11_1_merged1829_read_bundle_read(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int root, int stg11_0, int stg11_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg10_FIFO_buf76_stg11_1_merged1829_1808
    // stg10_FIFO_buf76_stg11_1_merged1829_1809
    // stg10_FIFO_buf76_stg11_1_merged1829_1810
    // stg10_FIFO_buf76_stg11_1_merged1829_1811
    // stg10_FIFO_buf76_stg11_1_merged1829_1812
    // stg10_FIFO_buf76_stg11_1_merged1829_1813
    // stg10_FIFO_buf76_stg11_1_merged1829_1814
    // stg10_FIFO_buf76_stg11_1_merged1829_1815
    // stg10_FIFO_buf76_stg11_1_merged1829_1816
    // stg10_FIFO_buf76_stg11_1_merged1829_1817
    // stg10_FIFO_buf76_stg11_1_merged1829_1818
    // stg10_FIFO_buf76_stg11_1_merged1829_1819
    // stg10_FIFO_buf76_stg11_1_merged1829_1820
    // stg10_FIFO_buf76_stg11_1_merged1829_1821
    // stg10_FIFO_buf76_stg11_1_merged1829_1822
    // stg10_FIFO_buf76_stg11_1_merged1829_1823
    // stg10_FIFO_buf76_stg11_1_merged1829_1824
    // stg10_FIFO_buf76_stg11_1_merged1829_1825
    // stg10_FIFO_buf76_stg11_1_merged1829_1826
    // stg10_FIFO_buf76_stg11_1_merged1829_1827
    // stg10_FIFO_buf76_stg11_1_merged1829_1828
    // stg10_FIFO_buf76_stg11_1_merged1829_1829
    // stg10_FIFO_buf76_stg11_1_merged1829_1830
    // stg10_FIFO_buf76_stg11_1_merged1829_1831
    // stg10_FIFO_buf76_stg11_1_merged1829_1832
    // stg10_FIFO_buf76_stg11_1_merged1829_1833
    // stg10_FIFO_buf76_stg11_1_merged1829_1834
    // stg10_FIFO_buf76_stg11_1_merged1829_1835
    // stg10_FIFO_buf76_stg11_1_merged1829_1836
    // stg10_FIFO_buf76_stg11_1_merged1829_1837
    // stg10_FIFO_buf76_stg11_1_merged1829_1838
    // stg10_FIFO_buf76_stg11_1_merged1829_1839
    // stg10_FIFO_buf76_stg11_1_merged1829_1840
    // stg10_FIFO_buf76_stg11_1_merged1829_1841
    // stg10_FIFO_buf76_stg11_1_merged1829_1842
    // stg10_FIFO_buf76_stg11_1_merged1829_1843
    // stg10_FIFO_buf76_stg11_1_merged1829_1844
    // stg10_FIFO_buf76_stg11_1_merged1829_1845
    // stg10_FIFO_buf76_stg11_1_merged1829_1846
    // stg10_FIFO_buf76_stg11_1_merged1829_1847
    // stg10_FIFO_buf76_stg11_1_merged1829_1848
    // stg10_FIFO_buf76_stg11_1_merged1829_1849
    // stg10_FIFO_buf76_stg11_1_merged1829_1850
    // stg10_FIFO_buf76_stg11_1_merged1829_1851
    // stg10_FIFO_buf76_stg11_1_merged1829_1852
    // stg10_FIFO_buf76_stg11_1_merged1829_1853
    // stg10_FIFO_buf76_stg11_1_merged1829_1854
    // stg10_FIFO_buf76_stg11_1_merged1829_1855
    // stg10_FIFO_buf76_stg11_1_merged1829_1856
    // stg10_FIFO_buf76_stg11_1_merged1829_1857
    // stg10_FIFO_buf76_stg11_1_merged1829_1858
    // stg10_FIFO_buf76_stg11_1_merged1829_1859
    // stg10_FIFO_buf76_stg11_1_merged1829_1860
    // stg10_FIFO_buf76_stg11_1_merged1829_1861
    // stg10_FIFO_buf76_stg11_1_merged1829_1862
    // stg10_FIFO_buf76_stg11_1_merged1829_1863
    // stg10_FIFO_buf76_stg11_1_merged1829_1864
    // stg10_FIFO_buf76_stg11_1_merged1829_1865
    // stg10_FIFO_buf76_stg11_1_merged1829_1866
    // stg10_FIFO_buf76_stg11_1_merged1829_1867
    // stg10_FIFO_buf76_stg11_1_merged1829_1868
    // stg10_FIFO_buf76_stg11_1_merged1829_1869
    // stg10_FIFO_buf76_stg11_1_merged1829_1870
    // stg10_FIFO_buf76_stg11_1_merged1829_1871

	hw_uint<1024> result;
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1808_res = stg10_FIFO_buf76_stg11_1_merged1829_1808_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<0, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1808_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1809_res = stg10_FIFO_buf76_stg11_1_merged1829_1809_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<16, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1809_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1810_res = stg10_FIFO_buf76_stg11_1_merged1829_1810_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<32, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1810_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1811_res = stg10_FIFO_buf76_stg11_1_merged1829_1811_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<48, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1811_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1812_res = stg10_FIFO_buf76_stg11_1_merged1829_1812_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<64, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1812_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1813_res = stg10_FIFO_buf76_stg11_1_merged1829_1813_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<80, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1813_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1814_res = stg10_FIFO_buf76_stg11_1_merged1829_1814_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<96, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1814_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1815_res = stg10_FIFO_buf76_stg11_1_merged1829_1815_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<112, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1815_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1816_res = stg10_FIFO_buf76_stg11_1_merged1829_1816_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<128, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1816_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1817_res = stg10_FIFO_buf76_stg11_1_merged1829_1817_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<144, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1817_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1818_res = stg10_FIFO_buf76_stg11_1_merged1829_1818_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<160, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1818_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1819_res = stg10_FIFO_buf76_stg11_1_merged1829_1819_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<176, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1819_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1820_res = stg10_FIFO_buf76_stg11_1_merged1829_1820_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<192, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1820_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1821_res = stg10_FIFO_buf76_stg11_1_merged1829_1821_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<208, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1821_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1822_res = stg10_FIFO_buf76_stg11_1_merged1829_1822_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<224, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1822_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1823_res = stg10_FIFO_buf76_stg11_1_merged1829_1823_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<240, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1823_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1824_res = stg10_FIFO_buf76_stg11_1_merged1829_1824_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<256, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1824_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1825_res = stg10_FIFO_buf76_stg11_1_merged1829_1825_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<272, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1825_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1826_res = stg10_FIFO_buf76_stg11_1_merged1829_1826_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<288, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1826_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1827_res = stg10_FIFO_buf76_stg11_1_merged1829_1827_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<304, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1827_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1828_res = stg10_FIFO_buf76_stg11_1_merged1829_1828_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<320, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1828_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1829_res = stg10_FIFO_buf76_stg11_1_merged1829_1829_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<336, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1829_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1830_res = stg10_FIFO_buf76_stg11_1_merged1829_1830_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<352, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1830_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1831_res = stg10_FIFO_buf76_stg11_1_merged1829_1831_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<368, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1831_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1832_res = stg10_FIFO_buf76_stg11_1_merged1829_1832_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<384, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1832_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1833_res = stg10_FIFO_buf76_stg11_1_merged1829_1833_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<400, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1833_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1834_res = stg10_FIFO_buf76_stg11_1_merged1829_1834_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<416, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1834_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1835_res = stg10_FIFO_buf76_stg11_1_merged1829_1835_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<432, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1835_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1836_res = stg10_FIFO_buf76_stg11_1_merged1829_1836_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<448, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1836_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1837_res = stg10_FIFO_buf76_stg11_1_merged1829_1837_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<464, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1837_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1838_res = stg10_FIFO_buf76_stg11_1_merged1829_1838_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<480, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1838_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1839_res = stg10_FIFO_buf76_stg11_1_merged1829_1839_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<496, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1839_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1840_res = stg10_FIFO_buf76_stg11_1_merged1829_1840_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<512, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1840_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1841_res = stg10_FIFO_buf76_stg11_1_merged1829_1841_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<528, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1841_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1842_res = stg10_FIFO_buf76_stg11_1_merged1829_1842_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<544, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1842_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1843_res = stg10_FIFO_buf76_stg11_1_merged1829_1843_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<560, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1843_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1844_res = stg10_FIFO_buf76_stg11_1_merged1829_1844_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<576, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1844_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1845_res = stg10_FIFO_buf76_stg11_1_merged1829_1845_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<592, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1845_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1846_res = stg10_FIFO_buf76_stg11_1_merged1829_1846_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<608, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1846_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1847_res = stg10_FIFO_buf76_stg11_1_merged1829_1847_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<624, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1847_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1848_res = stg10_FIFO_buf76_stg11_1_merged1829_1848_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<640, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1848_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1849_res = stg10_FIFO_buf76_stg11_1_merged1829_1849_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<656, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1849_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1850_res = stg10_FIFO_buf76_stg11_1_merged1829_1850_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<672, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1850_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1851_res = stg10_FIFO_buf76_stg11_1_merged1829_1851_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<688, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1851_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1852_res = stg10_FIFO_buf76_stg11_1_merged1829_1852_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<704, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1852_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1853_res = stg10_FIFO_buf76_stg11_1_merged1829_1853_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<720, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1853_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1854_res = stg10_FIFO_buf76_stg11_1_merged1829_1854_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<736, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1854_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1855_res = stg10_FIFO_buf76_stg11_1_merged1829_1855_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<752, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1855_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1856_res = stg10_FIFO_buf76_stg11_1_merged1829_1856_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<768, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1856_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1857_res = stg10_FIFO_buf76_stg11_1_merged1829_1857_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<784, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1857_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1858_res = stg10_FIFO_buf76_stg11_1_merged1829_1858_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<800, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1858_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1859_res = stg10_FIFO_buf76_stg11_1_merged1829_1859_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<816, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1859_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1860_res = stg10_FIFO_buf76_stg11_1_merged1829_1860_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<832, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1860_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1861_res = stg10_FIFO_buf76_stg11_1_merged1829_1861_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<848, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1861_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1862_res = stg10_FIFO_buf76_stg11_1_merged1829_1862_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<864, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1862_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1863_res = stg10_FIFO_buf76_stg11_1_merged1829_1863_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<880, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1863_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1864_res = stg10_FIFO_buf76_stg11_1_merged1829_1864_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<896, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1864_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1865_res = stg10_FIFO_buf76_stg11_1_merged1829_1865_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<912, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1865_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1866_res = stg10_FIFO_buf76_stg11_1_merged1829_1866_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<928, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1866_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1867_res = stg10_FIFO_buf76_stg11_1_merged1829_1867_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<944, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1867_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1868_res = stg10_FIFO_buf76_stg11_1_merged1829_1868_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<960, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1868_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1869_res = stg10_FIFO_buf76_stg11_1_merged1829_1869_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<976, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1869_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1870_res = stg10_FIFO_buf76_stg11_1_merged1829_1870_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<992, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1870_res);
	hw_uint<16> stg10_FIFO_buf76_stg11_1_merged1829_1871_res = stg10_FIFO_buf76_stg11_1_merged1829_1871_select(stg10_FIFO_buf76, root, stg11_0, stg11_1, dynamic_address);
	set_at<1008, 1024>(result, stg10_FIFO_buf76_stg11_1_merged1829_1871_res);
	return result;
}

struct stg11_stg11_1_merged1829_1792_to_stg11_stg11_ld17_merged1770_1776_cache {
	// RAM Box: {[15, 1135], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1793_to_stg11_stg11_ld17_merged1770_1777_cache {
	// RAM Box: {[14, 1134], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1794_to_stg11_stg11_ld17_merged1770_1778_cache {
	// RAM Box: {[13, 1133], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1795_to_stg11_stg11_ld17_merged1770_1779_cache {
	// RAM Box: {[12, 1132], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1796_to_stg11_stg11_ld17_merged1770_1780_cache {
	// RAM Box: {[11, 1131], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1797_to_stg11_stg11_ld17_merged1770_1781_cache {
	// RAM Box: {[10, 1130], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1798_to_stg11_stg11_ld17_merged1770_1782_cache {
	// RAM Box: {[9, 1129], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1799_to_stg11_stg11_ld17_merged1770_1783_cache {
	// RAM Box: {[8, 1128], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1800_to_stg11_stg11_ld17_merged1770_1784_cache {
	// RAM Box: {[7, 1127], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1801_to_stg11_stg11_ld17_merged1770_1785_cache {
	// RAM Box: {[6, 1126], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1802_to_stg11_stg11_ld17_merged1770_1786_cache {
	// RAM Box: {[5, 1125], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1803_to_stg11_stg11_ld17_merged1770_1787_cache {
	// RAM Box: {[4, 1124], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1804_to_stg11_stg11_ld17_merged1770_1788_cache {
	// RAM Box: {[3, 1123], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1805_to_stg11_stg11_ld17_merged1770_1789_cache {
	// RAM Box: {[2, 1122], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1806_to_stg11_stg11_ld17_merged1770_1790_cache {
	// RAM Box: {[1, 1121], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_stg11_1_merged1829_1807_to_stg11_stg11_ld17_merged1770_1791_cache {
	// RAM Box: {[0, 1120], [-3, 1922]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg11_cache {
  // Reader addrs...
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[15 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[14 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[13 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[12 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[11 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[10 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[9 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[8 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[7 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[6 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[5 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[4 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[3 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[2 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[1 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
    // { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // # of banks: 16
  stg11_stg11_1_merged1829_1792_to_stg11_stg11_ld17_merged1770_1776_cache stg11_stg11_1_merged1829_1792_to_stg11_stg11_ld17_merged1770_1776;
  stg11_stg11_1_merged1829_1793_to_stg11_stg11_ld17_merged1770_1777_cache stg11_stg11_1_merged1829_1793_to_stg11_stg11_ld17_merged1770_1777;
  stg11_stg11_1_merged1829_1794_to_stg11_stg11_ld17_merged1770_1778_cache stg11_stg11_1_merged1829_1794_to_stg11_stg11_ld17_merged1770_1778;
  stg11_stg11_1_merged1829_1795_to_stg11_stg11_ld17_merged1770_1779_cache stg11_stg11_1_merged1829_1795_to_stg11_stg11_ld17_merged1770_1779;
  stg11_stg11_1_merged1829_1796_to_stg11_stg11_ld17_merged1770_1780_cache stg11_stg11_1_merged1829_1796_to_stg11_stg11_ld17_merged1770_1780;
  stg11_stg11_1_merged1829_1797_to_stg11_stg11_ld17_merged1770_1781_cache stg11_stg11_1_merged1829_1797_to_stg11_stg11_ld17_merged1770_1781;
  stg11_stg11_1_merged1829_1798_to_stg11_stg11_ld17_merged1770_1782_cache stg11_stg11_1_merged1829_1798_to_stg11_stg11_ld17_merged1770_1782;
  stg11_stg11_1_merged1829_1799_to_stg11_stg11_ld17_merged1770_1783_cache stg11_stg11_1_merged1829_1799_to_stg11_stg11_ld17_merged1770_1783;
  stg11_stg11_1_merged1829_1800_to_stg11_stg11_ld17_merged1770_1784_cache stg11_stg11_1_merged1829_1800_to_stg11_stg11_ld17_merged1770_1784;
  stg11_stg11_1_merged1829_1801_to_stg11_stg11_ld17_merged1770_1785_cache stg11_stg11_1_merged1829_1801_to_stg11_stg11_ld17_merged1770_1785;
  stg11_stg11_1_merged1829_1802_to_stg11_stg11_ld17_merged1770_1786_cache stg11_stg11_1_merged1829_1802_to_stg11_stg11_ld17_merged1770_1786;
  stg11_stg11_1_merged1829_1803_to_stg11_stg11_ld17_merged1770_1787_cache stg11_stg11_1_merged1829_1803_to_stg11_stg11_ld17_merged1770_1787;
  stg11_stg11_1_merged1829_1804_to_stg11_stg11_ld17_merged1770_1788_cache stg11_stg11_1_merged1829_1804_to_stg11_stg11_ld17_merged1770_1788;
  stg11_stg11_1_merged1829_1805_to_stg11_stg11_ld17_merged1770_1789_cache stg11_stg11_1_merged1829_1805_to_stg11_stg11_ld17_merged1770_1789;
  stg11_stg11_1_merged1829_1806_to_stg11_stg11_ld17_merged1770_1790_cache stg11_stg11_1_merged1829_1806_to_stg11_stg11_ld17_merged1770_1790;
  stg11_stg11_1_merged1829_1807_to_stg11_stg11_ld17_merged1770_1791_cache stg11_stg11_1_merged1829_1807_to_stg11_stg11_ld17_merged1770_1791;
};



inline void stg11_stg11_1_merged1829_1792_write(hw_uint<16>& stg11_stg11_1_merged1829_1792, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1792_to_stg11_stg11_ld17_merged1770_1776.push(stg11_stg11_1_merged1829_1792);
}

inline void stg11_stg11_1_merged1829_1793_write(hw_uint<16>& stg11_stg11_1_merged1829_1793, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1793_to_stg11_stg11_ld17_merged1770_1777.push(stg11_stg11_1_merged1829_1793);
}

inline void stg11_stg11_1_merged1829_1794_write(hw_uint<16>& stg11_stg11_1_merged1829_1794, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1794_to_stg11_stg11_ld17_merged1770_1778.push(stg11_stg11_1_merged1829_1794);
}

inline void stg11_stg11_1_merged1829_1795_write(hw_uint<16>& stg11_stg11_1_merged1829_1795, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1795_to_stg11_stg11_ld17_merged1770_1779.push(stg11_stg11_1_merged1829_1795);
}

inline void stg11_stg11_1_merged1829_1796_write(hw_uint<16>& stg11_stg11_1_merged1829_1796, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1796_to_stg11_stg11_ld17_merged1770_1780.push(stg11_stg11_1_merged1829_1796);
}

inline void stg11_stg11_1_merged1829_1797_write(hw_uint<16>& stg11_stg11_1_merged1829_1797, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1797_to_stg11_stg11_ld17_merged1770_1781.push(stg11_stg11_1_merged1829_1797);
}

inline void stg11_stg11_1_merged1829_1798_write(hw_uint<16>& stg11_stg11_1_merged1829_1798, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1798_to_stg11_stg11_ld17_merged1770_1782.push(stg11_stg11_1_merged1829_1798);
}

inline void stg11_stg11_1_merged1829_1799_write(hw_uint<16>& stg11_stg11_1_merged1829_1799, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1799_to_stg11_stg11_ld17_merged1770_1783.push(stg11_stg11_1_merged1829_1799);
}

inline void stg11_stg11_1_merged1829_1800_write(hw_uint<16>& stg11_stg11_1_merged1829_1800, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1800_to_stg11_stg11_ld17_merged1770_1784.push(stg11_stg11_1_merged1829_1800);
}

inline void stg11_stg11_1_merged1829_1801_write(hw_uint<16>& stg11_stg11_1_merged1829_1801, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1801_to_stg11_stg11_ld17_merged1770_1785.push(stg11_stg11_1_merged1829_1801);
}

inline void stg11_stg11_1_merged1829_1802_write(hw_uint<16>& stg11_stg11_1_merged1829_1802, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1802_to_stg11_stg11_ld17_merged1770_1786.push(stg11_stg11_1_merged1829_1802);
}

inline void stg11_stg11_1_merged1829_1803_write(hw_uint<16>& stg11_stg11_1_merged1829_1803, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1803_to_stg11_stg11_ld17_merged1770_1787.push(stg11_stg11_1_merged1829_1803);
}

inline void stg11_stg11_1_merged1829_1804_write(hw_uint<16>& stg11_stg11_1_merged1829_1804, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1804_to_stg11_stg11_ld17_merged1770_1788.push(stg11_stg11_1_merged1829_1804);
}

inline void stg11_stg11_1_merged1829_1805_write(hw_uint<16>& stg11_stg11_1_merged1829_1805, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1805_to_stg11_stg11_ld17_merged1770_1789.push(stg11_stg11_1_merged1829_1805);
}

inline void stg11_stg11_1_merged1829_1806_write(hw_uint<16>& stg11_stg11_1_merged1829_1806, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1806_to_stg11_stg11_ld17_merged1770_1790.push(stg11_stg11_1_merged1829_1806);
}

inline void stg11_stg11_1_merged1829_1807_write(hw_uint<16>& stg11_stg11_1_merged1829_1807, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
  stg11.stg11_stg11_1_merged1829_1807_to_stg11_stg11_ld17_merged1770_1791.push(stg11_stg11_1_merged1829_1807);
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1776_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1776 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[15 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1792 = stg11.stg11_stg11_1_merged1829_1792_to_stg11_stg11_ld17_merged1770_1776.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1792;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1777_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1777 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[14 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1793 = stg11.stg11_stg11_1_merged1829_1793_to_stg11_stg11_ld17_merged1770_1777.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1793;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1778_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1778 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[13 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1794 = stg11.stg11_stg11_1_merged1829_1794_to_stg11_stg11_ld17_merged1770_1778.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1794;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1779_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1779 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[12 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1795 = stg11.stg11_stg11_1_merged1829_1795_to_stg11_stg11_ld17_merged1770_1779.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1795;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1780_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1780 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[11 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1796 = stg11.stg11_stg11_1_merged1829_1796_to_stg11_stg11_ld17_merged1770_1780.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1796;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1781_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1781 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[10 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1797 = stg11.stg11_stg11_1_merged1829_1797_to_stg11_stg11_ld17_merged1770_1781.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1797;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1782_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1782 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[9 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1798 = stg11.stg11_stg11_1_merged1829_1798_to_stg11_stg11_ld17_merged1770_1782.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1798;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1783_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1783 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[8 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1799 = stg11.stg11_stg11_1_merged1829_1799_to_stg11_stg11_ld17_merged1770_1783.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1799;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1784_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1784 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[7 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1800 = stg11.stg11_stg11_1_merged1829_1800_to_stg11_stg11_ld17_merged1770_1784.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1800;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1785_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1785 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[6 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1801 = stg11.stg11_stg11_1_merged1829_1801_to_stg11_stg11_ld17_merged1770_1785.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1801;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1786_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1786 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[5 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1802 = stg11.stg11_stg11_1_merged1829_1802_to_stg11_stg11_ld17_merged1770_1786.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1802;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1787_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1787 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[4 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1803 = stg11.stg11_stg11_1_merged1829_1803_to_stg11_stg11_ld17_merged1770_1787.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1803;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1788_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1788 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[3 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1804 = stg11.stg11_stg11_1_merged1829_1804_to_stg11_stg11_ld17_merged1770_1788.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1804;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1789_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1789 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[2 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1805 = stg11.stg11_stg11_1_merged1829_1805_to_stg11_stg11_ld17_merged1770_1789.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1805;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1790_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1790 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[1 + 16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1806 = stg11.stg11_stg11_1_merged1829_1806_to_stg11_stg11_ld17_merged1770_1790.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1806;
  return 0;
}

inline hw_uint<16> stg11_stg11_ld17_merged1770_1791_select(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_stg11_ld17_merged1770_1791 read pattern: { stg11_ld17_merged1770[root = 0, stg11_ld18, stg11_ld17] -> stg11[16stg11_ld17, -3 + stg11_ld18] : 0 <= stg11_ld18 <= 1925 and 0 <= stg11_ld17 <= 70 }
  // Read schedule : { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  // Write schedule: { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_stg11_1_merged1829_1807 = stg11.stg11_stg11_1_merged1829_1807_to_stg11_stg11_ld17_merged1770_1791.peek(/* one reader or all rams */ 0);
  return value_stg11_stg11_1_merged1829_1807;
  return 0;
}

// # of bundles = 2
// stg11_1_merged1829_write
//	stg11_stg11_1_merged1829_1792
//	stg11_stg11_1_merged1829_1793
//	stg11_stg11_1_merged1829_1794
//	stg11_stg11_1_merged1829_1795
//	stg11_stg11_1_merged1829_1796
//	stg11_stg11_1_merged1829_1797
//	stg11_stg11_1_merged1829_1798
//	stg11_stg11_1_merged1829_1799
//	stg11_stg11_1_merged1829_1800
//	stg11_stg11_1_merged1829_1801
//	stg11_stg11_1_merged1829_1802
//	stg11_stg11_1_merged1829_1803
//	stg11_stg11_1_merged1829_1804
//	stg11_stg11_1_merged1829_1805
//	stg11_stg11_1_merged1829_1806
//	stg11_stg11_1_merged1829_1807
inline void stg11_stg11_1_merged1829_write_bundle_write(hw_uint<256>& stg11_1_merged1829_write, stg11_cache& stg11, int root, int stg11_0, int stg11_1, int dynamic_address) {
	hw_uint<16> stg11_stg11_1_merged1829_1792_res = stg11_1_merged1829_write.extract<0, 15>();
	stg11_stg11_1_merged1829_1792_write(stg11_stg11_1_merged1829_1792_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1793_res = stg11_1_merged1829_write.extract<16, 31>();
	stg11_stg11_1_merged1829_1793_write(stg11_stg11_1_merged1829_1793_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1794_res = stg11_1_merged1829_write.extract<32, 47>();
	stg11_stg11_1_merged1829_1794_write(stg11_stg11_1_merged1829_1794_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1795_res = stg11_1_merged1829_write.extract<48, 63>();
	stg11_stg11_1_merged1829_1795_write(stg11_stg11_1_merged1829_1795_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1796_res = stg11_1_merged1829_write.extract<64, 79>();
	stg11_stg11_1_merged1829_1796_write(stg11_stg11_1_merged1829_1796_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1797_res = stg11_1_merged1829_write.extract<80, 95>();
	stg11_stg11_1_merged1829_1797_write(stg11_stg11_1_merged1829_1797_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1798_res = stg11_1_merged1829_write.extract<96, 111>();
	stg11_stg11_1_merged1829_1798_write(stg11_stg11_1_merged1829_1798_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1799_res = stg11_1_merged1829_write.extract<112, 127>();
	stg11_stg11_1_merged1829_1799_write(stg11_stg11_1_merged1829_1799_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1800_res = stg11_1_merged1829_write.extract<128, 143>();
	stg11_stg11_1_merged1829_1800_write(stg11_stg11_1_merged1829_1800_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1801_res = stg11_1_merged1829_write.extract<144, 159>();
	stg11_stg11_1_merged1829_1801_write(stg11_stg11_1_merged1829_1801_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1802_res = stg11_1_merged1829_write.extract<160, 175>();
	stg11_stg11_1_merged1829_1802_write(stg11_stg11_1_merged1829_1802_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1803_res = stg11_1_merged1829_write.extract<176, 191>();
	stg11_stg11_1_merged1829_1803_write(stg11_stg11_1_merged1829_1803_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1804_res = stg11_1_merged1829_write.extract<192, 207>();
	stg11_stg11_1_merged1829_1804_write(stg11_stg11_1_merged1829_1804_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1805_res = stg11_1_merged1829_write.extract<208, 223>();
	stg11_stg11_1_merged1829_1805_write(stg11_stg11_1_merged1829_1805_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1806_res = stg11_1_merged1829_write.extract<224, 239>();
	stg11_stg11_1_merged1829_1806_write(stg11_stg11_1_merged1829_1806_res, stg11, root, stg11_0, stg11_1, dynamic_address);
	hw_uint<16> stg11_stg11_1_merged1829_1807_res = stg11_1_merged1829_write.extract<240, 255>();
	stg11_stg11_1_merged1829_1807_write(stg11_stg11_1_merged1829_1807_res, stg11, root, stg11_0, stg11_1, dynamic_address);
}

// stg11_ld17_merged1770_read
//	stg11_stg11_ld17_merged1770_1776
//	stg11_stg11_ld17_merged1770_1777
//	stg11_stg11_ld17_merged1770_1778
//	stg11_stg11_ld17_merged1770_1779
//	stg11_stg11_ld17_merged1770_1780
//	stg11_stg11_ld17_merged1770_1781
//	stg11_stg11_ld17_merged1770_1782
//	stg11_stg11_ld17_merged1770_1783
//	stg11_stg11_ld17_merged1770_1784
//	stg11_stg11_ld17_merged1770_1785
//	stg11_stg11_ld17_merged1770_1786
//	stg11_stg11_ld17_merged1770_1787
//	stg11_stg11_ld17_merged1770_1788
//	stg11_stg11_ld17_merged1770_1789
//	stg11_stg11_ld17_merged1770_1790
//	stg11_stg11_ld17_merged1770_1791
inline hw_uint<256> stg11_stg11_ld17_merged1770_read_bundle_read(stg11_cache& stg11, int root, int stg11_ld18, int stg11_ld17, int dynamic_address) {
  // # of ports in bundle: 16
    // stg11_stg11_ld17_merged1770_1776
    // stg11_stg11_ld17_merged1770_1777
    // stg11_stg11_ld17_merged1770_1778
    // stg11_stg11_ld17_merged1770_1779
    // stg11_stg11_ld17_merged1770_1780
    // stg11_stg11_ld17_merged1770_1781
    // stg11_stg11_ld17_merged1770_1782
    // stg11_stg11_ld17_merged1770_1783
    // stg11_stg11_ld17_merged1770_1784
    // stg11_stg11_ld17_merged1770_1785
    // stg11_stg11_ld17_merged1770_1786
    // stg11_stg11_ld17_merged1770_1787
    // stg11_stg11_ld17_merged1770_1788
    // stg11_stg11_ld17_merged1770_1789
    // stg11_stg11_ld17_merged1770_1790
    // stg11_stg11_ld17_merged1770_1791

	hw_uint<256> result;
	hw_uint<16> stg11_stg11_ld17_merged1770_1776_res = stg11_stg11_ld17_merged1770_1776_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<0, 256>(result, stg11_stg11_ld17_merged1770_1776_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1777_res = stg11_stg11_ld17_merged1770_1777_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<16, 256>(result, stg11_stg11_ld17_merged1770_1777_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1778_res = stg11_stg11_ld17_merged1770_1778_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<32, 256>(result, stg11_stg11_ld17_merged1770_1778_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1779_res = stg11_stg11_ld17_merged1770_1779_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<48, 256>(result, stg11_stg11_ld17_merged1770_1779_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1780_res = stg11_stg11_ld17_merged1770_1780_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<64, 256>(result, stg11_stg11_ld17_merged1770_1780_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1781_res = stg11_stg11_ld17_merged1770_1781_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<80, 256>(result, stg11_stg11_ld17_merged1770_1781_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1782_res = stg11_stg11_ld17_merged1770_1782_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<96, 256>(result, stg11_stg11_ld17_merged1770_1782_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1783_res = stg11_stg11_ld17_merged1770_1783_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<112, 256>(result, stg11_stg11_ld17_merged1770_1783_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1784_res = stg11_stg11_ld17_merged1770_1784_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<128, 256>(result, stg11_stg11_ld17_merged1770_1784_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1785_res = stg11_stg11_ld17_merged1770_1785_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<144, 256>(result, stg11_stg11_ld17_merged1770_1785_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1786_res = stg11_stg11_ld17_merged1770_1786_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<160, 256>(result, stg11_stg11_ld17_merged1770_1786_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1787_res = stg11_stg11_ld17_merged1770_1787_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<176, 256>(result, stg11_stg11_ld17_merged1770_1787_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1788_res = stg11_stg11_ld17_merged1770_1788_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<192, 256>(result, stg11_stg11_ld17_merged1770_1788_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1789_res = stg11_stg11_ld17_merged1770_1789_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<208, 256>(result, stg11_stg11_ld17_merged1770_1789_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1790_res = stg11_stg11_ld17_merged1770_1790_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<224, 256>(result, stg11_stg11_ld17_merged1770_1790_res);
	hw_uint<16> stg11_stg11_ld17_merged1770_1791_res = stg11_stg11_ld17_merged1770_1791_select(stg11, root, stg11_ld18, stg11_ld17, dynamic_address);
	set_at<240, 256>(result, stg11_stg11_ld17_merged1770_1791_res);
	return result;
}

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_merged_banks_4_cache {
	// RAM Box: {[15, 1119], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_merged_banks_4_cache {
	// RAM Box: {[14, 1118], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_merged_banks_4_cache {
	// RAM Box: {[13, 1117], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_merged_banks_4_cache {
	// RAM Box: {[12, 1116], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_merged_banks_4_cache {
	// RAM Box: {[11, 1115], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_merged_banks_4_cache {
	// RAM Box: {[10, 1114], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_merged_banks_4_cache {
	// RAM Box: {[9, 1113], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_merged_banks_4_cache {
	// RAM Box: {[8, 1112], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_merged_banks_4_cache {
	// RAM Box: {[7, 1111], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_merged_banks_4_cache {
	// RAM Box: {[6, 1110], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_merged_banks_4_cache {
	// RAM Box: {[5, 1109], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_merged_banks_4_cache {
	// RAM Box: {[4, 1108], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_merged_banks_4_cache {
	// RAM Box: {[3, 1107], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_merged_banks_4_cache {
	// RAM Box: {[2, 1106], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_merged_banks_4_cache {
	// RAM Box: {[1, 1105], [-3, 1922]}
	// Capacity: 144
	// # of read delays: 4
  // 0, 1, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 70> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 70> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_71() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_72() {
		return f4;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_143() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_merged_banks_4_cache {
	// RAM Box: {[0, 1120], [-3, 1921]}
	// Capacity: 144
	// # of read delays: 5
  // 0, 1, 71, 72, 143
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 70> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_72() {
		return f6;
	}

	inline hw_uint<16> peek_142() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_143() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 70
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 70 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg11_FIFO_buf80_cache {
  // Reader addrs...
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[15 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[15 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[16 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[15 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[14 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[14 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[15 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[14 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[13 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[13 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[14 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[13 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[12 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[12 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[13 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[12 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[11 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[11 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[12 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[11 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[10 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[10 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[11 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[10 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[9 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[9 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[10 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[9 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[8 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[8 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[9 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[8 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[7 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[7 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[8 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[7 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[6 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[6 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[7 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[6 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[5 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[5 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[6 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[5 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[4 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[4 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[5 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[4 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[3 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[3 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[4 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[3 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[2 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[2 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[3 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[2 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[1 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[1 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[2 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[1 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[1 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
    // { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // # of banks: 16
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_merged_banks_4;
  stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_merged_banks_4_cache stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_merged_banks_4;
};



inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742);
}

inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_write(hw_uint<16>& stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
  stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_merged_banks_4.push(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743);
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1664_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1664 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[15 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1665_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1665 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[15 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1666_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1666 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[16 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_merged_banks_4.peek_71();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1667_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1667 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[15 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1668_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1668 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[14 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1669_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1669 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[14 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1670_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1670 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[15 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1671_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1671 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[14 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1672_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1672 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[13 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1673_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1673 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[13 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1674_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1674 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[14 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1675_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1675 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[13 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1676_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1676 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[12 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1677_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1677 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[12 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1678_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1678 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[13 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1679_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1679 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[12 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1680_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1680 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[11 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1681_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1681 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[11 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1682_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1682 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[12 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1683_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1683 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[11 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1684_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1684 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[10 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1685_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1685 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[10 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1686_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1686 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[11 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1687_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1687 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[10 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1688_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1688 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[9 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1689_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1689 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[9 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1690_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1690 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[10 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1691_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1691 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[9 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1692_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1692 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[8 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1693_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1693 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[8 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1694_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1694 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[9 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1695_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1695 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[8 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1696_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1696 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[7 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1697_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1697 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[7 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1698_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1698 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[8 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1699_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1699 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[7 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1700_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1700 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[6 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1701_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1701 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[6 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1702_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1702 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[7 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1703_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1703 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[6 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1704_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1704 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[5 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1705_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1705 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[5 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1706_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1706 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[6 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1707_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1707 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[5 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1708_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1708 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[4 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1709_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1709 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[4 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1710_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1710 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[5 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1711_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1711 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[4 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1712_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1712 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[3 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1713_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1713 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[3 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1714_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1714 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[4 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1715_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1715 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[3 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1716_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1716 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[2 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1717_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1717 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[2 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1718_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1718 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[3 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1719_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1719 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[2 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1720_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1720 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[1 + 16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1721_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1721 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[1 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1722_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1722 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[2 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1723_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1723 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[1 + 16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1724_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1724 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[16stg12_1, -3 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_merged_banks_4.peek_143();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1725_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1725 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1726_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1726 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[1 + 16stg12_1, -2 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_merged_banks_4.peek_72();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742;
  return 0;
}

inline hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1727_select(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg11_FIFO_buf80_stg12_1_merged1832_1727 read pattern: { stg12_1_merged1832[root = 0, stg12_0, stg12_1] -> stg11_FIFO_buf80[16stg12_1, -1 + stg12_0] : 0 <= stg12_0 <= 1923 and 0 <= stg12_1 <= 69 }
  // Read schedule : { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
  auto value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743 = stg11_FIFO_buf80.stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_merged_banks_4.peek_1();
  return value_stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743;
  return 0;
}

// # of bundles = 2
// stg11_to_gp_516_ld81_merged1778_write
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742
//	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743
inline void stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_write_bundle_write(hw_uint<256>& stg11_to_gp_516_ld81_merged1778_write, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg11_to_gp_516_ld82, int stg11_to_gp_516_ld81, int dynamic_address) {
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_res = stg11_to_gp_516_ld81_merged1778_write.extract<0, 15>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1728_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_res = stg11_to_gp_516_ld81_merged1778_write.extract<16, 31>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1729_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_res = stg11_to_gp_516_ld81_merged1778_write.extract<32, 47>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1730_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_res = stg11_to_gp_516_ld81_merged1778_write.extract<48, 63>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1731_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_res = stg11_to_gp_516_ld81_merged1778_write.extract<64, 79>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1732_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_res = stg11_to_gp_516_ld81_merged1778_write.extract<80, 95>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1733_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_res = stg11_to_gp_516_ld81_merged1778_write.extract<96, 111>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1734_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_res = stg11_to_gp_516_ld81_merged1778_write.extract<112, 127>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1735_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_res = stg11_to_gp_516_ld81_merged1778_write.extract<128, 143>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1736_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_res = stg11_to_gp_516_ld81_merged1778_write.extract<144, 159>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1737_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_res = stg11_to_gp_516_ld81_merged1778_write.extract<160, 175>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1738_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_res = stg11_to_gp_516_ld81_merged1778_write.extract<176, 191>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1739_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_res = stg11_to_gp_516_ld81_merged1778_write.extract<192, 207>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1740_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_res = stg11_to_gp_516_ld81_merged1778_write.extract<208, 223>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1741_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_res = stg11_to_gp_516_ld81_merged1778_write.extract<224, 239>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1742_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
	hw_uint<16> stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_res = stg11_to_gp_516_ld81_merged1778_write.extract<240, 255>();
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_write(stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_1743_res, stg11_FIFO_buf80, root, stg11_to_gp_516_ld82, stg11_to_gp_516_ld81, dynamic_address);
}

// stg12_1_merged1832_read
//	stg11_FIFO_buf80_stg12_1_merged1832_1664
//	stg11_FIFO_buf80_stg12_1_merged1832_1665
//	stg11_FIFO_buf80_stg12_1_merged1832_1666
//	stg11_FIFO_buf80_stg12_1_merged1832_1667
//	stg11_FIFO_buf80_stg12_1_merged1832_1668
//	stg11_FIFO_buf80_stg12_1_merged1832_1669
//	stg11_FIFO_buf80_stg12_1_merged1832_1670
//	stg11_FIFO_buf80_stg12_1_merged1832_1671
//	stg11_FIFO_buf80_stg12_1_merged1832_1672
//	stg11_FIFO_buf80_stg12_1_merged1832_1673
//	stg11_FIFO_buf80_stg12_1_merged1832_1674
//	stg11_FIFO_buf80_stg12_1_merged1832_1675
//	stg11_FIFO_buf80_stg12_1_merged1832_1676
//	stg11_FIFO_buf80_stg12_1_merged1832_1677
//	stg11_FIFO_buf80_stg12_1_merged1832_1678
//	stg11_FIFO_buf80_stg12_1_merged1832_1679
//	stg11_FIFO_buf80_stg12_1_merged1832_1680
//	stg11_FIFO_buf80_stg12_1_merged1832_1681
//	stg11_FIFO_buf80_stg12_1_merged1832_1682
//	stg11_FIFO_buf80_stg12_1_merged1832_1683
//	stg11_FIFO_buf80_stg12_1_merged1832_1684
//	stg11_FIFO_buf80_stg12_1_merged1832_1685
//	stg11_FIFO_buf80_stg12_1_merged1832_1686
//	stg11_FIFO_buf80_stg12_1_merged1832_1687
//	stg11_FIFO_buf80_stg12_1_merged1832_1688
//	stg11_FIFO_buf80_stg12_1_merged1832_1689
//	stg11_FIFO_buf80_stg12_1_merged1832_1690
//	stg11_FIFO_buf80_stg12_1_merged1832_1691
//	stg11_FIFO_buf80_stg12_1_merged1832_1692
//	stg11_FIFO_buf80_stg12_1_merged1832_1693
//	stg11_FIFO_buf80_stg12_1_merged1832_1694
//	stg11_FIFO_buf80_stg12_1_merged1832_1695
//	stg11_FIFO_buf80_stg12_1_merged1832_1696
//	stg11_FIFO_buf80_stg12_1_merged1832_1697
//	stg11_FIFO_buf80_stg12_1_merged1832_1698
//	stg11_FIFO_buf80_stg12_1_merged1832_1699
//	stg11_FIFO_buf80_stg12_1_merged1832_1700
//	stg11_FIFO_buf80_stg12_1_merged1832_1701
//	stg11_FIFO_buf80_stg12_1_merged1832_1702
//	stg11_FIFO_buf80_stg12_1_merged1832_1703
//	stg11_FIFO_buf80_stg12_1_merged1832_1704
//	stg11_FIFO_buf80_stg12_1_merged1832_1705
//	stg11_FIFO_buf80_stg12_1_merged1832_1706
//	stg11_FIFO_buf80_stg12_1_merged1832_1707
//	stg11_FIFO_buf80_stg12_1_merged1832_1708
//	stg11_FIFO_buf80_stg12_1_merged1832_1709
//	stg11_FIFO_buf80_stg12_1_merged1832_1710
//	stg11_FIFO_buf80_stg12_1_merged1832_1711
//	stg11_FIFO_buf80_stg12_1_merged1832_1712
//	stg11_FIFO_buf80_stg12_1_merged1832_1713
//	stg11_FIFO_buf80_stg12_1_merged1832_1714
//	stg11_FIFO_buf80_stg12_1_merged1832_1715
//	stg11_FIFO_buf80_stg12_1_merged1832_1716
//	stg11_FIFO_buf80_stg12_1_merged1832_1717
//	stg11_FIFO_buf80_stg12_1_merged1832_1718
//	stg11_FIFO_buf80_stg12_1_merged1832_1719
//	stg11_FIFO_buf80_stg12_1_merged1832_1720
//	stg11_FIFO_buf80_stg12_1_merged1832_1721
//	stg11_FIFO_buf80_stg12_1_merged1832_1722
//	stg11_FIFO_buf80_stg12_1_merged1832_1723
//	stg11_FIFO_buf80_stg12_1_merged1832_1724
//	stg11_FIFO_buf80_stg12_1_merged1832_1725
//	stg11_FIFO_buf80_stg12_1_merged1832_1726
//	stg11_FIFO_buf80_stg12_1_merged1832_1727
inline hw_uint<1024> stg11_FIFO_buf80_stg12_1_merged1832_read_bundle_read(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int root, int stg12_0, int stg12_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg11_FIFO_buf80_stg12_1_merged1832_1664
    // stg11_FIFO_buf80_stg12_1_merged1832_1665
    // stg11_FIFO_buf80_stg12_1_merged1832_1666
    // stg11_FIFO_buf80_stg12_1_merged1832_1667
    // stg11_FIFO_buf80_stg12_1_merged1832_1668
    // stg11_FIFO_buf80_stg12_1_merged1832_1669
    // stg11_FIFO_buf80_stg12_1_merged1832_1670
    // stg11_FIFO_buf80_stg12_1_merged1832_1671
    // stg11_FIFO_buf80_stg12_1_merged1832_1672
    // stg11_FIFO_buf80_stg12_1_merged1832_1673
    // stg11_FIFO_buf80_stg12_1_merged1832_1674
    // stg11_FIFO_buf80_stg12_1_merged1832_1675
    // stg11_FIFO_buf80_stg12_1_merged1832_1676
    // stg11_FIFO_buf80_stg12_1_merged1832_1677
    // stg11_FIFO_buf80_stg12_1_merged1832_1678
    // stg11_FIFO_buf80_stg12_1_merged1832_1679
    // stg11_FIFO_buf80_stg12_1_merged1832_1680
    // stg11_FIFO_buf80_stg12_1_merged1832_1681
    // stg11_FIFO_buf80_stg12_1_merged1832_1682
    // stg11_FIFO_buf80_stg12_1_merged1832_1683
    // stg11_FIFO_buf80_stg12_1_merged1832_1684
    // stg11_FIFO_buf80_stg12_1_merged1832_1685
    // stg11_FIFO_buf80_stg12_1_merged1832_1686
    // stg11_FIFO_buf80_stg12_1_merged1832_1687
    // stg11_FIFO_buf80_stg12_1_merged1832_1688
    // stg11_FIFO_buf80_stg12_1_merged1832_1689
    // stg11_FIFO_buf80_stg12_1_merged1832_1690
    // stg11_FIFO_buf80_stg12_1_merged1832_1691
    // stg11_FIFO_buf80_stg12_1_merged1832_1692
    // stg11_FIFO_buf80_stg12_1_merged1832_1693
    // stg11_FIFO_buf80_stg12_1_merged1832_1694
    // stg11_FIFO_buf80_stg12_1_merged1832_1695
    // stg11_FIFO_buf80_stg12_1_merged1832_1696
    // stg11_FIFO_buf80_stg12_1_merged1832_1697
    // stg11_FIFO_buf80_stg12_1_merged1832_1698
    // stg11_FIFO_buf80_stg12_1_merged1832_1699
    // stg11_FIFO_buf80_stg12_1_merged1832_1700
    // stg11_FIFO_buf80_stg12_1_merged1832_1701
    // stg11_FIFO_buf80_stg12_1_merged1832_1702
    // stg11_FIFO_buf80_stg12_1_merged1832_1703
    // stg11_FIFO_buf80_stg12_1_merged1832_1704
    // stg11_FIFO_buf80_stg12_1_merged1832_1705
    // stg11_FIFO_buf80_stg12_1_merged1832_1706
    // stg11_FIFO_buf80_stg12_1_merged1832_1707
    // stg11_FIFO_buf80_stg12_1_merged1832_1708
    // stg11_FIFO_buf80_stg12_1_merged1832_1709
    // stg11_FIFO_buf80_stg12_1_merged1832_1710
    // stg11_FIFO_buf80_stg12_1_merged1832_1711
    // stg11_FIFO_buf80_stg12_1_merged1832_1712
    // stg11_FIFO_buf80_stg12_1_merged1832_1713
    // stg11_FIFO_buf80_stg12_1_merged1832_1714
    // stg11_FIFO_buf80_stg12_1_merged1832_1715
    // stg11_FIFO_buf80_stg12_1_merged1832_1716
    // stg11_FIFO_buf80_stg12_1_merged1832_1717
    // stg11_FIFO_buf80_stg12_1_merged1832_1718
    // stg11_FIFO_buf80_stg12_1_merged1832_1719
    // stg11_FIFO_buf80_stg12_1_merged1832_1720
    // stg11_FIFO_buf80_stg12_1_merged1832_1721
    // stg11_FIFO_buf80_stg12_1_merged1832_1722
    // stg11_FIFO_buf80_stg12_1_merged1832_1723
    // stg11_FIFO_buf80_stg12_1_merged1832_1724
    // stg11_FIFO_buf80_stg12_1_merged1832_1725
    // stg11_FIFO_buf80_stg12_1_merged1832_1726
    // stg11_FIFO_buf80_stg12_1_merged1832_1727

	hw_uint<1024> result;
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1664_res = stg11_FIFO_buf80_stg12_1_merged1832_1664_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<0, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1664_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1665_res = stg11_FIFO_buf80_stg12_1_merged1832_1665_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<16, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1665_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1666_res = stg11_FIFO_buf80_stg12_1_merged1832_1666_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<32, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1666_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1667_res = stg11_FIFO_buf80_stg12_1_merged1832_1667_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<48, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1667_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1668_res = stg11_FIFO_buf80_stg12_1_merged1832_1668_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<64, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1668_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1669_res = stg11_FIFO_buf80_stg12_1_merged1832_1669_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<80, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1669_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1670_res = stg11_FIFO_buf80_stg12_1_merged1832_1670_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<96, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1670_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1671_res = stg11_FIFO_buf80_stg12_1_merged1832_1671_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<112, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1671_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1672_res = stg11_FIFO_buf80_stg12_1_merged1832_1672_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<128, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1672_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1673_res = stg11_FIFO_buf80_stg12_1_merged1832_1673_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<144, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1673_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1674_res = stg11_FIFO_buf80_stg12_1_merged1832_1674_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<160, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1674_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1675_res = stg11_FIFO_buf80_stg12_1_merged1832_1675_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<176, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1675_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1676_res = stg11_FIFO_buf80_stg12_1_merged1832_1676_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<192, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1676_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1677_res = stg11_FIFO_buf80_stg12_1_merged1832_1677_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<208, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1677_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1678_res = stg11_FIFO_buf80_stg12_1_merged1832_1678_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<224, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1678_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1679_res = stg11_FIFO_buf80_stg12_1_merged1832_1679_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<240, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1679_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1680_res = stg11_FIFO_buf80_stg12_1_merged1832_1680_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<256, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1680_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1681_res = stg11_FIFO_buf80_stg12_1_merged1832_1681_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<272, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1681_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1682_res = stg11_FIFO_buf80_stg12_1_merged1832_1682_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<288, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1682_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1683_res = stg11_FIFO_buf80_stg12_1_merged1832_1683_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<304, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1683_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1684_res = stg11_FIFO_buf80_stg12_1_merged1832_1684_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<320, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1684_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1685_res = stg11_FIFO_buf80_stg12_1_merged1832_1685_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<336, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1685_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1686_res = stg11_FIFO_buf80_stg12_1_merged1832_1686_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<352, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1686_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1687_res = stg11_FIFO_buf80_stg12_1_merged1832_1687_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<368, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1687_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1688_res = stg11_FIFO_buf80_stg12_1_merged1832_1688_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<384, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1688_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1689_res = stg11_FIFO_buf80_stg12_1_merged1832_1689_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<400, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1689_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1690_res = stg11_FIFO_buf80_stg12_1_merged1832_1690_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<416, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1690_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1691_res = stg11_FIFO_buf80_stg12_1_merged1832_1691_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<432, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1691_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1692_res = stg11_FIFO_buf80_stg12_1_merged1832_1692_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<448, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1692_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1693_res = stg11_FIFO_buf80_stg12_1_merged1832_1693_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<464, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1693_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1694_res = stg11_FIFO_buf80_stg12_1_merged1832_1694_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<480, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1694_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1695_res = stg11_FIFO_buf80_stg12_1_merged1832_1695_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<496, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1695_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1696_res = stg11_FIFO_buf80_stg12_1_merged1832_1696_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<512, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1696_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1697_res = stg11_FIFO_buf80_stg12_1_merged1832_1697_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<528, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1697_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1698_res = stg11_FIFO_buf80_stg12_1_merged1832_1698_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<544, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1698_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1699_res = stg11_FIFO_buf80_stg12_1_merged1832_1699_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<560, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1699_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1700_res = stg11_FIFO_buf80_stg12_1_merged1832_1700_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<576, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1700_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1701_res = stg11_FIFO_buf80_stg12_1_merged1832_1701_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<592, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1701_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1702_res = stg11_FIFO_buf80_stg12_1_merged1832_1702_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<608, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1702_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1703_res = stg11_FIFO_buf80_stg12_1_merged1832_1703_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<624, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1703_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1704_res = stg11_FIFO_buf80_stg12_1_merged1832_1704_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<640, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1704_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1705_res = stg11_FIFO_buf80_stg12_1_merged1832_1705_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<656, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1705_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1706_res = stg11_FIFO_buf80_stg12_1_merged1832_1706_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<672, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1706_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1707_res = stg11_FIFO_buf80_stg12_1_merged1832_1707_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<688, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1707_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1708_res = stg11_FIFO_buf80_stg12_1_merged1832_1708_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<704, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1708_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1709_res = stg11_FIFO_buf80_stg12_1_merged1832_1709_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<720, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1709_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1710_res = stg11_FIFO_buf80_stg12_1_merged1832_1710_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<736, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1710_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1711_res = stg11_FIFO_buf80_stg12_1_merged1832_1711_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<752, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1711_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1712_res = stg11_FIFO_buf80_stg12_1_merged1832_1712_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<768, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1712_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1713_res = stg11_FIFO_buf80_stg12_1_merged1832_1713_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<784, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1713_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1714_res = stg11_FIFO_buf80_stg12_1_merged1832_1714_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<800, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1714_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1715_res = stg11_FIFO_buf80_stg12_1_merged1832_1715_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<816, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1715_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1716_res = stg11_FIFO_buf80_stg12_1_merged1832_1716_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<832, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1716_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1717_res = stg11_FIFO_buf80_stg12_1_merged1832_1717_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<848, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1717_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1718_res = stg11_FIFO_buf80_stg12_1_merged1832_1718_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<864, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1718_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1719_res = stg11_FIFO_buf80_stg12_1_merged1832_1719_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<880, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1719_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1720_res = stg11_FIFO_buf80_stg12_1_merged1832_1720_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<896, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1720_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1721_res = stg11_FIFO_buf80_stg12_1_merged1832_1721_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<912, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1721_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1722_res = stg11_FIFO_buf80_stg12_1_merged1832_1722_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<928, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1722_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1723_res = stg11_FIFO_buf80_stg12_1_merged1832_1723_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<944, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1723_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1724_res = stg11_FIFO_buf80_stg12_1_merged1832_1724_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<960, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1724_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1725_res = stg11_FIFO_buf80_stg12_1_merged1832_1725_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<976, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1725_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1726_res = stg11_FIFO_buf80_stg12_1_merged1832_1726_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<992, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1726_res);
	hw_uint<16> stg11_FIFO_buf80_stg12_1_merged1832_1727_res = stg11_FIFO_buf80_stg12_1_merged1832_1727_select(stg11_FIFO_buf80, root, stg12_0, stg12_1, dynamic_address);
	set_at<1008, 1024>(result, stg11_FIFO_buf80_stg12_1_merged1832_1727_res);
	return result;
}

struct stg12_stg12_1_merged1832_1648_to_stg12_stg12_ld21_merged1772_1632_cache {
	// RAM Box: {[15, 1119], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1649_to_stg12_stg12_ld21_merged1772_1633_cache {
	// RAM Box: {[14, 1118], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1650_to_stg12_stg12_ld21_merged1772_1634_cache {
	// RAM Box: {[13, 1117], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1651_to_stg12_stg12_ld21_merged1772_1635_cache {
	// RAM Box: {[12, 1116], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1652_to_stg12_stg12_ld21_merged1772_1636_cache {
	// RAM Box: {[11, 1115], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1653_to_stg12_stg12_ld21_merged1772_1637_cache {
	// RAM Box: {[10, 1114], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1654_to_stg12_stg12_ld21_merged1772_1638_cache {
	// RAM Box: {[9, 1113], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1655_to_stg12_stg12_ld21_merged1772_1639_cache {
	// RAM Box: {[8, 1112], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1656_to_stg12_stg12_ld21_merged1772_1640_cache {
	// RAM Box: {[7, 1111], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1657_to_stg12_stg12_ld21_merged1772_1641_cache {
	// RAM Box: {[6, 1110], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1658_to_stg12_stg12_ld21_merged1772_1642_cache {
	// RAM Box: {[5, 1109], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1659_to_stg12_stg12_ld21_merged1772_1643_cache {
	// RAM Box: {[4, 1108], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1660_to_stg12_stg12_ld21_merged1772_1644_cache {
	// RAM Box: {[3, 1107], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1661_to_stg12_stg12_ld21_merged1772_1645_cache {
	// RAM Box: {[2, 1106], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1662_to_stg12_stg12_ld21_merged1772_1646_cache {
	// RAM Box: {[1, 1105], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_stg12_1_merged1832_1663_to_stg12_stg12_ld21_merged1772_1647_cache {
	// RAM Box: {[0, 1104], [-2, 1921]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg12_cache {
  // Reader addrs...
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[15 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[14 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[13 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[12 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[11 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[10 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[9 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[8 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[7 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[6 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[5 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[4 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[3 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[2 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[1 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
    // { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // # of banks: 16
  stg12_stg12_1_merged1832_1648_to_stg12_stg12_ld21_merged1772_1632_cache stg12_stg12_1_merged1832_1648_to_stg12_stg12_ld21_merged1772_1632;
  stg12_stg12_1_merged1832_1649_to_stg12_stg12_ld21_merged1772_1633_cache stg12_stg12_1_merged1832_1649_to_stg12_stg12_ld21_merged1772_1633;
  stg12_stg12_1_merged1832_1650_to_stg12_stg12_ld21_merged1772_1634_cache stg12_stg12_1_merged1832_1650_to_stg12_stg12_ld21_merged1772_1634;
  stg12_stg12_1_merged1832_1651_to_stg12_stg12_ld21_merged1772_1635_cache stg12_stg12_1_merged1832_1651_to_stg12_stg12_ld21_merged1772_1635;
  stg12_stg12_1_merged1832_1652_to_stg12_stg12_ld21_merged1772_1636_cache stg12_stg12_1_merged1832_1652_to_stg12_stg12_ld21_merged1772_1636;
  stg12_stg12_1_merged1832_1653_to_stg12_stg12_ld21_merged1772_1637_cache stg12_stg12_1_merged1832_1653_to_stg12_stg12_ld21_merged1772_1637;
  stg12_stg12_1_merged1832_1654_to_stg12_stg12_ld21_merged1772_1638_cache stg12_stg12_1_merged1832_1654_to_stg12_stg12_ld21_merged1772_1638;
  stg12_stg12_1_merged1832_1655_to_stg12_stg12_ld21_merged1772_1639_cache stg12_stg12_1_merged1832_1655_to_stg12_stg12_ld21_merged1772_1639;
  stg12_stg12_1_merged1832_1656_to_stg12_stg12_ld21_merged1772_1640_cache stg12_stg12_1_merged1832_1656_to_stg12_stg12_ld21_merged1772_1640;
  stg12_stg12_1_merged1832_1657_to_stg12_stg12_ld21_merged1772_1641_cache stg12_stg12_1_merged1832_1657_to_stg12_stg12_ld21_merged1772_1641;
  stg12_stg12_1_merged1832_1658_to_stg12_stg12_ld21_merged1772_1642_cache stg12_stg12_1_merged1832_1658_to_stg12_stg12_ld21_merged1772_1642;
  stg12_stg12_1_merged1832_1659_to_stg12_stg12_ld21_merged1772_1643_cache stg12_stg12_1_merged1832_1659_to_stg12_stg12_ld21_merged1772_1643;
  stg12_stg12_1_merged1832_1660_to_stg12_stg12_ld21_merged1772_1644_cache stg12_stg12_1_merged1832_1660_to_stg12_stg12_ld21_merged1772_1644;
  stg12_stg12_1_merged1832_1661_to_stg12_stg12_ld21_merged1772_1645_cache stg12_stg12_1_merged1832_1661_to_stg12_stg12_ld21_merged1772_1645;
  stg12_stg12_1_merged1832_1662_to_stg12_stg12_ld21_merged1772_1646_cache stg12_stg12_1_merged1832_1662_to_stg12_stg12_ld21_merged1772_1646;
  stg12_stg12_1_merged1832_1663_to_stg12_stg12_ld21_merged1772_1647_cache stg12_stg12_1_merged1832_1663_to_stg12_stg12_ld21_merged1772_1647;
};



inline void stg12_stg12_1_merged1832_1648_write(hw_uint<16>& stg12_stg12_1_merged1832_1648, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1648_to_stg12_stg12_ld21_merged1772_1632.push(stg12_stg12_1_merged1832_1648);
}

inline void stg12_stg12_1_merged1832_1649_write(hw_uint<16>& stg12_stg12_1_merged1832_1649, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1649_to_stg12_stg12_ld21_merged1772_1633.push(stg12_stg12_1_merged1832_1649);
}

inline void stg12_stg12_1_merged1832_1650_write(hw_uint<16>& stg12_stg12_1_merged1832_1650, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1650_to_stg12_stg12_ld21_merged1772_1634.push(stg12_stg12_1_merged1832_1650);
}

inline void stg12_stg12_1_merged1832_1651_write(hw_uint<16>& stg12_stg12_1_merged1832_1651, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1651_to_stg12_stg12_ld21_merged1772_1635.push(stg12_stg12_1_merged1832_1651);
}

inline void stg12_stg12_1_merged1832_1652_write(hw_uint<16>& stg12_stg12_1_merged1832_1652, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1652_to_stg12_stg12_ld21_merged1772_1636.push(stg12_stg12_1_merged1832_1652);
}

inline void stg12_stg12_1_merged1832_1653_write(hw_uint<16>& stg12_stg12_1_merged1832_1653, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1653_to_stg12_stg12_ld21_merged1772_1637.push(stg12_stg12_1_merged1832_1653);
}

inline void stg12_stg12_1_merged1832_1654_write(hw_uint<16>& stg12_stg12_1_merged1832_1654, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1654_to_stg12_stg12_ld21_merged1772_1638.push(stg12_stg12_1_merged1832_1654);
}

inline void stg12_stg12_1_merged1832_1655_write(hw_uint<16>& stg12_stg12_1_merged1832_1655, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1655_to_stg12_stg12_ld21_merged1772_1639.push(stg12_stg12_1_merged1832_1655);
}

inline void stg12_stg12_1_merged1832_1656_write(hw_uint<16>& stg12_stg12_1_merged1832_1656, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1656_to_stg12_stg12_ld21_merged1772_1640.push(stg12_stg12_1_merged1832_1656);
}

inline void stg12_stg12_1_merged1832_1657_write(hw_uint<16>& stg12_stg12_1_merged1832_1657, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1657_to_stg12_stg12_ld21_merged1772_1641.push(stg12_stg12_1_merged1832_1657);
}

inline void stg12_stg12_1_merged1832_1658_write(hw_uint<16>& stg12_stg12_1_merged1832_1658, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1658_to_stg12_stg12_ld21_merged1772_1642.push(stg12_stg12_1_merged1832_1658);
}

inline void stg12_stg12_1_merged1832_1659_write(hw_uint<16>& stg12_stg12_1_merged1832_1659, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1659_to_stg12_stg12_ld21_merged1772_1643.push(stg12_stg12_1_merged1832_1659);
}

inline void stg12_stg12_1_merged1832_1660_write(hw_uint<16>& stg12_stg12_1_merged1832_1660, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1660_to_stg12_stg12_ld21_merged1772_1644.push(stg12_stg12_1_merged1832_1660);
}

inline void stg12_stg12_1_merged1832_1661_write(hw_uint<16>& stg12_stg12_1_merged1832_1661, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1661_to_stg12_stg12_ld21_merged1772_1645.push(stg12_stg12_1_merged1832_1661);
}

inline void stg12_stg12_1_merged1832_1662_write(hw_uint<16>& stg12_stg12_1_merged1832_1662, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1662_to_stg12_stg12_ld21_merged1772_1646.push(stg12_stg12_1_merged1832_1662);
}

inline void stg12_stg12_1_merged1832_1663_write(hw_uint<16>& stg12_stg12_1_merged1832_1663, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
  stg12.stg12_stg12_1_merged1832_1663_to_stg12_stg12_ld21_merged1772_1647.push(stg12_stg12_1_merged1832_1663);
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1632_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1632 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[15 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1648 = stg12.stg12_stg12_1_merged1832_1648_to_stg12_stg12_ld21_merged1772_1632.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1648;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1633_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1633 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[14 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1649 = stg12.stg12_stg12_1_merged1832_1649_to_stg12_stg12_ld21_merged1772_1633.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1649;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1634_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1634 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[13 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1650 = stg12.stg12_stg12_1_merged1832_1650_to_stg12_stg12_ld21_merged1772_1634.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1650;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1635_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1635 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[12 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1651 = stg12.stg12_stg12_1_merged1832_1651_to_stg12_stg12_ld21_merged1772_1635.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1651;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1636_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1636 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[11 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1652 = stg12.stg12_stg12_1_merged1832_1652_to_stg12_stg12_ld21_merged1772_1636.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1652;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1637_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1637 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[10 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1653 = stg12.stg12_stg12_1_merged1832_1653_to_stg12_stg12_ld21_merged1772_1637.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1653;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1638_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1638 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[9 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1654 = stg12.stg12_stg12_1_merged1832_1654_to_stg12_stg12_ld21_merged1772_1638.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1654;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1639_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1639 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[8 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1655 = stg12.stg12_stg12_1_merged1832_1655_to_stg12_stg12_ld21_merged1772_1639.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1655;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1640_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1640 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[7 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1656 = stg12.stg12_stg12_1_merged1832_1656_to_stg12_stg12_ld21_merged1772_1640.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1656;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1641_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1641 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[6 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1657 = stg12.stg12_stg12_1_merged1832_1657_to_stg12_stg12_ld21_merged1772_1641.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1657;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1642_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1642 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[5 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1658 = stg12.stg12_stg12_1_merged1832_1658_to_stg12_stg12_ld21_merged1772_1642.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1658;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1643_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1643 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[4 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1659 = stg12.stg12_stg12_1_merged1832_1659_to_stg12_stg12_ld21_merged1772_1643.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1659;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1644_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1644 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[3 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1660 = stg12.stg12_stg12_1_merged1832_1660_to_stg12_stg12_ld21_merged1772_1644.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1660;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1645_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1645 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[2 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1661 = stg12.stg12_stg12_1_merged1832_1661_to_stg12_stg12_ld21_merged1772_1645.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1661;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1646_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1646 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[1 + 16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1662 = stg12.stg12_stg12_1_merged1832_1662_to_stg12_stg12_ld21_merged1772_1646.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1662;
  return 0;
}

inline hw_uint<16> stg12_stg12_ld21_merged1772_1647_select(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_stg12_ld21_merged1772_1647 read pattern: { stg12_ld21_merged1772[root = 0, stg12_ld22, stg12_ld21] -> stg12[16stg12_ld21, -2 + stg12_ld22] : 0 <= stg12_ld22 <= 1923 and 0 <= stg12_ld21 <= 69 }
  // Read schedule : { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  // Write schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_stg12_1_merged1832_1663 = stg12.stg12_stg12_1_merged1832_1663_to_stg12_stg12_ld21_merged1772_1647.peek(/* one reader or all rams */ 0);
  return value_stg12_stg12_1_merged1832_1663;
  return 0;
}

// # of bundles = 2
// stg12_1_merged1832_write
//	stg12_stg12_1_merged1832_1648
//	stg12_stg12_1_merged1832_1649
//	stg12_stg12_1_merged1832_1650
//	stg12_stg12_1_merged1832_1651
//	stg12_stg12_1_merged1832_1652
//	stg12_stg12_1_merged1832_1653
//	stg12_stg12_1_merged1832_1654
//	stg12_stg12_1_merged1832_1655
//	stg12_stg12_1_merged1832_1656
//	stg12_stg12_1_merged1832_1657
//	stg12_stg12_1_merged1832_1658
//	stg12_stg12_1_merged1832_1659
//	stg12_stg12_1_merged1832_1660
//	stg12_stg12_1_merged1832_1661
//	stg12_stg12_1_merged1832_1662
//	stg12_stg12_1_merged1832_1663
inline void stg12_stg12_1_merged1832_write_bundle_write(hw_uint<256>& stg12_1_merged1832_write, stg12_cache& stg12, int root, int stg12_0, int stg12_1, int dynamic_address) {
	hw_uint<16> stg12_stg12_1_merged1832_1648_res = stg12_1_merged1832_write.extract<0, 15>();
	stg12_stg12_1_merged1832_1648_write(stg12_stg12_1_merged1832_1648_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1649_res = stg12_1_merged1832_write.extract<16, 31>();
	stg12_stg12_1_merged1832_1649_write(stg12_stg12_1_merged1832_1649_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1650_res = stg12_1_merged1832_write.extract<32, 47>();
	stg12_stg12_1_merged1832_1650_write(stg12_stg12_1_merged1832_1650_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1651_res = stg12_1_merged1832_write.extract<48, 63>();
	stg12_stg12_1_merged1832_1651_write(stg12_stg12_1_merged1832_1651_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1652_res = stg12_1_merged1832_write.extract<64, 79>();
	stg12_stg12_1_merged1832_1652_write(stg12_stg12_1_merged1832_1652_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1653_res = stg12_1_merged1832_write.extract<80, 95>();
	stg12_stg12_1_merged1832_1653_write(stg12_stg12_1_merged1832_1653_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1654_res = stg12_1_merged1832_write.extract<96, 111>();
	stg12_stg12_1_merged1832_1654_write(stg12_stg12_1_merged1832_1654_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1655_res = stg12_1_merged1832_write.extract<112, 127>();
	stg12_stg12_1_merged1832_1655_write(stg12_stg12_1_merged1832_1655_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1656_res = stg12_1_merged1832_write.extract<128, 143>();
	stg12_stg12_1_merged1832_1656_write(stg12_stg12_1_merged1832_1656_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1657_res = stg12_1_merged1832_write.extract<144, 159>();
	stg12_stg12_1_merged1832_1657_write(stg12_stg12_1_merged1832_1657_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1658_res = stg12_1_merged1832_write.extract<160, 175>();
	stg12_stg12_1_merged1832_1658_write(stg12_stg12_1_merged1832_1658_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1659_res = stg12_1_merged1832_write.extract<176, 191>();
	stg12_stg12_1_merged1832_1659_write(stg12_stg12_1_merged1832_1659_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1660_res = stg12_1_merged1832_write.extract<192, 207>();
	stg12_stg12_1_merged1832_1660_write(stg12_stg12_1_merged1832_1660_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1661_res = stg12_1_merged1832_write.extract<208, 223>();
	stg12_stg12_1_merged1832_1661_write(stg12_stg12_1_merged1832_1661_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1662_res = stg12_1_merged1832_write.extract<224, 239>();
	stg12_stg12_1_merged1832_1662_write(stg12_stg12_1_merged1832_1662_res, stg12, root, stg12_0, stg12_1, dynamic_address);
	hw_uint<16> stg12_stg12_1_merged1832_1663_res = stg12_1_merged1832_write.extract<240, 255>();
	stg12_stg12_1_merged1832_1663_write(stg12_stg12_1_merged1832_1663_res, stg12, root, stg12_0, stg12_1, dynamic_address);
}

// stg12_ld21_merged1772_read
//	stg12_stg12_ld21_merged1772_1632
//	stg12_stg12_ld21_merged1772_1633
//	stg12_stg12_ld21_merged1772_1634
//	stg12_stg12_ld21_merged1772_1635
//	stg12_stg12_ld21_merged1772_1636
//	stg12_stg12_ld21_merged1772_1637
//	stg12_stg12_ld21_merged1772_1638
//	stg12_stg12_ld21_merged1772_1639
//	stg12_stg12_ld21_merged1772_1640
//	stg12_stg12_ld21_merged1772_1641
//	stg12_stg12_ld21_merged1772_1642
//	stg12_stg12_ld21_merged1772_1643
//	stg12_stg12_ld21_merged1772_1644
//	stg12_stg12_ld21_merged1772_1645
//	stg12_stg12_ld21_merged1772_1646
//	stg12_stg12_ld21_merged1772_1647
inline hw_uint<256> stg12_stg12_ld21_merged1772_read_bundle_read(stg12_cache& stg12, int root, int stg12_ld22, int stg12_ld21, int dynamic_address) {
  // # of ports in bundle: 16
    // stg12_stg12_ld21_merged1772_1632
    // stg12_stg12_ld21_merged1772_1633
    // stg12_stg12_ld21_merged1772_1634
    // stg12_stg12_ld21_merged1772_1635
    // stg12_stg12_ld21_merged1772_1636
    // stg12_stg12_ld21_merged1772_1637
    // stg12_stg12_ld21_merged1772_1638
    // stg12_stg12_ld21_merged1772_1639
    // stg12_stg12_ld21_merged1772_1640
    // stg12_stg12_ld21_merged1772_1641
    // stg12_stg12_ld21_merged1772_1642
    // stg12_stg12_ld21_merged1772_1643
    // stg12_stg12_ld21_merged1772_1644
    // stg12_stg12_ld21_merged1772_1645
    // stg12_stg12_ld21_merged1772_1646
    // stg12_stg12_ld21_merged1772_1647

	hw_uint<256> result;
	hw_uint<16> stg12_stg12_ld21_merged1772_1632_res = stg12_stg12_ld21_merged1772_1632_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<0, 256>(result, stg12_stg12_ld21_merged1772_1632_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1633_res = stg12_stg12_ld21_merged1772_1633_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<16, 256>(result, stg12_stg12_ld21_merged1772_1633_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1634_res = stg12_stg12_ld21_merged1772_1634_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<32, 256>(result, stg12_stg12_ld21_merged1772_1634_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1635_res = stg12_stg12_ld21_merged1772_1635_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<48, 256>(result, stg12_stg12_ld21_merged1772_1635_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1636_res = stg12_stg12_ld21_merged1772_1636_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<64, 256>(result, stg12_stg12_ld21_merged1772_1636_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1637_res = stg12_stg12_ld21_merged1772_1637_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<80, 256>(result, stg12_stg12_ld21_merged1772_1637_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1638_res = stg12_stg12_ld21_merged1772_1638_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<96, 256>(result, stg12_stg12_ld21_merged1772_1638_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1639_res = stg12_stg12_ld21_merged1772_1639_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<112, 256>(result, stg12_stg12_ld21_merged1772_1639_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1640_res = stg12_stg12_ld21_merged1772_1640_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<128, 256>(result, stg12_stg12_ld21_merged1772_1640_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1641_res = stg12_stg12_ld21_merged1772_1641_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<144, 256>(result, stg12_stg12_ld21_merged1772_1641_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1642_res = stg12_stg12_ld21_merged1772_1642_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<160, 256>(result, stg12_stg12_ld21_merged1772_1642_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1643_res = stg12_stg12_ld21_merged1772_1643_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<176, 256>(result, stg12_stg12_ld21_merged1772_1643_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1644_res = stg12_stg12_ld21_merged1772_1644_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<192, 256>(result, stg12_stg12_ld21_merged1772_1644_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1645_res = stg12_stg12_ld21_merged1772_1645_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<208, 256>(result, stg12_stg12_ld21_merged1772_1645_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1646_res = stg12_stg12_ld21_merged1772_1646_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<224, 256>(result, stg12_stg12_ld21_merged1772_1646_res);
	hw_uint<16> stg12_stg12_ld21_merged1772_1647_res = stg12_stg12_ld21_merged1772_1647_select(stg12, root, stg12_ld22, stg12_ld21, dynamic_address);
	set_at<240, 256>(result, stg12_stg12_ld21_merged1772_1647_res);
	return result;
}

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_merged_banks_4_cache {
	// RAM Box: {[15, 1103], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_merged_banks_4_cache {
	// RAM Box: {[14, 1102], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_merged_banks_4_cache {
	// RAM Box: {[13, 1101], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_merged_banks_4_cache {
	// RAM Box: {[12, 1100], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_merged_banks_4_cache {
	// RAM Box: {[11, 1099], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_merged_banks_4_cache {
	// RAM Box: {[10, 1098], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_merged_banks_4_cache {
	// RAM Box: {[9, 1097], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_merged_banks_4_cache {
	// RAM Box: {[8, 1096], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_merged_banks_4_cache {
	// RAM Box: {[7, 1095], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_merged_banks_4_cache {
	// RAM Box: {[6, 1094], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_merged_banks_4_cache {
	// RAM Box: {[5, 1093], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_merged_banks_4_cache {
	// RAM Box: {[4, 1092], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_merged_banks_4_cache {
	// RAM Box: {[3, 1091], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_merged_banks_4_cache {
	// RAM Box: {[2, 1090], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_merged_banks_4_cache {
	// RAM Box: {[1, 1089], [-2, 1921]}
	// Capacity: 142
	// # of read delays: 4
  // 0, 1, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 69> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 69> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_70() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_71() {
		return f4;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_141() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_merged_banks_4_cache {
	// RAM Box: {[0, 1104], [-2, 1920]}
	// Capacity: 142
	// # of read delays: 5
  // 0, 1, 70, 71, 141
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 69> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_71() {
		return f6;
	}

	inline hw_uint<16> peek_140() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_141() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 69
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 69 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg12_FIFO_buf84_cache {
  // Reader addrs...
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[15 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[15 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[16 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[15 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[14 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[14 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[15 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[14 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[13 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[13 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[14 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[13 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[12 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[12 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[13 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[12 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[11 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[11 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[12 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[11 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[10 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[10 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[11 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[10 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[9 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[9 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[10 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[9 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[8 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[8 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[9 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[8 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[7 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[7 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[8 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[7 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[6 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[6 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[7 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[6 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[5 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[5 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[6 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[5 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[4 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[4 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[5 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[4 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[3 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[3 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[4 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[3 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[2 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[2 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[3 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[2 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[1 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[1 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[2 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[1 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[1 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
    // { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // # of banks: 16
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_merged_banks_4;
  stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_merged_banks_4_cache stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_merged_banks_4;
};



inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598);
}

inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_write(hw_uint<16>& stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
  stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_merged_banks_4.push(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599);
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1520_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1520 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[15 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1521_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1521 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[15 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1522_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1522 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[16 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_merged_banks_4.peek_70();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1523_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1523 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[15 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1524_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1524 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[14 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1525_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1525 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[14 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1526_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1526 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[15 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1527_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1527 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[14 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1528_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1528 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[13 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1529_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1529 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[13 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1530_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1530 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[14 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1531_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1531 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[13 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1532_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1532 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[12 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1533_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1533 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[12 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1534_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1534 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[13 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1535_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1535 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[12 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1536_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1536 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[11 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1537_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1537 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[11 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1538_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1538 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[12 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1539_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1539 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[11 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1540_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1540 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[10 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1541_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1541 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[10 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1542_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1542 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[11 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1543_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1543 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[10 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1544_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1544 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[9 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1545_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1545 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[9 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1546_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1546 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[10 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1547_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1547 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[9 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1548_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1548 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[8 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1549_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1549 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[8 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1550_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1550 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[9 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1551_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1551 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[8 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1552_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1552 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[7 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1553_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1553 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[7 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1554_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1554 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[8 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1555_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1555 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[7 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1556_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1556 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[6 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1557_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1557 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[6 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1558_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1558 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[7 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1559_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1559 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[6 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1560_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1560 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[5 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1561_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1561 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[5 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1562_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1562 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[6 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1563_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1563 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[5 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1564_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1564 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[4 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1565_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1565 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[4 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1566_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1566 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[5 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1567_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1567 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[4 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1568_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1568 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[3 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1569_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1569 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[3 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1570_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1570 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[4 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1571_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1571 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[3 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1572_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1572 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[2 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1573_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1573 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[2 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1574_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1574 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[3 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1575_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1575 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[2 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1576_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1576 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[1 + 16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1577_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1577 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[1 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1578_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1578 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[2 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1579_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1579 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[1 + 16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1580_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1580 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[16stg13_1, -2 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_merged_banks_4.peek_141();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1581_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1581 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1582_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1582 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[1 + 16stg13_1, -1 + stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_merged_banks_4.peek_71();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598;
  return 0;
}

inline hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1583_select(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg12_FIFO_buf84_stg13_1_merged1835_1583 read pattern: { stg13_1_merged1835[root = 0, stg13_0, stg13_1] -> stg12_FIFO_buf84[16stg13_1, stg13_0] : 0 <= stg13_0 <= 1921 and 0 <= stg13_1 <= 68 }
  // Read schedule : { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
  auto value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599 = stg12_FIFO_buf84.stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_merged_banks_4.peek_1();
  return value_stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599;
  return 0;
}

// # of bundles = 2
// stg12_to_gp_620_ld85_merged1756_write
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598
//	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599
inline void stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_write_bundle_write(hw_uint<256>& stg12_to_gp_620_ld85_merged1756_write, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg12_to_gp_620_ld86, int stg12_to_gp_620_ld85, int dynamic_address) {
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_res = stg12_to_gp_620_ld85_merged1756_write.extract<0, 15>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1584_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_res = stg12_to_gp_620_ld85_merged1756_write.extract<16, 31>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1585_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_res = stg12_to_gp_620_ld85_merged1756_write.extract<32, 47>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1586_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_res = stg12_to_gp_620_ld85_merged1756_write.extract<48, 63>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1587_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_res = stg12_to_gp_620_ld85_merged1756_write.extract<64, 79>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1588_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_res = stg12_to_gp_620_ld85_merged1756_write.extract<80, 95>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1589_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_res = stg12_to_gp_620_ld85_merged1756_write.extract<96, 111>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1590_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_res = stg12_to_gp_620_ld85_merged1756_write.extract<112, 127>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1591_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_res = stg12_to_gp_620_ld85_merged1756_write.extract<128, 143>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1592_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_res = stg12_to_gp_620_ld85_merged1756_write.extract<144, 159>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1593_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_res = stg12_to_gp_620_ld85_merged1756_write.extract<160, 175>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1594_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_res = stg12_to_gp_620_ld85_merged1756_write.extract<176, 191>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1595_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_res = stg12_to_gp_620_ld85_merged1756_write.extract<192, 207>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1596_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_res = stg12_to_gp_620_ld85_merged1756_write.extract<208, 223>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1597_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_res = stg12_to_gp_620_ld85_merged1756_write.extract<224, 239>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1598_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
	hw_uint<16> stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_res = stg12_to_gp_620_ld85_merged1756_write.extract<240, 255>();
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_write(stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_1599_res, stg12_FIFO_buf84, root, stg12_to_gp_620_ld86, stg12_to_gp_620_ld85, dynamic_address);
}

// stg13_1_merged1835_read
//	stg12_FIFO_buf84_stg13_1_merged1835_1520
//	stg12_FIFO_buf84_stg13_1_merged1835_1521
//	stg12_FIFO_buf84_stg13_1_merged1835_1522
//	stg12_FIFO_buf84_stg13_1_merged1835_1523
//	stg12_FIFO_buf84_stg13_1_merged1835_1524
//	stg12_FIFO_buf84_stg13_1_merged1835_1525
//	stg12_FIFO_buf84_stg13_1_merged1835_1526
//	stg12_FIFO_buf84_stg13_1_merged1835_1527
//	stg12_FIFO_buf84_stg13_1_merged1835_1528
//	stg12_FIFO_buf84_stg13_1_merged1835_1529
//	stg12_FIFO_buf84_stg13_1_merged1835_1530
//	stg12_FIFO_buf84_stg13_1_merged1835_1531
//	stg12_FIFO_buf84_stg13_1_merged1835_1532
//	stg12_FIFO_buf84_stg13_1_merged1835_1533
//	stg12_FIFO_buf84_stg13_1_merged1835_1534
//	stg12_FIFO_buf84_stg13_1_merged1835_1535
//	stg12_FIFO_buf84_stg13_1_merged1835_1536
//	stg12_FIFO_buf84_stg13_1_merged1835_1537
//	stg12_FIFO_buf84_stg13_1_merged1835_1538
//	stg12_FIFO_buf84_stg13_1_merged1835_1539
//	stg12_FIFO_buf84_stg13_1_merged1835_1540
//	stg12_FIFO_buf84_stg13_1_merged1835_1541
//	stg12_FIFO_buf84_stg13_1_merged1835_1542
//	stg12_FIFO_buf84_stg13_1_merged1835_1543
//	stg12_FIFO_buf84_stg13_1_merged1835_1544
//	stg12_FIFO_buf84_stg13_1_merged1835_1545
//	stg12_FIFO_buf84_stg13_1_merged1835_1546
//	stg12_FIFO_buf84_stg13_1_merged1835_1547
//	stg12_FIFO_buf84_stg13_1_merged1835_1548
//	stg12_FIFO_buf84_stg13_1_merged1835_1549
//	stg12_FIFO_buf84_stg13_1_merged1835_1550
//	stg12_FIFO_buf84_stg13_1_merged1835_1551
//	stg12_FIFO_buf84_stg13_1_merged1835_1552
//	stg12_FIFO_buf84_stg13_1_merged1835_1553
//	stg12_FIFO_buf84_stg13_1_merged1835_1554
//	stg12_FIFO_buf84_stg13_1_merged1835_1555
//	stg12_FIFO_buf84_stg13_1_merged1835_1556
//	stg12_FIFO_buf84_stg13_1_merged1835_1557
//	stg12_FIFO_buf84_stg13_1_merged1835_1558
//	stg12_FIFO_buf84_stg13_1_merged1835_1559
//	stg12_FIFO_buf84_stg13_1_merged1835_1560
//	stg12_FIFO_buf84_stg13_1_merged1835_1561
//	stg12_FIFO_buf84_stg13_1_merged1835_1562
//	stg12_FIFO_buf84_stg13_1_merged1835_1563
//	stg12_FIFO_buf84_stg13_1_merged1835_1564
//	stg12_FIFO_buf84_stg13_1_merged1835_1565
//	stg12_FIFO_buf84_stg13_1_merged1835_1566
//	stg12_FIFO_buf84_stg13_1_merged1835_1567
//	stg12_FIFO_buf84_stg13_1_merged1835_1568
//	stg12_FIFO_buf84_stg13_1_merged1835_1569
//	stg12_FIFO_buf84_stg13_1_merged1835_1570
//	stg12_FIFO_buf84_stg13_1_merged1835_1571
//	stg12_FIFO_buf84_stg13_1_merged1835_1572
//	stg12_FIFO_buf84_stg13_1_merged1835_1573
//	stg12_FIFO_buf84_stg13_1_merged1835_1574
//	stg12_FIFO_buf84_stg13_1_merged1835_1575
//	stg12_FIFO_buf84_stg13_1_merged1835_1576
//	stg12_FIFO_buf84_stg13_1_merged1835_1577
//	stg12_FIFO_buf84_stg13_1_merged1835_1578
//	stg12_FIFO_buf84_stg13_1_merged1835_1579
//	stg12_FIFO_buf84_stg13_1_merged1835_1580
//	stg12_FIFO_buf84_stg13_1_merged1835_1581
//	stg12_FIFO_buf84_stg13_1_merged1835_1582
//	stg12_FIFO_buf84_stg13_1_merged1835_1583
inline hw_uint<1024> stg12_FIFO_buf84_stg13_1_merged1835_read_bundle_read(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int root, int stg13_0, int stg13_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg12_FIFO_buf84_stg13_1_merged1835_1520
    // stg12_FIFO_buf84_stg13_1_merged1835_1521
    // stg12_FIFO_buf84_stg13_1_merged1835_1522
    // stg12_FIFO_buf84_stg13_1_merged1835_1523
    // stg12_FIFO_buf84_stg13_1_merged1835_1524
    // stg12_FIFO_buf84_stg13_1_merged1835_1525
    // stg12_FIFO_buf84_stg13_1_merged1835_1526
    // stg12_FIFO_buf84_stg13_1_merged1835_1527
    // stg12_FIFO_buf84_stg13_1_merged1835_1528
    // stg12_FIFO_buf84_stg13_1_merged1835_1529
    // stg12_FIFO_buf84_stg13_1_merged1835_1530
    // stg12_FIFO_buf84_stg13_1_merged1835_1531
    // stg12_FIFO_buf84_stg13_1_merged1835_1532
    // stg12_FIFO_buf84_stg13_1_merged1835_1533
    // stg12_FIFO_buf84_stg13_1_merged1835_1534
    // stg12_FIFO_buf84_stg13_1_merged1835_1535
    // stg12_FIFO_buf84_stg13_1_merged1835_1536
    // stg12_FIFO_buf84_stg13_1_merged1835_1537
    // stg12_FIFO_buf84_stg13_1_merged1835_1538
    // stg12_FIFO_buf84_stg13_1_merged1835_1539
    // stg12_FIFO_buf84_stg13_1_merged1835_1540
    // stg12_FIFO_buf84_stg13_1_merged1835_1541
    // stg12_FIFO_buf84_stg13_1_merged1835_1542
    // stg12_FIFO_buf84_stg13_1_merged1835_1543
    // stg12_FIFO_buf84_stg13_1_merged1835_1544
    // stg12_FIFO_buf84_stg13_1_merged1835_1545
    // stg12_FIFO_buf84_stg13_1_merged1835_1546
    // stg12_FIFO_buf84_stg13_1_merged1835_1547
    // stg12_FIFO_buf84_stg13_1_merged1835_1548
    // stg12_FIFO_buf84_stg13_1_merged1835_1549
    // stg12_FIFO_buf84_stg13_1_merged1835_1550
    // stg12_FIFO_buf84_stg13_1_merged1835_1551
    // stg12_FIFO_buf84_stg13_1_merged1835_1552
    // stg12_FIFO_buf84_stg13_1_merged1835_1553
    // stg12_FIFO_buf84_stg13_1_merged1835_1554
    // stg12_FIFO_buf84_stg13_1_merged1835_1555
    // stg12_FIFO_buf84_stg13_1_merged1835_1556
    // stg12_FIFO_buf84_stg13_1_merged1835_1557
    // stg12_FIFO_buf84_stg13_1_merged1835_1558
    // stg12_FIFO_buf84_stg13_1_merged1835_1559
    // stg12_FIFO_buf84_stg13_1_merged1835_1560
    // stg12_FIFO_buf84_stg13_1_merged1835_1561
    // stg12_FIFO_buf84_stg13_1_merged1835_1562
    // stg12_FIFO_buf84_stg13_1_merged1835_1563
    // stg12_FIFO_buf84_stg13_1_merged1835_1564
    // stg12_FIFO_buf84_stg13_1_merged1835_1565
    // stg12_FIFO_buf84_stg13_1_merged1835_1566
    // stg12_FIFO_buf84_stg13_1_merged1835_1567
    // stg12_FIFO_buf84_stg13_1_merged1835_1568
    // stg12_FIFO_buf84_stg13_1_merged1835_1569
    // stg12_FIFO_buf84_stg13_1_merged1835_1570
    // stg12_FIFO_buf84_stg13_1_merged1835_1571
    // stg12_FIFO_buf84_stg13_1_merged1835_1572
    // stg12_FIFO_buf84_stg13_1_merged1835_1573
    // stg12_FIFO_buf84_stg13_1_merged1835_1574
    // stg12_FIFO_buf84_stg13_1_merged1835_1575
    // stg12_FIFO_buf84_stg13_1_merged1835_1576
    // stg12_FIFO_buf84_stg13_1_merged1835_1577
    // stg12_FIFO_buf84_stg13_1_merged1835_1578
    // stg12_FIFO_buf84_stg13_1_merged1835_1579
    // stg12_FIFO_buf84_stg13_1_merged1835_1580
    // stg12_FIFO_buf84_stg13_1_merged1835_1581
    // stg12_FIFO_buf84_stg13_1_merged1835_1582
    // stg12_FIFO_buf84_stg13_1_merged1835_1583

	hw_uint<1024> result;
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1520_res = stg12_FIFO_buf84_stg13_1_merged1835_1520_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<0, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1520_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1521_res = stg12_FIFO_buf84_stg13_1_merged1835_1521_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<16, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1521_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1522_res = stg12_FIFO_buf84_stg13_1_merged1835_1522_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<32, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1522_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1523_res = stg12_FIFO_buf84_stg13_1_merged1835_1523_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<48, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1523_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1524_res = stg12_FIFO_buf84_stg13_1_merged1835_1524_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<64, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1524_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1525_res = stg12_FIFO_buf84_stg13_1_merged1835_1525_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<80, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1525_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1526_res = stg12_FIFO_buf84_stg13_1_merged1835_1526_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<96, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1526_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1527_res = stg12_FIFO_buf84_stg13_1_merged1835_1527_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<112, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1527_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1528_res = stg12_FIFO_buf84_stg13_1_merged1835_1528_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<128, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1528_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1529_res = stg12_FIFO_buf84_stg13_1_merged1835_1529_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<144, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1529_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1530_res = stg12_FIFO_buf84_stg13_1_merged1835_1530_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<160, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1530_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1531_res = stg12_FIFO_buf84_stg13_1_merged1835_1531_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<176, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1531_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1532_res = stg12_FIFO_buf84_stg13_1_merged1835_1532_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<192, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1532_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1533_res = stg12_FIFO_buf84_stg13_1_merged1835_1533_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<208, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1533_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1534_res = stg12_FIFO_buf84_stg13_1_merged1835_1534_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<224, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1534_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1535_res = stg12_FIFO_buf84_stg13_1_merged1835_1535_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<240, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1535_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1536_res = stg12_FIFO_buf84_stg13_1_merged1835_1536_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<256, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1536_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1537_res = stg12_FIFO_buf84_stg13_1_merged1835_1537_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<272, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1537_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1538_res = stg12_FIFO_buf84_stg13_1_merged1835_1538_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<288, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1538_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1539_res = stg12_FIFO_buf84_stg13_1_merged1835_1539_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<304, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1539_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1540_res = stg12_FIFO_buf84_stg13_1_merged1835_1540_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<320, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1540_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1541_res = stg12_FIFO_buf84_stg13_1_merged1835_1541_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<336, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1541_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1542_res = stg12_FIFO_buf84_stg13_1_merged1835_1542_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<352, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1542_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1543_res = stg12_FIFO_buf84_stg13_1_merged1835_1543_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<368, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1543_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1544_res = stg12_FIFO_buf84_stg13_1_merged1835_1544_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<384, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1544_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1545_res = stg12_FIFO_buf84_stg13_1_merged1835_1545_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<400, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1545_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1546_res = stg12_FIFO_buf84_stg13_1_merged1835_1546_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<416, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1546_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1547_res = stg12_FIFO_buf84_stg13_1_merged1835_1547_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<432, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1547_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1548_res = stg12_FIFO_buf84_stg13_1_merged1835_1548_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<448, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1548_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1549_res = stg12_FIFO_buf84_stg13_1_merged1835_1549_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<464, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1549_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1550_res = stg12_FIFO_buf84_stg13_1_merged1835_1550_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<480, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1550_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1551_res = stg12_FIFO_buf84_stg13_1_merged1835_1551_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<496, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1551_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1552_res = stg12_FIFO_buf84_stg13_1_merged1835_1552_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<512, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1552_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1553_res = stg12_FIFO_buf84_stg13_1_merged1835_1553_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<528, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1553_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1554_res = stg12_FIFO_buf84_stg13_1_merged1835_1554_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<544, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1554_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1555_res = stg12_FIFO_buf84_stg13_1_merged1835_1555_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<560, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1555_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1556_res = stg12_FIFO_buf84_stg13_1_merged1835_1556_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<576, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1556_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1557_res = stg12_FIFO_buf84_stg13_1_merged1835_1557_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<592, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1557_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1558_res = stg12_FIFO_buf84_stg13_1_merged1835_1558_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<608, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1558_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1559_res = stg12_FIFO_buf84_stg13_1_merged1835_1559_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<624, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1559_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1560_res = stg12_FIFO_buf84_stg13_1_merged1835_1560_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<640, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1560_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1561_res = stg12_FIFO_buf84_stg13_1_merged1835_1561_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<656, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1561_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1562_res = stg12_FIFO_buf84_stg13_1_merged1835_1562_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<672, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1562_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1563_res = stg12_FIFO_buf84_stg13_1_merged1835_1563_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<688, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1563_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1564_res = stg12_FIFO_buf84_stg13_1_merged1835_1564_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<704, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1564_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1565_res = stg12_FIFO_buf84_stg13_1_merged1835_1565_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<720, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1565_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1566_res = stg12_FIFO_buf84_stg13_1_merged1835_1566_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<736, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1566_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1567_res = stg12_FIFO_buf84_stg13_1_merged1835_1567_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<752, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1567_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1568_res = stg12_FIFO_buf84_stg13_1_merged1835_1568_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<768, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1568_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1569_res = stg12_FIFO_buf84_stg13_1_merged1835_1569_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<784, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1569_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1570_res = stg12_FIFO_buf84_stg13_1_merged1835_1570_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<800, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1570_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1571_res = stg12_FIFO_buf84_stg13_1_merged1835_1571_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<816, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1571_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1572_res = stg12_FIFO_buf84_stg13_1_merged1835_1572_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<832, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1572_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1573_res = stg12_FIFO_buf84_stg13_1_merged1835_1573_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<848, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1573_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1574_res = stg12_FIFO_buf84_stg13_1_merged1835_1574_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<864, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1574_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1575_res = stg12_FIFO_buf84_stg13_1_merged1835_1575_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<880, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1575_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1576_res = stg12_FIFO_buf84_stg13_1_merged1835_1576_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<896, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1576_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1577_res = stg12_FIFO_buf84_stg13_1_merged1835_1577_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<912, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1577_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1578_res = stg12_FIFO_buf84_stg13_1_merged1835_1578_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<928, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1578_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1579_res = stg12_FIFO_buf84_stg13_1_merged1835_1579_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<944, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1579_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1580_res = stg12_FIFO_buf84_stg13_1_merged1835_1580_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<960, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1580_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1581_res = stg12_FIFO_buf84_stg13_1_merged1835_1581_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<976, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1581_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1582_res = stg12_FIFO_buf84_stg13_1_merged1835_1582_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<992, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1582_res);
	hw_uint<16> stg12_FIFO_buf84_stg13_1_merged1835_1583_res = stg12_FIFO_buf84_stg13_1_merged1835_1583_select(stg12_FIFO_buf84, root, stg13_0, stg13_1, dynamic_address);
	set_at<1008, 1024>(result, stg12_FIFO_buf84_stg13_1_merged1835_1583_res);
	return result;
}

struct stg13_stg13_1_merged1835_1504_to_stg13_stg13_ld25_merged1851_1488_cache {
	// RAM Box: {[15, 1103], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1505_to_stg13_stg13_ld25_merged1851_1489_cache {
	// RAM Box: {[14, 1102], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1506_to_stg13_stg13_ld25_merged1851_1490_cache {
	// RAM Box: {[13, 1101], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1507_to_stg13_stg13_ld25_merged1851_1491_cache {
	// RAM Box: {[12, 1100], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1508_to_stg13_stg13_ld25_merged1851_1492_cache {
	// RAM Box: {[11, 1099], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1509_to_stg13_stg13_ld25_merged1851_1493_cache {
	// RAM Box: {[10, 1098], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1510_to_stg13_stg13_ld25_merged1851_1494_cache {
	// RAM Box: {[9, 1097], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1511_to_stg13_stg13_ld25_merged1851_1495_cache {
	// RAM Box: {[8, 1096], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1512_to_stg13_stg13_ld25_merged1851_1496_cache {
	// RAM Box: {[7, 1095], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1513_to_stg13_stg13_ld25_merged1851_1497_cache {
	// RAM Box: {[6, 1094], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1514_to_stg13_stg13_ld25_merged1851_1498_cache {
	// RAM Box: {[5, 1093], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1515_to_stg13_stg13_ld25_merged1851_1499_cache {
	// RAM Box: {[4, 1092], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1516_to_stg13_stg13_ld25_merged1851_1500_cache {
	// RAM Box: {[3, 1091], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1517_to_stg13_stg13_ld25_merged1851_1501_cache {
	// RAM Box: {[2, 1090], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1518_to_stg13_stg13_ld25_merged1851_1502_cache {
	// RAM Box: {[1, 1089], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_stg13_1_merged1835_1519_to_stg13_stg13_ld25_merged1851_1503_cache {
	// RAM Box: {[0, 1088], [-1, 1920]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg13_cache {
  // Reader addrs...
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[15 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[14 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[13 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[12 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[11 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[10 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[9 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[8 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[7 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[6 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[5 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[4 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[3 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[2 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[1 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
    // { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // # of banks: 16
  stg13_stg13_1_merged1835_1504_to_stg13_stg13_ld25_merged1851_1488_cache stg13_stg13_1_merged1835_1504_to_stg13_stg13_ld25_merged1851_1488;
  stg13_stg13_1_merged1835_1505_to_stg13_stg13_ld25_merged1851_1489_cache stg13_stg13_1_merged1835_1505_to_stg13_stg13_ld25_merged1851_1489;
  stg13_stg13_1_merged1835_1506_to_stg13_stg13_ld25_merged1851_1490_cache stg13_stg13_1_merged1835_1506_to_stg13_stg13_ld25_merged1851_1490;
  stg13_stg13_1_merged1835_1507_to_stg13_stg13_ld25_merged1851_1491_cache stg13_stg13_1_merged1835_1507_to_stg13_stg13_ld25_merged1851_1491;
  stg13_stg13_1_merged1835_1508_to_stg13_stg13_ld25_merged1851_1492_cache stg13_stg13_1_merged1835_1508_to_stg13_stg13_ld25_merged1851_1492;
  stg13_stg13_1_merged1835_1509_to_stg13_stg13_ld25_merged1851_1493_cache stg13_stg13_1_merged1835_1509_to_stg13_stg13_ld25_merged1851_1493;
  stg13_stg13_1_merged1835_1510_to_stg13_stg13_ld25_merged1851_1494_cache stg13_stg13_1_merged1835_1510_to_stg13_stg13_ld25_merged1851_1494;
  stg13_stg13_1_merged1835_1511_to_stg13_stg13_ld25_merged1851_1495_cache stg13_stg13_1_merged1835_1511_to_stg13_stg13_ld25_merged1851_1495;
  stg13_stg13_1_merged1835_1512_to_stg13_stg13_ld25_merged1851_1496_cache stg13_stg13_1_merged1835_1512_to_stg13_stg13_ld25_merged1851_1496;
  stg13_stg13_1_merged1835_1513_to_stg13_stg13_ld25_merged1851_1497_cache stg13_stg13_1_merged1835_1513_to_stg13_stg13_ld25_merged1851_1497;
  stg13_stg13_1_merged1835_1514_to_stg13_stg13_ld25_merged1851_1498_cache stg13_stg13_1_merged1835_1514_to_stg13_stg13_ld25_merged1851_1498;
  stg13_stg13_1_merged1835_1515_to_stg13_stg13_ld25_merged1851_1499_cache stg13_stg13_1_merged1835_1515_to_stg13_stg13_ld25_merged1851_1499;
  stg13_stg13_1_merged1835_1516_to_stg13_stg13_ld25_merged1851_1500_cache stg13_stg13_1_merged1835_1516_to_stg13_stg13_ld25_merged1851_1500;
  stg13_stg13_1_merged1835_1517_to_stg13_stg13_ld25_merged1851_1501_cache stg13_stg13_1_merged1835_1517_to_stg13_stg13_ld25_merged1851_1501;
  stg13_stg13_1_merged1835_1518_to_stg13_stg13_ld25_merged1851_1502_cache stg13_stg13_1_merged1835_1518_to_stg13_stg13_ld25_merged1851_1502;
  stg13_stg13_1_merged1835_1519_to_stg13_stg13_ld25_merged1851_1503_cache stg13_stg13_1_merged1835_1519_to_stg13_stg13_ld25_merged1851_1503;
};



inline void stg13_stg13_1_merged1835_1504_write(hw_uint<16>& stg13_stg13_1_merged1835_1504, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1504_to_stg13_stg13_ld25_merged1851_1488.push(stg13_stg13_1_merged1835_1504);
}

inline void stg13_stg13_1_merged1835_1505_write(hw_uint<16>& stg13_stg13_1_merged1835_1505, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1505_to_stg13_stg13_ld25_merged1851_1489.push(stg13_stg13_1_merged1835_1505);
}

inline void stg13_stg13_1_merged1835_1506_write(hw_uint<16>& stg13_stg13_1_merged1835_1506, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1506_to_stg13_stg13_ld25_merged1851_1490.push(stg13_stg13_1_merged1835_1506);
}

inline void stg13_stg13_1_merged1835_1507_write(hw_uint<16>& stg13_stg13_1_merged1835_1507, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1507_to_stg13_stg13_ld25_merged1851_1491.push(stg13_stg13_1_merged1835_1507);
}

inline void stg13_stg13_1_merged1835_1508_write(hw_uint<16>& stg13_stg13_1_merged1835_1508, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1508_to_stg13_stg13_ld25_merged1851_1492.push(stg13_stg13_1_merged1835_1508);
}

inline void stg13_stg13_1_merged1835_1509_write(hw_uint<16>& stg13_stg13_1_merged1835_1509, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1509_to_stg13_stg13_ld25_merged1851_1493.push(stg13_stg13_1_merged1835_1509);
}

inline void stg13_stg13_1_merged1835_1510_write(hw_uint<16>& stg13_stg13_1_merged1835_1510, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1510_to_stg13_stg13_ld25_merged1851_1494.push(stg13_stg13_1_merged1835_1510);
}

inline void stg13_stg13_1_merged1835_1511_write(hw_uint<16>& stg13_stg13_1_merged1835_1511, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1511_to_stg13_stg13_ld25_merged1851_1495.push(stg13_stg13_1_merged1835_1511);
}

inline void stg13_stg13_1_merged1835_1512_write(hw_uint<16>& stg13_stg13_1_merged1835_1512, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1512_to_stg13_stg13_ld25_merged1851_1496.push(stg13_stg13_1_merged1835_1512);
}

inline void stg13_stg13_1_merged1835_1513_write(hw_uint<16>& stg13_stg13_1_merged1835_1513, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1513_to_stg13_stg13_ld25_merged1851_1497.push(stg13_stg13_1_merged1835_1513);
}

inline void stg13_stg13_1_merged1835_1514_write(hw_uint<16>& stg13_stg13_1_merged1835_1514, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1514_to_stg13_stg13_ld25_merged1851_1498.push(stg13_stg13_1_merged1835_1514);
}

inline void stg13_stg13_1_merged1835_1515_write(hw_uint<16>& stg13_stg13_1_merged1835_1515, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1515_to_stg13_stg13_ld25_merged1851_1499.push(stg13_stg13_1_merged1835_1515);
}

inline void stg13_stg13_1_merged1835_1516_write(hw_uint<16>& stg13_stg13_1_merged1835_1516, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1516_to_stg13_stg13_ld25_merged1851_1500.push(stg13_stg13_1_merged1835_1516);
}

inline void stg13_stg13_1_merged1835_1517_write(hw_uint<16>& stg13_stg13_1_merged1835_1517, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1517_to_stg13_stg13_ld25_merged1851_1501.push(stg13_stg13_1_merged1835_1517);
}

inline void stg13_stg13_1_merged1835_1518_write(hw_uint<16>& stg13_stg13_1_merged1835_1518, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1518_to_stg13_stg13_ld25_merged1851_1502.push(stg13_stg13_1_merged1835_1518);
}

inline void stg13_stg13_1_merged1835_1519_write(hw_uint<16>& stg13_stg13_1_merged1835_1519, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
  stg13.stg13_stg13_1_merged1835_1519_to_stg13_stg13_ld25_merged1851_1503.push(stg13_stg13_1_merged1835_1519);
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1488_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1488 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[15 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1504 = stg13.stg13_stg13_1_merged1835_1504_to_stg13_stg13_ld25_merged1851_1488.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1504;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1489_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1489 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[14 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1505 = stg13.stg13_stg13_1_merged1835_1505_to_stg13_stg13_ld25_merged1851_1489.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1505;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1490_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1490 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[13 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1506 = stg13.stg13_stg13_1_merged1835_1506_to_stg13_stg13_ld25_merged1851_1490.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1506;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1491_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1491 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[12 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1507 = stg13.stg13_stg13_1_merged1835_1507_to_stg13_stg13_ld25_merged1851_1491.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1507;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1492_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1492 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[11 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1508 = stg13.stg13_stg13_1_merged1835_1508_to_stg13_stg13_ld25_merged1851_1492.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1508;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1493_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1493 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[10 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1509 = stg13.stg13_stg13_1_merged1835_1509_to_stg13_stg13_ld25_merged1851_1493.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1509;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1494_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1494 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[9 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1510 = stg13.stg13_stg13_1_merged1835_1510_to_stg13_stg13_ld25_merged1851_1494.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1510;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1495_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1495 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[8 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1511 = stg13.stg13_stg13_1_merged1835_1511_to_stg13_stg13_ld25_merged1851_1495.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1511;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1496_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1496 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[7 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1512 = stg13.stg13_stg13_1_merged1835_1512_to_stg13_stg13_ld25_merged1851_1496.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1512;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1497_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1497 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[6 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1513 = stg13.stg13_stg13_1_merged1835_1513_to_stg13_stg13_ld25_merged1851_1497.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1513;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1498_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1498 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[5 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1514 = stg13.stg13_stg13_1_merged1835_1514_to_stg13_stg13_ld25_merged1851_1498.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1514;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1499_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1499 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[4 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1515 = stg13.stg13_stg13_1_merged1835_1515_to_stg13_stg13_ld25_merged1851_1499.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1515;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1500_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1500 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[3 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1516 = stg13.stg13_stg13_1_merged1835_1516_to_stg13_stg13_ld25_merged1851_1500.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1516;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1501_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1501 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[2 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1517 = stg13.stg13_stg13_1_merged1835_1517_to_stg13_stg13_ld25_merged1851_1501.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1517;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1502_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1502 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[1 + 16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1518 = stg13.stg13_stg13_1_merged1835_1518_to_stg13_stg13_ld25_merged1851_1502.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1518;
  return 0;
}

inline hw_uint<16> stg13_stg13_ld25_merged1851_1503_select(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_stg13_ld25_merged1851_1503 read pattern: { stg13_ld25_merged1851[root = 0, stg13_ld26, stg13_ld25] -> stg13[16stg13_ld25, -1 + stg13_ld26] : 0 <= stg13_ld26 <= 1921 and 0 <= stg13_ld25 <= 68 }
  // Read schedule : { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  // Write schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_stg13_1_merged1835_1519 = stg13.stg13_stg13_1_merged1835_1519_to_stg13_stg13_ld25_merged1851_1503.peek(/* one reader or all rams */ 0);
  return value_stg13_stg13_1_merged1835_1519;
  return 0;
}

// # of bundles = 2
// stg13_1_merged1835_write
//	stg13_stg13_1_merged1835_1504
//	stg13_stg13_1_merged1835_1505
//	stg13_stg13_1_merged1835_1506
//	stg13_stg13_1_merged1835_1507
//	stg13_stg13_1_merged1835_1508
//	stg13_stg13_1_merged1835_1509
//	stg13_stg13_1_merged1835_1510
//	stg13_stg13_1_merged1835_1511
//	stg13_stg13_1_merged1835_1512
//	stg13_stg13_1_merged1835_1513
//	stg13_stg13_1_merged1835_1514
//	stg13_stg13_1_merged1835_1515
//	stg13_stg13_1_merged1835_1516
//	stg13_stg13_1_merged1835_1517
//	stg13_stg13_1_merged1835_1518
//	stg13_stg13_1_merged1835_1519
inline void stg13_stg13_1_merged1835_write_bundle_write(hw_uint<256>& stg13_1_merged1835_write, stg13_cache& stg13, int root, int stg13_0, int stg13_1, int dynamic_address) {
	hw_uint<16> stg13_stg13_1_merged1835_1504_res = stg13_1_merged1835_write.extract<0, 15>();
	stg13_stg13_1_merged1835_1504_write(stg13_stg13_1_merged1835_1504_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1505_res = stg13_1_merged1835_write.extract<16, 31>();
	stg13_stg13_1_merged1835_1505_write(stg13_stg13_1_merged1835_1505_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1506_res = stg13_1_merged1835_write.extract<32, 47>();
	stg13_stg13_1_merged1835_1506_write(stg13_stg13_1_merged1835_1506_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1507_res = stg13_1_merged1835_write.extract<48, 63>();
	stg13_stg13_1_merged1835_1507_write(stg13_stg13_1_merged1835_1507_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1508_res = stg13_1_merged1835_write.extract<64, 79>();
	stg13_stg13_1_merged1835_1508_write(stg13_stg13_1_merged1835_1508_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1509_res = stg13_1_merged1835_write.extract<80, 95>();
	stg13_stg13_1_merged1835_1509_write(stg13_stg13_1_merged1835_1509_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1510_res = stg13_1_merged1835_write.extract<96, 111>();
	stg13_stg13_1_merged1835_1510_write(stg13_stg13_1_merged1835_1510_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1511_res = stg13_1_merged1835_write.extract<112, 127>();
	stg13_stg13_1_merged1835_1511_write(stg13_stg13_1_merged1835_1511_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1512_res = stg13_1_merged1835_write.extract<128, 143>();
	stg13_stg13_1_merged1835_1512_write(stg13_stg13_1_merged1835_1512_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1513_res = stg13_1_merged1835_write.extract<144, 159>();
	stg13_stg13_1_merged1835_1513_write(stg13_stg13_1_merged1835_1513_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1514_res = stg13_1_merged1835_write.extract<160, 175>();
	stg13_stg13_1_merged1835_1514_write(stg13_stg13_1_merged1835_1514_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1515_res = stg13_1_merged1835_write.extract<176, 191>();
	stg13_stg13_1_merged1835_1515_write(stg13_stg13_1_merged1835_1515_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1516_res = stg13_1_merged1835_write.extract<192, 207>();
	stg13_stg13_1_merged1835_1516_write(stg13_stg13_1_merged1835_1516_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1517_res = stg13_1_merged1835_write.extract<208, 223>();
	stg13_stg13_1_merged1835_1517_write(stg13_stg13_1_merged1835_1517_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1518_res = stg13_1_merged1835_write.extract<224, 239>();
	stg13_stg13_1_merged1835_1518_write(stg13_stg13_1_merged1835_1518_res, stg13, root, stg13_0, stg13_1, dynamic_address);
	hw_uint<16> stg13_stg13_1_merged1835_1519_res = stg13_1_merged1835_write.extract<240, 255>();
	stg13_stg13_1_merged1835_1519_write(stg13_stg13_1_merged1835_1519_res, stg13, root, stg13_0, stg13_1, dynamic_address);
}

// stg13_ld25_merged1851_read
//	stg13_stg13_ld25_merged1851_1488
//	stg13_stg13_ld25_merged1851_1489
//	stg13_stg13_ld25_merged1851_1490
//	stg13_stg13_ld25_merged1851_1491
//	stg13_stg13_ld25_merged1851_1492
//	stg13_stg13_ld25_merged1851_1493
//	stg13_stg13_ld25_merged1851_1494
//	stg13_stg13_ld25_merged1851_1495
//	stg13_stg13_ld25_merged1851_1496
//	stg13_stg13_ld25_merged1851_1497
//	stg13_stg13_ld25_merged1851_1498
//	stg13_stg13_ld25_merged1851_1499
//	stg13_stg13_ld25_merged1851_1500
//	stg13_stg13_ld25_merged1851_1501
//	stg13_stg13_ld25_merged1851_1502
//	stg13_stg13_ld25_merged1851_1503
inline hw_uint<256> stg13_stg13_ld25_merged1851_read_bundle_read(stg13_cache& stg13, int root, int stg13_ld26, int stg13_ld25, int dynamic_address) {
  // # of ports in bundle: 16
    // stg13_stg13_ld25_merged1851_1488
    // stg13_stg13_ld25_merged1851_1489
    // stg13_stg13_ld25_merged1851_1490
    // stg13_stg13_ld25_merged1851_1491
    // stg13_stg13_ld25_merged1851_1492
    // stg13_stg13_ld25_merged1851_1493
    // stg13_stg13_ld25_merged1851_1494
    // stg13_stg13_ld25_merged1851_1495
    // stg13_stg13_ld25_merged1851_1496
    // stg13_stg13_ld25_merged1851_1497
    // stg13_stg13_ld25_merged1851_1498
    // stg13_stg13_ld25_merged1851_1499
    // stg13_stg13_ld25_merged1851_1500
    // stg13_stg13_ld25_merged1851_1501
    // stg13_stg13_ld25_merged1851_1502
    // stg13_stg13_ld25_merged1851_1503

	hw_uint<256> result;
	hw_uint<16> stg13_stg13_ld25_merged1851_1488_res = stg13_stg13_ld25_merged1851_1488_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<0, 256>(result, stg13_stg13_ld25_merged1851_1488_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1489_res = stg13_stg13_ld25_merged1851_1489_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<16, 256>(result, stg13_stg13_ld25_merged1851_1489_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1490_res = stg13_stg13_ld25_merged1851_1490_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<32, 256>(result, stg13_stg13_ld25_merged1851_1490_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1491_res = stg13_stg13_ld25_merged1851_1491_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<48, 256>(result, stg13_stg13_ld25_merged1851_1491_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1492_res = stg13_stg13_ld25_merged1851_1492_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<64, 256>(result, stg13_stg13_ld25_merged1851_1492_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1493_res = stg13_stg13_ld25_merged1851_1493_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<80, 256>(result, stg13_stg13_ld25_merged1851_1493_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1494_res = stg13_stg13_ld25_merged1851_1494_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<96, 256>(result, stg13_stg13_ld25_merged1851_1494_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1495_res = stg13_stg13_ld25_merged1851_1495_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<112, 256>(result, stg13_stg13_ld25_merged1851_1495_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1496_res = stg13_stg13_ld25_merged1851_1496_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<128, 256>(result, stg13_stg13_ld25_merged1851_1496_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1497_res = stg13_stg13_ld25_merged1851_1497_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<144, 256>(result, stg13_stg13_ld25_merged1851_1497_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1498_res = stg13_stg13_ld25_merged1851_1498_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<160, 256>(result, stg13_stg13_ld25_merged1851_1498_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1499_res = stg13_stg13_ld25_merged1851_1499_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<176, 256>(result, stg13_stg13_ld25_merged1851_1499_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1500_res = stg13_stg13_ld25_merged1851_1500_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<192, 256>(result, stg13_stg13_ld25_merged1851_1500_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1501_res = stg13_stg13_ld25_merged1851_1501_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<208, 256>(result, stg13_stg13_ld25_merged1851_1501_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1502_res = stg13_stg13_ld25_merged1851_1502_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<224, 256>(result, stg13_stg13_ld25_merged1851_1502_res);
	hw_uint<16> stg13_stg13_ld25_merged1851_1503_res = stg13_stg13_ld25_merged1851_1503_select(stg13, root, stg13_ld26, stg13_ld25, dynamic_address);
	set_at<240, 256>(result, stg13_stg13_ld25_merged1851_1503_res);
	return result;
}

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_merged_banks_4_cache {
	// RAM Box: {[15, 1087], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_merged_banks_4_cache {
	// RAM Box: {[14, 1086], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_merged_banks_4_cache {
	// RAM Box: {[13, 1085], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_merged_banks_4_cache {
	// RAM Box: {[12, 1084], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_merged_banks_4_cache {
	// RAM Box: {[11, 1083], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_merged_banks_4_cache {
	// RAM Box: {[10, 1082], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_merged_banks_4_cache {
	// RAM Box: {[9, 1081], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_merged_banks_4_cache {
	// RAM Box: {[8, 1080], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_merged_banks_4_cache {
	// RAM Box: {[7, 1079], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_merged_banks_4_cache {
	// RAM Box: {[6, 1078], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_merged_banks_4_cache {
	// RAM Box: {[5, 1077], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_merged_banks_4_cache {
	// RAM Box: {[4, 1076], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_merged_banks_4_cache {
	// RAM Box: {[3, 1075], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_merged_banks_4_cache {
	// RAM Box: {[2, 1074], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_merged_banks_4_cache {
	// RAM Box: {[1, 1073], [-1, 1920]}
	// Capacity: 140
	// # of read delays: 4
  // 0, 1, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 68> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 68> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_69() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_70() {
		return f4;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_139() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_merged_banks_4_cache {
	// RAM Box: {[0, 1088], [-1, 1919]}
	// Capacity: 140
	// # of read delays: 5
  // 0, 1, 69, 70, 139
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 67> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 68> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_68() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_69() {
		return f4;
	}

	inline hw_uint<16> peek_70() {
		return f6;
	}

	inline hw_uint<16> peek_138() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_139() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 68
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 68 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 67
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 67 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg13_FIFO_buf88_cache {
  // Reader addrs...
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[15 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[15 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[16 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[15 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[14 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[14 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[15 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[14 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[13 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[13 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[14 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[13 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[12 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[12 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[13 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[12 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[11 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[11 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[12 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[11 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[10 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[10 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[11 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[10 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[9 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[9 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[10 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[9 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[8 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[8 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[9 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[8 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[7 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[7 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[8 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[7 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[6 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[6 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[7 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[6 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[5 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[5 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[6 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[5 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[4 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[4 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[5 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[4 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[3 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[3 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[4 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[3 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[2 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[2 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[3 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[2 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[1 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[1 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[2 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[1 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[1 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
    // { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // # of banks: 16
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_merged_banks_4;
  stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_merged_banks_4_cache stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_merged_banks_4;
};



inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454);
}

inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_write(hw_uint<16>& stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
  stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_merged_banks_4.push(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455);
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1376_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1376 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[15 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1377_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1377 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[15 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1378_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1378 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[16 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_merged_banks_4.peek_69();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1379_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1379 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[15 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1380_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1380 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[14 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1381_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1381 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[14 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1382_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1382 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[15 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1383_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1383 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[14 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1384_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1384 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[13 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1385_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1385 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[13 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1386_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1386 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[14 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1387_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1387 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[13 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1388_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1388 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[12 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1389_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1389 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[12 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1390_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1390 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[13 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1391_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1391 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[12 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1392_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1392 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[11 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1393_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1393 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[11 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1394_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1394 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[12 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1395_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1395 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[11 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1396_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1396 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[10 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1397_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1397 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[10 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1398_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1398 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[11 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1399_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1399 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[10 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1400_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1400 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[9 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1401_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1401 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[9 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1402_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1402 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[10 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1403_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1403 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[9 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1404_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1404 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[8 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1405_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1405 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[8 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1406_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1406 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[9 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1407_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1407 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[8 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1408_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1408 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[7 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1409_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1409 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[7 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1410_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1410 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[8 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1411_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1411 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[7 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1412_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1412 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[6 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1413_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1413 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[6 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1414_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1414 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[7 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1415_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1415 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[6 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1416_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1416 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[5 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1417_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1417 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[5 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1418_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1418 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[6 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1419_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1419 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[5 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1420_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1420 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[4 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1421_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1421 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[4 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1422_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1422 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[5 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1423_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1423 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[4 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1424_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1424 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[3 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1425_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1425 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[3 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1426_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1426 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[4 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1427_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1427 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[3 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1428_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1428 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[2 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1429_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1429 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[2 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1430_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1430 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[3 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1431_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1431 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[2 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1432_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1432 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[1 + 16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1433_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1433 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[1 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1434_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1434 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[2 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1435_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1435 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[1 + 16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1436_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1436 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[16stg14_1, -1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_merged_banks_4.peek_139();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1437_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1437 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1438_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1438 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[1 + 16stg14_1, stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_merged_banks_4.peek_70();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454;
  return 0;
}

inline hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1439_select(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg13_FIFO_buf88_stg14_1_merged1838_1439 read pattern: { stg14_1_merged1838[root = 0, stg14_0, stg14_1] -> stg13_FIFO_buf88[16stg14_1, 1 + stg14_0] : 0 <= stg14_0 <= 1919 and 0 <= stg14_1 <= 67 }
  // Read schedule : { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
  auto value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455 = stg13_FIFO_buf88.stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_merged_banks_4.peek_1();
  return value_stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455;
  return 0;
}

// # of bundles = 2
// stg13_to_gp_724_ld89_merged1750_write
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454
//	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455
inline void stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_write_bundle_write(hw_uint<256>& stg13_to_gp_724_ld89_merged1750_write, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg13_to_gp_724_ld90, int stg13_to_gp_724_ld89, int dynamic_address) {
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_res = stg13_to_gp_724_ld89_merged1750_write.extract<0, 15>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1440_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_res = stg13_to_gp_724_ld89_merged1750_write.extract<16, 31>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1441_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_res = stg13_to_gp_724_ld89_merged1750_write.extract<32, 47>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1442_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_res = stg13_to_gp_724_ld89_merged1750_write.extract<48, 63>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1443_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_res = stg13_to_gp_724_ld89_merged1750_write.extract<64, 79>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1444_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_res = stg13_to_gp_724_ld89_merged1750_write.extract<80, 95>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1445_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_res = stg13_to_gp_724_ld89_merged1750_write.extract<96, 111>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1446_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_res = stg13_to_gp_724_ld89_merged1750_write.extract<112, 127>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1447_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_res = stg13_to_gp_724_ld89_merged1750_write.extract<128, 143>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1448_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_res = stg13_to_gp_724_ld89_merged1750_write.extract<144, 159>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1449_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_res = stg13_to_gp_724_ld89_merged1750_write.extract<160, 175>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1450_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_res = stg13_to_gp_724_ld89_merged1750_write.extract<176, 191>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1451_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_res = stg13_to_gp_724_ld89_merged1750_write.extract<192, 207>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1452_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_res = stg13_to_gp_724_ld89_merged1750_write.extract<208, 223>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1453_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_res = stg13_to_gp_724_ld89_merged1750_write.extract<224, 239>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1454_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
	hw_uint<16> stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_res = stg13_to_gp_724_ld89_merged1750_write.extract<240, 255>();
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_write(stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_1455_res, stg13_FIFO_buf88, root, stg13_to_gp_724_ld90, stg13_to_gp_724_ld89, dynamic_address);
}

// stg14_1_merged1838_read
//	stg13_FIFO_buf88_stg14_1_merged1838_1376
//	stg13_FIFO_buf88_stg14_1_merged1838_1377
//	stg13_FIFO_buf88_stg14_1_merged1838_1378
//	stg13_FIFO_buf88_stg14_1_merged1838_1379
//	stg13_FIFO_buf88_stg14_1_merged1838_1380
//	stg13_FIFO_buf88_stg14_1_merged1838_1381
//	stg13_FIFO_buf88_stg14_1_merged1838_1382
//	stg13_FIFO_buf88_stg14_1_merged1838_1383
//	stg13_FIFO_buf88_stg14_1_merged1838_1384
//	stg13_FIFO_buf88_stg14_1_merged1838_1385
//	stg13_FIFO_buf88_stg14_1_merged1838_1386
//	stg13_FIFO_buf88_stg14_1_merged1838_1387
//	stg13_FIFO_buf88_stg14_1_merged1838_1388
//	stg13_FIFO_buf88_stg14_1_merged1838_1389
//	stg13_FIFO_buf88_stg14_1_merged1838_1390
//	stg13_FIFO_buf88_stg14_1_merged1838_1391
//	stg13_FIFO_buf88_stg14_1_merged1838_1392
//	stg13_FIFO_buf88_stg14_1_merged1838_1393
//	stg13_FIFO_buf88_stg14_1_merged1838_1394
//	stg13_FIFO_buf88_stg14_1_merged1838_1395
//	stg13_FIFO_buf88_stg14_1_merged1838_1396
//	stg13_FIFO_buf88_stg14_1_merged1838_1397
//	stg13_FIFO_buf88_stg14_1_merged1838_1398
//	stg13_FIFO_buf88_stg14_1_merged1838_1399
//	stg13_FIFO_buf88_stg14_1_merged1838_1400
//	stg13_FIFO_buf88_stg14_1_merged1838_1401
//	stg13_FIFO_buf88_stg14_1_merged1838_1402
//	stg13_FIFO_buf88_stg14_1_merged1838_1403
//	stg13_FIFO_buf88_stg14_1_merged1838_1404
//	stg13_FIFO_buf88_stg14_1_merged1838_1405
//	stg13_FIFO_buf88_stg14_1_merged1838_1406
//	stg13_FIFO_buf88_stg14_1_merged1838_1407
//	stg13_FIFO_buf88_stg14_1_merged1838_1408
//	stg13_FIFO_buf88_stg14_1_merged1838_1409
//	stg13_FIFO_buf88_stg14_1_merged1838_1410
//	stg13_FIFO_buf88_stg14_1_merged1838_1411
//	stg13_FIFO_buf88_stg14_1_merged1838_1412
//	stg13_FIFO_buf88_stg14_1_merged1838_1413
//	stg13_FIFO_buf88_stg14_1_merged1838_1414
//	stg13_FIFO_buf88_stg14_1_merged1838_1415
//	stg13_FIFO_buf88_stg14_1_merged1838_1416
//	stg13_FIFO_buf88_stg14_1_merged1838_1417
//	stg13_FIFO_buf88_stg14_1_merged1838_1418
//	stg13_FIFO_buf88_stg14_1_merged1838_1419
//	stg13_FIFO_buf88_stg14_1_merged1838_1420
//	stg13_FIFO_buf88_stg14_1_merged1838_1421
//	stg13_FIFO_buf88_stg14_1_merged1838_1422
//	stg13_FIFO_buf88_stg14_1_merged1838_1423
//	stg13_FIFO_buf88_stg14_1_merged1838_1424
//	stg13_FIFO_buf88_stg14_1_merged1838_1425
//	stg13_FIFO_buf88_stg14_1_merged1838_1426
//	stg13_FIFO_buf88_stg14_1_merged1838_1427
//	stg13_FIFO_buf88_stg14_1_merged1838_1428
//	stg13_FIFO_buf88_stg14_1_merged1838_1429
//	stg13_FIFO_buf88_stg14_1_merged1838_1430
//	stg13_FIFO_buf88_stg14_1_merged1838_1431
//	stg13_FIFO_buf88_stg14_1_merged1838_1432
//	stg13_FIFO_buf88_stg14_1_merged1838_1433
//	stg13_FIFO_buf88_stg14_1_merged1838_1434
//	stg13_FIFO_buf88_stg14_1_merged1838_1435
//	stg13_FIFO_buf88_stg14_1_merged1838_1436
//	stg13_FIFO_buf88_stg14_1_merged1838_1437
//	stg13_FIFO_buf88_stg14_1_merged1838_1438
//	stg13_FIFO_buf88_stg14_1_merged1838_1439
inline hw_uint<1024> stg13_FIFO_buf88_stg14_1_merged1838_read_bundle_read(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int root, int stg14_0, int stg14_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg13_FIFO_buf88_stg14_1_merged1838_1376
    // stg13_FIFO_buf88_stg14_1_merged1838_1377
    // stg13_FIFO_buf88_stg14_1_merged1838_1378
    // stg13_FIFO_buf88_stg14_1_merged1838_1379
    // stg13_FIFO_buf88_stg14_1_merged1838_1380
    // stg13_FIFO_buf88_stg14_1_merged1838_1381
    // stg13_FIFO_buf88_stg14_1_merged1838_1382
    // stg13_FIFO_buf88_stg14_1_merged1838_1383
    // stg13_FIFO_buf88_stg14_1_merged1838_1384
    // stg13_FIFO_buf88_stg14_1_merged1838_1385
    // stg13_FIFO_buf88_stg14_1_merged1838_1386
    // stg13_FIFO_buf88_stg14_1_merged1838_1387
    // stg13_FIFO_buf88_stg14_1_merged1838_1388
    // stg13_FIFO_buf88_stg14_1_merged1838_1389
    // stg13_FIFO_buf88_stg14_1_merged1838_1390
    // stg13_FIFO_buf88_stg14_1_merged1838_1391
    // stg13_FIFO_buf88_stg14_1_merged1838_1392
    // stg13_FIFO_buf88_stg14_1_merged1838_1393
    // stg13_FIFO_buf88_stg14_1_merged1838_1394
    // stg13_FIFO_buf88_stg14_1_merged1838_1395
    // stg13_FIFO_buf88_stg14_1_merged1838_1396
    // stg13_FIFO_buf88_stg14_1_merged1838_1397
    // stg13_FIFO_buf88_stg14_1_merged1838_1398
    // stg13_FIFO_buf88_stg14_1_merged1838_1399
    // stg13_FIFO_buf88_stg14_1_merged1838_1400
    // stg13_FIFO_buf88_stg14_1_merged1838_1401
    // stg13_FIFO_buf88_stg14_1_merged1838_1402
    // stg13_FIFO_buf88_stg14_1_merged1838_1403
    // stg13_FIFO_buf88_stg14_1_merged1838_1404
    // stg13_FIFO_buf88_stg14_1_merged1838_1405
    // stg13_FIFO_buf88_stg14_1_merged1838_1406
    // stg13_FIFO_buf88_stg14_1_merged1838_1407
    // stg13_FIFO_buf88_stg14_1_merged1838_1408
    // stg13_FIFO_buf88_stg14_1_merged1838_1409
    // stg13_FIFO_buf88_stg14_1_merged1838_1410
    // stg13_FIFO_buf88_stg14_1_merged1838_1411
    // stg13_FIFO_buf88_stg14_1_merged1838_1412
    // stg13_FIFO_buf88_stg14_1_merged1838_1413
    // stg13_FIFO_buf88_stg14_1_merged1838_1414
    // stg13_FIFO_buf88_stg14_1_merged1838_1415
    // stg13_FIFO_buf88_stg14_1_merged1838_1416
    // stg13_FIFO_buf88_stg14_1_merged1838_1417
    // stg13_FIFO_buf88_stg14_1_merged1838_1418
    // stg13_FIFO_buf88_stg14_1_merged1838_1419
    // stg13_FIFO_buf88_stg14_1_merged1838_1420
    // stg13_FIFO_buf88_stg14_1_merged1838_1421
    // stg13_FIFO_buf88_stg14_1_merged1838_1422
    // stg13_FIFO_buf88_stg14_1_merged1838_1423
    // stg13_FIFO_buf88_stg14_1_merged1838_1424
    // stg13_FIFO_buf88_stg14_1_merged1838_1425
    // stg13_FIFO_buf88_stg14_1_merged1838_1426
    // stg13_FIFO_buf88_stg14_1_merged1838_1427
    // stg13_FIFO_buf88_stg14_1_merged1838_1428
    // stg13_FIFO_buf88_stg14_1_merged1838_1429
    // stg13_FIFO_buf88_stg14_1_merged1838_1430
    // stg13_FIFO_buf88_stg14_1_merged1838_1431
    // stg13_FIFO_buf88_stg14_1_merged1838_1432
    // stg13_FIFO_buf88_stg14_1_merged1838_1433
    // stg13_FIFO_buf88_stg14_1_merged1838_1434
    // stg13_FIFO_buf88_stg14_1_merged1838_1435
    // stg13_FIFO_buf88_stg14_1_merged1838_1436
    // stg13_FIFO_buf88_stg14_1_merged1838_1437
    // stg13_FIFO_buf88_stg14_1_merged1838_1438
    // stg13_FIFO_buf88_stg14_1_merged1838_1439

	hw_uint<1024> result;
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1376_res = stg13_FIFO_buf88_stg14_1_merged1838_1376_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<0, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1376_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1377_res = stg13_FIFO_buf88_stg14_1_merged1838_1377_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<16, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1377_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1378_res = stg13_FIFO_buf88_stg14_1_merged1838_1378_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<32, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1378_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1379_res = stg13_FIFO_buf88_stg14_1_merged1838_1379_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<48, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1379_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1380_res = stg13_FIFO_buf88_stg14_1_merged1838_1380_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<64, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1380_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1381_res = stg13_FIFO_buf88_stg14_1_merged1838_1381_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<80, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1381_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1382_res = stg13_FIFO_buf88_stg14_1_merged1838_1382_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<96, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1382_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1383_res = stg13_FIFO_buf88_stg14_1_merged1838_1383_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<112, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1383_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1384_res = stg13_FIFO_buf88_stg14_1_merged1838_1384_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<128, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1384_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1385_res = stg13_FIFO_buf88_stg14_1_merged1838_1385_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<144, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1385_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1386_res = stg13_FIFO_buf88_stg14_1_merged1838_1386_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<160, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1386_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1387_res = stg13_FIFO_buf88_stg14_1_merged1838_1387_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<176, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1387_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1388_res = stg13_FIFO_buf88_stg14_1_merged1838_1388_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<192, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1388_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1389_res = stg13_FIFO_buf88_stg14_1_merged1838_1389_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<208, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1389_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1390_res = stg13_FIFO_buf88_stg14_1_merged1838_1390_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<224, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1390_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1391_res = stg13_FIFO_buf88_stg14_1_merged1838_1391_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<240, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1391_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1392_res = stg13_FIFO_buf88_stg14_1_merged1838_1392_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<256, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1392_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1393_res = stg13_FIFO_buf88_stg14_1_merged1838_1393_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<272, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1393_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1394_res = stg13_FIFO_buf88_stg14_1_merged1838_1394_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<288, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1394_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1395_res = stg13_FIFO_buf88_stg14_1_merged1838_1395_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<304, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1395_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1396_res = stg13_FIFO_buf88_stg14_1_merged1838_1396_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<320, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1396_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1397_res = stg13_FIFO_buf88_stg14_1_merged1838_1397_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<336, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1397_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1398_res = stg13_FIFO_buf88_stg14_1_merged1838_1398_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<352, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1398_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1399_res = stg13_FIFO_buf88_stg14_1_merged1838_1399_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<368, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1399_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1400_res = stg13_FIFO_buf88_stg14_1_merged1838_1400_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<384, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1400_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1401_res = stg13_FIFO_buf88_stg14_1_merged1838_1401_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<400, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1401_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1402_res = stg13_FIFO_buf88_stg14_1_merged1838_1402_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<416, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1402_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1403_res = stg13_FIFO_buf88_stg14_1_merged1838_1403_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<432, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1403_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1404_res = stg13_FIFO_buf88_stg14_1_merged1838_1404_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<448, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1404_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1405_res = stg13_FIFO_buf88_stg14_1_merged1838_1405_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<464, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1405_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1406_res = stg13_FIFO_buf88_stg14_1_merged1838_1406_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<480, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1406_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1407_res = stg13_FIFO_buf88_stg14_1_merged1838_1407_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<496, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1407_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1408_res = stg13_FIFO_buf88_stg14_1_merged1838_1408_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<512, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1408_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1409_res = stg13_FIFO_buf88_stg14_1_merged1838_1409_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<528, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1409_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1410_res = stg13_FIFO_buf88_stg14_1_merged1838_1410_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<544, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1410_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1411_res = stg13_FIFO_buf88_stg14_1_merged1838_1411_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<560, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1411_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1412_res = stg13_FIFO_buf88_stg14_1_merged1838_1412_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<576, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1412_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1413_res = stg13_FIFO_buf88_stg14_1_merged1838_1413_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<592, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1413_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1414_res = stg13_FIFO_buf88_stg14_1_merged1838_1414_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<608, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1414_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1415_res = stg13_FIFO_buf88_stg14_1_merged1838_1415_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<624, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1415_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1416_res = stg13_FIFO_buf88_stg14_1_merged1838_1416_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<640, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1416_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1417_res = stg13_FIFO_buf88_stg14_1_merged1838_1417_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<656, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1417_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1418_res = stg13_FIFO_buf88_stg14_1_merged1838_1418_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<672, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1418_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1419_res = stg13_FIFO_buf88_stg14_1_merged1838_1419_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<688, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1419_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1420_res = stg13_FIFO_buf88_stg14_1_merged1838_1420_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<704, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1420_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1421_res = stg13_FIFO_buf88_stg14_1_merged1838_1421_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<720, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1421_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1422_res = stg13_FIFO_buf88_stg14_1_merged1838_1422_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<736, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1422_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1423_res = stg13_FIFO_buf88_stg14_1_merged1838_1423_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<752, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1423_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1424_res = stg13_FIFO_buf88_stg14_1_merged1838_1424_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<768, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1424_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1425_res = stg13_FIFO_buf88_stg14_1_merged1838_1425_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<784, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1425_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1426_res = stg13_FIFO_buf88_stg14_1_merged1838_1426_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<800, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1426_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1427_res = stg13_FIFO_buf88_stg14_1_merged1838_1427_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<816, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1427_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1428_res = stg13_FIFO_buf88_stg14_1_merged1838_1428_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<832, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1428_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1429_res = stg13_FIFO_buf88_stg14_1_merged1838_1429_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<848, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1429_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1430_res = stg13_FIFO_buf88_stg14_1_merged1838_1430_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<864, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1430_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1431_res = stg13_FIFO_buf88_stg14_1_merged1838_1431_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<880, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1431_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1432_res = stg13_FIFO_buf88_stg14_1_merged1838_1432_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<896, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1432_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1433_res = stg13_FIFO_buf88_stg14_1_merged1838_1433_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<912, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1433_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1434_res = stg13_FIFO_buf88_stg14_1_merged1838_1434_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<928, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1434_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1435_res = stg13_FIFO_buf88_stg14_1_merged1838_1435_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<944, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1435_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1436_res = stg13_FIFO_buf88_stg14_1_merged1838_1436_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<960, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1436_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1437_res = stg13_FIFO_buf88_stg14_1_merged1838_1437_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<976, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1437_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1438_res = stg13_FIFO_buf88_stg14_1_merged1838_1438_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<992, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1438_res);
	hw_uint<16> stg13_FIFO_buf88_stg14_1_merged1838_1439_res = stg13_FIFO_buf88_stg14_1_merged1838_1439_select(stg13_FIFO_buf88, root, stg14_0, stg14_1, dynamic_address);
	set_at<1008, 1024>(result, stg13_FIFO_buf88_stg14_1_merged1838_1439_res);
	return result;
}

struct stg14_stg14_1_merged1838_1360_to_stg14_stg14_ld29_merged1845_1344_cache {
	// RAM Box: {[15, 1087], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1361_to_stg14_stg14_ld29_merged1845_1345_cache {
	// RAM Box: {[14, 1086], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1362_to_stg14_stg14_ld29_merged1845_1346_cache {
	// RAM Box: {[13, 1085], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1363_to_stg14_stg14_ld29_merged1845_1347_cache {
	// RAM Box: {[12, 1084], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1364_to_stg14_stg14_ld29_merged1845_1348_cache {
	// RAM Box: {[11, 1083], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1365_to_stg14_stg14_ld29_merged1845_1349_cache {
	// RAM Box: {[10, 1082], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1366_to_stg14_stg14_ld29_merged1845_1350_cache {
	// RAM Box: {[9, 1081], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1367_to_stg14_stg14_ld29_merged1845_1351_cache {
	// RAM Box: {[8, 1080], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1368_to_stg14_stg14_ld29_merged1845_1352_cache {
	// RAM Box: {[7, 1079], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1369_to_stg14_stg14_ld29_merged1845_1353_cache {
	// RAM Box: {[6, 1078], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1370_to_stg14_stg14_ld29_merged1845_1354_cache {
	// RAM Box: {[5, 1077], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1371_to_stg14_stg14_ld29_merged1845_1355_cache {
	// RAM Box: {[4, 1076], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1372_to_stg14_stg14_ld29_merged1845_1356_cache {
	// RAM Box: {[3, 1075], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1373_to_stg14_stg14_ld29_merged1845_1357_cache {
	// RAM Box: {[2, 1074], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1374_to_stg14_stg14_ld29_merged1845_1358_cache {
	// RAM Box: {[1, 1073], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_stg14_1_merged1838_1375_to_stg14_stg14_ld29_merged1845_1359_cache {
	// RAM Box: {[0, 1072], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_cache {
  // Reader addrs...
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[15 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[14 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[13 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[12 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[11 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[10 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[9 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[8 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[7 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[6 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[5 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[4 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[3 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[2 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[1 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
    // { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // # of banks: 16
  stg14_stg14_1_merged1838_1360_to_stg14_stg14_ld29_merged1845_1344_cache stg14_stg14_1_merged1838_1360_to_stg14_stg14_ld29_merged1845_1344;
  stg14_stg14_1_merged1838_1361_to_stg14_stg14_ld29_merged1845_1345_cache stg14_stg14_1_merged1838_1361_to_stg14_stg14_ld29_merged1845_1345;
  stg14_stg14_1_merged1838_1362_to_stg14_stg14_ld29_merged1845_1346_cache stg14_stg14_1_merged1838_1362_to_stg14_stg14_ld29_merged1845_1346;
  stg14_stg14_1_merged1838_1363_to_stg14_stg14_ld29_merged1845_1347_cache stg14_stg14_1_merged1838_1363_to_stg14_stg14_ld29_merged1845_1347;
  stg14_stg14_1_merged1838_1364_to_stg14_stg14_ld29_merged1845_1348_cache stg14_stg14_1_merged1838_1364_to_stg14_stg14_ld29_merged1845_1348;
  stg14_stg14_1_merged1838_1365_to_stg14_stg14_ld29_merged1845_1349_cache stg14_stg14_1_merged1838_1365_to_stg14_stg14_ld29_merged1845_1349;
  stg14_stg14_1_merged1838_1366_to_stg14_stg14_ld29_merged1845_1350_cache stg14_stg14_1_merged1838_1366_to_stg14_stg14_ld29_merged1845_1350;
  stg14_stg14_1_merged1838_1367_to_stg14_stg14_ld29_merged1845_1351_cache stg14_stg14_1_merged1838_1367_to_stg14_stg14_ld29_merged1845_1351;
  stg14_stg14_1_merged1838_1368_to_stg14_stg14_ld29_merged1845_1352_cache stg14_stg14_1_merged1838_1368_to_stg14_stg14_ld29_merged1845_1352;
  stg14_stg14_1_merged1838_1369_to_stg14_stg14_ld29_merged1845_1353_cache stg14_stg14_1_merged1838_1369_to_stg14_stg14_ld29_merged1845_1353;
  stg14_stg14_1_merged1838_1370_to_stg14_stg14_ld29_merged1845_1354_cache stg14_stg14_1_merged1838_1370_to_stg14_stg14_ld29_merged1845_1354;
  stg14_stg14_1_merged1838_1371_to_stg14_stg14_ld29_merged1845_1355_cache stg14_stg14_1_merged1838_1371_to_stg14_stg14_ld29_merged1845_1355;
  stg14_stg14_1_merged1838_1372_to_stg14_stg14_ld29_merged1845_1356_cache stg14_stg14_1_merged1838_1372_to_stg14_stg14_ld29_merged1845_1356;
  stg14_stg14_1_merged1838_1373_to_stg14_stg14_ld29_merged1845_1357_cache stg14_stg14_1_merged1838_1373_to_stg14_stg14_ld29_merged1845_1357;
  stg14_stg14_1_merged1838_1374_to_stg14_stg14_ld29_merged1845_1358_cache stg14_stg14_1_merged1838_1374_to_stg14_stg14_ld29_merged1845_1358;
  stg14_stg14_1_merged1838_1375_to_stg14_stg14_ld29_merged1845_1359_cache stg14_stg14_1_merged1838_1375_to_stg14_stg14_ld29_merged1845_1359;
};



inline void stg14_stg14_1_merged1838_1360_write(hw_uint<16>& stg14_stg14_1_merged1838_1360, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1360_to_stg14_stg14_ld29_merged1845_1344.push(stg14_stg14_1_merged1838_1360);
}

inline void stg14_stg14_1_merged1838_1361_write(hw_uint<16>& stg14_stg14_1_merged1838_1361, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1361_to_stg14_stg14_ld29_merged1845_1345.push(stg14_stg14_1_merged1838_1361);
}

inline void stg14_stg14_1_merged1838_1362_write(hw_uint<16>& stg14_stg14_1_merged1838_1362, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1362_to_stg14_stg14_ld29_merged1845_1346.push(stg14_stg14_1_merged1838_1362);
}

inline void stg14_stg14_1_merged1838_1363_write(hw_uint<16>& stg14_stg14_1_merged1838_1363, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1363_to_stg14_stg14_ld29_merged1845_1347.push(stg14_stg14_1_merged1838_1363);
}

inline void stg14_stg14_1_merged1838_1364_write(hw_uint<16>& stg14_stg14_1_merged1838_1364, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1364_to_stg14_stg14_ld29_merged1845_1348.push(stg14_stg14_1_merged1838_1364);
}

inline void stg14_stg14_1_merged1838_1365_write(hw_uint<16>& stg14_stg14_1_merged1838_1365, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1365_to_stg14_stg14_ld29_merged1845_1349.push(stg14_stg14_1_merged1838_1365);
}

inline void stg14_stg14_1_merged1838_1366_write(hw_uint<16>& stg14_stg14_1_merged1838_1366, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1366_to_stg14_stg14_ld29_merged1845_1350.push(stg14_stg14_1_merged1838_1366);
}

inline void stg14_stg14_1_merged1838_1367_write(hw_uint<16>& stg14_stg14_1_merged1838_1367, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1367_to_stg14_stg14_ld29_merged1845_1351.push(stg14_stg14_1_merged1838_1367);
}

inline void stg14_stg14_1_merged1838_1368_write(hw_uint<16>& stg14_stg14_1_merged1838_1368, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1368_to_stg14_stg14_ld29_merged1845_1352.push(stg14_stg14_1_merged1838_1368);
}

inline void stg14_stg14_1_merged1838_1369_write(hw_uint<16>& stg14_stg14_1_merged1838_1369, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1369_to_stg14_stg14_ld29_merged1845_1353.push(stg14_stg14_1_merged1838_1369);
}

inline void stg14_stg14_1_merged1838_1370_write(hw_uint<16>& stg14_stg14_1_merged1838_1370, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1370_to_stg14_stg14_ld29_merged1845_1354.push(stg14_stg14_1_merged1838_1370);
}

inline void stg14_stg14_1_merged1838_1371_write(hw_uint<16>& stg14_stg14_1_merged1838_1371, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1371_to_stg14_stg14_ld29_merged1845_1355.push(stg14_stg14_1_merged1838_1371);
}

inline void stg14_stg14_1_merged1838_1372_write(hw_uint<16>& stg14_stg14_1_merged1838_1372, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1372_to_stg14_stg14_ld29_merged1845_1356.push(stg14_stg14_1_merged1838_1372);
}

inline void stg14_stg14_1_merged1838_1373_write(hw_uint<16>& stg14_stg14_1_merged1838_1373, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1373_to_stg14_stg14_ld29_merged1845_1357.push(stg14_stg14_1_merged1838_1373);
}

inline void stg14_stg14_1_merged1838_1374_write(hw_uint<16>& stg14_stg14_1_merged1838_1374, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1374_to_stg14_stg14_ld29_merged1845_1358.push(stg14_stg14_1_merged1838_1374);
}

inline void stg14_stg14_1_merged1838_1375_write(hw_uint<16>& stg14_stg14_1_merged1838_1375, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
  stg14.stg14_stg14_1_merged1838_1375_to_stg14_stg14_ld29_merged1845_1359.push(stg14_stg14_1_merged1838_1375);
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1344_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1344 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[15 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1360 = stg14.stg14_stg14_1_merged1838_1360_to_stg14_stg14_ld29_merged1845_1344.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1360;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1345_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1345 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[14 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1361 = stg14.stg14_stg14_1_merged1838_1361_to_stg14_stg14_ld29_merged1845_1345.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1361;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1346_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1346 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[13 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1362 = stg14.stg14_stg14_1_merged1838_1362_to_stg14_stg14_ld29_merged1845_1346.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1362;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1347_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1347 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[12 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1363 = stg14.stg14_stg14_1_merged1838_1363_to_stg14_stg14_ld29_merged1845_1347.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1363;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1348_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1348 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[11 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1364 = stg14.stg14_stg14_1_merged1838_1364_to_stg14_stg14_ld29_merged1845_1348.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1364;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1349_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1349 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[10 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1365 = stg14.stg14_stg14_1_merged1838_1365_to_stg14_stg14_ld29_merged1845_1349.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1365;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1350_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1350 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[9 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1366 = stg14.stg14_stg14_1_merged1838_1366_to_stg14_stg14_ld29_merged1845_1350.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1366;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1351_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1351 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[8 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1367 = stg14.stg14_stg14_1_merged1838_1367_to_stg14_stg14_ld29_merged1845_1351.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1367;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1352_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1352 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[7 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1368 = stg14.stg14_stg14_1_merged1838_1368_to_stg14_stg14_ld29_merged1845_1352.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1368;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1353_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1353 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[6 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1369 = stg14.stg14_stg14_1_merged1838_1369_to_stg14_stg14_ld29_merged1845_1353.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1369;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1354_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1354 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[5 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1370 = stg14.stg14_stg14_1_merged1838_1370_to_stg14_stg14_ld29_merged1845_1354.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1370;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1355_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1355 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[4 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1371 = stg14.stg14_stg14_1_merged1838_1371_to_stg14_stg14_ld29_merged1845_1355.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1371;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1356_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1356 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[3 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1372 = stg14.stg14_stg14_1_merged1838_1372_to_stg14_stg14_ld29_merged1845_1356.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1372;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1357_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1357 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[2 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1373 = stg14.stg14_stg14_1_merged1838_1373_to_stg14_stg14_ld29_merged1845_1357.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1373;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1358_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1358 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[1 + 16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1374 = stg14.stg14_stg14_1_merged1838_1374_to_stg14_stg14_ld29_merged1845_1358.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1374;
  return 0;
}

inline hw_uint<16> stg14_stg14_ld29_merged1845_1359_select(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_stg14_ld29_merged1845_1359 read pattern: { stg14_ld29_merged1845[root = 0, stg14_ld30, stg14_ld29] -> stg14[16stg14_ld29, stg14_ld30] : 0 <= stg14_ld30 <= 1919 and 0 <= stg14_ld29 <= 67 }
  // Read schedule : { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_stg14_1_merged1838_1375 = stg14.stg14_stg14_1_merged1838_1375_to_stg14_stg14_ld29_merged1845_1359.peek(/* one reader or all rams */ 0);
  return value_stg14_stg14_1_merged1838_1375;
  return 0;
}

// # of bundles = 2
// stg14_1_merged1838_write
//	stg14_stg14_1_merged1838_1360
//	stg14_stg14_1_merged1838_1361
//	stg14_stg14_1_merged1838_1362
//	stg14_stg14_1_merged1838_1363
//	stg14_stg14_1_merged1838_1364
//	stg14_stg14_1_merged1838_1365
//	stg14_stg14_1_merged1838_1366
//	stg14_stg14_1_merged1838_1367
//	stg14_stg14_1_merged1838_1368
//	stg14_stg14_1_merged1838_1369
//	stg14_stg14_1_merged1838_1370
//	stg14_stg14_1_merged1838_1371
//	stg14_stg14_1_merged1838_1372
//	stg14_stg14_1_merged1838_1373
//	stg14_stg14_1_merged1838_1374
//	stg14_stg14_1_merged1838_1375
inline void stg14_stg14_1_merged1838_write_bundle_write(hw_uint<256>& stg14_1_merged1838_write, stg14_cache& stg14, int root, int stg14_0, int stg14_1, int dynamic_address) {
	hw_uint<16> stg14_stg14_1_merged1838_1360_res = stg14_1_merged1838_write.extract<0, 15>();
	stg14_stg14_1_merged1838_1360_write(stg14_stg14_1_merged1838_1360_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1361_res = stg14_1_merged1838_write.extract<16, 31>();
	stg14_stg14_1_merged1838_1361_write(stg14_stg14_1_merged1838_1361_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1362_res = stg14_1_merged1838_write.extract<32, 47>();
	stg14_stg14_1_merged1838_1362_write(stg14_stg14_1_merged1838_1362_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1363_res = stg14_1_merged1838_write.extract<48, 63>();
	stg14_stg14_1_merged1838_1363_write(stg14_stg14_1_merged1838_1363_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1364_res = stg14_1_merged1838_write.extract<64, 79>();
	stg14_stg14_1_merged1838_1364_write(stg14_stg14_1_merged1838_1364_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1365_res = stg14_1_merged1838_write.extract<80, 95>();
	stg14_stg14_1_merged1838_1365_write(stg14_stg14_1_merged1838_1365_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1366_res = stg14_1_merged1838_write.extract<96, 111>();
	stg14_stg14_1_merged1838_1366_write(stg14_stg14_1_merged1838_1366_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1367_res = stg14_1_merged1838_write.extract<112, 127>();
	stg14_stg14_1_merged1838_1367_write(stg14_stg14_1_merged1838_1367_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1368_res = stg14_1_merged1838_write.extract<128, 143>();
	stg14_stg14_1_merged1838_1368_write(stg14_stg14_1_merged1838_1368_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1369_res = stg14_1_merged1838_write.extract<144, 159>();
	stg14_stg14_1_merged1838_1369_write(stg14_stg14_1_merged1838_1369_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1370_res = stg14_1_merged1838_write.extract<160, 175>();
	stg14_stg14_1_merged1838_1370_write(stg14_stg14_1_merged1838_1370_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1371_res = stg14_1_merged1838_write.extract<176, 191>();
	stg14_stg14_1_merged1838_1371_write(stg14_stg14_1_merged1838_1371_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1372_res = stg14_1_merged1838_write.extract<192, 207>();
	stg14_stg14_1_merged1838_1372_write(stg14_stg14_1_merged1838_1372_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1373_res = stg14_1_merged1838_write.extract<208, 223>();
	stg14_stg14_1_merged1838_1373_write(stg14_stg14_1_merged1838_1373_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1374_res = stg14_1_merged1838_write.extract<224, 239>();
	stg14_stg14_1_merged1838_1374_write(stg14_stg14_1_merged1838_1374_res, stg14, root, stg14_0, stg14_1, dynamic_address);
	hw_uint<16> stg14_stg14_1_merged1838_1375_res = stg14_1_merged1838_write.extract<240, 255>();
	stg14_stg14_1_merged1838_1375_write(stg14_stg14_1_merged1838_1375_res, stg14, root, stg14_0, stg14_1, dynamic_address);
}

// stg14_ld29_merged1845_read
//	stg14_stg14_ld29_merged1845_1344
//	stg14_stg14_ld29_merged1845_1345
//	stg14_stg14_ld29_merged1845_1346
//	stg14_stg14_ld29_merged1845_1347
//	stg14_stg14_ld29_merged1845_1348
//	stg14_stg14_ld29_merged1845_1349
//	stg14_stg14_ld29_merged1845_1350
//	stg14_stg14_ld29_merged1845_1351
//	stg14_stg14_ld29_merged1845_1352
//	stg14_stg14_ld29_merged1845_1353
//	stg14_stg14_ld29_merged1845_1354
//	stg14_stg14_ld29_merged1845_1355
//	stg14_stg14_ld29_merged1845_1356
//	stg14_stg14_ld29_merged1845_1357
//	stg14_stg14_ld29_merged1845_1358
//	stg14_stg14_ld29_merged1845_1359
inline hw_uint<256> stg14_stg14_ld29_merged1845_read_bundle_read(stg14_cache& stg14, int root, int stg14_ld30, int stg14_ld29, int dynamic_address) {
  // # of ports in bundle: 16
    // stg14_stg14_ld29_merged1845_1344
    // stg14_stg14_ld29_merged1845_1345
    // stg14_stg14_ld29_merged1845_1346
    // stg14_stg14_ld29_merged1845_1347
    // stg14_stg14_ld29_merged1845_1348
    // stg14_stg14_ld29_merged1845_1349
    // stg14_stg14_ld29_merged1845_1350
    // stg14_stg14_ld29_merged1845_1351
    // stg14_stg14_ld29_merged1845_1352
    // stg14_stg14_ld29_merged1845_1353
    // stg14_stg14_ld29_merged1845_1354
    // stg14_stg14_ld29_merged1845_1355
    // stg14_stg14_ld29_merged1845_1356
    // stg14_stg14_ld29_merged1845_1357
    // stg14_stg14_ld29_merged1845_1358
    // stg14_stg14_ld29_merged1845_1359

	hw_uint<256> result;
	hw_uint<16> stg14_stg14_ld29_merged1845_1344_res = stg14_stg14_ld29_merged1845_1344_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<0, 256>(result, stg14_stg14_ld29_merged1845_1344_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1345_res = stg14_stg14_ld29_merged1845_1345_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<16, 256>(result, stg14_stg14_ld29_merged1845_1345_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1346_res = stg14_stg14_ld29_merged1845_1346_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<32, 256>(result, stg14_stg14_ld29_merged1845_1346_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1347_res = stg14_stg14_ld29_merged1845_1347_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<48, 256>(result, stg14_stg14_ld29_merged1845_1347_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1348_res = stg14_stg14_ld29_merged1845_1348_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<64, 256>(result, stg14_stg14_ld29_merged1845_1348_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1349_res = stg14_stg14_ld29_merged1845_1349_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<80, 256>(result, stg14_stg14_ld29_merged1845_1349_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1350_res = stg14_stg14_ld29_merged1845_1350_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<96, 256>(result, stg14_stg14_ld29_merged1845_1350_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1351_res = stg14_stg14_ld29_merged1845_1351_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<112, 256>(result, stg14_stg14_ld29_merged1845_1351_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1352_res = stg14_stg14_ld29_merged1845_1352_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<128, 256>(result, stg14_stg14_ld29_merged1845_1352_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1353_res = stg14_stg14_ld29_merged1845_1353_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<144, 256>(result, stg14_stg14_ld29_merged1845_1353_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1354_res = stg14_stg14_ld29_merged1845_1354_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<160, 256>(result, stg14_stg14_ld29_merged1845_1354_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1355_res = stg14_stg14_ld29_merged1845_1355_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<176, 256>(result, stg14_stg14_ld29_merged1845_1355_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1356_res = stg14_stg14_ld29_merged1845_1356_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<192, 256>(result, stg14_stg14_ld29_merged1845_1356_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1357_res = stg14_stg14_ld29_merged1845_1357_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<208, 256>(result, stg14_stg14_ld29_merged1845_1357_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1358_res = stg14_stg14_ld29_merged1845_1358_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<224, 256>(result, stg14_stg14_ld29_merged1845_1358_res);
	hw_uint<16> stg14_stg14_ld29_merged1845_1359_res = stg14_stg14_ld29_merged1845_1359_select(stg14, root, stg14_ld30, stg14_ld29, dynamic_address);
	set_at<240, 256>(result, stg14_stg14_ld29_merged1845_1359_res);
	return result;
}

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176_cache {
	// RAM Box: {[15, 1087], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177_cache {
	// RAM Box: {[14, 1086], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178_cache {
	// RAM Box: {[13, 1085], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179_cache {
	// RAM Box: {[12, 1084], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180_cache {
	// RAM Box: {[11, 1083], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181_cache {
	// RAM Box: {[10, 1082], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182_cache {
	// RAM Box: {[9, 1081], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183_cache {
	// RAM Box: {[8, 1080], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184_cache {
	// RAM Box: {[7, 1079], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185_cache {
	// RAM Box: {[6, 1078], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186_cache {
	// RAM Box: {[5, 1077], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187_cache {
	// RAM Box: {[4, 1076], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188_cache {
	// RAM Box: {[3, 1075], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189_cache {
	// RAM Box: {[2, 1074], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190_cache {
	// RAM Box: {[1, 1073], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191_cache {
	// RAM Box: {[0, 1072], [0, 1919]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg14_FIFO_buf92_cache {
  // Reader addrs...
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[15 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[14 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[13 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[12 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[11 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[10 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[9 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[8 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[7 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[6 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[5 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[4 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[3 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[2 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[1 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
    // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // # of banks: 16
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190;
  stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191_cache stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191;
};



inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310);
}

inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311_write(hw_uint<16>& stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
  stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191.push(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311);
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[15 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[14 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[13 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[12 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[11 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[10 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[9 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[8 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[7 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[6 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[5 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[4 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[3 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[2 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[1 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310;
  return 0;
}

inline hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191_select(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191 read pattern: { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> stg14_FIFO_buf92[16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
  // Read schedule : { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  // Write schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
  auto value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311 = stg14_FIFO_buf92.stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311_to_stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191.peek(/* one reader or all rams */ 0);
  return value_stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311;
  return 0;
}

// # of bundles = 2
// jacdyn_16_1_merged1841_read
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190
//	stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191
inline hw_uint<256> stg14_FIFO_buf92_jacdyn_16_1_merged1841_read_bundle_read(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int jacdyn_16_0, int jacdyn_16_1, int dynamic_address) {
  // # of ports in bundle: 16
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190
    // stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191

	hw_uint<256> result;
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<0, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2176_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<16, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2177_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<32, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2178_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<48, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2179_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<64, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2180_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<80, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2181_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<96, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2182_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<112, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2183_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<128, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2184_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<144, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2185_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<160, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2186_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<176, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2187_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<192, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2188_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<208, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2189_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<224, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2190_res);
	hw_uint<16> stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191_res = stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191_select(stg14_FIFO_buf92, root, jacdyn_16_0, jacdyn_16_1, dynamic_address);
	set_at<240, 256>(result, stg14_FIFO_buf92_jacdyn_16_1_merged1841_2191_res);
	return result;
}

// stg14_to_gp_128_ld93_merged1780_write
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310
//	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311
inline void stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_write_bundle_write(hw_uint<256>& stg14_to_gp_128_ld93_merged1780_write, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int root, int stg14_to_gp_128_ld94, int stg14_to_gp_128_ld93, int dynamic_address) {
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296_res = stg14_to_gp_128_ld93_merged1780_write.extract<0, 15>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1296_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297_res = stg14_to_gp_128_ld93_merged1780_write.extract<16, 31>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1297_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298_res = stg14_to_gp_128_ld93_merged1780_write.extract<32, 47>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1298_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299_res = stg14_to_gp_128_ld93_merged1780_write.extract<48, 63>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1299_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300_res = stg14_to_gp_128_ld93_merged1780_write.extract<64, 79>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1300_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301_res = stg14_to_gp_128_ld93_merged1780_write.extract<80, 95>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1301_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302_res = stg14_to_gp_128_ld93_merged1780_write.extract<96, 111>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1302_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303_res = stg14_to_gp_128_ld93_merged1780_write.extract<112, 127>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1303_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304_res = stg14_to_gp_128_ld93_merged1780_write.extract<128, 143>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1304_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305_res = stg14_to_gp_128_ld93_merged1780_write.extract<144, 159>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1305_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306_res = stg14_to_gp_128_ld93_merged1780_write.extract<160, 175>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1306_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307_res = stg14_to_gp_128_ld93_merged1780_write.extract<176, 191>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1307_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308_res = stg14_to_gp_128_ld93_merged1780_write.extract<192, 207>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1308_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309_res = stg14_to_gp_128_ld93_merged1780_write.extract<208, 223>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1309_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310_res = stg14_to_gp_128_ld93_merged1780_write.extract<224, 239>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1310_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
	hw_uint<16> stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311_res = stg14_to_gp_128_ld93_merged1780_write.extract<240, 255>();
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311_write(stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_1311_res, stg14_FIFO_buf92, root, stg14_to_gp_128_ld94, stg14_to_gp_128_ld93, dynamic_address);
}

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_merged_banks_4_cache {
	// RAM Box: {[15, 1279], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_merged_banks_4_cache {
	// RAM Box: {[14, 1278], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_merged_banks_4_cache {
	// RAM Box: {[13, 1277], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_merged_banks_4_cache {
	// RAM Box: {[12, 1276], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_merged_banks_4_cache {
	// RAM Box: {[11, 1275], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_merged_banks_4_cache {
	// RAM Box: {[10, 1274], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_merged_banks_4_cache {
	// RAM Box: {[9, 1273], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_merged_banks_4_cache {
	// RAM Box: {[8, 1272], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_merged_banks_4_cache {
	// RAM Box: {[7, 1271], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_merged_banks_4_cache {
	// RAM Box: {[6, 1270], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_merged_banks_4_cache {
	// RAM Box: {[5, 1269], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_merged_banks_4_cache {
	// RAM Box: {[4, 1268], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_merged_banks_4_cache {
	// RAM Box: {[3, 1267], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_merged_banks_4_cache {
	// RAM Box: {[2, 1266], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_merged_banks_4_cache {
	// RAM Box: {[1, 1265], [-13, 1932]}
	// Capacity: 164
	// # of read delays: 4
  // 0, 1, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 80> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 80> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_81() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_82() {
		return f4;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_163() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_merged_banks_4_cache {
	// RAM Box: {[0, 1280], [-13, 1931]}
	// Capacity: 164
	// # of read delays: 5
  // 0, 1, 81, 82, 163
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 80> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_82() {
		return f6;
	}

	inline hw_uint<16> peek_162() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_163() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 80
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 80 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg1_FIFO_buf72_cache {
  // Reader addrs...
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[15 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[15 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[16 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[15 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[14 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[14 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[15 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[14 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[13 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[13 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[14 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[13 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[12 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[12 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[13 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[12 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[11 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[11 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[12 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[11 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[10 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[10 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[11 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[10 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[9 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[9 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[10 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[9 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[8 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[8 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[9 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[8 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[7 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[7 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[8 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[7 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[6 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[6 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[7 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[6 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[5 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[5 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[6 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[5 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[4 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[4 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[5 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[4 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[3 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[3 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[4 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[3 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[2 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[2 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[3 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[2 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[1 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[1 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[2 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[1 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[1 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
    // { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // # of banks: 16
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_merged_banks_4;
  stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_merged_banks_4_cache stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_merged_banks_4;
};



inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166);
}

inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_write(hw_uint<16>& stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
  stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_merged_banks_4.push(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167);
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1088_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1088 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[15 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1089_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1089 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[15 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1090_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1090 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[16 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_merged_banks_4.peek_81();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1091_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1091 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[15 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1092_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1092 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[14 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1093_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1093 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[14 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1094_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1094 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[15 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1095_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1095 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[14 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1096_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1096 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[13 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1097_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1097 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[13 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1098_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1098 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[14 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1099_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1099 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[13 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1100_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1100 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[12 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1101_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1101 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[12 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1102_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1102 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[13 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1103_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1103 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[12 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1104_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1104 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[11 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1105_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1105 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[11 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1106_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1106 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[12 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1107_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1107 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[11 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1108_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1108 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[10 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1109_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1109 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[10 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1110_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1110 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[11 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1111_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1111 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[10 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1112_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1112 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[9 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1113_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1113 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[9 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1114_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1114 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[10 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1115_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1115 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[9 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1116_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1116 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[8 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1117_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1117 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[8 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1118_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1118 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[9 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1119_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1119 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[8 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1120_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1120 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[7 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1121_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1121 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[7 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1122_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1122 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[8 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1123_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1123 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[7 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1124_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1124 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[6 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1125_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1125 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[6 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1126_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1126 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[7 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1127_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1127 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[6 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1128_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1128 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[5 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1129_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1129 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[5 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1130_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1130 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[6 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1131_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1131 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[5 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1132_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1132 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[4 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1133_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1133 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[4 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1134_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1134 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[5 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1135_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1135 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[4 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1136_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1136 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[3 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1137_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1137 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[3 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1138_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1138 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[4 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1139_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1139 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[3 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1140_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1140 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[2 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1141_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1141 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[2 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1142_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1142 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[3 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1143_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1143 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[2 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1144_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1144 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[1 + 16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1145_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1145 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[1 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1146_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1146 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[2 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1147_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1147 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[1 + 16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1148_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1148 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[16stg2_1, -13 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_merged_banks_4.peek_163();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1149_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1149 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1150_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1150 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[1 + 16stg2_1, -12 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_merged_banks_4.peek_82();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166;
  return 0;
}

inline hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1151_select(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg1_FIFO_buf72_stg2_1_merged1802_1151 read pattern: { stg2_1_merged1802[root = 0, stg2_0, stg2_1] -> stg1_FIFO_buf72[16stg2_1, -11 + stg2_0] : 0 <= stg2_0 <= 1943 and 0 <= stg2_1 <= 79 }
  // Read schedule : { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
  auto value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167 = stg1_FIFO_buf72.stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_merged_banks_4.peek_1();
  return value_stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167;
  return 0;
}

// # of bundles = 2
// stg1_to_gp_98_ld73_merged1776_write
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166
//	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167
inline void stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_write_bundle_write(hw_uint<256>& stg1_to_gp_98_ld73_merged1776_write, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg1_to_gp_98_ld74, int stg1_to_gp_98_ld73, int dynamic_address) {
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_res = stg1_to_gp_98_ld73_merged1776_write.extract<0, 15>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1152_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_res = stg1_to_gp_98_ld73_merged1776_write.extract<16, 31>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1153_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_res = stg1_to_gp_98_ld73_merged1776_write.extract<32, 47>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1154_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_res = stg1_to_gp_98_ld73_merged1776_write.extract<48, 63>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1155_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_res = stg1_to_gp_98_ld73_merged1776_write.extract<64, 79>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1156_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_res = stg1_to_gp_98_ld73_merged1776_write.extract<80, 95>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1157_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_res = stg1_to_gp_98_ld73_merged1776_write.extract<96, 111>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1158_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_res = stg1_to_gp_98_ld73_merged1776_write.extract<112, 127>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1159_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_res = stg1_to_gp_98_ld73_merged1776_write.extract<128, 143>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1160_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_res = stg1_to_gp_98_ld73_merged1776_write.extract<144, 159>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1161_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_res = stg1_to_gp_98_ld73_merged1776_write.extract<160, 175>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1162_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_res = stg1_to_gp_98_ld73_merged1776_write.extract<176, 191>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1163_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_res = stg1_to_gp_98_ld73_merged1776_write.extract<192, 207>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1164_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_res = stg1_to_gp_98_ld73_merged1776_write.extract<208, 223>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1165_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_res = stg1_to_gp_98_ld73_merged1776_write.extract<224, 239>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1166_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
	hw_uint<16> stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_res = stg1_to_gp_98_ld73_merged1776_write.extract<240, 255>();
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_write(stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_1167_res, stg1_FIFO_buf72, root, stg1_to_gp_98_ld74, stg1_to_gp_98_ld73, dynamic_address);
}

// stg2_1_merged1802_read
//	stg1_FIFO_buf72_stg2_1_merged1802_1088
//	stg1_FIFO_buf72_stg2_1_merged1802_1089
//	stg1_FIFO_buf72_stg2_1_merged1802_1090
//	stg1_FIFO_buf72_stg2_1_merged1802_1091
//	stg1_FIFO_buf72_stg2_1_merged1802_1092
//	stg1_FIFO_buf72_stg2_1_merged1802_1093
//	stg1_FIFO_buf72_stg2_1_merged1802_1094
//	stg1_FIFO_buf72_stg2_1_merged1802_1095
//	stg1_FIFO_buf72_stg2_1_merged1802_1096
//	stg1_FIFO_buf72_stg2_1_merged1802_1097
//	stg1_FIFO_buf72_stg2_1_merged1802_1098
//	stg1_FIFO_buf72_stg2_1_merged1802_1099
//	stg1_FIFO_buf72_stg2_1_merged1802_1100
//	stg1_FIFO_buf72_stg2_1_merged1802_1101
//	stg1_FIFO_buf72_stg2_1_merged1802_1102
//	stg1_FIFO_buf72_stg2_1_merged1802_1103
//	stg1_FIFO_buf72_stg2_1_merged1802_1104
//	stg1_FIFO_buf72_stg2_1_merged1802_1105
//	stg1_FIFO_buf72_stg2_1_merged1802_1106
//	stg1_FIFO_buf72_stg2_1_merged1802_1107
//	stg1_FIFO_buf72_stg2_1_merged1802_1108
//	stg1_FIFO_buf72_stg2_1_merged1802_1109
//	stg1_FIFO_buf72_stg2_1_merged1802_1110
//	stg1_FIFO_buf72_stg2_1_merged1802_1111
//	stg1_FIFO_buf72_stg2_1_merged1802_1112
//	stg1_FIFO_buf72_stg2_1_merged1802_1113
//	stg1_FIFO_buf72_stg2_1_merged1802_1114
//	stg1_FIFO_buf72_stg2_1_merged1802_1115
//	stg1_FIFO_buf72_stg2_1_merged1802_1116
//	stg1_FIFO_buf72_stg2_1_merged1802_1117
//	stg1_FIFO_buf72_stg2_1_merged1802_1118
//	stg1_FIFO_buf72_stg2_1_merged1802_1119
//	stg1_FIFO_buf72_stg2_1_merged1802_1120
//	stg1_FIFO_buf72_stg2_1_merged1802_1121
//	stg1_FIFO_buf72_stg2_1_merged1802_1122
//	stg1_FIFO_buf72_stg2_1_merged1802_1123
//	stg1_FIFO_buf72_stg2_1_merged1802_1124
//	stg1_FIFO_buf72_stg2_1_merged1802_1125
//	stg1_FIFO_buf72_stg2_1_merged1802_1126
//	stg1_FIFO_buf72_stg2_1_merged1802_1127
//	stg1_FIFO_buf72_stg2_1_merged1802_1128
//	stg1_FIFO_buf72_stg2_1_merged1802_1129
//	stg1_FIFO_buf72_stg2_1_merged1802_1130
//	stg1_FIFO_buf72_stg2_1_merged1802_1131
//	stg1_FIFO_buf72_stg2_1_merged1802_1132
//	stg1_FIFO_buf72_stg2_1_merged1802_1133
//	stg1_FIFO_buf72_stg2_1_merged1802_1134
//	stg1_FIFO_buf72_stg2_1_merged1802_1135
//	stg1_FIFO_buf72_stg2_1_merged1802_1136
//	stg1_FIFO_buf72_stg2_1_merged1802_1137
//	stg1_FIFO_buf72_stg2_1_merged1802_1138
//	stg1_FIFO_buf72_stg2_1_merged1802_1139
//	stg1_FIFO_buf72_stg2_1_merged1802_1140
//	stg1_FIFO_buf72_stg2_1_merged1802_1141
//	stg1_FIFO_buf72_stg2_1_merged1802_1142
//	stg1_FIFO_buf72_stg2_1_merged1802_1143
//	stg1_FIFO_buf72_stg2_1_merged1802_1144
//	stg1_FIFO_buf72_stg2_1_merged1802_1145
//	stg1_FIFO_buf72_stg2_1_merged1802_1146
//	stg1_FIFO_buf72_stg2_1_merged1802_1147
//	stg1_FIFO_buf72_stg2_1_merged1802_1148
//	stg1_FIFO_buf72_stg2_1_merged1802_1149
//	stg1_FIFO_buf72_stg2_1_merged1802_1150
//	stg1_FIFO_buf72_stg2_1_merged1802_1151
inline hw_uint<1024> stg1_FIFO_buf72_stg2_1_merged1802_read_bundle_read(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int root, int stg2_0, int stg2_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg1_FIFO_buf72_stg2_1_merged1802_1088
    // stg1_FIFO_buf72_stg2_1_merged1802_1089
    // stg1_FIFO_buf72_stg2_1_merged1802_1090
    // stg1_FIFO_buf72_stg2_1_merged1802_1091
    // stg1_FIFO_buf72_stg2_1_merged1802_1092
    // stg1_FIFO_buf72_stg2_1_merged1802_1093
    // stg1_FIFO_buf72_stg2_1_merged1802_1094
    // stg1_FIFO_buf72_stg2_1_merged1802_1095
    // stg1_FIFO_buf72_stg2_1_merged1802_1096
    // stg1_FIFO_buf72_stg2_1_merged1802_1097
    // stg1_FIFO_buf72_stg2_1_merged1802_1098
    // stg1_FIFO_buf72_stg2_1_merged1802_1099
    // stg1_FIFO_buf72_stg2_1_merged1802_1100
    // stg1_FIFO_buf72_stg2_1_merged1802_1101
    // stg1_FIFO_buf72_stg2_1_merged1802_1102
    // stg1_FIFO_buf72_stg2_1_merged1802_1103
    // stg1_FIFO_buf72_stg2_1_merged1802_1104
    // stg1_FIFO_buf72_stg2_1_merged1802_1105
    // stg1_FIFO_buf72_stg2_1_merged1802_1106
    // stg1_FIFO_buf72_stg2_1_merged1802_1107
    // stg1_FIFO_buf72_stg2_1_merged1802_1108
    // stg1_FIFO_buf72_stg2_1_merged1802_1109
    // stg1_FIFO_buf72_stg2_1_merged1802_1110
    // stg1_FIFO_buf72_stg2_1_merged1802_1111
    // stg1_FIFO_buf72_stg2_1_merged1802_1112
    // stg1_FIFO_buf72_stg2_1_merged1802_1113
    // stg1_FIFO_buf72_stg2_1_merged1802_1114
    // stg1_FIFO_buf72_stg2_1_merged1802_1115
    // stg1_FIFO_buf72_stg2_1_merged1802_1116
    // stg1_FIFO_buf72_stg2_1_merged1802_1117
    // stg1_FIFO_buf72_stg2_1_merged1802_1118
    // stg1_FIFO_buf72_stg2_1_merged1802_1119
    // stg1_FIFO_buf72_stg2_1_merged1802_1120
    // stg1_FIFO_buf72_stg2_1_merged1802_1121
    // stg1_FIFO_buf72_stg2_1_merged1802_1122
    // stg1_FIFO_buf72_stg2_1_merged1802_1123
    // stg1_FIFO_buf72_stg2_1_merged1802_1124
    // stg1_FIFO_buf72_stg2_1_merged1802_1125
    // stg1_FIFO_buf72_stg2_1_merged1802_1126
    // stg1_FIFO_buf72_stg2_1_merged1802_1127
    // stg1_FIFO_buf72_stg2_1_merged1802_1128
    // stg1_FIFO_buf72_stg2_1_merged1802_1129
    // stg1_FIFO_buf72_stg2_1_merged1802_1130
    // stg1_FIFO_buf72_stg2_1_merged1802_1131
    // stg1_FIFO_buf72_stg2_1_merged1802_1132
    // stg1_FIFO_buf72_stg2_1_merged1802_1133
    // stg1_FIFO_buf72_stg2_1_merged1802_1134
    // stg1_FIFO_buf72_stg2_1_merged1802_1135
    // stg1_FIFO_buf72_stg2_1_merged1802_1136
    // stg1_FIFO_buf72_stg2_1_merged1802_1137
    // stg1_FIFO_buf72_stg2_1_merged1802_1138
    // stg1_FIFO_buf72_stg2_1_merged1802_1139
    // stg1_FIFO_buf72_stg2_1_merged1802_1140
    // stg1_FIFO_buf72_stg2_1_merged1802_1141
    // stg1_FIFO_buf72_stg2_1_merged1802_1142
    // stg1_FIFO_buf72_stg2_1_merged1802_1143
    // stg1_FIFO_buf72_stg2_1_merged1802_1144
    // stg1_FIFO_buf72_stg2_1_merged1802_1145
    // stg1_FIFO_buf72_stg2_1_merged1802_1146
    // stg1_FIFO_buf72_stg2_1_merged1802_1147
    // stg1_FIFO_buf72_stg2_1_merged1802_1148
    // stg1_FIFO_buf72_stg2_1_merged1802_1149
    // stg1_FIFO_buf72_stg2_1_merged1802_1150
    // stg1_FIFO_buf72_stg2_1_merged1802_1151

	hw_uint<1024> result;
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1088_res = stg1_FIFO_buf72_stg2_1_merged1802_1088_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<0, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1088_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1089_res = stg1_FIFO_buf72_stg2_1_merged1802_1089_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<16, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1089_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1090_res = stg1_FIFO_buf72_stg2_1_merged1802_1090_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<32, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1090_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1091_res = stg1_FIFO_buf72_stg2_1_merged1802_1091_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<48, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1091_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1092_res = stg1_FIFO_buf72_stg2_1_merged1802_1092_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<64, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1092_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1093_res = stg1_FIFO_buf72_stg2_1_merged1802_1093_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<80, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1093_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1094_res = stg1_FIFO_buf72_stg2_1_merged1802_1094_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<96, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1094_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1095_res = stg1_FIFO_buf72_stg2_1_merged1802_1095_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<112, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1095_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1096_res = stg1_FIFO_buf72_stg2_1_merged1802_1096_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<128, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1096_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1097_res = stg1_FIFO_buf72_stg2_1_merged1802_1097_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<144, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1097_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1098_res = stg1_FIFO_buf72_stg2_1_merged1802_1098_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<160, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1098_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1099_res = stg1_FIFO_buf72_stg2_1_merged1802_1099_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<176, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1099_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1100_res = stg1_FIFO_buf72_stg2_1_merged1802_1100_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<192, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1100_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1101_res = stg1_FIFO_buf72_stg2_1_merged1802_1101_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<208, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1101_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1102_res = stg1_FIFO_buf72_stg2_1_merged1802_1102_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<224, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1102_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1103_res = stg1_FIFO_buf72_stg2_1_merged1802_1103_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<240, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1103_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1104_res = stg1_FIFO_buf72_stg2_1_merged1802_1104_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<256, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1104_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1105_res = stg1_FIFO_buf72_stg2_1_merged1802_1105_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<272, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1105_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1106_res = stg1_FIFO_buf72_stg2_1_merged1802_1106_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<288, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1106_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1107_res = stg1_FIFO_buf72_stg2_1_merged1802_1107_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<304, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1107_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1108_res = stg1_FIFO_buf72_stg2_1_merged1802_1108_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<320, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1108_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1109_res = stg1_FIFO_buf72_stg2_1_merged1802_1109_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<336, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1109_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1110_res = stg1_FIFO_buf72_stg2_1_merged1802_1110_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<352, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1110_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1111_res = stg1_FIFO_buf72_stg2_1_merged1802_1111_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<368, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1111_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1112_res = stg1_FIFO_buf72_stg2_1_merged1802_1112_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<384, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1112_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1113_res = stg1_FIFO_buf72_stg2_1_merged1802_1113_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<400, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1113_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1114_res = stg1_FIFO_buf72_stg2_1_merged1802_1114_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<416, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1114_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1115_res = stg1_FIFO_buf72_stg2_1_merged1802_1115_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<432, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1115_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1116_res = stg1_FIFO_buf72_stg2_1_merged1802_1116_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<448, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1116_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1117_res = stg1_FIFO_buf72_stg2_1_merged1802_1117_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<464, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1117_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1118_res = stg1_FIFO_buf72_stg2_1_merged1802_1118_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<480, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1118_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1119_res = stg1_FIFO_buf72_stg2_1_merged1802_1119_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<496, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1119_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1120_res = stg1_FIFO_buf72_stg2_1_merged1802_1120_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<512, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1120_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1121_res = stg1_FIFO_buf72_stg2_1_merged1802_1121_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<528, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1121_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1122_res = stg1_FIFO_buf72_stg2_1_merged1802_1122_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<544, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1122_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1123_res = stg1_FIFO_buf72_stg2_1_merged1802_1123_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<560, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1123_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1124_res = stg1_FIFO_buf72_stg2_1_merged1802_1124_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<576, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1124_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1125_res = stg1_FIFO_buf72_stg2_1_merged1802_1125_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<592, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1125_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1126_res = stg1_FIFO_buf72_stg2_1_merged1802_1126_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<608, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1126_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1127_res = stg1_FIFO_buf72_stg2_1_merged1802_1127_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<624, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1127_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1128_res = stg1_FIFO_buf72_stg2_1_merged1802_1128_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<640, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1128_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1129_res = stg1_FIFO_buf72_stg2_1_merged1802_1129_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<656, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1129_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1130_res = stg1_FIFO_buf72_stg2_1_merged1802_1130_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<672, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1130_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1131_res = stg1_FIFO_buf72_stg2_1_merged1802_1131_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<688, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1131_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1132_res = stg1_FIFO_buf72_stg2_1_merged1802_1132_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<704, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1132_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1133_res = stg1_FIFO_buf72_stg2_1_merged1802_1133_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<720, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1133_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1134_res = stg1_FIFO_buf72_stg2_1_merged1802_1134_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<736, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1134_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1135_res = stg1_FIFO_buf72_stg2_1_merged1802_1135_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<752, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1135_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1136_res = stg1_FIFO_buf72_stg2_1_merged1802_1136_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<768, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1136_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1137_res = stg1_FIFO_buf72_stg2_1_merged1802_1137_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<784, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1137_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1138_res = stg1_FIFO_buf72_stg2_1_merged1802_1138_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<800, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1138_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1139_res = stg1_FIFO_buf72_stg2_1_merged1802_1139_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<816, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1139_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1140_res = stg1_FIFO_buf72_stg2_1_merged1802_1140_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<832, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1140_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1141_res = stg1_FIFO_buf72_stg2_1_merged1802_1141_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<848, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1141_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1142_res = stg1_FIFO_buf72_stg2_1_merged1802_1142_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<864, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1142_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1143_res = stg1_FIFO_buf72_stg2_1_merged1802_1143_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<880, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1143_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1144_res = stg1_FIFO_buf72_stg2_1_merged1802_1144_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<896, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1144_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1145_res = stg1_FIFO_buf72_stg2_1_merged1802_1145_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<912, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1145_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1146_res = stg1_FIFO_buf72_stg2_1_merged1802_1146_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<928, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1146_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1147_res = stg1_FIFO_buf72_stg2_1_merged1802_1147_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<944, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1147_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1148_res = stg1_FIFO_buf72_stg2_1_merged1802_1148_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<960, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1148_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1149_res = stg1_FIFO_buf72_stg2_1_merged1802_1149_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<976, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1149_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1150_res = stg1_FIFO_buf72_stg2_1_merged1802_1150_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<992, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1150_res);
	hw_uint<16> stg1_FIFO_buf72_stg2_1_merged1802_1151_res = stg1_FIFO_buf72_stg2_1_merged1802_1151_select(stg1_FIFO_buf72, root, stg2_0, stg2_1, dynamic_address);
	set_at<1008, 1024>(result, stg1_FIFO_buf72_stg2_1_merged1802_1151_res);
	return result;
}

struct stg2_stg2_1_merged1802_1072_to_stg2_stg2_ld33_merged1859_1056_cache {
	// RAM Box: {[15, 1279], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1073_to_stg2_stg2_ld33_merged1859_1057_cache {
	// RAM Box: {[14, 1278], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1074_to_stg2_stg2_ld33_merged1859_1058_cache {
	// RAM Box: {[13, 1277], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1075_to_stg2_stg2_ld33_merged1859_1059_cache {
	// RAM Box: {[12, 1276], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1076_to_stg2_stg2_ld33_merged1859_1060_cache {
	// RAM Box: {[11, 1275], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1077_to_stg2_stg2_ld33_merged1859_1061_cache {
	// RAM Box: {[10, 1274], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1078_to_stg2_stg2_ld33_merged1859_1062_cache {
	// RAM Box: {[9, 1273], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1079_to_stg2_stg2_ld33_merged1859_1063_cache {
	// RAM Box: {[8, 1272], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1080_to_stg2_stg2_ld33_merged1859_1064_cache {
	// RAM Box: {[7, 1271], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1081_to_stg2_stg2_ld33_merged1859_1065_cache {
	// RAM Box: {[6, 1270], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1082_to_stg2_stg2_ld33_merged1859_1066_cache {
	// RAM Box: {[5, 1269], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1083_to_stg2_stg2_ld33_merged1859_1067_cache {
	// RAM Box: {[4, 1268], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1084_to_stg2_stg2_ld33_merged1859_1068_cache {
	// RAM Box: {[3, 1267], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1085_to_stg2_stg2_ld33_merged1859_1069_cache {
	// RAM Box: {[2, 1266], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1086_to_stg2_stg2_ld33_merged1859_1070_cache {
	// RAM Box: {[1, 1265], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_stg2_1_merged1802_1087_to_stg2_stg2_ld33_merged1859_1071_cache {
	// RAM Box: {[0, 1264], [-12, 1931]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg2_cache {
  // Reader addrs...
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[15 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[14 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[13 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[12 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[11 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[10 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[9 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[8 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[7 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[6 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[5 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[4 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[3 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[2 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[1 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
    // { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // # of banks: 16
  stg2_stg2_1_merged1802_1072_to_stg2_stg2_ld33_merged1859_1056_cache stg2_stg2_1_merged1802_1072_to_stg2_stg2_ld33_merged1859_1056;
  stg2_stg2_1_merged1802_1073_to_stg2_stg2_ld33_merged1859_1057_cache stg2_stg2_1_merged1802_1073_to_stg2_stg2_ld33_merged1859_1057;
  stg2_stg2_1_merged1802_1074_to_stg2_stg2_ld33_merged1859_1058_cache stg2_stg2_1_merged1802_1074_to_stg2_stg2_ld33_merged1859_1058;
  stg2_stg2_1_merged1802_1075_to_stg2_stg2_ld33_merged1859_1059_cache stg2_stg2_1_merged1802_1075_to_stg2_stg2_ld33_merged1859_1059;
  stg2_stg2_1_merged1802_1076_to_stg2_stg2_ld33_merged1859_1060_cache stg2_stg2_1_merged1802_1076_to_stg2_stg2_ld33_merged1859_1060;
  stg2_stg2_1_merged1802_1077_to_stg2_stg2_ld33_merged1859_1061_cache stg2_stg2_1_merged1802_1077_to_stg2_stg2_ld33_merged1859_1061;
  stg2_stg2_1_merged1802_1078_to_stg2_stg2_ld33_merged1859_1062_cache stg2_stg2_1_merged1802_1078_to_stg2_stg2_ld33_merged1859_1062;
  stg2_stg2_1_merged1802_1079_to_stg2_stg2_ld33_merged1859_1063_cache stg2_stg2_1_merged1802_1079_to_stg2_stg2_ld33_merged1859_1063;
  stg2_stg2_1_merged1802_1080_to_stg2_stg2_ld33_merged1859_1064_cache stg2_stg2_1_merged1802_1080_to_stg2_stg2_ld33_merged1859_1064;
  stg2_stg2_1_merged1802_1081_to_stg2_stg2_ld33_merged1859_1065_cache stg2_stg2_1_merged1802_1081_to_stg2_stg2_ld33_merged1859_1065;
  stg2_stg2_1_merged1802_1082_to_stg2_stg2_ld33_merged1859_1066_cache stg2_stg2_1_merged1802_1082_to_stg2_stg2_ld33_merged1859_1066;
  stg2_stg2_1_merged1802_1083_to_stg2_stg2_ld33_merged1859_1067_cache stg2_stg2_1_merged1802_1083_to_stg2_stg2_ld33_merged1859_1067;
  stg2_stg2_1_merged1802_1084_to_stg2_stg2_ld33_merged1859_1068_cache stg2_stg2_1_merged1802_1084_to_stg2_stg2_ld33_merged1859_1068;
  stg2_stg2_1_merged1802_1085_to_stg2_stg2_ld33_merged1859_1069_cache stg2_stg2_1_merged1802_1085_to_stg2_stg2_ld33_merged1859_1069;
  stg2_stg2_1_merged1802_1086_to_stg2_stg2_ld33_merged1859_1070_cache stg2_stg2_1_merged1802_1086_to_stg2_stg2_ld33_merged1859_1070;
  stg2_stg2_1_merged1802_1087_to_stg2_stg2_ld33_merged1859_1071_cache stg2_stg2_1_merged1802_1087_to_stg2_stg2_ld33_merged1859_1071;
};



inline void stg2_stg2_1_merged1802_1072_write(hw_uint<16>& stg2_stg2_1_merged1802_1072, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1072_to_stg2_stg2_ld33_merged1859_1056.push(stg2_stg2_1_merged1802_1072);
}

inline void stg2_stg2_1_merged1802_1073_write(hw_uint<16>& stg2_stg2_1_merged1802_1073, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1073_to_stg2_stg2_ld33_merged1859_1057.push(stg2_stg2_1_merged1802_1073);
}

inline void stg2_stg2_1_merged1802_1074_write(hw_uint<16>& stg2_stg2_1_merged1802_1074, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1074_to_stg2_stg2_ld33_merged1859_1058.push(stg2_stg2_1_merged1802_1074);
}

inline void stg2_stg2_1_merged1802_1075_write(hw_uint<16>& stg2_stg2_1_merged1802_1075, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1075_to_stg2_stg2_ld33_merged1859_1059.push(stg2_stg2_1_merged1802_1075);
}

inline void stg2_stg2_1_merged1802_1076_write(hw_uint<16>& stg2_stg2_1_merged1802_1076, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1076_to_stg2_stg2_ld33_merged1859_1060.push(stg2_stg2_1_merged1802_1076);
}

inline void stg2_stg2_1_merged1802_1077_write(hw_uint<16>& stg2_stg2_1_merged1802_1077, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1077_to_stg2_stg2_ld33_merged1859_1061.push(stg2_stg2_1_merged1802_1077);
}

inline void stg2_stg2_1_merged1802_1078_write(hw_uint<16>& stg2_stg2_1_merged1802_1078, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1078_to_stg2_stg2_ld33_merged1859_1062.push(stg2_stg2_1_merged1802_1078);
}

inline void stg2_stg2_1_merged1802_1079_write(hw_uint<16>& stg2_stg2_1_merged1802_1079, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1079_to_stg2_stg2_ld33_merged1859_1063.push(stg2_stg2_1_merged1802_1079);
}

inline void stg2_stg2_1_merged1802_1080_write(hw_uint<16>& stg2_stg2_1_merged1802_1080, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1080_to_stg2_stg2_ld33_merged1859_1064.push(stg2_stg2_1_merged1802_1080);
}

inline void stg2_stg2_1_merged1802_1081_write(hw_uint<16>& stg2_stg2_1_merged1802_1081, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1081_to_stg2_stg2_ld33_merged1859_1065.push(stg2_stg2_1_merged1802_1081);
}

inline void stg2_stg2_1_merged1802_1082_write(hw_uint<16>& stg2_stg2_1_merged1802_1082, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1082_to_stg2_stg2_ld33_merged1859_1066.push(stg2_stg2_1_merged1802_1082);
}

inline void stg2_stg2_1_merged1802_1083_write(hw_uint<16>& stg2_stg2_1_merged1802_1083, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1083_to_stg2_stg2_ld33_merged1859_1067.push(stg2_stg2_1_merged1802_1083);
}

inline void stg2_stg2_1_merged1802_1084_write(hw_uint<16>& stg2_stg2_1_merged1802_1084, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1084_to_stg2_stg2_ld33_merged1859_1068.push(stg2_stg2_1_merged1802_1084);
}

inline void stg2_stg2_1_merged1802_1085_write(hw_uint<16>& stg2_stg2_1_merged1802_1085, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1085_to_stg2_stg2_ld33_merged1859_1069.push(stg2_stg2_1_merged1802_1085);
}

inline void stg2_stg2_1_merged1802_1086_write(hw_uint<16>& stg2_stg2_1_merged1802_1086, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1086_to_stg2_stg2_ld33_merged1859_1070.push(stg2_stg2_1_merged1802_1086);
}

inline void stg2_stg2_1_merged1802_1087_write(hw_uint<16>& stg2_stg2_1_merged1802_1087, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
  stg2.stg2_stg2_1_merged1802_1087_to_stg2_stg2_ld33_merged1859_1071.push(stg2_stg2_1_merged1802_1087);
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1056_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1056 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[15 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1072 = stg2.stg2_stg2_1_merged1802_1072_to_stg2_stg2_ld33_merged1859_1056.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1072;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1057_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1057 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[14 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1073 = stg2.stg2_stg2_1_merged1802_1073_to_stg2_stg2_ld33_merged1859_1057.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1073;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1058_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1058 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[13 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1074 = stg2.stg2_stg2_1_merged1802_1074_to_stg2_stg2_ld33_merged1859_1058.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1074;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1059_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1059 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[12 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1075 = stg2.stg2_stg2_1_merged1802_1075_to_stg2_stg2_ld33_merged1859_1059.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1075;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1060_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1060 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[11 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1076 = stg2.stg2_stg2_1_merged1802_1076_to_stg2_stg2_ld33_merged1859_1060.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1076;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1061_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1061 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[10 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1077 = stg2.stg2_stg2_1_merged1802_1077_to_stg2_stg2_ld33_merged1859_1061.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1077;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1062_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1062 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[9 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1078 = stg2.stg2_stg2_1_merged1802_1078_to_stg2_stg2_ld33_merged1859_1062.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1078;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1063_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1063 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[8 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1079 = stg2.stg2_stg2_1_merged1802_1079_to_stg2_stg2_ld33_merged1859_1063.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1079;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1064_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1064 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[7 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1080 = stg2.stg2_stg2_1_merged1802_1080_to_stg2_stg2_ld33_merged1859_1064.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1080;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1065_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1065 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[6 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1081 = stg2.stg2_stg2_1_merged1802_1081_to_stg2_stg2_ld33_merged1859_1065.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1081;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1066_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1066 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[5 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1082 = stg2.stg2_stg2_1_merged1802_1082_to_stg2_stg2_ld33_merged1859_1066.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1082;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1067_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1067 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[4 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1083 = stg2.stg2_stg2_1_merged1802_1083_to_stg2_stg2_ld33_merged1859_1067.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1083;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1068_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1068 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[3 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1084 = stg2.stg2_stg2_1_merged1802_1084_to_stg2_stg2_ld33_merged1859_1068.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1084;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1069_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1069 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[2 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1085 = stg2.stg2_stg2_1_merged1802_1085_to_stg2_stg2_ld33_merged1859_1069.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1085;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1070_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1070 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[1 + 16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1086 = stg2.stg2_stg2_1_merged1802_1086_to_stg2_stg2_ld33_merged1859_1070.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1086;
  return 0;
}

inline hw_uint<16> stg2_stg2_ld33_merged1859_1071_select(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_stg2_ld33_merged1859_1071 read pattern: { stg2_ld33_merged1859[root = 0, stg2_ld34, stg2_ld33] -> stg2[16stg2_ld33, -12 + stg2_ld34] : 0 <= stg2_ld34 <= 1943 and 0 <= stg2_ld33 <= 79 }
  // Read schedule : { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  // Write schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_stg2_1_merged1802_1087 = stg2.stg2_stg2_1_merged1802_1087_to_stg2_stg2_ld33_merged1859_1071.peek(/* one reader or all rams */ 0);
  return value_stg2_stg2_1_merged1802_1087;
  return 0;
}

// # of bundles = 2
// stg2_1_merged1802_write
//	stg2_stg2_1_merged1802_1072
//	stg2_stg2_1_merged1802_1073
//	stg2_stg2_1_merged1802_1074
//	stg2_stg2_1_merged1802_1075
//	stg2_stg2_1_merged1802_1076
//	stg2_stg2_1_merged1802_1077
//	stg2_stg2_1_merged1802_1078
//	stg2_stg2_1_merged1802_1079
//	stg2_stg2_1_merged1802_1080
//	stg2_stg2_1_merged1802_1081
//	stg2_stg2_1_merged1802_1082
//	stg2_stg2_1_merged1802_1083
//	stg2_stg2_1_merged1802_1084
//	stg2_stg2_1_merged1802_1085
//	stg2_stg2_1_merged1802_1086
//	stg2_stg2_1_merged1802_1087
inline void stg2_stg2_1_merged1802_write_bundle_write(hw_uint<256>& stg2_1_merged1802_write, stg2_cache& stg2, int root, int stg2_0, int stg2_1, int dynamic_address) {
	hw_uint<16> stg2_stg2_1_merged1802_1072_res = stg2_1_merged1802_write.extract<0, 15>();
	stg2_stg2_1_merged1802_1072_write(stg2_stg2_1_merged1802_1072_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1073_res = stg2_1_merged1802_write.extract<16, 31>();
	stg2_stg2_1_merged1802_1073_write(stg2_stg2_1_merged1802_1073_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1074_res = stg2_1_merged1802_write.extract<32, 47>();
	stg2_stg2_1_merged1802_1074_write(stg2_stg2_1_merged1802_1074_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1075_res = stg2_1_merged1802_write.extract<48, 63>();
	stg2_stg2_1_merged1802_1075_write(stg2_stg2_1_merged1802_1075_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1076_res = stg2_1_merged1802_write.extract<64, 79>();
	stg2_stg2_1_merged1802_1076_write(stg2_stg2_1_merged1802_1076_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1077_res = stg2_1_merged1802_write.extract<80, 95>();
	stg2_stg2_1_merged1802_1077_write(stg2_stg2_1_merged1802_1077_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1078_res = stg2_1_merged1802_write.extract<96, 111>();
	stg2_stg2_1_merged1802_1078_write(stg2_stg2_1_merged1802_1078_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1079_res = stg2_1_merged1802_write.extract<112, 127>();
	stg2_stg2_1_merged1802_1079_write(stg2_stg2_1_merged1802_1079_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1080_res = stg2_1_merged1802_write.extract<128, 143>();
	stg2_stg2_1_merged1802_1080_write(stg2_stg2_1_merged1802_1080_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1081_res = stg2_1_merged1802_write.extract<144, 159>();
	stg2_stg2_1_merged1802_1081_write(stg2_stg2_1_merged1802_1081_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1082_res = stg2_1_merged1802_write.extract<160, 175>();
	stg2_stg2_1_merged1802_1082_write(stg2_stg2_1_merged1802_1082_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1083_res = stg2_1_merged1802_write.extract<176, 191>();
	stg2_stg2_1_merged1802_1083_write(stg2_stg2_1_merged1802_1083_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1084_res = stg2_1_merged1802_write.extract<192, 207>();
	stg2_stg2_1_merged1802_1084_write(stg2_stg2_1_merged1802_1084_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1085_res = stg2_1_merged1802_write.extract<208, 223>();
	stg2_stg2_1_merged1802_1085_write(stg2_stg2_1_merged1802_1085_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1086_res = stg2_1_merged1802_write.extract<224, 239>();
	stg2_stg2_1_merged1802_1086_write(stg2_stg2_1_merged1802_1086_res, stg2, root, stg2_0, stg2_1, dynamic_address);
	hw_uint<16> stg2_stg2_1_merged1802_1087_res = stg2_1_merged1802_write.extract<240, 255>();
	stg2_stg2_1_merged1802_1087_write(stg2_stg2_1_merged1802_1087_res, stg2, root, stg2_0, stg2_1, dynamic_address);
}

// stg2_ld33_merged1859_read
//	stg2_stg2_ld33_merged1859_1056
//	stg2_stg2_ld33_merged1859_1057
//	stg2_stg2_ld33_merged1859_1058
//	stg2_stg2_ld33_merged1859_1059
//	stg2_stg2_ld33_merged1859_1060
//	stg2_stg2_ld33_merged1859_1061
//	stg2_stg2_ld33_merged1859_1062
//	stg2_stg2_ld33_merged1859_1063
//	stg2_stg2_ld33_merged1859_1064
//	stg2_stg2_ld33_merged1859_1065
//	stg2_stg2_ld33_merged1859_1066
//	stg2_stg2_ld33_merged1859_1067
//	stg2_stg2_ld33_merged1859_1068
//	stg2_stg2_ld33_merged1859_1069
//	stg2_stg2_ld33_merged1859_1070
//	stg2_stg2_ld33_merged1859_1071
inline hw_uint<256> stg2_stg2_ld33_merged1859_read_bundle_read(stg2_cache& stg2, int root, int stg2_ld34, int stg2_ld33, int dynamic_address) {
  // # of ports in bundle: 16
    // stg2_stg2_ld33_merged1859_1056
    // stg2_stg2_ld33_merged1859_1057
    // stg2_stg2_ld33_merged1859_1058
    // stg2_stg2_ld33_merged1859_1059
    // stg2_stg2_ld33_merged1859_1060
    // stg2_stg2_ld33_merged1859_1061
    // stg2_stg2_ld33_merged1859_1062
    // stg2_stg2_ld33_merged1859_1063
    // stg2_stg2_ld33_merged1859_1064
    // stg2_stg2_ld33_merged1859_1065
    // stg2_stg2_ld33_merged1859_1066
    // stg2_stg2_ld33_merged1859_1067
    // stg2_stg2_ld33_merged1859_1068
    // stg2_stg2_ld33_merged1859_1069
    // stg2_stg2_ld33_merged1859_1070
    // stg2_stg2_ld33_merged1859_1071

	hw_uint<256> result;
	hw_uint<16> stg2_stg2_ld33_merged1859_1056_res = stg2_stg2_ld33_merged1859_1056_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<0, 256>(result, stg2_stg2_ld33_merged1859_1056_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1057_res = stg2_stg2_ld33_merged1859_1057_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<16, 256>(result, stg2_stg2_ld33_merged1859_1057_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1058_res = stg2_stg2_ld33_merged1859_1058_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<32, 256>(result, stg2_stg2_ld33_merged1859_1058_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1059_res = stg2_stg2_ld33_merged1859_1059_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<48, 256>(result, stg2_stg2_ld33_merged1859_1059_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1060_res = stg2_stg2_ld33_merged1859_1060_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<64, 256>(result, stg2_stg2_ld33_merged1859_1060_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1061_res = stg2_stg2_ld33_merged1859_1061_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<80, 256>(result, stg2_stg2_ld33_merged1859_1061_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1062_res = stg2_stg2_ld33_merged1859_1062_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<96, 256>(result, stg2_stg2_ld33_merged1859_1062_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1063_res = stg2_stg2_ld33_merged1859_1063_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<112, 256>(result, stg2_stg2_ld33_merged1859_1063_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1064_res = stg2_stg2_ld33_merged1859_1064_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<128, 256>(result, stg2_stg2_ld33_merged1859_1064_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1065_res = stg2_stg2_ld33_merged1859_1065_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<144, 256>(result, stg2_stg2_ld33_merged1859_1065_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1066_res = stg2_stg2_ld33_merged1859_1066_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<160, 256>(result, stg2_stg2_ld33_merged1859_1066_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1067_res = stg2_stg2_ld33_merged1859_1067_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<176, 256>(result, stg2_stg2_ld33_merged1859_1067_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1068_res = stg2_stg2_ld33_merged1859_1068_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<192, 256>(result, stg2_stg2_ld33_merged1859_1068_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1069_res = stg2_stg2_ld33_merged1859_1069_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<208, 256>(result, stg2_stg2_ld33_merged1859_1069_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1070_res = stg2_stg2_ld33_merged1859_1070_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<224, 256>(result, stg2_stg2_ld33_merged1859_1070_res);
	hw_uint<16> stg2_stg2_ld33_merged1859_1071_res = stg2_stg2_ld33_merged1859_1071_select(stg2, root, stg2_ld34, stg2_ld33, dynamic_address);
	set_at<240, 256>(result, stg2_stg2_ld33_merged1859_1071_res);
	return result;
}

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_merged_banks_4_cache {
	// RAM Box: {[15, 1263], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_merged_banks_4_cache {
	// RAM Box: {[14, 1262], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_merged_banks_4_cache {
	// RAM Box: {[13, 1261], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_merged_banks_4_cache {
	// RAM Box: {[12, 1260], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_merged_banks_4_cache {
	// RAM Box: {[11, 1259], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_merged_banks_4_cache {
	// RAM Box: {[10, 1258], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_merged_banks_4_cache {
	// RAM Box: {[9, 1257], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_merged_banks_4_cache {
	// RAM Box: {[8, 1256], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_merged_banks_4_cache {
	// RAM Box: {[7, 1255], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_merged_banks_4_cache {
	// RAM Box: {[6, 1254], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_merged_banks_4_cache {
	// RAM Box: {[5, 1253], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_merged_banks_4_cache {
	// RAM Box: {[4, 1252], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_merged_banks_4_cache {
	// RAM Box: {[3, 1251], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_merged_banks_4_cache {
	// RAM Box: {[2, 1250], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_merged_banks_4_cache {
	// RAM Box: {[1, 1249], [-12, 1931]}
	// Capacity: 162
	// # of read delays: 4
  // 0, 1, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 79> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 79> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_80() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_81() {
		return f4;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_161() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_merged_banks_4_cache {
	// RAM Box: {[0, 1264], [-12, 1930]}
	// Capacity: 162
	// # of read delays: 5
  // 0, 1, 80, 81, 161
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 79> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_81() {
		return f6;
	}

	inline hw_uint<16> peek_160() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_161() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 79
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 79 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg2_FIFO_buf96_cache {
  // Reader addrs...
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[1 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[1 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[2 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[1 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[1 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[15 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[15 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[16 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[15 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[14 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[14 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[15 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[14 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[13 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[13 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[14 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[13 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[12 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[12 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[13 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[12 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[11 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[11 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[12 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[11 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[10 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[10 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[11 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[10 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[9 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[9 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[10 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[9 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[8 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[8 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[9 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[8 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[7 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[7 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[8 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[7 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[6 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[6 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[7 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[6 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[5 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[5 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[6 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[5 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[4 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[4 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[5 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[4 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[3 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[3 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[4 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[3 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[2 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[2 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[3 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
    // { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[2 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // # of banks: 16
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_merged_banks_4;
  stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_merged_banks_4_cache stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_merged_banks_4;
};



inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022);
}

inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_write(hw_uint<16>& stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
  stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_merged_banks_4.push(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023);
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1000_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_1000 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[1 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1001_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_1001 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[1 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1002_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_1002 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[2 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1003_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_1003 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[1 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1004_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_1004 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1005_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_1005 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1006_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_1006 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[1 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1007_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_1007 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_944_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_944 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[15 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_945_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_945 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[15 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_946_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_946 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[16 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_merged_banks_4.peek_80();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_947_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_947 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[15 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_948_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_948 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[14 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_949_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_949 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[14 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_950_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_950 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[15 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_951_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_951 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[14 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_952_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_952 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[13 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_953_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_953 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[13 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_954_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_954 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[14 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_955_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_955 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[13 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_956_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_956 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[12 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_957_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_957 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[12 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_958_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_958 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[13 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_959_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_959 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[12 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_960_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_960 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[11 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_961_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_961 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[11 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_962_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_962 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[12 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_963_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_963 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[11 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_964_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_964 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[10 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_965_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_965 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[10 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_966_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_966 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[11 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_967_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_967 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[10 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_968_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_968 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[9 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_969_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_969 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[9 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_970_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_970 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[10 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_971_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_971 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[9 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_972_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_972 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[8 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_973_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_973 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[8 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_974_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_974 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[9 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_975_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_975 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[8 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_976_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_976 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[7 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_977_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_977 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[7 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_978_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_978 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[8 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_979_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_979 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[7 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_980_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_980 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[6 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_981_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_981 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[6 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_982_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_982 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[7 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_983_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_983 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[6 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_984_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_984 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[5 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_985_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_985 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[5 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_986_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_986 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[6 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_987_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_987 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[5 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_988_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_988 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[4 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_989_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_989 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[4 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_990_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_990 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[5 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_991_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_991 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[4 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_992_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_992 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[3 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_993_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_993 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[3 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_994_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_994 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[4 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_995_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_995 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[3 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_996_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_996 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[2 + 16stg3_1, -12 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_merged_banks_4.peek_161();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_997_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_997 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[2 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_998_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_998 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[3 + 16stg3_1, -11 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_merged_banks_4.peek_81();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020;
  return 0;
}

inline hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_999_select(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg2_FIFO_buf96_stg3_1_merged1805_999 read pattern: { stg3_1_merged1805[root = 0, stg3_0, stg3_1] -> stg2_FIFO_buf96[2 + 16stg3_1, -10 + stg3_0] : 0 <= stg3_0 <= 1941 and 0 <= stg3_1 <= 78 }
  // Read schedule : { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
  auto value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021 = stg2_FIFO_buf96.stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_merged_banks_4.peek_1();
  return value_stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021;
  return 0;
}

// # of bundles = 2
// stg2_to_gp_1032_ld97_merged1788_write
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022
//	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023
inline void stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_write_bundle_write(hw_uint<256>& stg2_to_gp_1032_ld97_merged1788_write, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg2_to_gp_1032_ld98, int stg2_to_gp_1032_ld97, int dynamic_address) {
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_res = stg2_to_gp_1032_ld97_merged1788_write.extract<0, 15>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1008_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_res = stg2_to_gp_1032_ld97_merged1788_write.extract<16, 31>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1009_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_res = stg2_to_gp_1032_ld97_merged1788_write.extract<32, 47>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1010_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_res = stg2_to_gp_1032_ld97_merged1788_write.extract<48, 63>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1011_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_res = stg2_to_gp_1032_ld97_merged1788_write.extract<64, 79>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1012_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_res = stg2_to_gp_1032_ld97_merged1788_write.extract<80, 95>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1013_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_res = stg2_to_gp_1032_ld97_merged1788_write.extract<96, 111>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1014_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_res = stg2_to_gp_1032_ld97_merged1788_write.extract<112, 127>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1015_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_res = stg2_to_gp_1032_ld97_merged1788_write.extract<128, 143>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1016_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_res = stg2_to_gp_1032_ld97_merged1788_write.extract<144, 159>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1017_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_res = stg2_to_gp_1032_ld97_merged1788_write.extract<160, 175>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1018_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_res = stg2_to_gp_1032_ld97_merged1788_write.extract<176, 191>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1019_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_res = stg2_to_gp_1032_ld97_merged1788_write.extract<192, 207>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1020_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_res = stg2_to_gp_1032_ld97_merged1788_write.extract<208, 223>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1021_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_res = stg2_to_gp_1032_ld97_merged1788_write.extract<224, 239>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1022_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
	hw_uint<16> stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_res = stg2_to_gp_1032_ld97_merged1788_write.extract<240, 255>();
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_write(stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_1023_res, stg2_FIFO_buf96, root, stg2_to_gp_1032_ld98, stg2_to_gp_1032_ld97, dynamic_address);
}

// stg3_1_merged1805_read
//	stg2_FIFO_buf96_stg3_1_merged1805_944
//	stg2_FIFO_buf96_stg3_1_merged1805_945
//	stg2_FIFO_buf96_stg3_1_merged1805_946
//	stg2_FIFO_buf96_stg3_1_merged1805_947
//	stg2_FIFO_buf96_stg3_1_merged1805_948
//	stg2_FIFO_buf96_stg3_1_merged1805_949
//	stg2_FIFO_buf96_stg3_1_merged1805_950
//	stg2_FIFO_buf96_stg3_1_merged1805_951
//	stg2_FIFO_buf96_stg3_1_merged1805_952
//	stg2_FIFO_buf96_stg3_1_merged1805_953
//	stg2_FIFO_buf96_stg3_1_merged1805_954
//	stg2_FIFO_buf96_stg3_1_merged1805_955
//	stg2_FIFO_buf96_stg3_1_merged1805_956
//	stg2_FIFO_buf96_stg3_1_merged1805_957
//	stg2_FIFO_buf96_stg3_1_merged1805_958
//	stg2_FIFO_buf96_stg3_1_merged1805_959
//	stg2_FIFO_buf96_stg3_1_merged1805_960
//	stg2_FIFO_buf96_stg3_1_merged1805_961
//	stg2_FIFO_buf96_stg3_1_merged1805_962
//	stg2_FIFO_buf96_stg3_1_merged1805_963
//	stg2_FIFO_buf96_stg3_1_merged1805_964
//	stg2_FIFO_buf96_stg3_1_merged1805_965
//	stg2_FIFO_buf96_stg3_1_merged1805_966
//	stg2_FIFO_buf96_stg3_1_merged1805_967
//	stg2_FIFO_buf96_stg3_1_merged1805_968
//	stg2_FIFO_buf96_stg3_1_merged1805_969
//	stg2_FIFO_buf96_stg3_1_merged1805_970
//	stg2_FIFO_buf96_stg3_1_merged1805_971
//	stg2_FIFO_buf96_stg3_1_merged1805_972
//	stg2_FIFO_buf96_stg3_1_merged1805_973
//	stg2_FIFO_buf96_stg3_1_merged1805_974
//	stg2_FIFO_buf96_stg3_1_merged1805_975
//	stg2_FIFO_buf96_stg3_1_merged1805_976
//	stg2_FIFO_buf96_stg3_1_merged1805_977
//	stg2_FIFO_buf96_stg3_1_merged1805_978
//	stg2_FIFO_buf96_stg3_1_merged1805_979
//	stg2_FIFO_buf96_stg3_1_merged1805_980
//	stg2_FIFO_buf96_stg3_1_merged1805_981
//	stg2_FIFO_buf96_stg3_1_merged1805_982
//	stg2_FIFO_buf96_stg3_1_merged1805_983
//	stg2_FIFO_buf96_stg3_1_merged1805_984
//	stg2_FIFO_buf96_stg3_1_merged1805_985
//	stg2_FIFO_buf96_stg3_1_merged1805_986
//	stg2_FIFO_buf96_stg3_1_merged1805_987
//	stg2_FIFO_buf96_stg3_1_merged1805_988
//	stg2_FIFO_buf96_stg3_1_merged1805_989
//	stg2_FIFO_buf96_stg3_1_merged1805_990
//	stg2_FIFO_buf96_stg3_1_merged1805_991
//	stg2_FIFO_buf96_stg3_1_merged1805_992
//	stg2_FIFO_buf96_stg3_1_merged1805_993
//	stg2_FIFO_buf96_stg3_1_merged1805_994
//	stg2_FIFO_buf96_stg3_1_merged1805_995
//	stg2_FIFO_buf96_stg3_1_merged1805_996
//	stg2_FIFO_buf96_stg3_1_merged1805_997
//	stg2_FIFO_buf96_stg3_1_merged1805_998
//	stg2_FIFO_buf96_stg3_1_merged1805_999
//	stg2_FIFO_buf96_stg3_1_merged1805_1000
//	stg2_FIFO_buf96_stg3_1_merged1805_1001
//	stg2_FIFO_buf96_stg3_1_merged1805_1002
//	stg2_FIFO_buf96_stg3_1_merged1805_1003
//	stg2_FIFO_buf96_stg3_1_merged1805_1004
//	stg2_FIFO_buf96_stg3_1_merged1805_1005
//	stg2_FIFO_buf96_stg3_1_merged1805_1006
//	stg2_FIFO_buf96_stg3_1_merged1805_1007
inline hw_uint<1024> stg2_FIFO_buf96_stg3_1_merged1805_read_bundle_read(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int root, int stg3_0, int stg3_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg2_FIFO_buf96_stg3_1_merged1805_944
    // stg2_FIFO_buf96_stg3_1_merged1805_945
    // stg2_FIFO_buf96_stg3_1_merged1805_946
    // stg2_FIFO_buf96_stg3_1_merged1805_947
    // stg2_FIFO_buf96_stg3_1_merged1805_948
    // stg2_FIFO_buf96_stg3_1_merged1805_949
    // stg2_FIFO_buf96_stg3_1_merged1805_950
    // stg2_FIFO_buf96_stg3_1_merged1805_951
    // stg2_FIFO_buf96_stg3_1_merged1805_952
    // stg2_FIFO_buf96_stg3_1_merged1805_953
    // stg2_FIFO_buf96_stg3_1_merged1805_954
    // stg2_FIFO_buf96_stg3_1_merged1805_955
    // stg2_FIFO_buf96_stg3_1_merged1805_956
    // stg2_FIFO_buf96_stg3_1_merged1805_957
    // stg2_FIFO_buf96_stg3_1_merged1805_958
    // stg2_FIFO_buf96_stg3_1_merged1805_959
    // stg2_FIFO_buf96_stg3_1_merged1805_960
    // stg2_FIFO_buf96_stg3_1_merged1805_961
    // stg2_FIFO_buf96_stg3_1_merged1805_962
    // stg2_FIFO_buf96_stg3_1_merged1805_963
    // stg2_FIFO_buf96_stg3_1_merged1805_964
    // stg2_FIFO_buf96_stg3_1_merged1805_965
    // stg2_FIFO_buf96_stg3_1_merged1805_966
    // stg2_FIFO_buf96_stg3_1_merged1805_967
    // stg2_FIFO_buf96_stg3_1_merged1805_968
    // stg2_FIFO_buf96_stg3_1_merged1805_969
    // stg2_FIFO_buf96_stg3_1_merged1805_970
    // stg2_FIFO_buf96_stg3_1_merged1805_971
    // stg2_FIFO_buf96_stg3_1_merged1805_972
    // stg2_FIFO_buf96_stg3_1_merged1805_973
    // stg2_FIFO_buf96_stg3_1_merged1805_974
    // stg2_FIFO_buf96_stg3_1_merged1805_975
    // stg2_FIFO_buf96_stg3_1_merged1805_976
    // stg2_FIFO_buf96_stg3_1_merged1805_977
    // stg2_FIFO_buf96_stg3_1_merged1805_978
    // stg2_FIFO_buf96_stg3_1_merged1805_979
    // stg2_FIFO_buf96_stg3_1_merged1805_980
    // stg2_FIFO_buf96_stg3_1_merged1805_981
    // stg2_FIFO_buf96_stg3_1_merged1805_982
    // stg2_FIFO_buf96_stg3_1_merged1805_983
    // stg2_FIFO_buf96_stg3_1_merged1805_984
    // stg2_FIFO_buf96_stg3_1_merged1805_985
    // stg2_FIFO_buf96_stg3_1_merged1805_986
    // stg2_FIFO_buf96_stg3_1_merged1805_987
    // stg2_FIFO_buf96_stg3_1_merged1805_988
    // stg2_FIFO_buf96_stg3_1_merged1805_989
    // stg2_FIFO_buf96_stg3_1_merged1805_990
    // stg2_FIFO_buf96_stg3_1_merged1805_991
    // stg2_FIFO_buf96_stg3_1_merged1805_992
    // stg2_FIFO_buf96_stg3_1_merged1805_993
    // stg2_FIFO_buf96_stg3_1_merged1805_994
    // stg2_FIFO_buf96_stg3_1_merged1805_995
    // stg2_FIFO_buf96_stg3_1_merged1805_996
    // stg2_FIFO_buf96_stg3_1_merged1805_997
    // stg2_FIFO_buf96_stg3_1_merged1805_998
    // stg2_FIFO_buf96_stg3_1_merged1805_999
    // stg2_FIFO_buf96_stg3_1_merged1805_1000
    // stg2_FIFO_buf96_stg3_1_merged1805_1001
    // stg2_FIFO_buf96_stg3_1_merged1805_1002
    // stg2_FIFO_buf96_stg3_1_merged1805_1003
    // stg2_FIFO_buf96_stg3_1_merged1805_1004
    // stg2_FIFO_buf96_stg3_1_merged1805_1005
    // stg2_FIFO_buf96_stg3_1_merged1805_1006
    // stg2_FIFO_buf96_stg3_1_merged1805_1007

	hw_uint<1024> result;
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_944_res = stg2_FIFO_buf96_stg3_1_merged1805_944_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<0, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_944_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_945_res = stg2_FIFO_buf96_stg3_1_merged1805_945_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<16, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_945_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_946_res = stg2_FIFO_buf96_stg3_1_merged1805_946_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<32, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_946_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_947_res = stg2_FIFO_buf96_stg3_1_merged1805_947_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<48, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_947_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_948_res = stg2_FIFO_buf96_stg3_1_merged1805_948_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<64, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_948_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_949_res = stg2_FIFO_buf96_stg3_1_merged1805_949_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<80, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_949_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_950_res = stg2_FIFO_buf96_stg3_1_merged1805_950_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<96, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_950_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_951_res = stg2_FIFO_buf96_stg3_1_merged1805_951_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<112, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_951_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_952_res = stg2_FIFO_buf96_stg3_1_merged1805_952_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<128, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_952_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_953_res = stg2_FIFO_buf96_stg3_1_merged1805_953_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<144, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_953_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_954_res = stg2_FIFO_buf96_stg3_1_merged1805_954_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<160, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_954_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_955_res = stg2_FIFO_buf96_stg3_1_merged1805_955_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<176, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_955_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_956_res = stg2_FIFO_buf96_stg3_1_merged1805_956_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<192, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_956_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_957_res = stg2_FIFO_buf96_stg3_1_merged1805_957_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<208, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_957_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_958_res = stg2_FIFO_buf96_stg3_1_merged1805_958_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<224, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_958_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_959_res = stg2_FIFO_buf96_stg3_1_merged1805_959_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<240, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_959_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_960_res = stg2_FIFO_buf96_stg3_1_merged1805_960_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<256, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_960_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_961_res = stg2_FIFO_buf96_stg3_1_merged1805_961_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<272, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_961_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_962_res = stg2_FIFO_buf96_stg3_1_merged1805_962_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<288, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_962_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_963_res = stg2_FIFO_buf96_stg3_1_merged1805_963_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<304, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_963_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_964_res = stg2_FIFO_buf96_stg3_1_merged1805_964_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<320, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_964_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_965_res = stg2_FIFO_buf96_stg3_1_merged1805_965_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<336, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_965_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_966_res = stg2_FIFO_buf96_stg3_1_merged1805_966_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<352, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_966_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_967_res = stg2_FIFO_buf96_stg3_1_merged1805_967_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<368, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_967_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_968_res = stg2_FIFO_buf96_stg3_1_merged1805_968_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<384, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_968_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_969_res = stg2_FIFO_buf96_stg3_1_merged1805_969_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<400, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_969_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_970_res = stg2_FIFO_buf96_stg3_1_merged1805_970_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<416, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_970_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_971_res = stg2_FIFO_buf96_stg3_1_merged1805_971_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<432, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_971_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_972_res = stg2_FIFO_buf96_stg3_1_merged1805_972_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<448, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_972_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_973_res = stg2_FIFO_buf96_stg3_1_merged1805_973_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<464, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_973_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_974_res = stg2_FIFO_buf96_stg3_1_merged1805_974_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<480, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_974_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_975_res = stg2_FIFO_buf96_stg3_1_merged1805_975_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<496, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_975_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_976_res = stg2_FIFO_buf96_stg3_1_merged1805_976_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<512, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_976_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_977_res = stg2_FIFO_buf96_stg3_1_merged1805_977_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<528, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_977_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_978_res = stg2_FIFO_buf96_stg3_1_merged1805_978_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<544, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_978_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_979_res = stg2_FIFO_buf96_stg3_1_merged1805_979_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<560, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_979_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_980_res = stg2_FIFO_buf96_stg3_1_merged1805_980_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<576, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_980_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_981_res = stg2_FIFO_buf96_stg3_1_merged1805_981_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<592, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_981_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_982_res = stg2_FIFO_buf96_stg3_1_merged1805_982_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<608, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_982_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_983_res = stg2_FIFO_buf96_stg3_1_merged1805_983_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<624, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_983_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_984_res = stg2_FIFO_buf96_stg3_1_merged1805_984_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<640, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_984_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_985_res = stg2_FIFO_buf96_stg3_1_merged1805_985_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<656, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_985_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_986_res = stg2_FIFO_buf96_stg3_1_merged1805_986_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<672, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_986_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_987_res = stg2_FIFO_buf96_stg3_1_merged1805_987_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<688, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_987_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_988_res = stg2_FIFO_buf96_stg3_1_merged1805_988_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<704, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_988_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_989_res = stg2_FIFO_buf96_stg3_1_merged1805_989_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<720, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_989_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_990_res = stg2_FIFO_buf96_stg3_1_merged1805_990_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<736, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_990_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_991_res = stg2_FIFO_buf96_stg3_1_merged1805_991_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<752, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_991_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_992_res = stg2_FIFO_buf96_stg3_1_merged1805_992_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<768, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_992_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_993_res = stg2_FIFO_buf96_stg3_1_merged1805_993_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<784, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_993_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_994_res = stg2_FIFO_buf96_stg3_1_merged1805_994_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<800, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_994_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_995_res = stg2_FIFO_buf96_stg3_1_merged1805_995_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<816, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_995_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_996_res = stg2_FIFO_buf96_stg3_1_merged1805_996_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<832, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_996_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_997_res = stg2_FIFO_buf96_stg3_1_merged1805_997_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<848, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_997_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_998_res = stg2_FIFO_buf96_stg3_1_merged1805_998_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<864, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_998_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_999_res = stg2_FIFO_buf96_stg3_1_merged1805_999_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<880, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_999_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1000_res = stg2_FIFO_buf96_stg3_1_merged1805_1000_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<896, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_1000_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1001_res = stg2_FIFO_buf96_stg3_1_merged1805_1001_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<912, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_1001_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1002_res = stg2_FIFO_buf96_stg3_1_merged1805_1002_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<928, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_1002_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1003_res = stg2_FIFO_buf96_stg3_1_merged1805_1003_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<944, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_1003_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1004_res = stg2_FIFO_buf96_stg3_1_merged1805_1004_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<960, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_1004_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1005_res = stg2_FIFO_buf96_stg3_1_merged1805_1005_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<976, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_1005_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1006_res = stg2_FIFO_buf96_stg3_1_merged1805_1006_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<992, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_1006_res);
	hw_uint<16> stg2_FIFO_buf96_stg3_1_merged1805_1007_res = stg2_FIFO_buf96_stg3_1_merged1805_1007_select(stg2_FIFO_buf96, root, stg3_0, stg3_1, dynamic_address);
	set_at<1008, 1024>(result, stg2_FIFO_buf96_stg3_1_merged1805_1007_res);
	return result;
}

struct stg3_stg3_1_merged1805_928_to_stg3_stg3_ld37_merged1766_912_cache {
	// RAM Box: {[15, 1263], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_929_to_stg3_stg3_ld37_merged1766_913_cache {
	// RAM Box: {[14, 1262], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_930_to_stg3_stg3_ld37_merged1766_914_cache {
	// RAM Box: {[13, 1261], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_931_to_stg3_stg3_ld37_merged1766_915_cache {
	// RAM Box: {[12, 1260], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_932_to_stg3_stg3_ld37_merged1766_916_cache {
	// RAM Box: {[11, 1259], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_933_to_stg3_stg3_ld37_merged1766_917_cache {
	// RAM Box: {[10, 1258], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_934_to_stg3_stg3_ld37_merged1766_918_cache {
	// RAM Box: {[9, 1257], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_935_to_stg3_stg3_ld37_merged1766_919_cache {
	// RAM Box: {[8, 1256], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_936_to_stg3_stg3_ld37_merged1766_920_cache {
	// RAM Box: {[7, 1255], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_937_to_stg3_stg3_ld37_merged1766_921_cache {
	// RAM Box: {[6, 1254], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_938_to_stg3_stg3_ld37_merged1766_922_cache {
	// RAM Box: {[5, 1253], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_939_to_stg3_stg3_ld37_merged1766_923_cache {
	// RAM Box: {[4, 1252], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_940_to_stg3_stg3_ld37_merged1766_924_cache {
	// RAM Box: {[3, 1251], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_941_to_stg3_stg3_ld37_merged1766_925_cache {
	// RAM Box: {[2, 1250], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_942_to_stg3_stg3_ld37_merged1766_926_cache {
	// RAM Box: {[1, 1249], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_stg3_1_merged1805_943_to_stg3_stg3_ld37_merged1766_927_cache {
	// RAM Box: {[0, 1248], [-11, 1930]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg3_cache {
  // Reader addrs...
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[15 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[14 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[13 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[12 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[11 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[10 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[9 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[8 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[7 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[6 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[5 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[4 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[3 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[2 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[1 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
    // { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // # of banks: 16
  stg3_stg3_1_merged1805_928_to_stg3_stg3_ld37_merged1766_912_cache stg3_stg3_1_merged1805_928_to_stg3_stg3_ld37_merged1766_912;
  stg3_stg3_1_merged1805_929_to_stg3_stg3_ld37_merged1766_913_cache stg3_stg3_1_merged1805_929_to_stg3_stg3_ld37_merged1766_913;
  stg3_stg3_1_merged1805_930_to_stg3_stg3_ld37_merged1766_914_cache stg3_stg3_1_merged1805_930_to_stg3_stg3_ld37_merged1766_914;
  stg3_stg3_1_merged1805_931_to_stg3_stg3_ld37_merged1766_915_cache stg3_stg3_1_merged1805_931_to_stg3_stg3_ld37_merged1766_915;
  stg3_stg3_1_merged1805_932_to_stg3_stg3_ld37_merged1766_916_cache stg3_stg3_1_merged1805_932_to_stg3_stg3_ld37_merged1766_916;
  stg3_stg3_1_merged1805_933_to_stg3_stg3_ld37_merged1766_917_cache stg3_stg3_1_merged1805_933_to_stg3_stg3_ld37_merged1766_917;
  stg3_stg3_1_merged1805_934_to_stg3_stg3_ld37_merged1766_918_cache stg3_stg3_1_merged1805_934_to_stg3_stg3_ld37_merged1766_918;
  stg3_stg3_1_merged1805_935_to_stg3_stg3_ld37_merged1766_919_cache stg3_stg3_1_merged1805_935_to_stg3_stg3_ld37_merged1766_919;
  stg3_stg3_1_merged1805_936_to_stg3_stg3_ld37_merged1766_920_cache stg3_stg3_1_merged1805_936_to_stg3_stg3_ld37_merged1766_920;
  stg3_stg3_1_merged1805_937_to_stg3_stg3_ld37_merged1766_921_cache stg3_stg3_1_merged1805_937_to_stg3_stg3_ld37_merged1766_921;
  stg3_stg3_1_merged1805_938_to_stg3_stg3_ld37_merged1766_922_cache stg3_stg3_1_merged1805_938_to_stg3_stg3_ld37_merged1766_922;
  stg3_stg3_1_merged1805_939_to_stg3_stg3_ld37_merged1766_923_cache stg3_stg3_1_merged1805_939_to_stg3_stg3_ld37_merged1766_923;
  stg3_stg3_1_merged1805_940_to_stg3_stg3_ld37_merged1766_924_cache stg3_stg3_1_merged1805_940_to_stg3_stg3_ld37_merged1766_924;
  stg3_stg3_1_merged1805_941_to_stg3_stg3_ld37_merged1766_925_cache stg3_stg3_1_merged1805_941_to_stg3_stg3_ld37_merged1766_925;
  stg3_stg3_1_merged1805_942_to_stg3_stg3_ld37_merged1766_926_cache stg3_stg3_1_merged1805_942_to_stg3_stg3_ld37_merged1766_926;
  stg3_stg3_1_merged1805_943_to_stg3_stg3_ld37_merged1766_927_cache stg3_stg3_1_merged1805_943_to_stg3_stg3_ld37_merged1766_927;
};



inline void stg3_stg3_1_merged1805_928_write(hw_uint<16>& stg3_stg3_1_merged1805_928, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_928_to_stg3_stg3_ld37_merged1766_912.push(stg3_stg3_1_merged1805_928);
}

inline void stg3_stg3_1_merged1805_929_write(hw_uint<16>& stg3_stg3_1_merged1805_929, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_929_to_stg3_stg3_ld37_merged1766_913.push(stg3_stg3_1_merged1805_929);
}

inline void stg3_stg3_1_merged1805_930_write(hw_uint<16>& stg3_stg3_1_merged1805_930, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_930_to_stg3_stg3_ld37_merged1766_914.push(stg3_stg3_1_merged1805_930);
}

inline void stg3_stg3_1_merged1805_931_write(hw_uint<16>& stg3_stg3_1_merged1805_931, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_931_to_stg3_stg3_ld37_merged1766_915.push(stg3_stg3_1_merged1805_931);
}

inline void stg3_stg3_1_merged1805_932_write(hw_uint<16>& stg3_stg3_1_merged1805_932, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_932_to_stg3_stg3_ld37_merged1766_916.push(stg3_stg3_1_merged1805_932);
}

inline void stg3_stg3_1_merged1805_933_write(hw_uint<16>& stg3_stg3_1_merged1805_933, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_933_to_stg3_stg3_ld37_merged1766_917.push(stg3_stg3_1_merged1805_933);
}

inline void stg3_stg3_1_merged1805_934_write(hw_uint<16>& stg3_stg3_1_merged1805_934, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_934_to_stg3_stg3_ld37_merged1766_918.push(stg3_stg3_1_merged1805_934);
}

inline void stg3_stg3_1_merged1805_935_write(hw_uint<16>& stg3_stg3_1_merged1805_935, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_935_to_stg3_stg3_ld37_merged1766_919.push(stg3_stg3_1_merged1805_935);
}

inline void stg3_stg3_1_merged1805_936_write(hw_uint<16>& stg3_stg3_1_merged1805_936, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_936_to_stg3_stg3_ld37_merged1766_920.push(stg3_stg3_1_merged1805_936);
}

inline void stg3_stg3_1_merged1805_937_write(hw_uint<16>& stg3_stg3_1_merged1805_937, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_937_to_stg3_stg3_ld37_merged1766_921.push(stg3_stg3_1_merged1805_937);
}

inline void stg3_stg3_1_merged1805_938_write(hw_uint<16>& stg3_stg3_1_merged1805_938, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_938_to_stg3_stg3_ld37_merged1766_922.push(stg3_stg3_1_merged1805_938);
}

inline void stg3_stg3_1_merged1805_939_write(hw_uint<16>& stg3_stg3_1_merged1805_939, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_939_to_stg3_stg3_ld37_merged1766_923.push(stg3_stg3_1_merged1805_939);
}

inline void stg3_stg3_1_merged1805_940_write(hw_uint<16>& stg3_stg3_1_merged1805_940, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_940_to_stg3_stg3_ld37_merged1766_924.push(stg3_stg3_1_merged1805_940);
}

inline void stg3_stg3_1_merged1805_941_write(hw_uint<16>& stg3_stg3_1_merged1805_941, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_941_to_stg3_stg3_ld37_merged1766_925.push(stg3_stg3_1_merged1805_941);
}

inline void stg3_stg3_1_merged1805_942_write(hw_uint<16>& stg3_stg3_1_merged1805_942, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_942_to_stg3_stg3_ld37_merged1766_926.push(stg3_stg3_1_merged1805_942);
}

inline void stg3_stg3_1_merged1805_943_write(hw_uint<16>& stg3_stg3_1_merged1805_943, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
  stg3.stg3_stg3_1_merged1805_943_to_stg3_stg3_ld37_merged1766_927.push(stg3_stg3_1_merged1805_943);
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_912_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_912 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[15 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_928 = stg3.stg3_stg3_1_merged1805_928_to_stg3_stg3_ld37_merged1766_912.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_928;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_913_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_913 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[14 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_929 = stg3.stg3_stg3_1_merged1805_929_to_stg3_stg3_ld37_merged1766_913.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_929;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_914_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_914 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[13 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_930 = stg3.stg3_stg3_1_merged1805_930_to_stg3_stg3_ld37_merged1766_914.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_930;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_915_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_915 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[12 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_931 = stg3.stg3_stg3_1_merged1805_931_to_stg3_stg3_ld37_merged1766_915.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_931;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_916_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_916 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[11 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_932 = stg3.stg3_stg3_1_merged1805_932_to_stg3_stg3_ld37_merged1766_916.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_932;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_917_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_917 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[10 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_933 = stg3.stg3_stg3_1_merged1805_933_to_stg3_stg3_ld37_merged1766_917.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_933;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_918_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_918 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[9 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_934 = stg3.stg3_stg3_1_merged1805_934_to_stg3_stg3_ld37_merged1766_918.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_934;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_919_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_919 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[8 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_935 = stg3.stg3_stg3_1_merged1805_935_to_stg3_stg3_ld37_merged1766_919.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_935;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_920_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_920 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[7 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_936 = stg3.stg3_stg3_1_merged1805_936_to_stg3_stg3_ld37_merged1766_920.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_936;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_921_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_921 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[6 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_937 = stg3.stg3_stg3_1_merged1805_937_to_stg3_stg3_ld37_merged1766_921.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_937;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_922_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_922 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[5 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_938 = stg3.stg3_stg3_1_merged1805_938_to_stg3_stg3_ld37_merged1766_922.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_938;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_923_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_923 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[4 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_939 = stg3.stg3_stg3_1_merged1805_939_to_stg3_stg3_ld37_merged1766_923.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_939;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_924_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_924 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[3 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_940 = stg3.stg3_stg3_1_merged1805_940_to_stg3_stg3_ld37_merged1766_924.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_940;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_925_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_925 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[2 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_941 = stg3.stg3_stg3_1_merged1805_941_to_stg3_stg3_ld37_merged1766_925.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_941;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_926_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_926 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[1 + 16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_942 = stg3.stg3_stg3_1_merged1805_942_to_stg3_stg3_ld37_merged1766_926.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_942;
  return 0;
}

inline hw_uint<16> stg3_stg3_ld37_merged1766_927_select(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_stg3_ld37_merged1766_927 read pattern: { stg3_ld37_merged1766[root = 0, stg3_ld38, stg3_ld37] -> stg3[16stg3_ld37, -11 + stg3_ld38] : 0 <= stg3_ld38 <= 1941 and 0 <= stg3_ld37 <= 78 }
  // Read schedule : { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  // Write schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_stg3_1_merged1805_943 = stg3.stg3_stg3_1_merged1805_943_to_stg3_stg3_ld37_merged1766_927.peek(/* one reader or all rams */ 0);
  return value_stg3_stg3_1_merged1805_943;
  return 0;
}

// # of bundles = 2
// stg3_1_merged1805_write
//	stg3_stg3_1_merged1805_928
//	stg3_stg3_1_merged1805_929
//	stg3_stg3_1_merged1805_930
//	stg3_stg3_1_merged1805_931
//	stg3_stg3_1_merged1805_932
//	stg3_stg3_1_merged1805_933
//	stg3_stg3_1_merged1805_934
//	stg3_stg3_1_merged1805_935
//	stg3_stg3_1_merged1805_936
//	stg3_stg3_1_merged1805_937
//	stg3_stg3_1_merged1805_938
//	stg3_stg3_1_merged1805_939
//	stg3_stg3_1_merged1805_940
//	stg3_stg3_1_merged1805_941
//	stg3_stg3_1_merged1805_942
//	stg3_stg3_1_merged1805_943
inline void stg3_stg3_1_merged1805_write_bundle_write(hw_uint<256>& stg3_1_merged1805_write, stg3_cache& stg3, int root, int stg3_0, int stg3_1, int dynamic_address) {
	hw_uint<16> stg3_stg3_1_merged1805_928_res = stg3_1_merged1805_write.extract<0, 15>();
	stg3_stg3_1_merged1805_928_write(stg3_stg3_1_merged1805_928_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_929_res = stg3_1_merged1805_write.extract<16, 31>();
	stg3_stg3_1_merged1805_929_write(stg3_stg3_1_merged1805_929_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_930_res = stg3_1_merged1805_write.extract<32, 47>();
	stg3_stg3_1_merged1805_930_write(stg3_stg3_1_merged1805_930_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_931_res = stg3_1_merged1805_write.extract<48, 63>();
	stg3_stg3_1_merged1805_931_write(stg3_stg3_1_merged1805_931_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_932_res = stg3_1_merged1805_write.extract<64, 79>();
	stg3_stg3_1_merged1805_932_write(stg3_stg3_1_merged1805_932_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_933_res = stg3_1_merged1805_write.extract<80, 95>();
	stg3_stg3_1_merged1805_933_write(stg3_stg3_1_merged1805_933_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_934_res = stg3_1_merged1805_write.extract<96, 111>();
	stg3_stg3_1_merged1805_934_write(stg3_stg3_1_merged1805_934_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_935_res = stg3_1_merged1805_write.extract<112, 127>();
	stg3_stg3_1_merged1805_935_write(stg3_stg3_1_merged1805_935_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_936_res = stg3_1_merged1805_write.extract<128, 143>();
	stg3_stg3_1_merged1805_936_write(stg3_stg3_1_merged1805_936_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_937_res = stg3_1_merged1805_write.extract<144, 159>();
	stg3_stg3_1_merged1805_937_write(stg3_stg3_1_merged1805_937_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_938_res = stg3_1_merged1805_write.extract<160, 175>();
	stg3_stg3_1_merged1805_938_write(stg3_stg3_1_merged1805_938_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_939_res = stg3_1_merged1805_write.extract<176, 191>();
	stg3_stg3_1_merged1805_939_write(stg3_stg3_1_merged1805_939_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_940_res = stg3_1_merged1805_write.extract<192, 207>();
	stg3_stg3_1_merged1805_940_write(stg3_stg3_1_merged1805_940_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_941_res = stg3_1_merged1805_write.extract<208, 223>();
	stg3_stg3_1_merged1805_941_write(stg3_stg3_1_merged1805_941_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_942_res = stg3_1_merged1805_write.extract<224, 239>();
	stg3_stg3_1_merged1805_942_write(stg3_stg3_1_merged1805_942_res, stg3, root, stg3_0, stg3_1, dynamic_address);
	hw_uint<16> stg3_stg3_1_merged1805_943_res = stg3_1_merged1805_write.extract<240, 255>();
	stg3_stg3_1_merged1805_943_write(stg3_stg3_1_merged1805_943_res, stg3, root, stg3_0, stg3_1, dynamic_address);
}

// stg3_ld37_merged1766_read
//	stg3_stg3_ld37_merged1766_912
//	stg3_stg3_ld37_merged1766_913
//	stg3_stg3_ld37_merged1766_914
//	stg3_stg3_ld37_merged1766_915
//	stg3_stg3_ld37_merged1766_916
//	stg3_stg3_ld37_merged1766_917
//	stg3_stg3_ld37_merged1766_918
//	stg3_stg3_ld37_merged1766_919
//	stg3_stg3_ld37_merged1766_920
//	stg3_stg3_ld37_merged1766_921
//	stg3_stg3_ld37_merged1766_922
//	stg3_stg3_ld37_merged1766_923
//	stg3_stg3_ld37_merged1766_924
//	stg3_stg3_ld37_merged1766_925
//	stg3_stg3_ld37_merged1766_926
//	stg3_stg3_ld37_merged1766_927
inline hw_uint<256> stg3_stg3_ld37_merged1766_read_bundle_read(stg3_cache& stg3, int root, int stg3_ld38, int stg3_ld37, int dynamic_address) {
  // # of ports in bundle: 16
    // stg3_stg3_ld37_merged1766_912
    // stg3_stg3_ld37_merged1766_913
    // stg3_stg3_ld37_merged1766_914
    // stg3_stg3_ld37_merged1766_915
    // stg3_stg3_ld37_merged1766_916
    // stg3_stg3_ld37_merged1766_917
    // stg3_stg3_ld37_merged1766_918
    // stg3_stg3_ld37_merged1766_919
    // stg3_stg3_ld37_merged1766_920
    // stg3_stg3_ld37_merged1766_921
    // stg3_stg3_ld37_merged1766_922
    // stg3_stg3_ld37_merged1766_923
    // stg3_stg3_ld37_merged1766_924
    // stg3_stg3_ld37_merged1766_925
    // stg3_stg3_ld37_merged1766_926
    // stg3_stg3_ld37_merged1766_927

	hw_uint<256> result;
	hw_uint<16> stg3_stg3_ld37_merged1766_912_res = stg3_stg3_ld37_merged1766_912_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<0, 256>(result, stg3_stg3_ld37_merged1766_912_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_913_res = stg3_stg3_ld37_merged1766_913_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<16, 256>(result, stg3_stg3_ld37_merged1766_913_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_914_res = stg3_stg3_ld37_merged1766_914_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<32, 256>(result, stg3_stg3_ld37_merged1766_914_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_915_res = stg3_stg3_ld37_merged1766_915_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<48, 256>(result, stg3_stg3_ld37_merged1766_915_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_916_res = stg3_stg3_ld37_merged1766_916_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<64, 256>(result, stg3_stg3_ld37_merged1766_916_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_917_res = stg3_stg3_ld37_merged1766_917_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<80, 256>(result, stg3_stg3_ld37_merged1766_917_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_918_res = stg3_stg3_ld37_merged1766_918_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<96, 256>(result, stg3_stg3_ld37_merged1766_918_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_919_res = stg3_stg3_ld37_merged1766_919_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<112, 256>(result, stg3_stg3_ld37_merged1766_919_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_920_res = stg3_stg3_ld37_merged1766_920_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<128, 256>(result, stg3_stg3_ld37_merged1766_920_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_921_res = stg3_stg3_ld37_merged1766_921_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<144, 256>(result, stg3_stg3_ld37_merged1766_921_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_922_res = stg3_stg3_ld37_merged1766_922_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<160, 256>(result, stg3_stg3_ld37_merged1766_922_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_923_res = stg3_stg3_ld37_merged1766_923_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<176, 256>(result, stg3_stg3_ld37_merged1766_923_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_924_res = stg3_stg3_ld37_merged1766_924_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<192, 256>(result, stg3_stg3_ld37_merged1766_924_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_925_res = stg3_stg3_ld37_merged1766_925_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<208, 256>(result, stg3_stg3_ld37_merged1766_925_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_926_res = stg3_stg3_ld37_merged1766_926_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<224, 256>(result, stg3_stg3_ld37_merged1766_926_res);
	hw_uint<16> stg3_stg3_ld37_merged1766_927_res = stg3_stg3_ld37_merged1766_927_select(stg3, root, stg3_ld38, stg3_ld37, dynamic_address);
	set_at<240, 256>(result, stg3_stg3_ld37_merged1766_927_res);
	return result;
}

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_merged_banks_4_cache {
	// RAM Box: {[15, 1247], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_merged_banks_4_cache {
	// RAM Box: {[14, 1246], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_merged_banks_4_cache {
	// RAM Box: {[13, 1245], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_merged_banks_4_cache {
	// RAM Box: {[12, 1244], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_merged_banks_4_cache {
	// RAM Box: {[11, 1243], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_merged_banks_4_cache {
	// RAM Box: {[10, 1242], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_merged_banks_4_cache {
	// RAM Box: {[9, 1241], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_merged_banks_4_cache {
	// RAM Box: {[8, 1240], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_merged_banks_4_cache {
	// RAM Box: {[7, 1239], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_merged_banks_4_cache {
	// RAM Box: {[6, 1238], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_merged_banks_4_cache {
	// RAM Box: {[5, 1237], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_merged_banks_4_cache {
	// RAM Box: {[4, 1236], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_merged_banks_4_cache {
	// RAM Box: {[3, 1235], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_merged_banks_4_cache {
	// RAM Box: {[2, 1234], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_merged_banks_4_cache {
	// RAM Box: {[1, 1233], [-11, 1930]}
	// Capacity: 160
	// # of read delays: 4
  // 0, 1, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 78> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 78> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_79() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_80() {
		return f4;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_159() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_merged_banks_4_cache {
	// RAM Box: {[0, 1248], [-11, 1929]}
	// Capacity: 160
	// # of read delays: 5
  // 0, 1, 79, 80, 159
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 78> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_80() {
		return f6;
	}

	inline hw_uint<16> peek_158() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_159() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 78
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 78 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg3_FIFO_buf100_cache {
  // Reader addrs...
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[15 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[15 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[16 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[15 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[14 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[14 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[15 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[14 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[13 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[13 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[14 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[13 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[12 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[12 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[13 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[12 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[11 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[11 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[12 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[11 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[10 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[10 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[11 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[10 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[9 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[9 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[10 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[9 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[8 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[8 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[9 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[8 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[7 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[7 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[8 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[7 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[6 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[6 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[7 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[6 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[5 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[5 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[6 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[5 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[4 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[4 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[5 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[4 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[3 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[3 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[4 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[3 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[2 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[2 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[3 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[2 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[1 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[1 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[2 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[1 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[1 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
    // { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // # of banks: 16
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_merged_banks_4;
  stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_merged_banks_4_cache stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_merged_banks_4;
};



inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878);
}

inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_write(hw_uint<16>& stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
  stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_merged_banks_4.push(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879);
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_800_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_800 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[15 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_801_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_801 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[15 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_802_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_802 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[16 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_merged_banks_4.peek_79();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_803_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_803 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[15 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_804_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_804 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[14 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_805_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_805 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[14 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_806_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_806 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[15 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_807_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_807 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[14 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_808_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_808 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[13 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_809_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_809 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[13 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_810_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_810 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[14 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_811_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_811 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[13 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_812_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_812 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[12 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_813_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_813 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[12 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_814_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_814 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[13 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_815_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_815 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[12 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_816_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_816 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[11 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_817_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_817 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[11 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_818_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_818 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[12 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_819_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_819 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[11 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_820_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_820 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[10 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_821_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_821 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[10 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_822_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_822 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[11 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_823_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_823 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[10 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_824_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_824 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[9 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_825_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_825 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[9 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_826_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_826 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[10 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_827_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_827 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[9 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_828_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_828 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[8 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_829_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_829 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[8 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_830_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_830 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[9 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_831_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_831 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[8 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_832_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_832 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[7 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_833_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_833 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[7 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_834_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_834 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[8 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_835_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_835 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[7 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_836_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_836 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[6 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_837_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_837 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[6 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_838_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_838 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[7 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_839_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_839 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[6 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_840_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_840 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[5 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_841_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_841 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[5 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_842_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_842 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[6 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_843_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_843 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[5 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_844_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_844 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[4 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_845_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_845 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[4 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_846_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_846 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[5 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_847_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_847 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[4 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_848_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_848 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[3 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_849_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_849 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[3 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_850_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_850 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[4 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_851_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_851 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[3 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_852_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_852 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[2 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_853_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_853 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[2 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_854_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_854 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[3 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_855_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_855 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[2 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_856_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_856 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[1 + 16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_857_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_857 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[1 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_858_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_858 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[2 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_859_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_859 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[1 + 16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_860_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_860 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[16stg4_1, -11 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_merged_banks_4.peek_159();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_861_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_861 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_862_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_862 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[1 + 16stg4_1, -10 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_merged_banks_4.peek_80();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878;
  return 0;
}

inline hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_863_select(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg3_FIFO_buf100_stg4_1_merged1808_863 read pattern: { stg4_1_merged1808[root = 0, stg4_0, stg4_1] -> stg3_FIFO_buf100[16stg4_1, -9 + stg4_0] : 0 <= stg4_0 <= 1939 and 0 <= stg4_1 <= 77 }
  // Read schedule : { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
  auto value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879 = stg3_FIFO_buf100.stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_merged_banks_4.peek_1();
  return value_stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879;
  return 0;
}

// # of bundles = 2
// stg3_to_gp_1136_ld101_merged1746_write
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878
//	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879
inline void stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_write_bundle_write(hw_uint<256>& stg3_to_gp_1136_ld101_merged1746_write, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg3_to_gp_1136_ld102, int stg3_to_gp_1136_ld101, int dynamic_address) {
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_res = stg3_to_gp_1136_ld101_merged1746_write.extract<0, 15>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_864_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_res = stg3_to_gp_1136_ld101_merged1746_write.extract<16, 31>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_865_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_res = stg3_to_gp_1136_ld101_merged1746_write.extract<32, 47>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_866_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_res = stg3_to_gp_1136_ld101_merged1746_write.extract<48, 63>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_867_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_res = stg3_to_gp_1136_ld101_merged1746_write.extract<64, 79>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_868_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_res = stg3_to_gp_1136_ld101_merged1746_write.extract<80, 95>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_869_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_res = stg3_to_gp_1136_ld101_merged1746_write.extract<96, 111>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_870_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_res = stg3_to_gp_1136_ld101_merged1746_write.extract<112, 127>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_871_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_res = stg3_to_gp_1136_ld101_merged1746_write.extract<128, 143>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_872_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_res = stg3_to_gp_1136_ld101_merged1746_write.extract<144, 159>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_873_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_res = stg3_to_gp_1136_ld101_merged1746_write.extract<160, 175>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_874_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_res = stg3_to_gp_1136_ld101_merged1746_write.extract<176, 191>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_875_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_res = stg3_to_gp_1136_ld101_merged1746_write.extract<192, 207>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_876_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_res = stg3_to_gp_1136_ld101_merged1746_write.extract<208, 223>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_877_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_res = stg3_to_gp_1136_ld101_merged1746_write.extract<224, 239>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_878_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
	hw_uint<16> stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_res = stg3_to_gp_1136_ld101_merged1746_write.extract<240, 255>();
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_write(stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_879_res, stg3_FIFO_buf100, root, stg3_to_gp_1136_ld102, stg3_to_gp_1136_ld101, dynamic_address);
}

// stg4_1_merged1808_read
//	stg3_FIFO_buf100_stg4_1_merged1808_800
//	stg3_FIFO_buf100_stg4_1_merged1808_801
//	stg3_FIFO_buf100_stg4_1_merged1808_802
//	stg3_FIFO_buf100_stg4_1_merged1808_803
//	stg3_FIFO_buf100_stg4_1_merged1808_804
//	stg3_FIFO_buf100_stg4_1_merged1808_805
//	stg3_FIFO_buf100_stg4_1_merged1808_806
//	stg3_FIFO_buf100_stg4_1_merged1808_807
//	stg3_FIFO_buf100_stg4_1_merged1808_808
//	stg3_FIFO_buf100_stg4_1_merged1808_809
//	stg3_FIFO_buf100_stg4_1_merged1808_810
//	stg3_FIFO_buf100_stg4_1_merged1808_811
//	stg3_FIFO_buf100_stg4_1_merged1808_812
//	stg3_FIFO_buf100_stg4_1_merged1808_813
//	stg3_FIFO_buf100_stg4_1_merged1808_814
//	stg3_FIFO_buf100_stg4_1_merged1808_815
//	stg3_FIFO_buf100_stg4_1_merged1808_816
//	stg3_FIFO_buf100_stg4_1_merged1808_817
//	stg3_FIFO_buf100_stg4_1_merged1808_818
//	stg3_FIFO_buf100_stg4_1_merged1808_819
//	stg3_FIFO_buf100_stg4_1_merged1808_820
//	stg3_FIFO_buf100_stg4_1_merged1808_821
//	stg3_FIFO_buf100_stg4_1_merged1808_822
//	stg3_FIFO_buf100_stg4_1_merged1808_823
//	stg3_FIFO_buf100_stg4_1_merged1808_824
//	stg3_FIFO_buf100_stg4_1_merged1808_825
//	stg3_FIFO_buf100_stg4_1_merged1808_826
//	stg3_FIFO_buf100_stg4_1_merged1808_827
//	stg3_FIFO_buf100_stg4_1_merged1808_828
//	stg3_FIFO_buf100_stg4_1_merged1808_829
//	stg3_FIFO_buf100_stg4_1_merged1808_830
//	stg3_FIFO_buf100_stg4_1_merged1808_831
//	stg3_FIFO_buf100_stg4_1_merged1808_832
//	stg3_FIFO_buf100_stg4_1_merged1808_833
//	stg3_FIFO_buf100_stg4_1_merged1808_834
//	stg3_FIFO_buf100_stg4_1_merged1808_835
//	stg3_FIFO_buf100_stg4_1_merged1808_836
//	stg3_FIFO_buf100_stg4_1_merged1808_837
//	stg3_FIFO_buf100_stg4_1_merged1808_838
//	stg3_FIFO_buf100_stg4_1_merged1808_839
//	stg3_FIFO_buf100_stg4_1_merged1808_840
//	stg3_FIFO_buf100_stg4_1_merged1808_841
//	stg3_FIFO_buf100_stg4_1_merged1808_842
//	stg3_FIFO_buf100_stg4_1_merged1808_843
//	stg3_FIFO_buf100_stg4_1_merged1808_844
//	stg3_FIFO_buf100_stg4_1_merged1808_845
//	stg3_FIFO_buf100_stg4_1_merged1808_846
//	stg3_FIFO_buf100_stg4_1_merged1808_847
//	stg3_FIFO_buf100_stg4_1_merged1808_848
//	stg3_FIFO_buf100_stg4_1_merged1808_849
//	stg3_FIFO_buf100_stg4_1_merged1808_850
//	stg3_FIFO_buf100_stg4_1_merged1808_851
//	stg3_FIFO_buf100_stg4_1_merged1808_852
//	stg3_FIFO_buf100_stg4_1_merged1808_853
//	stg3_FIFO_buf100_stg4_1_merged1808_854
//	stg3_FIFO_buf100_stg4_1_merged1808_855
//	stg3_FIFO_buf100_stg4_1_merged1808_856
//	stg3_FIFO_buf100_stg4_1_merged1808_857
//	stg3_FIFO_buf100_stg4_1_merged1808_858
//	stg3_FIFO_buf100_stg4_1_merged1808_859
//	stg3_FIFO_buf100_stg4_1_merged1808_860
//	stg3_FIFO_buf100_stg4_1_merged1808_861
//	stg3_FIFO_buf100_stg4_1_merged1808_862
//	stg3_FIFO_buf100_stg4_1_merged1808_863
inline hw_uint<1024> stg3_FIFO_buf100_stg4_1_merged1808_read_bundle_read(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int root, int stg4_0, int stg4_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg3_FIFO_buf100_stg4_1_merged1808_800
    // stg3_FIFO_buf100_stg4_1_merged1808_801
    // stg3_FIFO_buf100_stg4_1_merged1808_802
    // stg3_FIFO_buf100_stg4_1_merged1808_803
    // stg3_FIFO_buf100_stg4_1_merged1808_804
    // stg3_FIFO_buf100_stg4_1_merged1808_805
    // stg3_FIFO_buf100_stg4_1_merged1808_806
    // stg3_FIFO_buf100_stg4_1_merged1808_807
    // stg3_FIFO_buf100_stg4_1_merged1808_808
    // stg3_FIFO_buf100_stg4_1_merged1808_809
    // stg3_FIFO_buf100_stg4_1_merged1808_810
    // stg3_FIFO_buf100_stg4_1_merged1808_811
    // stg3_FIFO_buf100_stg4_1_merged1808_812
    // stg3_FIFO_buf100_stg4_1_merged1808_813
    // stg3_FIFO_buf100_stg4_1_merged1808_814
    // stg3_FIFO_buf100_stg4_1_merged1808_815
    // stg3_FIFO_buf100_stg4_1_merged1808_816
    // stg3_FIFO_buf100_stg4_1_merged1808_817
    // stg3_FIFO_buf100_stg4_1_merged1808_818
    // stg3_FIFO_buf100_stg4_1_merged1808_819
    // stg3_FIFO_buf100_stg4_1_merged1808_820
    // stg3_FIFO_buf100_stg4_1_merged1808_821
    // stg3_FIFO_buf100_stg4_1_merged1808_822
    // stg3_FIFO_buf100_stg4_1_merged1808_823
    // stg3_FIFO_buf100_stg4_1_merged1808_824
    // stg3_FIFO_buf100_stg4_1_merged1808_825
    // stg3_FIFO_buf100_stg4_1_merged1808_826
    // stg3_FIFO_buf100_stg4_1_merged1808_827
    // stg3_FIFO_buf100_stg4_1_merged1808_828
    // stg3_FIFO_buf100_stg4_1_merged1808_829
    // stg3_FIFO_buf100_stg4_1_merged1808_830
    // stg3_FIFO_buf100_stg4_1_merged1808_831
    // stg3_FIFO_buf100_stg4_1_merged1808_832
    // stg3_FIFO_buf100_stg4_1_merged1808_833
    // stg3_FIFO_buf100_stg4_1_merged1808_834
    // stg3_FIFO_buf100_stg4_1_merged1808_835
    // stg3_FIFO_buf100_stg4_1_merged1808_836
    // stg3_FIFO_buf100_stg4_1_merged1808_837
    // stg3_FIFO_buf100_stg4_1_merged1808_838
    // stg3_FIFO_buf100_stg4_1_merged1808_839
    // stg3_FIFO_buf100_stg4_1_merged1808_840
    // stg3_FIFO_buf100_stg4_1_merged1808_841
    // stg3_FIFO_buf100_stg4_1_merged1808_842
    // stg3_FIFO_buf100_stg4_1_merged1808_843
    // stg3_FIFO_buf100_stg4_1_merged1808_844
    // stg3_FIFO_buf100_stg4_1_merged1808_845
    // stg3_FIFO_buf100_stg4_1_merged1808_846
    // stg3_FIFO_buf100_stg4_1_merged1808_847
    // stg3_FIFO_buf100_stg4_1_merged1808_848
    // stg3_FIFO_buf100_stg4_1_merged1808_849
    // stg3_FIFO_buf100_stg4_1_merged1808_850
    // stg3_FIFO_buf100_stg4_1_merged1808_851
    // stg3_FIFO_buf100_stg4_1_merged1808_852
    // stg3_FIFO_buf100_stg4_1_merged1808_853
    // stg3_FIFO_buf100_stg4_1_merged1808_854
    // stg3_FIFO_buf100_stg4_1_merged1808_855
    // stg3_FIFO_buf100_stg4_1_merged1808_856
    // stg3_FIFO_buf100_stg4_1_merged1808_857
    // stg3_FIFO_buf100_stg4_1_merged1808_858
    // stg3_FIFO_buf100_stg4_1_merged1808_859
    // stg3_FIFO_buf100_stg4_1_merged1808_860
    // stg3_FIFO_buf100_stg4_1_merged1808_861
    // stg3_FIFO_buf100_stg4_1_merged1808_862
    // stg3_FIFO_buf100_stg4_1_merged1808_863

	hw_uint<1024> result;
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_800_res = stg3_FIFO_buf100_stg4_1_merged1808_800_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<0, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_800_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_801_res = stg3_FIFO_buf100_stg4_1_merged1808_801_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<16, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_801_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_802_res = stg3_FIFO_buf100_stg4_1_merged1808_802_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<32, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_802_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_803_res = stg3_FIFO_buf100_stg4_1_merged1808_803_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<48, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_803_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_804_res = stg3_FIFO_buf100_stg4_1_merged1808_804_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<64, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_804_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_805_res = stg3_FIFO_buf100_stg4_1_merged1808_805_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<80, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_805_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_806_res = stg3_FIFO_buf100_stg4_1_merged1808_806_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<96, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_806_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_807_res = stg3_FIFO_buf100_stg4_1_merged1808_807_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<112, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_807_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_808_res = stg3_FIFO_buf100_stg4_1_merged1808_808_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<128, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_808_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_809_res = stg3_FIFO_buf100_stg4_1_merged1808_809_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<144, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_809_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_810_res = stg3_FIFO_buf100_stg4_1_merged1808_810_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<160, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_810_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_811_res = stg3_FIFO_buf100_stg4_1_merged1808_811_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<176, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_811_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_812_res = stg3_FIFO_buf100_stg4_1_merged1808_812_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<192, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_812_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_813_res = stg3_FIFO_buf100_stg4_1_merged1808_813_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<208, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_813_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_814_res = stg3_FIFO_buf100_stg4_1_merged1808_814_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<224, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_814_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_815_res = stg3_FIFO_buf100_stg4_1_merged1808_815_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<240, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_815_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_816_res = stg3_FIFO_buf100_stg4_1_merged1808_816_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<256, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_816_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_817_res = stg3_FIFO_buf100_stg4_1_merged1808_817_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<272, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_817_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_818_res = stg3_FIFO_buf100_stg4_1_merged1808_818_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<288, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_818_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_819_res = stg3_FIFO_buf100_stg4_1_merged1808_819_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<304, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_819_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_820_res = stg3_FIFO_buf100_stg4_1_merged1808_820_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<320, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_820_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_821_res = stg3_FIFO_buf100_stg4_1_merged1808_821_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<336, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_821_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_822_res = stg3_FIFO_buf100_stg4_1_merged1808_822_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<352, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_822_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_823_res = stg3_FIFO_buf100_stg4_1_merged1808_823_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<368, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_823_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_824_res = stg3_FIFO_buf100_stg4_1_merged1808_824_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<384, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_824_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_825_res = stg3_FIFO_buf100_stg4_1_merged1808_825_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<400, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_825_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_826_res = stg3_FIFO_buf100_stg4_1_merged1808_826_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<416, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_826_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_827_res = stg3_FIFO_buf100_stg4_1_merged1808_827_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<432, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_827_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_828_res = stg3_FIFO_buf100_stg4_1_merged1808_828_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<448, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_828_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_829_res = stg3_FIFO_buf100_stg4_1_merged1808_829_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<464, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_829_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_830_res = stg3_FIFO_buf100_stg4_1_merged1808_830_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<480, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_830_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_831_res = stg3_FIFO_buf100_stg4_1_merged1808_831_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<496, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_831_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_832_res = stg3_FIFO_buf100_stg4_1_merged1808_832_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<512, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_832_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_833_res = stg3_FIFO_buf100_stg4_1_merged1808_833_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<528, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_833_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_834_res = stg3_FIFO_buf100_stg4_1_merged1808_834_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<544, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_834_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_835_res = stg3_FIFO_buf100_stg4_1_merged1808_835_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<560, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_835_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_836_res = stg3_FIFO_buf100_stg4_1_merged1808_836_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<576, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_836_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_837_res = stg3_FIFO_buf100_stg4_1_merged1808_837_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<592, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_837_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_838_res = stg3_FIFO_buf100_stg4_1_merged1808_838_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<608, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_838_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_839_res = stg3_FIFO_buf100_stg4_1_merged1808_839_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<624, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_839_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_840_res = stg3_FIFO_buf100_stg4_1_merged1808_840_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<640, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_840_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_841_res = stg3_FIFO_buf100_stg4_1_merged1808_841_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<656, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_841_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_842_res = stg3_FIFO_buf100_stg4_1_merged1808_842_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<672, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_842_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_843_res = stg3_FIFO_buf100_stg4_1_merged1808_843_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<688, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_843_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_844_res = stg3_FIFO_buf100_stg4_1_merged1808_844_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<704, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_844_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_845_res = stg3_FIFO_buf100_stg4_1_merged1808_845_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<720, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_845_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_846_res = stg3_FIFO_buf100_stg4_1_merged1808_846_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<736, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_846_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_847_res = stg3_FIFO_buf100_stg4_1_merged1808_847_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<752, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_847_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_848_res = stg3_FIFO_buf100_stg4_1_merged1808_848_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<768, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_848_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_849_res = stg3_FIFO_buf100_stg4_1_merged1808_849_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<784, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_849_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_850_res = stg3_FIFO_buf100_stg4_1_merged1808_850_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<800, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_850_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_851_res = stg3_FIFO_buf100_stg4_1_merged1808_851_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<816, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_851_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_852_res = stg3_FIFO_buf100_stg4_1_merged1808_852_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<832, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_852_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_853_res = stg3_FIFO_buf100_stg4_1_merged1808_853_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<848, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_853_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_854_res = stg3_FIFO_buf100_stg4_1_merged1808_854_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<864, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_854_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_855_res = stg3_FIFO_buf100_stg4_1_merged1808_855_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<880, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_855_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_856_res = stg3_FIFO_buf100_stg4_1_merged1808_856_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<896, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_856_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_857_res = stg3_FIFO_buf100_stg4_1_merged1808_857_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<912, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_857_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_858_res = stg3_FIFO_buf100_stg4_1_merged1808_858_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<928, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_858_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_859_res = stg3_FIFO_buf100_stg4_1_merged1808_859_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<944, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_859_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_860_res = stg3_FIFO_buf100_stg4_1_merged1808_860_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<960, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_860_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_861_res = stg3_FIFO_buf100_stg4_1_merged1808_861_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<976, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_861_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_862_res = stg3_FIFO_buf100_stg4_1_merged1808_862_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<992, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_862_res);
	hw_uint<16> stg3_FIFO_buf100_stg4_1_merged1808_863_res = stg3_FIFO_buf100_stg4_1_merged1808_863_select(stg3_FIFO_buf100, root, stg4_0, stg4_1, dynamic_address);
	set_at<1008, 1024>(result, stg3_FIFO_buf100_stg4_1_merged1808_863_res);
	return result;
}

struct stg4_stg4_1_merged1808_784_to_stg4_stg4_ld41_merged1784_768_cache {
	// RAM Box: {[15, 1247], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_785_to_stg4_stg4_ld41_merged1784_769_cache {
	// RAM Box: {[14, 1246], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_786_to_stg4_stg4_ld41_merged1784_770_cache {
	// RAM Box: {[13, 1245], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_787_to_stg4_stg4_ld41_merged1784_771_cache {
	// RAM Box: {[12, 1244], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_788_to_stg4_stg4_ld41_merged1784_772_cache {
	// RAM Box: {[11, 1243], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_789_to_stg4_stg4_ld41_merged1784_773_cache {
	// RAM Box: {[10, 1242], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_790_to_stg4_stg4_ld41_merged1784_774_cache {
	// RAM Box: {[9, 1241], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_791_to_stg4_stg4_ld41_merged1784_775_cache {
	// RAM Box: {[8, 1240], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_792_to_stg4_stg4_ld41_merged1784_776_cache {
	// RAM Box: {[7, 1239], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_793_to_stg4_stg4_ld41_merged1784_777_cache {
	// RAM Box: {[6, 1238], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_794_to_stg4_stg4_ld41_merged1784_778_cache {
	// RAM Box: {[5, 1237], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_795_to_stg4_stg4_ld41_merged1784_779_cache {
	// RAM Box: {[4, 1236], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_796_to_stg4_stg4_ld41_merged1784_780_cache {
	// RAM Box: {[3, 1235], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_797_to_stg4_stg4_ld41_merged1784_781_cache {
	// RAM Box: {[2, 1234], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_798_to_stg4_stg4_ld41_merged1784_782_cache {
	// RAM Box: {[1, 1233], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_stg4_1_merged1808_799_to_stg4_stg4_ld41_merged1784_783_cache {
	// RAM Box: {[0, 1232], [-10, 1929]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg4_cache {
  // Reader addrs...
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[15 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[14 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[13 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[12 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[11 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[10 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[9 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[8 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[7 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[6 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[5 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[4 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[3 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[2 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[1 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
    // { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // # of banks: 16
  stg4_stg4_1_merged1808_784_to_stg4_stg4_ld41_merged1784_768_cache stg4_stg4_1_merged1808_784_to_stg4_stg4_ld41_merged1784_768;
  stg4_stg4_1_merged1808_785_to_stg4_stg4_ld41_merged1784_769_cache stg4_stg4_1_merged1808_785_to_stg4_stg4_ld41_merged1784_769;
  stg4_stg4_1_merged1808_786_to_stg4_stg4_ld41_merged1784_770_cache stg4_stg4_1_merged1808_786_to_stg4_stg4_ld41_merged1784_770;
  stg4_stg4_1_merged1808_787_to_stg4_stg4_ld41_merged1784_771_cache stg4_stg4_1_merged1808_787_to_stg4_stg4_ld41_merged1784_771;
  stg4_stg4_1_merged1808_788_to_stg4_stg4_ld41_merged1784_772_cache stg4_stg4_1_merged1808_788_to_stg4_stg4_ld41_merged1784_772;
  stg4_stg4_1_merged1808_789_to_stg4_stg4_ld41_merged1784_773_cache stg4_stg4_1_merged1808_789_to_stg4_stg4_ld41_merged1784_773;
  stg4_stg4_1_merged1808_790_to_stg4_stg4_ld41_merged1784_774_cache stg4_stg4_1_merged1808_790_to_stg4_stg4_ld41_merged1784_774;
  stg4_stg4_1_merged1808_791_to_stg4_stg4_ld41_merged1784_775_cache stg4_stg4_1_merged1808_791_to_stg4_stg4_ld41_merged1784_775;
  stg4_stg4_1_merged1808_792_to_stg4_stg4_ld41_merged1784_776_cache stg4_stg4_1_merged1808_792_to_stg4_stg4_ld41_merged1784_776;
  stg4_stg4_1_merged1808_793_to_stg4_stg4_ld41_merged1784_777_cache stg4_stg4_1_merged1808_793_to_stg4_stg4_ld41_merged1784_777;
  stg4_stg4_1_merged1808_794_to_stg4_stg4_ld41_merged1784_778_cache stg4_stg4_1_merged1808_794_to_stg4_stg4_ld41_merged1784_778;
  stg4_stg4_1_merged1808_795_to_stg4_stg4_ld41_merged1784_779_cache stg4_stg4_1_merged1808_795_to_stg4_stg4_ld41_merged1784_779;
  stg4_stg4_1_merged1808_796_to_stg4_stg4_ld41_merged1784_780_cache stg4_stg4_1_merged1808_796_to_stg4_stg4_ld41_merged1784_780;
  stg4_stg4_1_merged1808_797_to_stg4_stg4_ld41_merged1784_781_cache stg4_stg4_1_merged1808_797_to_stg4_stg4_ld41_merged1784_781;
  stg4_stg4_1_merged1808_798_to_stg4_stg4_ld41_merged1784_782_cache stg4_stg4_1_merged1808_798_to_stg4_stg4_ld41_merged1784_782;
  stg4_stg4_1_merged1808_799_to_stg4_stg4_ld41_merged1784_783_cache stg4_stg4_1_merged1808_799_to_stg4_stg4_ld41_merged1784_783;
};



inline void stg4_stg4_1_merged1808_784_write(hw_uint<16>& stg4_stg4_1_merged1808_784, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_784_to_stg4_stg4_ld41_merged1784_768.push(stg4_stg4_1_merged1808_784);
}

inline void stg4_stg4_1_merged1808_785_write(hw_uint<16>& stg4_stg4_1_merged1808_785, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_785_to_stg4_stg4_ld41_merged1784_769.push(stg4_stg4_1_merged1808_785);
}

inline void stg4_stg4_1_merged1808_786_write(hw_uint<16>& stg4_stg4_1_merged1808_786, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_786_to_stg4_stg4_ld41_merged1784_770.push(stg4_stg4_1_merged1808_786);
}

inline void stg4_stg4_1_merged1808_787_write(hw_uint<16>& stg4_stg4_1_merged1808_787, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_787_to_stg4_stg4_ld41_merged1784_771.push(stg4_stg4_1_merged1808_787);
}

inline void stg4_stg4_1_merged1808_788_write(hw_uint<16>& stg4_stg4_1_merged1808_788, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_788_to_stg4_stg4_ld41_merged1784_772.push(stg4_stg4_1_merged1808_788);
}

inline void stg4_stg4_1_merged1808_789_write(hw_uint<16>& stg4_stg4_1_merged1808_789, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_789_to_stg4_stg4_ld41_merged1784_773.push(stg4_stg4_1_merged1808_789);
}

inline void stg4_stg4_1_merged1808_790_write(hw_uint<16>& stg4_stg4_1_merged1808_790, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_790_to_stg4_stg4_ld41_merged1784_774.push(stg4_stg4_1_merged1808_790);
}

inline void stg4_stg4_1_merged1808_791_write(hw_uint<16>& stg4_stg4_1_merged1808_791, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_791_to_stg4_stg4_ld41_merged1784_775.push(stg4_stg4_1_merged1808_791);
}

inline void stg4_stg4_1_merged1808_792_write(hw_uint<16>& stg4_stg4_1_merged1808_792, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_792_to_stg4_stg4_ld41_merged1784_776.push(stg4_stg4_1_merged1808_792);
}

inline void stg4_stg4_1_merged1808_793_write(hw_uint<16>& stg4_stg4_1_merged1808_793, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_793_to_stg4_stg4_ld41_merged1784_777.push(stg4_stg4_1_merged1808_793);
}

inline void stg4_stg4_1_merged1808_794_write(hw_uint<16>& stg4_stg4_1_merged1808_794, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_794_to_stg4_stg4_ld41_merged1784_778.push(stg4_stg4_1_merged1808_794);
}

inline void stg4_stg4_1_merged1808_795_write(hw_uint<16>& stg4_stg4_1_merged1808_795, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_795_to_stg4_stg4_ld41_merged1784_779.push(stg4_stg4_1_merged1808_795);
}

inline void stg4_stg4_1_merged1808_796_write(hw_uint<16>& stg4_stg4_1_merged1808_796, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_796_to_stg4_stg4_ld41_merged1784_780.push(stg4_stg4_1_merged1808_796);
}

inline void stg4_stg4_1_merged1808_797_write(hw_uint<16>& stg4_stg4_1_merged1808_797, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_797_to_stg4_stg4_ld41_merged1784_781.push(stg4_stg4_1_merged1808_797);
}

inline void stg4_stg4_1_merged1808_798_write(hw_uint<16>& stg4_stg4_1_merged1808_798, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_798_to_stg4_stg4_ld41_merged1784_782.push(stg4_stg4_1_merged1808_798);
}

inline void stg4_stg4_1_merged1808_799_write(hw_uint<16>& stg4_stg4_1_merged1808_799, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
  stg4.stg4_stg4_1_merged1808_799_to_stg4_stg4_ld41_merged1784_783.push(stg4_stg4_1_merged1808_799);
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_768_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_768 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[15 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_784 = stg4.stg4_stg4_1_merged1808_784_to_stg4_stg4_ld41_merged1784_768.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_784;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_769_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_769 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[14 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_785 = stg4.stg4_stg4_1_merged1808_785_to_stg4_stg4_ld41_merged1784_769.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_785;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_770_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_770 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[13 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_786 = stg4.stg4_stg4_1_merged1808_786_to_stg4_stg4_ld41_merged1784_770.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_786;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_771_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_771 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[12 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_787 = stg4.stg4_stg4_1_merged1808_787_to_stg4_stg4_ld41_merged1784_771.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_787;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_772_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_772 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[11 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_788 = stg4.stg4_stg4_1_merged1808_788_to_stg4_stg4_ld41_merged1784_772.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_788;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_773_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_773 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[10 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_789 = stg4.stg4_stg4_1_merged1808_789_to_stg4_stg4_ld41_merged1784_773.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_789;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_774_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_774 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[9 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_790 = stg4.stg4_stg4_1_merged1808_790_to_stg4_stg4_ld41_merged1784_774.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_790;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_775_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_775 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[8 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_791 = stg4.stg4_stg4_1_merged1808_791_to_stg4_stg4_ld41_merged1784_775.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_791;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_776_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_776 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[7 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_792 = stg4.stg4_stg4_1_merged1808_792_to_stg4_stg4_ld41_merged1784_776.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_792;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_777_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_777 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[6 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_793 = stg4.stg4_stg4_1_merged1808_793_to_stg4_stg4_ld41_merged1784_777.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_793;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_778_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_778 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[5 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_794 = stg4.stg4_stg4_1_merged1808_794_to_stg4_stg4_ld41_merged1784_778.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_794;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_779_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_779 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[4 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_795 = stg4.stg4_stg4_1_merged1808_795_to_stg4_stg4_ld41_merged1784_779.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_795;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_780_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_780 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[3 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_796 = stg4.stg4_stg4_1_merged1808_796_to_stg4_stg4_ld41_merged1784_780.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_796;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_781_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_781 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[2 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_797 = stg4.stg4_stg4_1_merged1808_797_to_stg4_stg4_ld41_merged1784_781.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_797;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_782_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_782 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[1 + 16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_798 = stg4.stg4_stg4_1_merged1808_798_to_stg4_stg4_ld41_merged1784_782.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_798;
  return 0;
}

inline hw_uint<16> stg4_stg4_ld41_merged1784_783_select(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_stg4_ld41_merged1784_783 read pattern: { stg4_ld41_merged1784[root = 0, stg4_ld42, stg4_ld41] -> stg4[16stg4_ld41, -10 + stg4_ld42] : 0 <= stg4_ld42 <= 1939 and 0 <= stg4_ld41 <= 77 }
  // Read schedule : { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  // Write schedule: { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_stg4_1_merged1808_799 = stg4.stg4_stg4_1_merged1808_799_to_stg4_stg4_ld41_merged1784_783.peek(/* one reader or all rams */ 0);
  return value_stg4_stg4_1_merged1808_799;
  return 0;
}

// # of bundles = 2
// stg4_1_merged1808_write
//	stg4_stg4_1_merged1808_784
//	stg4_stg4_1_merged1808_785
//	stg4_stg4_1_merged1808_786
//	stg4_stg4_1_merged1808_787
//	stg4_stg4_1_merged1808_788
//	stg4_stg4_1_merged1808_789
//	stg4_stg4_1_merged1808_790
//	stg4_stg4_1_merged1808_791
//	stg4_stg4_1_merged1808_792
//	stg4_stg4_1_merged1808_793
//	stg4_stg4_1_merged1808_794
//	stg4_stg4_1_merged1808_795
//	stg4_stg4_1_merged1808_796
//	stg4_stg4_1_merged1808_797
//	stg4_stg4_1_merged1808_798
//	stg4_stg4_1_merged1808_799
inline void stg4_stg4_1_merged1808_write_bundle_write(hw_uint<256>& stg4_1_merged1808_write, stg4_cache& stg4, int root, int stg4_0, int stg4_1, int dynamic_address) {
	hw_uint<16> stg4_stg4_1_merged1808_784_res = stg4_1_merged1808_write.extract<0, 15>();
	stg4_stg4_1_merged1808_784_write(stg4_stg4_1_merged1808_784_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_785_res = stg4_1_merged1808_write.extract<16, 31>();
	stg4_stg4_1_merged1808_785_write(stg4_stg4_1_merged1808_785_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_786_res = stg4_1_merged1808_write.extract<32, 47>();
	stg4_stg4_1_merged1808_786_write(stg4_stg4_1_merged1808_786_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_787_res = stg4_1_merged1808_write.extract<48, 63>();
	stg4_stg4_1_merged1808_787_write(stg4_stg4_1_merged1808_787_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_788_res = stg4_1_merged1808_write.extract<64, 79>();
	stg4_stg4_1_merged1808_788_write(stg4_stg4_1_merged1808_788_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_789_res = stg4_1_merged1808_write.extract<80, 95>();
	stg4_stg4_1_merged1808_789_write(stg4_stg4_1_merged1808_789_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_790_res = stg4_1_merged1808_write.extract<96, 111>();
	stg4_stg4_1_merged1808_790_write(stg4_stg4_1_merged1808_790_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_791_res = stg4_1_merged1808_write.extract<112, 127>();
	stg4_stg4_1_merged1808_791_write(stg4_stg4_1_merged1808_791_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_792_res = stg4_1_merged1808_write.extract<128, 143>();
	stg4_stg4_1_merged1808_792_write(stg4_stg4_1_merged1808_792_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_793_res = stg4_1_merged1808_write.extract<144, 159>();
	stg4_stg4_1_merged1808_793_write(stg4_stg4_1_merged1808_793_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_794_res = stg4_1_merged1808_write.extract<160, 175>();
	stg4_stg4_1_merged1808_794_write(stg4_stg4_1_merged1808_794_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_795_res = stg4_1_merged1808_write.extract<176, 191>();
	stg4_stg4_1_merged1808_795_write(stg4_stg4_1_merged1808_795_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_796_res = stg4_1_merged1808_write.extract<192, 207>();
	stg4_stg4_1_merged1808_796_write(stg4_stg4_1_merged1808_796_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_797_res = stg4_1_merged1808_write.extract<208, 223>();
	stg4_stg4_1_merged1808_797_write(stg4_stg4_1_merged1808_797_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_798_res = stg4_1_merged1808_write.extract<224, 239>();
	stg4_stg4_1_merged1808_798_write(stg4_stg4_1_merged1808_798_res, stg4, root, stg4_0, stg4_1, dynamic_address);
	hw_uint<16> stg4_stg4_1_merged1808_799_res = stg4_1_merged1808_write.extract<240, 255>();
	stg4_stg4_1_merged1808_799_write(stg4_stg4_1_merged1808_799_res, stg4, root, stg4_0, stg4_1, dynamic_address);
}

// stg4_ld41_merged1784_read
//	stg4_stg4_ld41_merged1784_768
//	stg4_stg4_ld41_merged1784_769
//	stg4_stg4_ld41_merged1784_770
//	stg4_stg4_ld41_merged1784_771
//	stg4_stg4_ld41_merged1784_772
//	stg4_stg4_ld41_merged1784_773
//	stg4_stg4_ld41_merged1784_774
//	stg4_stg4_ld41_merged1784_775
//	stg4_stg4_ld41_merged1784_776
//	stg4_stg4_ld41_merged1784_777
//	stg4_stg4_ld41_merged1784_778
//	stg4_stg4_ld41_merged1784_779
//	stg4_stg4_ld41_merged1784_780
//	stg4_stg4_ld41_merged1784_781
//	stg4_stg4_ld41_merged1784_782
//	stg4_stg4_ld41_merged1784_783
inline hw_uint<256> stg4_stg4_ld41_merged1784_read_bundle_read(stg4_cache& stg4, int root, int stg4_ld42, int stg4_ld41, int dynamic_address) {
  // # of ports in bundle: 16
    // stg4_stg4_ld41_merged1784_768
    // stg4_stg4_ld41_merged1784_769
    // stg4_stg4_ld41_merged1784_770
    // stg4_stg4_ld41_merged1784_771
    // stg4_stg4_ld41_merged1784_772
    // stg4_stg4_ld41_merged1784_773
    // stg4_stg4_ld41_merged1784_774
    // stg4_stg4_ld41_merged1784_775
    // stg4_stg4_ld41_merged1784_776
    // stg4_stg4_ld41_merged1784_777
    // stg4_stg4_ld41_merged1784_778
    // stg4_stg4_ld41_merged1784_779
    // stg4_stg4_ld41_merged1784_780
    // stg4_stg4_ld41_merged1784_781
    // stg4_stg4_ld41_merged1784_782
    // stg4_stg4_ld41_merged1784_783

	hw_uint<256> result;
	hw_uint<16> stg4_stg4_ld41_merged1784_768_res = stg4_stg4_ld41_merged1784_768_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<0, 256>(result, stg4_stg4_ld41_merged1784_768_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_769_res = stg4_stg4_ld41_merged1784_769_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<16, 256>(result, stg4_stg4_ld41_merged1784_769_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_770_res = stg4_stg4_ld41_merged1784_770_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<32, 256>(result, stg4_stg4_ld41_merged1784_770_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_771_res = stg4_stg4_ld41_merged1784_771_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<48, 256>(result, stg4_stg4_ld41_merged1784_771_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_772_res = stg4_stg4_ld41_merged1784_772_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<64, 256>(result, stg4_stg4_ld41_merged1784_772_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_773_res = stg4_stg4_ld41_merged1784_773_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<80, 256>(result, stg4_stg4_ld41_merged1784_773_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_774_res = stg4_stg4_ld41_merged1784_774_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<96, 256>(result, stg4_stg4_ld41_merged1784_774_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_775_res = stg4_stg4_ld41_merged1784_775_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<112, 256>(result, stg4_stg4_ld41_merged1784_775_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_776_res = stg4_stg4_ld41_merged1784_776_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<128, 256>(result, stg4_stg4_ld41_merged1784_776_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_777_res = stg4_stg4_ld41_merged1784_777_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<144, 256>(result, stg4_stg4_ld41_merged1784_777_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_778_res = stg4_stg4_ld41_merged1784_778_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<160, 256>(result, stg4_stg4_ld41_merged1784_778_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_779_res = stg4_stg4_ld41_merged1784_779_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<176, 256>(result, stg4_stg4_ld41_merged1784_779_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_780_res = stg4_stg4_ld41_merged1784_780_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<192, 256>(result, stg4_stg4_ld41_merged1784_780_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_781_res = stg4_stg4_ld41_merged1784_781_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<208, 256>(result, stg4_stg4_ld41_merged1784_781_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_782_res = stg4_stg4_ld41_merged1784_782_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<224, 256>(result, stg4_stg4_ld41_merged1784_782_res);
	hw_uint<16> stg4_stg4_ld41_merged1784_783_res = stg4_stg4_ld41_merged1784_783_select(stg4, root, stg4_ld42, stg4_ld41, dynamic_address);
	set_at<240, 256>(result, stg4_stg4_ld41_merged1784_783_res);
	return result;
}

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_merged_banks_4_cache {
	// RAM Box: {[15, 1231], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_merged_banks_4_cache {
	// RAM Box: {[14, 1230], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_merged_banks_4_cache {
	// RAM Box: {[13, 1229], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_merged_banks_4_cache {
	// RAM Box: {[12, 1228], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_merged_banks_4_cache {
	// RAM Box: {[11, 1227], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_merged_banks_4_cache {
	// RAM Box: {[10, 1226], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_merged_banks_4_cache {
	// RAM Box: {[9, 1225], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_merged_banks_4_cache {
	// RAM Box: {[8, 1224], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_merged_banks_4_cache {
	// RAM Box: {[7, 1223], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_merged_banks_4_cache {
	// RAM Box: {[6, 1222], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_merged_banks_4_cache {
	// RAM Box: {[5, 1221], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_merged_banks_4_cache {
	// RAM Box: {[4, 1220], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_merged_banks_4_cache {
	// RAM Box: {[3, 1219], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_merged_banks_4_cache {
	// RAM Box: {[2, 1218], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_merged_banks_4_cache {
	// RAM Box: {[1, 1217], [-10, 1929]}
	// Capacity: 158
	// # of read delays: 4
  // 0, 1, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 77> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 77> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_78() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_79() {
		return f4;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_157() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_merged_banks_4_cache {
	// RAM Box: {[0, 1232], [-10, 1928]}
	// Capacity: 158
	// # of read delays: 5
  // 0, 1, 78, 79, 157
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 77> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_79() {
		return f6;
	}

	inline hw_uint<16> peek_156() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_157() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 77
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 77 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg4_FIFO_buf104_cache {
  // Reader addrs...
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[15 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[15 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[16 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[15 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[14 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[14 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[15 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[14 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[13 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[13 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[14 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[13 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[12 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[12 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[13 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[12 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[11 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[11 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[12 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[11 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[10 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[10 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[11 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[10 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[9 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[9 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[10 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[9 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[8 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[8 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[9 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[8 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[7 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[7 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[8 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[7 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[6 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[6 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[7 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[6 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[5 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[5 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[6 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[5 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[4 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[4 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[5 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[4 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[3 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[3 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[4 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[3 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[2 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[2 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[3 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[2 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[1 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[1 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[2 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[1 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[1 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
    // { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // # of banks: 16
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_merged_banks_4;
  stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_merged_banks_4_cache stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_merged_banks_4;
};



inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734);
}

inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_write(hw_uint<16>& stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
  stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_merged_banks_4.push(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735);
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_656_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_656 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[15 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_657_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_657 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[15 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_658_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_658 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[16 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_merged_banks_4.peek_78();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_659_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_659 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[15 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_660_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_660 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[14 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_661_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_661 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[14 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_662_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_662 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[15 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_663_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_663 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[14 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_664_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_664 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[13 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_665_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_665 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[13 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_666_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_666 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[14 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_667_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_667 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[13 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_668_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_668 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[12 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_669_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_669 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[12 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_670_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_670 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[13 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_671_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_671 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[12 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_672_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_672 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[11 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_673_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_673 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[11 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_674_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_674 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[12 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_675_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_675 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[11 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_676_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_676 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[10 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_677_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_677 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[10 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_678_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_678 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[11 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_679_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_679 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[10 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_680_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_680 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[9 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_681_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_681 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[9 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_682_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_682 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[10 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_683_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_683 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[9 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_684_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_684 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[8 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_685_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_685 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[8 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_686_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_686 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[9 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_687_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_687 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[8 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_688_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_688 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[7 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_689_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_689 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[7 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_690_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_690 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[8 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_691_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_691 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[7 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_692_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_692 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[6 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_693_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_693 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[6 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_694_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_694 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[7 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_695_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_695 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[6 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_696_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_696 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[5 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_697_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_697 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[5 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_698_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_698 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[6 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_699_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_699 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[5 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_700_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_700 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[4 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_701_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_701 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[4 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_702_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_702 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[5 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_703_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_703 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[4 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_704_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_704 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[3 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_705_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_705 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[3 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_706_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_706 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[4 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_707_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_707 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[3 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_708_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_708 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[2 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_709_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_709 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[2 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_710_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_710 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[3 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_711_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_711 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[2 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_712_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_712 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[1 + 16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_713_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_713 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[1 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_714_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_714 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[2 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_715_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_715 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[1 + 16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_716_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_716 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[16stg5_1, -10 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_merged_banks_4.peek_157();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_717_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_717 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_718_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_718 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[1 + 16stg5_1, -9 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_merged_banks_4.peek_79();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734;
  return 0;
}

inline hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_719_select(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg4_FIFO_buf104_stg5_1_merged1811_719 read pattern: { stg5_1_merged1811[root = 0, stg5_0, stg5_1] -> stg4_FIFO_buf104[16stg5_1, -8 + stg5_0] : 0 <= stg5_0 <= 1937 and 0 <= stg5_1 <= 76 }
  // Read schedule : { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
  auto value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735 = stg4_FIFO_buf104.stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_merged_banks_4.peek_1();
  return value_stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735;
  return 0;
}

// # of bundles = 2
// stg4_to_gp_1240_ld105_merged1758_write
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734
//	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735
inline void stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_write_bundle_write(hw_uint<256>& stg4_to_gp_1240_ld105_merged1758_write, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg4_to_gp_1240_ld106, int stg4_to_gp_1240_ld105, int dynamic_address) {
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_res = stg4_to_gp_1240_ld105_merged1758_write.extract<0, 15>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_720_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_res = stg4_to_gp_1240_ld105_merged1758_write.extract<16, 31>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_721_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_res = stg4_to_gp_1240_ld105_merged1758_write.extract<32, 47>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_722_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_res = stg4_to_gp_1240_ld105_merged1758_write.extract<48, 63>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_723_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_res = stg4_to_gp_1240_ld105_merged1758_write.extract<64, 79>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_724_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_res = stg4_to_gp_1240_ld105_merged1758_write.extract<80, 95>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_725_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_res = stg4_to_gp_1240_ld105_merged1758_write.extract<96, 111>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_726_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_res = stg4_to_gp_1240_ld105_merged1758_write.extract<112, 127>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_727_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_res = stg4_to_gp_1240_ld105_merged1758_write.extract<128, 143>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_728_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_res = stg4_to_gp_1240_ld105_merged1758_write.extract<144, 159>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_729_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_res = stg4_to_gp_1240_ld105_merged1758_write.extract<160, 175>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_730_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_res = stg4_to_gp_1240_ld105_merged1758_write.extract<176, 191>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_731_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_res = stg4_to_gp_1240_ld105_merged1758_write.extract<192, 207>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_732_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_res = stg4_to_gp_1240_ld105_merged1758_write.extract<208, 223>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_733_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_res = stg4_to_gp_1240_ld105_merged1758_write.extract<224, 239>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_734_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
	hw_uint<16> stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_res = stg4_to_gp_1240_ld105_merged1758_write.extract<240, 255>();
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_write(stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_735_res, stg4_FIFO_buf104, root, stg4_to_gp_1240_ld106, stg4_to_gp_1240_ld105, dynamic_address);
}

// stg5_1_merged1811_read
//	stg4_FIFO_buf104_stg5_1_merged1811_656
//	stg4_FIFO_buf104_stg5_1_merged1811_657
//	stg4_FIFO_buf104_stg5_1_merged1811_658
//	stg4_FIFO_buf104_stg5_1_merged1811_659
//	stg4_FIFO_buf104_stg5_1_merged1811_660
//	stg4_FIFO_buf104_stg5_1_merged1811_661
//	stg4_FIFO_buf104_stg5_1_merged1811_662
//	stg4_FIFO_buf104_stg5_1_merged1811_663
//	stg4_FIFO_buf104_stg5_1_merged1811_664
//	stg4_FIFO_buf104_stg5_1_merged1811_665
//	stg4_FIFO_buf104_stg5_1_merged1811_666
//	stg4_FIFO_buf104_stg5_1_merged1811_667
//	stg4_FIFO_buf104_stg5_1_merged1811_668
//	stg4_FIFO_buf104_stg5_1_merged1811_669
//	stg4_FIFO_buf104_stg5_1_merged1811_670
//	stg4_FIFO_buf104_stg5_1_merged1811_671
//	stg4_FIFO_buf104_stg5_1_merged1811_672
//	stg4_FIFO_buf104_stg5_1_merged1811_673
//	stg4_FIFO_buf104_stg5_1_merged1811_674
//	stg4_FIFO_buf104_stg5_1_merged1811_675
//	stg4_FIFO_buf104_stg5_1_merged1811_676
//	stg4_FIFO_buf104_stg5_1_merged1811_677
//	stg4_FIFO_buf104_stg5_1_merged1811_678
//	stg4_FIFO_buf104_stg5_1_merged1811_679
//	stg4_FIFO_buf104_stg5_1_merged1811_680
//	stg4_FIFO_buf104_stg5_1_merged1811_681
//	stg4_FIFO_buf104_stg5_1_merged1811_682
//	stg4_FIFO_buf104_stg5_1_merged1811_683
//	stg4_FIFO_buf104_stg5_1_merged1811_684
//	stg4_FIFO_buf104_stg5_1_merged1811_685
//	stg4_FIFO_buf104_stg5_1_merged1811_686
//	stg4_FIFO_buf104_stg5_1_merged1811_687
//	stg4_FIFO_buf104_stg5_1_merged1811_688
//	stg4_FIFO_buf104_stg5_1_merged1811_689
//	stg4_FIFO_buf104_stg5_1_merged1811_690
//	stg4_FIFO_buf104_stg5_1_merged1811_691
//	stg4_FIFO_buf104_stg5_1_merged1811_692
//	stg4_FIFO_buf104_stg5_1_merged1811_693
//	stg4_FIFO_buf104_stg5_1_merged1811_694
//	stg4_FIFO_buf104_stg5_1_merged1811_695
//	stg4_FIFO_buf104_stg5_1_merged1811_696
//	stg4_FIFO_buf104_stg5_1_merged1811_697
//	stg4_FIFO_buf104_stg5_1_merged1811_698
//	stg4_FIFO_buf104_stg5_1_merged1811_699
//	stg4_FIFO_buf104_stg5_1_merged1811_700
//	stg4_FIFO_buf104_stg5_1_merged1811_701
//	stg4_FIFO_buf104_stg5_1_merged1811_702
//	stg4_FIFO_buf104_stg5_1_merged1811_703
//	stg4_FIFO_buf104_stg5_1_merged1811_704
//	stg4_FIFO_buf104_stg5_1_merged1811_705
//	stg4_FIFO_buf104_stg5_1_merged1811_706
//	stg4_FIFO_buf104_stg5_1_merged1811_707
//	stg4_FIFO_buf104_stg5_1_merged1811_708
//	stg4_FIFO_buf104_stg5_1_merged1811_709
//	stg4_FIFO_buf104_stg5_1_merged1811_710
//	stg4_FIFO_buf104_stg5_1_merged1811_711
//	stg4_FIFO_buf104_stg5_1_merged1811_712
//	stg4_FIFO_buf104_stg5_1_merged1811_713
//	stg4_FIFO_buf104_stg5_1_merged1811_714
//	stg4_FIFO_buf104_stg5_1_merged1811_715
//	stg4_FIFO_buf104_stg5_1_merged1811_716
//	stg4_FIFO_buf104_stg5_1_merged1811_717
//	stg4_FIFO_buf104_stg5_1_merged1811_718
//	stg4_FIFO_buf104_stg5_1_merged1811_719
inline hw_uint<1024> stg4_FIFO_buf104_stg5_1_merged1811_read_bundle_read(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int root, int stg5_0, int stg5_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg4_FIFO_buf104_stg5_1_merged1811_656
    // stg4_FIFO_buf104_stg5_1_merged1811_657
    // stg4_FIFO_buf104_stg5_1_merged1811_658
    // stg4_FIFO_buf104_stg5_1_merged1811_659
    // stg4_FIFO_buf104_stg5_1_merged1811_660
    // stg4_FIFO_buf104_stg5_1_merged1811_661
    // stg4_FIFO_buf104_stg5_1_merged1811_662
    // stg4_FIFO_buf104_stg5_1_merged1811_663
    // stg4_FIFO_buf104_stg5_1_merged1811_664
    // stg4_FIFO_buf104_stg5_1_merged1811_665
    // stg4_FIFO_buf104_stg5_1_merged1811_666
    // stg4_FIFO_buf104_stg5_1_merged1811_667
    // stg4_FIFO_buf104_stg5_1_merged1811_668
    // stg4_FIFO_buf104_stg5_1_merged1811_669
    // stg4_FIFO_buf104_stg5_1_merged1811_670
    // stg4_FIFO_buf104_stg5_1_merged1811_671
    // stg4_FIFO_buf104_stg5_1_merged1811_672
    // stg4_FIFO_buf104_stg5_1_merged1811_673
    // stg4_FIFO_buf104_stg5_1_merged1811_674
    // stg4_FIFO_buf104_stg5_1_merged1811_675
    // stg4_FIFO_buf104_stg5_1_merged1811_676
    // stg4_FIFO_buf104_stg5_1_merged1811_677
    // stg4_FIFO_buf104_stg5_1_merged1811_678
    // stg4_FIFO_buf104_stg5_1_merged1811_679
    // stg4_FIFO_buf104_stg5_1_merged1811_680
    // stg4_FIFO_buf104_stg5_1_merged1811_681
    // stg4_FIFO_buf104_stg5_1_merged1811_682
    // stg4_FIFO_buf104_stg5_1_merged1811_683
    // stg4_FIFO_buf104_stg5_1_merged1811_684
    // stg4_FIFO_buf104_stg5_1_merged1811_685
    // stg4_FIFO_buf104_stg5_1_merged1811_686
    // stg4_FIFO_buf104_stg5_1_merged1811_687
    // stg4_FIFO_buf104_stg5_1_merged1811_688
    // stg4_FIFO_buf104_stg5_1_merged1811_689
    // stg4_FIFO_buf104_stg5_1_merged1811_690
    // stg4_FIFO_buf104_stg5_1_merged1811_691
    // stg4_FIFO_buf104_stg5_1_merged1811_692
    // stg4_FIFO_buf104_stg5_1_merged1811_693
    // stg4_FIFO_buf104_stg5_1_merged1811_694
    // stg4_FIFO_buf104_stg5_1_merged1811_695
    // stg4_FIFO_buf104_stg5_1_merged1811_696
    // stg4_FIFO_buf104_stg5_1_merged1811_697
    // stg4_FIFO_buf104_stg5_1_merged1811_698
    // stg4_FIFO_buf104_stg5_1_merged1811_699
    // stg4_FIFO_buf104_stg5_1_merged1811_700
    // stg4_FIFO_buf104_stg5_1_merged1811_701
    // stg4_FIFO_buf104_stg5_1_merged1811_702
    // stg4_FIFO_buf104_stg5_1_merged1811_703
    // stg4_FIFO_buf104_stg5_1_merged1811_704
    // stg4_FIFO_buf104_stg5_1_merged1811_705
    // stg4_FIFO_buf104_stg5_1_merged1811_706
    // stg4_FIFO_buf104_stg5_1_merged1811_707
    // stg4_FIFO_buf104_stg5_1_merged1811_708
    // stg4_FIFO_buf104_stg5_1_merged1811_709
    // stg4_FIFO_buf104_stg5_1_merged1811_710
    // stg4_FIFO_buf104_stg5_1_merged1811_711
    // stg4_FIFO_buf104_stg5_1_merged1811_712
    // stg4_FIFO_buf104_stg5_1_merged1811_713
    // stg4_FIFO_buf104_stg5_1_merged1811_714
    // stg4_FIFO_buf104_stg5_1_merged1811_715
    // stg4_FIFO_buf104_stg5_1_merged1811_716
    // stg4_FIFO_buf104_stg5_1_merged1811_717
    // stg4_FIFO_buf104_stg5_1_merged1811_718
    // stg4_FIFO_buf104_stg5_1_merged1811_719

	hw_uint<1024> result;
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_656_res = stg4_FIFO_buf104_stg5_1_merged1811_656_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<0, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_656_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_657_res = stg4_FIFO_buf104_stg5_1_merged1811_657_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<16, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_657_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_658_res = stg4_FIFO_buf104_stg5_1_merged1811_658_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<32, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_658_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_659_res = stg4_FIFO_buf104_stg5_1_merged1811_659_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<48, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_659_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_660_res = stg4_FIFO_buf104_stg5_1_merged1811_660_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<64, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_660_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_661_res = stg4_FIFO_buf104_stg5_1_merged1811_661_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<80, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_661_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_662_res = stg4_FIFO_buf104_stg5_1_merged1811_662_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<96, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_662_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_663_res = stg4_FIFO_buf104_stg5_1_merged1811_663_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<112, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_663_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_664_res = stg4_FIFO_buf104_stg5_1_merged1811_664_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<128, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_664_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_665_res = stg4_FIFO_buf104_stg5_1_merged1811_665_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<144, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_665_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_666_res = stg4_FIFO_buf104_stg5_1_merged1811_666_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<160, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_666_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_667_res = stg4_FIFO_buf104_stg5_1_merged1811_667_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<176, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_667_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_668_res = stg4_FIFO_buf104_stg5_1_merged1811_668_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<192, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_668_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_669_res = stg4_FIFO_buf104_stg5_1_merged1811_669_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<208, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_669_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_670_res = stg4_FIFO_buf104_stg5_1_merged1811_670_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<224, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_670_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_671_res = stg4_FIFO_buf104_stg5_1_merged1811_671_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<240, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_671_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_672_res = stg4_FIFO_buf104_stg5_1_merged1811_672_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<256, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_672_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_673_res = stg4_FIFO_buf104_stg5_1_merged1811_673_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<272, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_673_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_674_res = stg4_FIFO_buf104_stg5_1_merged1811_674_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<288, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_674_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_675_res = stg4_FIFO_buf104_stg5_1_merged1811_675_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<304, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_675_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_676_res = stg4_FIFO_buf104_stg5_1_merged1811_676_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<320, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_676_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_677_res = stg4_FIFO_buf104_stg5_1_merged1811_677_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<336, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_677_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_678_res = stg4_FIFO_buf104_stg5_1_merged1811_678_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<352, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_678_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_679_res = stg4_FIFO_buf104_stg5_1_merged1811_679_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<368, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_679_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_680_res = stg4_FIFO_buf104_stg5_1_merged1811_680_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<384, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_680_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_681_res = stg4_FIFO_buf104_stg5_1_merged1811_681_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<400, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_681_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_682_res = stg4_FIFO_buf104_stg5_1_merged1811_682_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<416, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_682_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_683_res = stg4_FIFO_buf104_stg5_1_merged1811_683_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<432, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_683_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_684_res = stg4_FIFO_buf104_stg5_1_merged1811_684_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<448, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_684_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_685_res = stg4_FIFO_buf104_stg5_1_merged1811_685_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<464, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_685_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_686_res = stg4_FIFO_buf104_stg5_1_merged1811_686_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<480, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_686_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_687_res = stg4_FIFO_buf104_stg5_1_merged1811_687_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<496, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_687_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_688_res = stg4_FIFO_buf104_stg5_1_merged1811_688_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<512, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_688_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_689_res = stg4_FIFO_buf104_stg5_1_merged1811_689_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<528, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_689_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_690_res = stg4_FIFO_buf104_stg5_1_merged1811_690_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<544, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_690_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_691_res = stg4_FIFO_buf104_stg5_1_merged1811_691_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<560, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_691_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_692_res = stg4_FIFO_buf104_stg5_1_merged1811_692_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<576, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_692_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_693_res = stg4_FIFO_buf104_stg5_1_merged1811_693_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<592, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_693_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_694_res = stg4_FIFO_buf104_stg5_1_merged1811_694_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<608, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_694_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_695_res = stg4_FIFO_buf104_stg5_1_merged1811_695_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<624, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_695_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_696_res = stg4_FIFO_buf104_stg5_1_merged1811_696_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<640, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_696_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_697_res = stg4_FIFO_buf104_stg5_1_merged1811_697_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<656, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_697_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_698_res = stg4_FIFO_buf104_stg5_1_merged1811_698_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<672, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_698_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_699_res = stg4_FIFO_buf104_stg5_1_merged1811_699_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<688, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_699_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_700_res = stg4_FIFO_buf104_stg5_1_merged1811_700_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<704, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_700_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_701_res = stg4_FIFO_buf104_stg5_1_merged1811_701_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<720, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_701_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_702_res = stg4_FIFO_buf104_stg5_1_merged1811_702_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<736, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_702_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_703_res = stg4_FIFO_buf104_stg5_1_merged1811_703_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<752, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_703_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_704_res = stg4_FIFO_buf104_stg5_1_merged1811_704_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<768, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_704_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_705_res = stg4_FIFO_buf104_stg5_1_merged1811_705_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<784, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_705_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_706_res = stg4_FIFO_buf104_stg5_1_merged1811_706_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<800, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_706_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_707_res = stg4_FIFO_buf104_stg5_1_merged1811_707_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<816, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_707_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_708_res = stg4_FIFO_buf104_stg5_1_merged1811_708_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<832, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_708_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_709_res = stg4_FIFO_buf104_stg5_1_merged1811_709_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<848, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_709_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_710_res = stg4_FIFO_buf104_stg5_1_merged1811_710_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<864, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_710_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_711_res = stg4_FIFO_buf104_stg5_1_merged1811_711_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<880, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_711_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_712_res = stg4_FIFO_buf104_stg5_1_merged1811_712_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<896, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_712_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_713_res = stg4_FIFO_buf104_stg5_1_merged1811_713_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<912, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_713_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_714_res = stg4_FIFO_buf104_stg5_1_merged1811_714_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<928, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_714_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_715_res = stg4_FIFO_buf104_stg5_1_merged1811_715_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<944, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_715_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_716_res = stg4_FIFO_buf104_stg5_1_merged1811_716_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<960, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_716_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_717_res = stg4_FIFO_buf104_stg5_1_merged1811_717_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<976, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_717_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_718_res = stg4_FIFO_buf104_stg5_1_merged1811_718_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<992, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_718_res);
	hw_uint<16> stg4_FIFO_buf104_stg5_1_merged1811_719_res = stg4_FIFO_buf104_stg5_1_merged1811_719_select(stg4_FIFO_buf104, root, stg5_0, stg5_1, dynamic_address);
	set_at<1008, 1024>(result, stg4_FIFO_buf104_stg5_1_merged1811_719_res);
	return result;
}

struct stg5_stg5_1_merged1811_640_to_stg5_stg5_ld45_merged1853_624_cache {
	// RAM Box: {[15, 1231], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_641_to_stg5_stg5_ld45_merged1853_625_cache {
	// RAM Box: {[14, 1230], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_642_to_stg5_stg5_ld45_merged1853_626_cache {
	// RAM Box: {[13, 1229], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_643_to_stg5_stg5_ld45_merged1853_627_cache {
	// RAM Box: {[12, 1228], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_644_to_stg5_stg5_ld45_merged1853_628_cache {
	// RAM Box: {[11, 1227], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_645_to_stg5_stg5_ld45_merged1853_629_cache {
	// RAM Box: {[10, 1226], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_646_to_stg5_stg5_ld45_merged1853_630_cache {
	// RAM Box: {[9, 1225], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_647_to_stg5_stg5_ld45_merged1853_631_cache {
	// RAM Box: {[8, 1224], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_648_to_stg5_stg5_ld45_merged1853_632_cache {
	// RAM Box: {[7, 1223], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_649_to_stg5_stg5_ld45_merged1853_633_cache {
	// RAM Box: {[6, 1222], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_650_to_stg5_stg5_ld45_merged1853_634_cache {
	// RAM Box: {[5, 1221], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_651_to_stg5_stg5_ld45_merged1853_635_cache {
	// RAM Box: {[4, 1220], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_652_to_stg5_stg5_ld45_merged1853_636_cache {
	// RAM Box: {[3, 1219], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_653_to_stg5_stg5_ld45_merged1853_637_cache {
	// RAM Box: {[2, 1218], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_654_to_stg5_stg5_ld45_merged1853_638_cache {
	// RAM Box: {[1, 1217], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_stg5_1_merged1811_655_to_stg5_stg5_ld45_merged1853_639_cache {
	// RAM Box: {[0, 1216], [-9, 1928]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg5_cache {
  // Reader addrs...
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[15 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[14 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[13 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[12 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[11 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[10 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[9 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[8 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[7 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[6 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[5 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[4 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[3 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[2 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[1 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
    // { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // # of banks: 16
  stg5_stg5_1_merged1811_640_to_stg5_stg5_ld45_merged1853_624_cache stg5_stg5_1_merged1811_640_to_stg5_stg5_ld45_merged1853_624;
  stg5_stg5_1_merged1811_641_to_stg5_stg5_ld45_merged1853_625_cache stg5_stg5_1_merged1811_641_to_stg5_stg5_ld45_merged1853_625;
  stg5_stg5_1_merged1811_642_to_stg5_stg5_ld45_merged1853_626_cache stg5_stg5_1_merged1811_642_to_stg5_stg5_ld45_merged1853_626;
  stg5_stg5_1_merged1811_643_to_stg5_stg5_ld45_merged1853_627_cache stg5_stg5_1_merged1811_643_to_stg5_stg5_ld45_merged1853_627;
  stg5_stg5_1_merged1811_644_to_stg5_stg5_ld45_merged1853_628_cache stg5_stg5_1_merged1811_644_to_stg5_stg5_ld45_merged1853_628;
  stg5_stg5_1_merged1811_645_to_stg5_stg5_ld45_merged1853_629_cache stg5_stg5_1_merged1811_645_to_stg5_stg5_ld45_merged1853_629;
  stg5_stg5_1_merged1811_646_to_stg5_stg5_ld45_merged1853_630_cache stg5_stg5_1_merged1811_646_to_stg5_stg5_ld45_merged1853_630;
  stg5_stg5_1_merged1811_647_to_stg5_stg5_ld45_merged1853_631_cache stg5_stg5_1_merged1811_647_to_stg5_stg5_ld45_merged1853_631;
  stg5_stg5_1_merged1811_648_to_stg5_stg5_ld45_merged1853_632_cache stg5_stg5_1_merged1811_648_to_stg5_stg5_ld45_merged1853_632;
  stg5_stg5_1_merged1811_649_to_stg5_stg5_ld45_merged1853_633_cache stg5_stg5_1_merged1811_649_to_stg5_stg5_ld45_merged1853_633;
  stg5_stg5_1_merged1811_650_to_stg5_stg5_ld45_merged1853_634_cache stg5_stg5_1_merged1811_650_to_stg5_stg5_ld45_merged1853_634;
  stg5_stg5_1_merged1811_651_to_stg5_stg5_ld45_merged1853_635_cache stg5_stg5_1_merged1811_651_to_stg5_stg5_ld45_merged1853_635;
  stg5_stg5_1_merged1811_652_to_stg5_stg5_ld45_merged1853_636_cache stg5_stg5_1_merged1811_652_to_stg5_stg5_ld45_merged1853_636;
  stg5_stg5_1_merged1811_653_to_stg5_stg5_ld45_merged1853_637_cache stg5_stg5_1_merged1811_653_to_stg5_stg5_ld45_merged1853_637;
  stg5_stg5_1_merged1811_654_to_stg5_stg5_ld45_merged1853_638_cache stg5_stg5_1_merged1811_654_to_stg5_stg5_ld45_merged1853_638;
  stg5_stg5_1_merged1811_655_to_stg5_stg5_ld45_merged1853_639_cache stg5_stg5_1_merged1811_655_to_stg5_stg5_ld45_merged1853_639;
};



inline void stg5_stg5_1_merged1811_640_write(hw_uint<16>& stg5_stg5_1_merged1811_640, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_640_to_stg5_stg5_ld45_merged1853_624.push(stg5_stg5_1_merged1811_640);
}

inline void stg5_stg5_1_merged1811_641_write(hw_uint<16>& stg5_stg5_1_merged1811_641, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_641_to_stg5_stg5_ld45_merged1853_625.push(stg5_stg5_1_merged1811_641);
}

inline void stg5_stg5_1_merged1811_642_write(hw_uint<16>& stg5_stg5_1_merged1811_642, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_642_to_stg5_stg5_ld45_merged1853_626.push(stg5_stg5_1_merged1811_642);
}

inline void stg5_stg5_1_merged1811_643_write(hw_uint<16>& stg5_stg5_1_merged1811_643, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_643_to_stg5_stg5_ld45_merged1853_627.push(stg5_stg5_1_merged1811_643);
}

inline void stg5_stg5_1_merged1811_644_write(hw_uint<16>& stg5_stg5_1_merged1811_644, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_644_to_stg5_stg5_ld45_merged1853_628.push(stg5_stg5_1_merged1811_644);
}

inline void stg5_stg5_1_merged1811_645_write(hw_uint<16>& stg5_stg5_1_merged1811_645, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_645_to_stg5_stg5_ld45_merged1853_629.push(stg5_stg5_1_merged1811_645);
}

inline void stg5_stg5_1_merged1811_646_write(hw_uint<16>& stg5_stg5_1_merged1811_646, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_646_to_stg5_stg5_ld45_merged1853_630.push(stg5_stg5_1_merged1811_646);
}

inline void stg5_stg5_1_merged1811_647_write(hw_uint<16>& stg5_stg5_1_merged1811_647, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_647_to_stg5_stg5_ld45_merged1853_631.push(stg5_stg5_1_merged1811_647);
}

inline void stg5_stg5_1_merged1811_648_write(hw_uint<16>& stg5_stg5_1_merged1811_648, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_648_to_stg5_stg5_ld45_merged1853_632.push(stg5_stg5_1_merged1811_648);
}

inline void stg5_stg5_1_merged1811_649_write(hw_uint<16>& stg5_stg5_1_merged1811_649, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_649_to_stg5_stg5_ld45_merged1853_633.push(stg5_stg5_1_merged1811_649);
}

inline void stg5_stg5_1_merged1811_650_write(hw_uint<16>& stg5_stg5_1_merged1811_650, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_650_to_stg5_stg5_ld45_merged1853_634.push(stg5_stg5_1_merged1811_650);
}

inline void stg5_stg5_1_merged1811_651_write(hw_uint<16>& stg5_stg5_1_merged1811_651, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_651_to_stg5_stg5_ld45_merged1853_635.push(stg5_stg5_1_merged1811_651);
}

inline void stg5_stg5_1_merged1811_652_write(hw_uint<16>& stg5_stg5_1_merged1811_652, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_652_to_stg5_stg5_ld45_merged1853_636.push(stg5_stg5_1_merged1811_652);
}

inline void stg5_stg5_1_merged1811_653_write(hw_uint<16>& stg5_stg5_1_merged1811_653, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_653_to_stg5_stg5_ld45_merged1853_637.push(stg5_stg5_1_merged1811_653);
}

inline void stg5_stg5_1_merged1811_654_write(hw_uint<16>& stg5_stg5_1_merged1811_654, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_654_to_stg5_stg5_ld45_merged1853_638.push(stg5_stg5_1_merged1811_654);
}

inline void stg5_stg5_1_merged1811_655_write(hw_uint<16>& stg5_stg5_1_merged1811_655, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
  stg5.stg5_stg5_1_merged1811_655_to_stg5_stg5_ld45_merged1853_639.push(stg5_stg5_1_merged1811_655);
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_624_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_624 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[15 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_640 = stg5.stg5_stg5_1_merged1811_640_to_stg5_stg5_ld45_merged1853_624.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_640;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_625_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_625 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[14 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_641 = stg5.stg5_stg5_1_merged1811_641_to_stg5_stg5_ld45_merged1853_625.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_641;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_626_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_626 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[13 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_642 = stg5.stg5_stg5_1_merged1811_642_to_stg5_stg5_ld45_merged1853_626.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_642;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_627_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_627 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[12 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_643 = stg5.stg5_stg5_1_merged1811_643_to_stg5_stg5_ld45_merged1853_627.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_643;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_628_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_628 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[11 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_644 = stg5.stg5_stg5_1_merged1811_644_to_stg5_stg5_ld45_merged1853_628.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_644;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_629_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_629 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[10 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_645 = stg5.stg5_stg5_1_merged1811_645_to_stg5_stg5_ld45_merged1853_629.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_645;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_630_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_630 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[9 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_646 = stg5.stg5_stg5_1_merged1811_646_to_stg5_stg5_ld45_merged1853_630.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_646;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_631_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_631 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[8 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_647 = stg5.stg5_stg5_1_merged1811_647_to_stg5_stg5_ld45_merged1853_631.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_647;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_632_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_632 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[7 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_648 = stg5.stg5_stg5_1_merged1811_648_to_stg5_stg5_ld45_merged1853_632.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_648;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_633_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_633 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[6 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_649 = stg5.stg5_stg5_1_merged1811_649_to_stg5_stg5_ld45_merged1853_633.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_649;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_634_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_634 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[5 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_650 = stg5.stg5_stg5_1_merged1811_650_to_stg5_stg5_ld45_merged1853_634.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_650;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_635_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_635 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[4 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_651 = stg5.stg5_stg5_1_merged1811_651_to_stg5_stg5_ld45_merged1853_635.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_651;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_636_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_636 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[3 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_652 = stg5.stg5_stg5_1_merged1811_652_to_stg5_stg5_ld45_merged1853_636.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_652;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_637_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_637 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[2 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_653 = stg5.stg5_stg5_1_merged1811_653_to_stg5_stg5_ld45_merged1853_637.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_653;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_638_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_638 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[1 + 16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_654 = stg5.stg5_stg5_1_merged1811_654_to_stg5_stg5_ld45_merged1853_638.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_654;
  return 0;
}

inline hw_uint<16> stg5_stg5_ld45_merged1853_639_select(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_stg5_ld45_merged1853_639 read pattern: { stg5_ld45_merged1853[root = 0, stg5_ld46, stg5_ld45] -> stg5[16stg5_ld45, -9 + stg5_ld46] : 0 <= stg5_ld46 <= 1937 and 0 <= stg5_ld45 <= 76 }
  // Read schedule : { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  // Write schedule: { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_stg5_1_merged1811_655 = stg5.stg5_stg5_1_merged1811_655_to_stg5_stg5_ld45_merged1853_639.peek(/* one reader or all rams */ 0);
  return value_stg5_stg5_1_merged1811_655;
  return 0;
}

// # of bundles = 2
// stg5_1_merged1811_write
//	stg5_stg5_1_merged1811_640
//	stg5_stg5_1_merged1811_641
//	stg5_stg5_1_merged1811_642
//	stg5_stg5_1_merged1811_643
//	stg5_stg5_1_merged1811_644
//	stg5_stg5_1_merged1811_645
//	stg5_stg5_1_merged1811_646
//	stg5_stg5_1_merged1811_647
//	stg5_stg5_1_merged1811_648
//	stg5_stg5_1_merged1811_649
//	stg5_stg5_1_merged1811_650
//	stg5_stg5_1_merged1811_651
//	stg5_stg5_1_merged1811_652
//	stg5_stg5_1_merged1811_653
//	stg5_stg5_1_merged1811_654
//	stg5_stg5_1_merged1811_655
inline void stg5_stg5_1_merged1811_write_bundle_write(hw_uint<256>& stg5_1_merged1811_write, stg5_cache& stg5, int root, int stg5_0, int stg5_1, int dynamic_address) {
	hw_uint<16> stg5_stg5_1_merged1811_640_res = stg5_1_merged1811_write.extract<0, 15>();
	stg5_stg5_1_merged1811_640_write(stg5_stg5_1_merged1811_640_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_641_res = stg5_1_merged1811_write.extract<16, 31>();
	stg5_stg5_1_merged1811_641_write(stg5_stg5_1_merged1811_641_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_642_res = stg5_1_merged1811_write.extract<32, 47>();
	stg5_stg5_1_merged1811_642_write(stg5_stg5_1_merged1811_642_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_643_res = stg5_1_merged1811_write.extract<48, 63>();
	stg5_stg5_1_merged1811_643_write(stg5_stg5_1_merged1811_643_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_644_res = stg5_1_merged1811_write.extract<64, 79>();
	stg5_stg5_1_merged1811_644_write(stg5_stg5_1_merged1811_644_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_645_res = stg5_1_merged1811_write.extract<80, 95>();
	stg5_stg5_1_merged1811_645_write(stg5_stg5_1_merged1811_645_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_646_res = stg5_1_merged1811_write.extract<96, 111>();
	stg5_stg5_1_merged1811_646_write(stg5_stg5_1_merged1811_646_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_647_res = stg5_1_merged1811_write.extract<112, 127>();
	stg5_stg5_1_merged1811_647_write(stg5_stg5_1_merged1811_647_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_648_res = stg5_1_merged1811_write.extract<128, 143>();
	stg5_stg5_1_merged1811_648_write(stg5_stg5_1_merged1811_648_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_649_res = stg5_1_merged1811_write.extract<144, 159>();
	stg5_stg5_1_merged1811_649_write(stg5_stg5_1_merged1811_649_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_650_res = stg5_1_merged1811_write.extract<160, 175>();
	stg5_stg5_1_merged1811_650_write(stg5_stg5_1_merged1811_650_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_651_res = stg5_1_merged1811_write.extract<176, 191>();
	stg5_stg5_1_merged1811_651_write(stg5_stg5_1_merged1811_651_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_652_res = stg5_1_merged1811_write.extract<192, 207>();
	stg5_stg5_1_merged1811_652_write(stg5_stg5_1_merged1811_652_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_653_res = stg5_1_merged1811_write.extract<208, 223>();
	stg5_stg5_1_merged1811_653_write(stg5_stg5_1_merged1811_653_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_654_res = stg5_1_merged1811_write.extract<224, 239>();
	stg5_stg5_1_merged1811_654_write(stg5_stg5_1_merged1811_654_res, stg5, root, stg5_0, stg5_1, dynamic_address);
	hw_uint<16> stg5_stg5_1_merged1811_655_res = stg5_1_merged1811_write.extract<240, 255>();
	stg5_stg5_1_merged1811_655_write(stg5_stg5_1_merged1811_655_res, stg5, root, stg5_0, stg5_1, dynamic_address);
}

// stg5_ld45_merged1853_read
//	stg5_stg5_ld45_merged1853_624
//	stg5_stg5_ld45_merged1853_625
//	stg5_stg5_ld45_merged1853_626
//	stg5_stg5_ld45_merged1853_627
//	stg5_stg5_ld45_merged1853_628
//	stg5_stg5_ld45_merged1853_629
//	stg5_stg5_ld45_merged1853_630
//	stg5_stg5_ld45_merged1853_631
//	stg5_stg5_ld45_merged1853_632
//	stg5_stg5_ld45_merged1853_633
//	stg5_stg5_ld45_merged1853_634
//	stg5_stg5_ld45_merged1853_635
//	stg5_stg5_ld45_merged1853_636
//	stg5_stg5_ld45_merged1853_637
//	stg5_stg5_ld45_merged1853_638
//	stg5_stg5_ld45_merged1853_639
inline hw_uint<256> stg5_stg5_ld45_merged1853_read_bundle_read(stg5_cache& stg5, int root, int stg5_ld46, int stg5_ld45, int dynamic_address) {
  // # of ports in bundle: 16
    // stg5_stg5_ld45_merged1853_624
    // stg5_stg5_ld45_merged1853_625
    // stg5_stg5_ld45_merged1853_626
    // stg5_stg5_ld45_merged1853_627
    // stg5_stg5_ld45_merged1853_628
    // stg5_stg5_ld45_merged1853_629
    // stg5_stg5_ld45_merged1853_630
    // stg5_stg5_ld45_merged1853_631
    // stg5_stg5_ld45_merged1853_632
    // stg5_stg5_ld45_merged1853_633
    // stg5_stg5_ld45_merged1853_634
    // stg5_stg5_ld45_merged1853_635
    // stg5_stg5_ld45_merged1853_636
    // stg5_stg5_ld45_merged1853_637
    // stg5_stg5_ld45_merged1853_638
    // stg5_stg5_ld45_merged1853_639

	hw_uint<256> result;
	hw_uint<16> stg5_stg5_ld45_merged1853_624_res = stg5_stg5_ld45_merged1853_624_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<0, 256>(result, stg5_stg5_ld45_merged1853_624_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_625_res = stg5_stg5_ld45_merged1853_625_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<16, 256>(result, stg5_stg5_ld45_merged1853_625_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_626_res = stg5_stg5_ld45_merged1853_626_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<32, 256>(result, stg5_stg5_ld45_merged1853_626_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_627_res = stg5_stg5_ld45_merged1853_627_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<48, 256>(result, stg5_stg5_ld45_merged1853_627_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_628_res = stg5_stg5_ld45_merged1853_628_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<64, 256>(result, stg5_stg5_ld45_merged1853_628_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_629_res = stg5_stg5_ld45_merged1853_629_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<80, 256>(result, stg5_stg5_ld45_merged1853_629_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_630_res = stg5_stg5_ld45_merged1853_630_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<96, 256>(result, stg5_stg5_ld45_merged1853_630_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_631_res = stg5_stg5_ld45_merged1853_631_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<112, 256>(result, stg5_stg5_ld45_merged1853_631_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_632_res = stg5_stg5_ld45_merged1853_632_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<128, 256>(result, stg5_stg5_ld45_merged1853_632_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_633_res = stg5_stg5_ld45_merged1853_633_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<144, 256>(result, stg5_stg5_ld45_merged1853_633_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_634_res = stg5_stg5_ld45_merged1853_634_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<160, 256>(result, stg5_stg5_ld45_merged1853_634_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_635_res = stg5_stg5_ld45_merged1853_635_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<176, 256>(result, stg5_stg5_ld45_merged1853_635_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_636_res = stg5_stg5_ld45_merged1853_636_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<192, 256>(result, stg5_stg5_ld45_merged1853_636_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_637_res = stg5_stg5_ld45_merged1853_637_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<208, 256>(result, stg5_stg5_ld45_merged1853_637_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_638_res = stg5_stg5_ld45_merged1853_638_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<224, 256>(result, stg5_stg5_ld45_merged1853_638_res);
	hw_uint<16> stg5_stg5_ld45_merged1853_639_res = stg5_stg5_ld45_merged1853_639_select(stg5, root, stg5_ld46, stg5_ld45, dynamic_address);
	set_at<240, 256>(result, stg5_stg5_ld45_merged1853_639_res);
	return result;
}

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_merged_banks_4_cache {
	// RAM Box: {[15, 1215], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_merged_banks_4_cache {
	// RAM Box: {[14, 1214], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_merged_banks_4_cache {
	// RAM Box: {[13, 1213], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_merged_banks_4_cache {
	// RAM Box: {[12, 1212], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_merged_banks_4_cache {
	// RAM Box: {[11, 1211], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_merged_banks_4_cache {
	// RAM Box: {[10, 1210], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_merged_banks_4_cache {
	// RAM Box: {[9, 1209], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_merged_banks_4_cache {
	// RAM Box: {[8, 1208], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_merged_banks_4_cache {
	// RAM Box: {[7, 1207], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_merged_banks_4_cache {
	// RAM Box: {[6, 1206], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_merged_banks_4_cache {
	// RAM Box: {[5, 1205], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_merged_banks_4_cache {
	// RAM Box: {[4, 1204], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_merged_banks_4_cache {
	// RAM Box: {[3, 1203], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_merged_banks_4_cache {
	// RAM Box: {[2, 1202], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_merged_banks_4_cache {
	// RAM Box: {[1, 1201], [-9, 1928]}
	// Capacity: 156
	// # of read delays: 4
  // 0, 1, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 76> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 76> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_77() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_78() {
		return f4;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_155() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_merged_banks_4_cache {
	// RAM Box: {[0, 1216], [-9, 1927]}
	// Capacity: 156
	// # of read delays: 5
  // 0, 1, 77, 78, 155
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 76> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_78() {
		return f6;
	}

	inline hw_uint<16> peek_154() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_155() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 76
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 76 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg5_FIFO_buf108_cache {
  // Reader addrs...
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[15 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[15 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[16 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[15 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[14 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[14 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[15 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[14 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[13 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[13 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[14 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[13 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[12 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[12 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[13 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[12 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[11 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[11 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[12 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[11 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[10 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[10 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[11 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[10 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[9 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[9 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[10 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[9 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[8 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[8 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[9 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[8 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[7 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[7 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[8 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[7 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[6 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[6 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[7 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[6 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[5 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[5 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[6 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[5 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[4 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[4 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[5 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[4 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[3 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[3 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[4 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[3 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[2 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[2 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[3 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[2 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[1 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[1 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[2 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[1 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[1 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
    // { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // # of banks: 16
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_merged_banks_4;
  stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_merged_banks_4_cache stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_merged_banks_4;
};



inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590);
}

inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_write(hw_uint<16>& stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
  stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_merged_banks_4.push(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591);
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_512_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_512 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[15 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_513_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_513 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[15 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_514_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_514 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[16 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_merged_banks_4.peek_77();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_515_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_515 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[15 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_516_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_516 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[14 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_517_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_517 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[14 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_518_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_518 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[15 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_519_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_519 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[14 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_520_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_520 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[13 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_521_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_521 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[13 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_522_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_522 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[14 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_523_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_523 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[13 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_524_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_524 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[12 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_525_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_525 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[12 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_526_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_526 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[13 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_527_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_527 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[12 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_528_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_528 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[11 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_529_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_529 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[11 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_530_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_530 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[12 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_531_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_531 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[11 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_532_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_532 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[10 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_533_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_533 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[10 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_534_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_534 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[11 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_535_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_535 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[10 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_536_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_536 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[9 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_537_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_537 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[9 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_538_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_538 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[10 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_539_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_539 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[9 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_540_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_540 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[8 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_541_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_541 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[8 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_542_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_542 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[9 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_543_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_543 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[8 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_544_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_544 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[7 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_545_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_545 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[7 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_546_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_546 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[8 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_547_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_547 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[7 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_548_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_548 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[6 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_549_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_549 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[6 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_550_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_550 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[7 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_551_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_551 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[6 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_552_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_552 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[5 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_553_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_553 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[5 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_554_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_554 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[6 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_555_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_555 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[5 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_556_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_556 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[4 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_557_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_557 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[4 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_558_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_558 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[5 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_559_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_559 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[4 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_560_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_560 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[3 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_561_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_561 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[3 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_562_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_562 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[4 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_563_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_563 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[3 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_564_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_564 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[2 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_565_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_565 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[2 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_566_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_566 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[3 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_567_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_567 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[2 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_568_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_568 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[1 + 16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_569_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_569 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[1 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_570_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_570 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[2 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_571_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_571 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[1 + 16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_572_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_572 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[16stg6_1, -9 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_merged_banks_4.peek_155();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_573_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_573 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_574_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_574 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[1 + 16stg6_1, -8 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_merged_banks_4.peek_78();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590;
  return 0;
}

inline hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_575_select(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg5_FIFO_buf108_stg6_1_merged1814_575 read pattern: { stg6_1_merged1814[root = 0, stg6_0, stg6_1] -> stg5_FIFO_buf108[16stg6_1, -7 + stg6_0] : 0 <= stg6_0 <= 1935 and 0 <= stg6_1 <= 75 }
  // Read schedule : { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
  auto value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591 = stg5_FIFO_buf108.stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_merged_banks_4.peek_1();
  return value_stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591;
  return 0;
}

// # of bundles = 2
// stg5_to_gp_1344_ld109_merged1760_write
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590
//	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591
inline void stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_write_bundle_write(hw_uint<256>& stg5_to_gp_1344_ld109_merged1760_write, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg5_to_gp_1344_ld110, int stg5_to_gp_1344_ld109, int dynamic_address) {
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_res = stg5_to_gp_1344_ld109_merged1760_write.extract<0, 15>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_576_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_res = stg5_to_gp_1344_ld109_merged1760_write.extract<16, 31>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_577_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_res = stg5_to_gp_1344_ld109_merged1760_write.extract<32, 47>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_578_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_res = stg5_to_gp_1344_ld109_merged1760_write.extract<48, 63>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_579_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_res = stg5_to_gp_1344_ld109_merged1760_write.extract<64, 79>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_580_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_res = stg5_to_gp_1344_ld109_merged1760_write.extract<80, 95>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_581_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_res = stg5_to_gp_1344_ld109_merged1760_write.extract<96, 111>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_582_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_res = stg5_to_gp_1344_ld109_merged1760_write.extract<112, 127>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_583_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_res = stg5_to_gp_1344_ld109_merged1760_write.extract<128, 143>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_584_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_res = stg5_to_gp_1344_ld109_merged1760_write.extract<144, 159>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_585_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_res = stg5_to_gp_1344_ld109_merged1760_write.extract<160, 175>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_586_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_res = stg5_to_gp_1344_ld109_merged1760_write.extract<176, 191>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_587_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_res = stg5_to_gp_1344_ld109_merged1760_write.extract<192, 207>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_588_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_res = stg5_to_gp_1344_ld109_merged1760_write.extract<208, 223>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_589_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_res = stg5_to_gp_1344_ld109_merged1760_write.extract<224, 239>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_590_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
	hw_uint<16> stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_res = stg5_to_gp_1344_ld109_merged1760_write.extract<240, 255>();
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_write(stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_591_res, stg5_FIFO_buf108, root, stg5_to_gp_1344_ld110, stg5_to_gp_1344_ld109, dynamic_address);
}

// stg6_1_merged1814_read
//	stg5_FIFO_buf108_stg6_1_merged1814_512
//	stg5_FIFO_buf108_stg6_1_merged1814_513
//	stg5_FIFO_buf108_stg6_1_merged1814_514
//	stg5_FIFO_buf108_stg6_1_merged1814_515
//	stg5_FIFO_buf108_stg6_1_merged1814_516
//	stg5_FIFO_buf108_stg6_1_merged1814_517
//	stg5_FIFO_buf108_stg6_1_merged1814_518
//	stg5_FIFO_buf108_stg6_1_merged1814_519
//	stg5_FIFO_buf108_stg6_1_merged1814_520
//	stg5_FIFO_buf108_stg6_1_merged1814_521
//	stg5_FIFO_buf108_stg6_1_merged1814_522
//	stg5_FIFO_buf108_stg6_1_merged1814_523
//	stg5_FIFO_buf108_stg6_1_merged1814_524
//	stg5_FIFO_buf108_stg6_1_merged1814_525
//	stg5_FIFO_buf108_stg6_1_merged1814_526
//	stg5_FIFO_buf108_stg6_1_merged1814_527
//	stg5_FIFO_buf108_stg6_1_merged1814_528
//	stg5_FIFO_buf108_stg6_1_merged1814_529
//	stg5_FIFO_buf108_stg6_1_merged1814_530
//	stg5_FIFO_buf108_stg6_1_merged1814_531
//	stg5_FIFO_buf108_stg6_1_merged1814_532
//	stg5_FIFO_buf108_stg6_1_merged1814_533
//	stg5_FIFO_buf108_stg6_1_merged1814_534
//	stg5_FIFO_buf108_stg6_1_merged1814_535
//	stg5_FIFO_buf108_stg6_1_merged1814_536
//	stg5_FIFO_buf108_stg6_1_merged1814_537
//	stg5_FIFO_buf108_stg6_1_merged1814_538
//	stg5_FIFO_buf108_stg6_1_merged1814_539
//	stg5_FIFO_buf108_stg6_1_merged1814_540
//	stg5_FIFO_buf108_stg6_1_merged1814_541
//	stg5_FIFO_buf108_stg6_1_merged1814_542
//	stg5_FIFO_buf108_stg6_1_merged1814_543
//	stg5_FIFO_buf108_stg6_1_merged1814_544
//	stg5_FIFO_buf108_stg6_1_merged1814_545
//	stg5_FIFO_buf108_stg6_1_merged1814_546
//	stg5_FIFO_buf108_stg6_1_merged1814_547
//	stg5_FIFO_buf108_stg6_1_merged1814_548
//	stg5_FIFO_buf108_stg6_1_merged1814_549
//	stg5_FIFO_buf108_stg6_1_merged1814_550
//	stg5_FIFO_buf108_stg6_1_merged1814_551
//	stg5_FIFO_buf108_stg6_1_merged1814_552
//	stg5_FIFO_buf108_stg6_1_merged1814_553
//	stg5_FIFO_buf108_stg6_1_merged1814_554
//	stg5_FIFO_buf108_stg6_1_merged1814_555
//	stg5_FIFO_buf108_stg6_1_merged1814_556
//	stg5_FIFO_buf108_stg6_1_merged1814_557
//	stg5_FIFO_buf108_stg6_1_merged1814_558
//	stg5_FIFO_buf108_stg6_1_merged1814_559
//	stg5_FIFO_buf108_stg6_1_merged1814_560
//	stg5_FIFO_buf108_stg6_1_merged1814_561
//	stg5_FIFO_buf108_stg6_1_merged1814_562
//	stg5_FIFO_buf108_stg6_1_merged1814_563
//	stg5_FIFO_buf108_stg6_1_merged1814_564
//	stg5_FIFO_buf108_stg6_1_merged1814_565
//	stg5_FIFO_buf108_stg6_1_merged1814_566
//	stg5_FIFO_buf108_stg6_1_merged1814_567
//	stg5_FIFO_buf108_stg6_1_merged1814_568
//	stg5_FIFO_buf108_stg6_1_merged1814_569
//	stg5_FIFO_buf108_stg6_1_merged1814_570
//	stg5_FIFO_buf108_stg6_1_merged1814_571
//	stg5_FIFO_buf108_stg6_1_merged1814_572
//	stg5_FIFO_buf108_stg6_1_merged1814_573
//	stg5_FIFO_buf108_stg6_1_merged1814_574
//	stg5_FIFO_buf108_stg6_1_merged1814_575
inline hw_uint<1024> stg5_FIFO_buf108_stg6_1_merged1814_read_bundle_read(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int root, int stg6_0, int stg6_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg5_FIFO_buf108_stg6_1_merged1814_512
    // stg5_FIFO_buf108_stg6_1_merged1814_513
    // stg5_FIFO_buf108_stg6_1_merged1814_514
    // stg5_FIFO_buf108_stg6_1_merged1814_515
    // stg5_FIFO_buf108_stg6_1_merged1814_516
    // stg5_FIFO_buf108_stg6_1_merged1814_517
    // stg5_FIFO_buf108_stg6_1_merged1814_518
    // stg5_FIFO_buf108_stg6_1_merged1814_519
    // stg5_FIFO_buf108_stg6_1_merged1814_520
    // stg5_FIFO_buf108_stg6_1_merged1814_521
    // stg5_FIFO_buf108_stg6_1_merged1814_522
    // stg5_FIFO_buf108_stg6_1_merged1814_523
    // stg5_FIFO_buf108_stg6_1_merged1814_524
    // stg5_FIFO_buf108_stg6_1_merged1814_525
    // stg5_FIFO_buf108_stg6_1_merged1814_526
    // stg5_FIFO_buf108_stg6_1_merged1814_527
    // stg5_FIFO_buf108_stg6_1_merged1814_528
    // stg5_FIFO_buf108_stg6_1_merged1814_529
    // stg5_FIFO_buf108_stg6_1_merged1814_530
    // stg5_FIFO_buf108_stg6_1_merged1814_531
    // stg5_FIFO_buf108_stg6_1_merged1814_532
    // stg5_FIFO_buf108_stg6_1_merged1814_533
    // stg5_FIFO_buf108_stg6_1_merged1814_534
    // stg5_FIFO_buf108_stg6_1_merged1814_535
    // stg5_FIFO_buf108_stg6_1_merged1814_536
    // stg5_FIFO_buf108_stg6_1_merged1814_537
    // stg5_FIFO_buf108_stg6_1_merged1814_538
    // stg5_FIFO_buf108_stg6_1_merged1814_539
    // stg5_FIFO_buf108_stg6_1_merged1814_540
    // stg5_FIFO_buf108_stg6_1_merged1814_541
    // stg5_FIFO_buf108_stg6_1_merged1814_542
    // stg5_FIFO_buf108_stg6_1_merged1814_543
    // stg5_FIFO_buf108_stg6_1_merged1814_544
    // stg5_FIFO_buf108_stg6_1_merged1814_545
    // stg5_FIFO_buf108_stg6_1_merged1814_546
    // stg5_FIFO_buf108_stg6_1_merged1814_547
    // stg5_FIFO_buf108_stg6_1_merged1814_548
    // stg5_FIFO_buf108_stg6_1_merged1814_549
    // stg5_FIFO_buf108_stg6_1_merged1814_550
    // stg5_FIFO_buf108_stg6_1_merged1814_551
    // stg5_FIFO_buf108_stg6_1_merged1814_552
    // stg5_FIFO_buf108_stg6_1_merged1814_553
    // stg5_FIFO_buf108_stg6_1_merged1814_554
    // stg5_FIFO_buf108_stg6_1_merged1814_555
    // stg5_FIFO_buf108_stg6_1_merged1814_556
    // stg5_FIFO_buf108_stg6_1_merged1814_557
    // stg5_FIFO_buf108_stg6_1_merged1814_558
    // stg5_FIFO_buf108_stg6_1_merged1814_559
    // stg5_FIFO_buf108_stg6_1_merged1814_560
    // stg5_FIFO_buf108_stg6_1_merged1814_561
    // stg5_FIFO_buf108_stg6_1_merged1814_562
    // stg5_FIFO_buf108_stg6_1_merged1814_563
    // stg5_FIFO_buf108_stg6_1_merged1814_564
    // stg5_FIFO_buf108_stg6_1_merged1814_565
    // stg5_FIFO_buf108_stg6_1_merged1814_566
    // stg5_FIFO_buf108_stg6_1_merged1814_567
    // stg5_FIFO_buf108_stg6_1_merged1814_568
    // stg5_FIFO_buf108_stg6_1_merged1814_569
    // stg5_FIFO_buf108_stg6_1_merged1814_570
    // stg5_FIFO_buf108_stg6_1_merged1814_571
    // stg5_FIFO_buf108_stg6_1_merged1814_572
    // stg5_FIFO_buf108_stg6_1_merged1814_573
    // stg5_FIFO_buf108_stg6_1_merged1814_574
    // stg5_FIFO_buf108_stg6_1_merged1814_575

	hw_uint<1024> result;
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_512_res = stg5_FIFO_buf108_stg6_1_merged1814_512_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<0, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_512_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_513_res = stg5_FIFO_buf108_stg6_1_merged1814_513_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<16, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_513_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_514_res = stg5_FIFO_buf108_stg6_1_merged1814_514_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<32, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_514_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_515_res = stg5_FIFO_buf108_stg6_1_merged1814_515_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<48, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_515_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_516_res = stg5_FIFO_buf108_stg6_1_merged1814_516_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<64, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_516_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_517_res = stg5_FIFO_buf108_stg6_1_merged1814_517_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<80, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_517_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_518_res = stg5_FIFO_buf108_stg6_1_merged1814_518_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<96, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_518_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_519_res = stg5_FIFO_buf108_stg6_1_merged1814_519_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<112, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_519_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_520_res = stg5_FIFO_buf108_stg6_1_merged1814_520_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<128, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_520_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_521_res = stg5_FIFO_buf108_stg6_1_merged1814_521_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<144, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_521_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_522_res = stg5_FIFO_buf108_stg6_1_merged1814_522_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<160, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_522_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_523_res = stg5_FIFO_buf108_stg6_1_merged1814_523_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<176, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_523_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_524_res = stg5_FIFO_buf108_stg6_1_merged1814_524_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<192, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_524_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_525_res = stg5_FIFO_buf108_stg6_1_merged1814_525_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<208, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_525_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_526_res = stg5_FIFO_buf108_stg6_1_merged1814_526_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<224, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_526_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_527_res = stg5_FIFO_buf108_stg6_1_merged1814_527_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<240, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_527_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_528_res = stg5_FIFO_buf108_stg6_1_merged1814_528_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<256, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_528_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_529_res = stg5_FIFO_buf108_stg6_1_merged1814_529_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<272, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_529_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_530_res = stg5_FIFO_buf108_stg6_1_merged1814_530_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<288, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_530_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_531_res = stg5_FIFO_buf108_stg6_1_merged1814_531_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<304, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_531_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_532_res = stg5_FIFO_buf108_stg6_1_merged1814_532_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<320, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_532_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_533_res = stg5_FIFO_buf108_stg6_1_merged1814_533_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<336, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_533_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_534_res = stg5_FIFO_buf108_stg6_1_merged1814_534_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<352, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_534_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_535_res = stg5_FIFO_buf108_stg6_1_merged1814_535_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<368, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_535_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_536_res = stg5_FIFO_buf108_stg6_1_merged1814_536_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<384, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_536_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_537_res = stg5_FIFO_buf108_stg6_1_merged1814_537_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<400, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_537_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_538_res = stg5_FIFO_buf108_stg6_1_merged1814_538_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<416, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_538_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_539_res = stg5_FIFO_buf108_stg6_1_merged1814_539_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<432, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_539_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_540_res = stg5_FIFO_buf108_stg6_1_merged1814_540_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<448, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_540_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_541_res = stg5_FIFO_buf108_stg6_1_merged1814_541_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<464, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_541_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_542_res = stg5_FIFO_buf108_stg6_1_merged1814_542_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<480, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_542_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_543_res = stg5_FIFO_buf108_stg6_1_merged1814_543_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<496, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_543_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_544_res = stg5_FIFO_buf108_stg6_1_merged1814_544_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<512, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_544_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_545_res = stg5_FIFO_buf108_stg6_1_merged1814_545_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<528, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_545_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_546_res = stg5_FIFO_buf108_stg6_1_merged1814_546_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<544, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_546_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_547_res = stg5_FIFO_buf108_stg6_1_merged1814_547_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<560, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_547_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_548_res = stg5_FIFO_buf108_stg6_1_merged1814_548_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<576, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_548_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_549_res = stg5_FIFO_buf108_stg6_1_merged1814_549_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<592, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_549_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_550_res = stg5_FIFO_buf108_stg6_1_merged1814_550_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<608, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_550_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_551_res = stg5_FIFO_buf108_stg6_1_merged1814_551_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<624, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_551_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_552_res = stg5_FIFO_buf108_stg6_1_merged1814_552_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<640, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_552_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_553_res = stg5_FIFO_buf108_stg6_1_merged1814_553_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<656, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_553_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_554_res = stg5_FIFO_buf108_stg6_1_merged1814_554_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<672, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_554_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_555_res = stg5_FIFO_buf108_stg6_1_merged1814_555_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<688, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_555_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_556_res = stg5_FIFO_buf108_stg6_1_merged1814_556_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<704, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_556_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_557_res = stg5_FIFO_buf108_stg6_1_merged1814_557_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<720, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_557_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_558_res = stg5_FIFO_buf108_stg6_1_merged1814_558_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<736, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_558_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_559_res = stg5_FIFO_buf108_stg6_1_merged1814_559_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<752, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_559_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_560_res = stg5_FIFO_buf108_stg6_1_merged1814_560_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<768, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_560_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_561_res = stg5_FIFO_buf108_stg6_1_merged1814_561_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<784, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_561_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_562_res = stg5_FIFO_buf108_stg6_1_merged1814_562_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<800, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_562_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_563_res = stg5_FIFO_buf108_stg6_1_merged1814_563_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<816, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_563_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_564_res = stg5_FIFO_buf108_stg6_1_merged1814_564_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<832, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_564_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_565_res = stg5_FIFO_buf108_stg6_1_merged1814_565_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<848, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_565_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_566_res = stg5_FIFO_buf108_stg6_1_merged1814_566_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<864, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_566_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_567_res = stg5_FIFO_buf108_stg6_1_merged1814_567_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<880, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_567_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_568_res = stg5_FIFO_buf108_stg6_1_merged1814_568_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<896, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_568_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_569_res = stg5_FIFO_buf108_stg6_1_merged1814_569_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<912, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_569_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_570_res = stg5_FIFO_buf108_stg6_1_merged1814_570_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<928, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_570_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_571_res = stg5_FIFO_buf108_stg6_1_merged1814_571_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<944, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_571_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_572_res = stg5_FIFO_buf108_stg6_1_merged1814_572_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<960, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_572_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_573_res = stg5_FIFO_buf108_stg6_1_merged1814_573_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<976, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_573_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_574_res = stg5_FIFO_buf108_stg6_1_merged1814_574_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<992, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_574_res);
	hw_uint<16> stg5_FIFO_buf108_stg6_1_merged1814_575_res = stg5_FIFO_buf108_stg6_1_merged1814_575_select(stg5_FIFO_buf108, root, stg6_0, stg6_1, dynamic_address);
	set_at<1008, 1024>(result, stg5_FIFO_buf108_stg6_1_merged1814_575_res);
	return result;
}

struct stg6_stg6_1_merged1814_496_to_stg6_stg6_ld49_merged1855_480_cache {
	// RAM Box: {[15, 1215], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_497_to_stg6_stg6_ld49_merged1855_481_cache {
	// RAM Box: {[14, 1214], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_498_to_stg6_stg6_ld49_merged1855_482_cache {
	// RAM Box: {[13, 1213], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_499_to_stg6_stg6_ld49_merged1855_483_cache {
	// RAM Box: {[12, 1212], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_500_to_stg6_stg6_ld49_merged1855_484_cache {
	// RAM Box: {[11, 1211], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_501_to_stg6_stg6_ld49_merged1855_485_cache {
	// RAM Box: {[10, 1210], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_502_to_stg6_stg6_ld49_merged1855_486_cache {
	// RAM Box: {[9, 1209], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_503_to_stg6_stg6_ld49_merged1855_487_cache {
	// RAM Box: {[8, 1208], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_504_to_stg6_stg6_ld49_merged1855_488_cache {
	// RAM Box: {[7, 1207], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_505_to_stg6_stg6_ld49_merged1855_489_cache {
	// RAM Box: {[6, 1206], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_506_to_stg6_stg6_ld49_merged1855_490_cache {
	// RAM Box: {[5, 1205], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_507_to_stg6_stg6_ld49_merged1855_491_cache {
	// RAM Box: {[4, 1204], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_508_to_stg6_stg6_ld49_merged1855_492_cache {
	// RAM Box: {[3, 1203], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_509_to_stg6_stg6_ld49_merged1855_493_cache {
	// RAM Box: {[2, 1202], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_510_to_stg6_stg6_ld49_merged1855_494_cache {
	// RAM Box: {[1, 1201], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_stg6_1_merged1814_511_to_stg6_stg6_ld49_merged1855_495_cache {
	// RAM Box: {[0, 1200], [-8, 1927]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg6_cache {
  // Reader addrs...
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[15 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[14 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[13 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[12 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[11 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[10 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[9 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[8 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[7 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[6 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[5 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[4 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[3 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[2 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[1 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
    // { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // # of banks: 16
  stg6_stg6_1_merged1814_496_to_stg6_stg6_ld49_merged1855_480_cache stg6_stg6_1_merged1814_496_to_stg6_stg6_ld49_merged1855_480;
  stg6_stg6_1_merged1814_497_to_stg6_stg6_ld49_merged1855_481_cache stg6_stg6_1_merged1814_497_to_stg6_stg6_ld49_merged1855_481;
  stg6_stg6_1_merged1814_498_to_stg6_stg6_ld49_merged1855_482_cache stg6_stg6_1_merged1814_498_to_stg6_stg6_ld49_merged1855_482;
  stg6_stg6_1_merged1814_499_to_stg6_stg6_ld49_merged1855_483_cache stg6_stg6_1_merged1814_499_to_stg6_stg6_ld49_merged1855_483;
  stg6_stg6_1_merged1814_500_to_stg6_stg6_ld49_merged1855_484_cache stg6_stg6_1_merged1814_500_to_stg6_stg6_ld49_merged1855_484;
  stg6_stg6_1_merged1814_501_to_stg6_stg6_ld49_merged1855_485_cache stg6_stg6_1_merged1814_501_to_stg6_stg6_ld49_merged1855_485;
  stg6_stg6_1_merged1814_502_to_stg6_stg6_ld49_merged1855_486_cache stg6_stg6_1_merged1814_502_to_stg6_stg6_ld49_merged1855_486;
  stg6_stg6_1_merged1814_503_to_stg6_stg6_ld49_merged1855_487_cache stg6_stg6_1_merged1814_503_to_stg6_stg6_ld49_merged1855_487;
  stg6_stg6_1_merged1814_504_to_stg6_stg6_ld49_merged1855_488_cache stg6_stg6_1_merged1814_504_to_stg6_stg6_ld49_merged1855_488;
  stg6_stg6_1_merged1814_505_to_stg6_stg6_ld49_merged1855_489_cache stg6_stg6_1_merged1814_505_to_stg6_stg6_ld49_merged1855_489;
  stg6_stg6_1_merged1814_506_to_stg6_stg6_ld49_merged1855_490_cache stg6_stg6_1_merged1814_506_to_stg6_stg6_ld49_merged1855_490;
  stg6_stg6_1_merged1814_507_to_stg6_stg6_ld49_merged1855_491_cache stg6_stg6_1_merged1814_507_to_stg6_stg6_ld49_merged1855_491;
  stg6_stg6_1_merged1814_508_to_stg6_stg6_ld49_merged1855_492_cache stg6_stg6_1_merged1814_508_to_stg6_stg6_ld49_merged1855_492;
  stg6_stg6_1_merged1814_509_to_stg6_stg6_ld49_merged1855_493_cache stg6_stg6_1_merged1814_509_to_stg6_stg6_ld49_merged1855_493;
  stg6_stg6_1_merged1814_510_to_stg6_stg6_ld49_merged1855_494_cache stg6_stg6_1_merged1814_510_to_stg6_stg6_ld49_merged1855_494;
  stg6_stg6_1_merged1814_511_to_stg6_stg6_ld49_merged1855_495_cache stg6_stg6_1_merged1814_511_to_stg6_stg6_ld49_merged1855_495;
};



inline void stg6_stg6_1_merged1814_496_write(hw_uint<16>& stg6_stg6_1_merged1814_496, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_496_to_stg6_stg6_ld49_merged1855_480.push(stg6_stg6_1_merged1814_496);
}

inline void stg6_stg6_1_merged1814_497_write(hw_uint<16>& stg6_stg6_1_merged1814_497, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_497_to_stg6_stg6_ld49_merged1855_481.push(stg6_stg6_1_merged1814_497);
}

inline void stg6_stg6_1_merged1814_498_write(hw_uint<16>& stg6_stg6_1_merged1814_498, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_498_to_stg6_stg6_ld49_merged1855_482.push(stg6_stg6_1_merged1814_498);
}

inline void stg6_stg6_1_merged1814_499_write(hw_uint<16>& stg6_stg6_1_merged1814_499, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_499_to_stg6_stg6_ld49_merged1855_483.push(stg6_stg6_1_merged1814_499);
}

inline void stg6_stg6_1_merged1814_500_write(hw_uint<16>& stg6_stg6_1_merged1814_500, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_500_to_stg6_stg6_ld49_merged1855_484.push(stg6_stg6_1_merged1814_500);
}

inline void stg6_stg6_1_merged1814_501_write(hw_uint<16>& stg6_stg6_1_merged1814_501, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_501_to_stg6_stg6_ld49_merged1855_485.push(stg6_stg6_1_merged1814_501);
}

inline void stg6_stg6_1_merged1814_502_write(hw_uint<16>& stg6_stg6_1_merged1814_502, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_502_to_stg6_stg6_ld49_merged1855_486.push(stg6_stg6_1_merged1814_502);
}

inline void stg6_stg6_1_merged1814_503_write(hw_uint<16>& stg6_stg6_1_merged1814_503, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_503_to_stg6_stg6_ld49_merged1855_487.push(stg6_stg6_1_merged1814_503);
}

inline void stg6_stg6_1_merged1814_504_write(hw_uint<16>& stg6_stg6_1_merged1814_504, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_504_to_stg6_stg6_ld49_merged1855_488.push(stg6_stg6_1_merged1814_504);
}

inline void stg6_stg6_1_merged1814_505_write(hw_uint<16>& stg6_stg6_1_merged1814_505, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_505_to_stg6_stg6_ld49_merged1855_489.push(stg6_stg6_1_merged1814_505);
}

inline void stg6_stg6_1_merged1814_506_write(hw_uint<16>& stg6_stg6_1_merged1814_506, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_506_to_stg6_stg6_ld49_merged1855_490.push(stg6_stg6_1_merged1814_506);
}

inline void stg6_stg6_1_merged1814_507_write(hw_uint<16>& stg6_stg6_1_merged1814_507, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_507_to_stg6_stg6_ld49_merged1855_491.push(stg6_stg6_1_merged1814_507);
}

inline void stg6_stg6_1_merged1814_508_write(hw_uint<16>& stg6_stg6_1_merged1814_508, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_508_to_stg6_stg6_ld49_merged1855_492.push(stg6_stg6_1_merged1814_508);
}

inline void stg6_stg6_1_merged1814_509_write(hw_uint<16>& stg6_stg6_1_merged1814_509, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_509_to_stg6_stg6_ld49_merged1855_493.push(stg6_stg6_1_merged1814_509);
}

inline void stg6_stg6_1_merged1814_510_write(hw_uint<16>& stg6_stg6_1_merged1814_510, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_510_to_stg6_stg6_ld49_merged1855_494.push(stg6_stg6_1_merged1814_510);
}

inline void stg6_stg6_1_merged1814_511_write(hw_uint<16>& stg6_stg6_1_merged1814_511, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
  stg6.stg6_stg6_1_merged1814_511_to_stg6_stg6_ld49_merged1855_495.push(stg6_stg6_1_merged1814_511);
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_480_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_480 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[15 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_496 = stg6.stg6_stg6_1_merged1814_496_to_stg6_stg6_ld49_merged1855_480.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_496;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_481_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_481 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[14 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_497 = stg6.stg6_stg6_1_merged1814_497_to_stg6_stg6_ld49_merged1855_481.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_497;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_482_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_482 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[13 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_498 = stg6.stg6_stg6_1_merged1814_498_to_stg6_stg6_ld49_merged1855_482.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_498;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_483_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_483 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[12 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_499 = stg6.stg6_stg6_1_merged1814_499_to_stg6_stg6_ld49_merged1855_483.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_499;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_484_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_484 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[11 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_500 = stg6.stg6_stg6_1_merged1814_500_to_stg6_stg6_ld49_merged1855_484.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_500;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_485_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_485 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[10 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_501 = stg6.stg6_stg6_1_merged1814_501_to_stg6_stg6_ld49_merged1855_485.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_501;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_486_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_486 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[9 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_502 = stg6.stg6_stg6_1_merged1814_502_to_stg6_stg6_ld49_merged1855_486.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_502;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_487_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_487 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[8 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_503 = stg6.stg6_stg6_1_merged1814_503_to_stg6_stg6_ld49_merged1855_487.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_503;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_488_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_488 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[7 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_504 = stg6.stg6_stg6_1_merged1814_504_to_stg6_stg6_ld49_merged1855_488.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_504;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_489_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_489 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[6 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_505 = stg6.stg6_stg6_1_merged1814_505_to_stg6_stg6_ld49_merged1855_489.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_505;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_490_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_490 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[5 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_506 = stg6.stg6_stg6_1_merged1814_506_to_stg6_stg6_ld49_merged1855_490.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_506;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_491_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_491 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[4 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_507 = stg6.stg6_stg6_1_merged1814_507_to_stg6_stg6_ld49_merged1855_491.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_507;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_492_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_492 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[3 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_508 = stg6.stg6_stg6_1_merged1814_508_to_stg6_stg6_ld49_merged1855_492.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_508;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_493_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_493 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[2 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_509 = stg6.stg6_stg6_1_merged1814_509_to_stg6_stg6_ld49_merged1855_493.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_509;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_494_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_494 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[1 + 16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_510 = stg6.stg6_stg6_1_merged1814_510_to_stg6_stg6_ld49_merged1855_494.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_510;
  return 0;
}

inline hw_uint<16> stg6_stg6_ld49_merged1855_495_select(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_stg6_ld49_merged1855_495 read pattern: { stg6_ld49_merged1855[root = 0, stg6_ld50, stg6_ld49] -> stg6[16stg6_ld49, -8 + stg6_ld50] : 0 <= stg6_ld50 <= 1935 and 0 <= stg6_ld49 <= 75 }
  // Read schedule : { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  // Write schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_stg6_1_merged1814_511 = stg6.stg6_stg6_1_merged1814_511_to_stg6_stg6_ld49_merged1855_495.peek(/* one reader or all rams */ 0);
  return value_stg6_stg6_1_merged1814_511;
  return 0;
}

// # of bundles = 2
// stg6_1_merged1814_write
//	stg6_stg6_1_merged1814_496
//	stg6_stg6_1_merged1814_497
//	stg6_stg6_1_merged1814_498
//	stg6_stg6_1_merged1814_499
//	stg6_stg6_1_merged1814_500
//	stg6_stg6_1_merged1814_501
//	stg6_stg6_1_merged1814_502
//	stg6_stg6_1_merged1814_503
//	stg6_stg6_1_merged1814_504
//	stg6_stg6_1_merged1814_505
//	stg6_stg6_1_merged1814_506
//	stg6_stg6_1_merged1814_507
//	stg6_stg6_1_merged1814_508
//	stg6_stg6_1_merged1814_509
//	stg6_stg6_1_merged1814_510
//	stg6_stg6_1_merged1814_511
inline void stg6_stg6_1_merged1814_write_bundle_write(hw_uint<256>& stg6_1_merged1814_write, stg6_cache& stg6, int root, int stg6_0, int stg6_1, int dynamic_address) {
	hw_uint<16> stg6_stg6_1_merged1814_496_res = stg6_1_merged1814_write.extract<0, 15>();
	stg6_stg6_1_merged1814_496_write(stg6_stg6_1_merged1814_496_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_497_res = stg6_1_merged1814_write.extract<16, 31>();
	stg6_stg6_1_merged1814_497_write(stg6_stg6_1_merged1814_497_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_498_res = stg6_1_merged1814_write.extract<32, 47>();
	stg6_stg6_1_merged1814_498_write(stg6_stg6_1_merged1814_498_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_499_res = stg6_1_merged1814_write.extract<48, 63>();
	stg6_stg6_1_merged1814_499_write(stg6_stg6_1_merged1814_499_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_500_res = stg6_1_merged1814_write.extract<64, 79>();
	stg6_stg6_1_merged1814_500_write(stg6_stg6_1_merged1814_500_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_501_res = stg6_1_merged1814_write.extract<80, 95>();
	stg6_stg6_1_merged1814_501_write(stg6_stg6_1_merged1814_501_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_502_res = stg6_1_merged1814_write.extract<96, 111>();
	stg6_stg6_1_merged1814_502_write(stg6_stg6_1_merged1814_502_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_503_res = stg6_1_merged1814_write.extract<112, 127>();
	stg6_stg6_1_merged1814_503_write(stg6_stg6_1_merged1814_503_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_504_res = stg6_1_merged1814_write.extract<128, 143>();
	stg6_stg6_1_merged1814_504_write(stg6_stg6_1_merged1814_504_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_505_res = stg6_1_merged1814_write.extract<144, 159>();
	stg6_stg6_1_merged1814_505_write(stg6_stg6_1_merged1814_505_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_506_res = stg6_1_merged1814_write.extract<160, 175>();
	stg6_stg6_1_merged1814_506_write(stg6_stg6_1_merged1814_506_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_507_res = stg6_1_merged1814_write.extract<176, 191>();
	stg6_stg6_1_merged1814_507_write(stg6_stg6_1_merged1814_507_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_508_res = stg6_1_merged1814_write.extract<192, 207>();
	stg6_stg6_1_merged1814_508_write(stg6_stg6_1_merged1814_508_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_509_res = stg6_1_merged1814_write.extract<208, 223>();
	stg6_stg6_1_merged1814_509_write(stg6_stg6_1_merged1814_509_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_510_res = stg6_1_merged1814_write.extract<224, 239>();
	stg6_stg6_1_merged1814_510_write(stg6_stg6_1_merged1814_510_res, stg6, root, stg6_0, stg6_1, dynamic_address);
	hw_uint<16> stg6_stg6_1_merged1814_511_res = stg6_1_merged1814_write.extract<240, 255>();
	stg6_stg6_1_merged1814_511_write(stg6_stg6_1_merged1814_511_res, stg6, root, stg6_0, stg6_1, dynamic_address);
}

// stg6_ld49_merged1855_read
//	stg6_stg6_ld49_merged1855_480
//	stg6_stg6_ld49_merged1855_481
//	stg6_stg6_ld49_merged1855_482
//	stg6_stg6_ld49_merged1855_483
//	stg6_stg6_ld49_merged1855_484
//	stg6_stg6_ld49_merged1855_485
//	stg6_stg6_ld49_merged1855_486
//	stg6_stg6_ld49_merged1855_487
//	stg6_stg6_ld49_merged1855_488
//	stg6_stg6_ld49_merged1855_489
//	stg6_stg6_ld49_merged1855_490
//	stg6_stg6_ld49_merged1855_491
//	stg6_stg6_ld49_merged1855_492
//	stg6_stg6_ld49_merged1855_493
//	stg6_stg6_ld49_merged1855_494
//	stg6_stg6_ld49_merged1855_495
inline hw_uint<256> stg6_stg6_ld49_merged1855_read_bundle_read(stg6_cache& stg6, int root, int stg6_ld50, int stg6_ld49, int dynamic_address) {
  // # of ports in bundle: 16
    // stg6_stg6_ld49_merged1855_480
    // stg6_stg6_ld49_merged1855_481
    // stg6_stg6_ld49_merged1855_482
    // stg6_stg6_ld49_merged1855_483
    // stg6_stg6_ld49_merged1855_484
    // stg6_stg6_ld49_merged1855_485
    // stg6_stg6_ld49_merged1855_486
    // stg6_stg6_ld49_merged1855_487
    // stg6_stg6_ld49_merged1855_488
    // stg6_stg6_ld49_merged1855_489
    // stg6_stg6_ld49_merged1855_490
    // stg6_stg6_ld49_merged1855_491
    // stg6_stg6_ld49_merged1855_492
    // stg6_stg6_ld49_merged1855_493
    // stg6_stg6_ld49_merged1855_494
    // stg6_stg6_ld49_merged1855_495

	hw_uint<256> result;
	hw_uint<16> stg6_stg6_ld49_merged1855_480_res = stg6_stg6_ld49_merged1855_480_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<0, 256>(result, stg6_stg6_ld49_merged1855_480_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_481_res = stg6_stg6_ld49_merged1855_481_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<16, 256>(result, stg6_stg6_ld49_merged1855_481_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_482_res = stg6_stg6_ld49_merged1855_482_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<32, 256>(result, stg6_stg6_ld49_merged1855_482_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_483_res = stg6_stg6_ld49_merged1855_483_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<48, 256>(result, stg6_stg6_ld49_merged1855_483_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_484_res = stg6_stg6_ld49_merged1855_484_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<64, 256>(result, stg6_stg6_ld49_merged1855_484_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_485_res = stg6_stg6_ld49_merged1855_485_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<80, 256>(result, stg6_stg6_ld49_merged1855_485_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_486_res = stg6_stg6_ld49_merged1855_486_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<96, 256>(result, stg6_stg6_ld49_merged1855_486_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_487_res = stg6_stg6_ld49_merged1855_487_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<112, 256>(result, stg6_stg6_ld49_merged1855_487_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_488_res = stg6_stg6_ld49_merged1855_488_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<128, 256>(result, stg6_stg6_ld49_merged1855_488_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_489_res = stg6_stg6_ld49_merged1855_489_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<144, 256>(result, stg6_stg6_ld49_merged1855_489_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_490_res = stg6_stg6_ld49_merged1855_490_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<160, 256>(result, stg6_stg6_ld49_merged1855_490_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_491_res = stg6_stg6_ld49_merged1855_491_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<176, 256>(result, stg6_stg6_ld49_merged1855_491_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_492_res = stg6_stg6_ld49_merged1855_492_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<192, 256>(result, stg6_stg6_ld49_merged1855_492_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_493_res = stg6_stg6_ld49_merged1855_493_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<208, 256>(result, stg6_stg6_ld49_merged1855_493_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_494_res = stg6_stg6_ld49_merged1855_494_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<224, 256>(result, stg6_stg6_ld49_merged1855_494_res);
	hw_uint<16> stg6_stg6_ld49_merged1855_495_res = stg6_stg6_ld49_merged1855_495_select(stg6, root, stg6_ld50, stg6_ld49, dynamic_address);
	set_at<240, 256>(result, stg6_stg6_ld49_merged1855_495_res);
	return result;
}

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_merged_banks_4_cache {
	// RAM Box: {[15, 1199], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_merged_banks_4_cache {
	// RAM Box: {[14, 1198], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_merged_banks_4_cache {
	// RAM Box: {[13, 1197], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_merged_banks_4_cache {
	// RAM Box: {[12, 1196], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_merged_banks_4_cache {
	// RAM Box: {[11, 1195], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_merged_banks_4_cache {
	// RAM Box: {[10, 1194], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_merged_banks_4_cache {
	// RAM Box: {[9, 1193], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_merged_banks_4_cache {
	// RAM Box: {[8, 1192], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_merged_banks_4_cache {
	// RAM Box: {[7, 1191], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_merged_banks_4_cache {
	// RAM Box: {[6, 1190], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_merged_banks_4_cache {
	// RAM Box: {[5, 1189], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_merged_banks_4_cache {
	// RAM Box: {[4, 1188], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_merged_banks_4_cache {
	// RAM Box: {[3, 1187], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_merged_banks_4_cache {
	// RAM Box: {[2, 1186], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_merged_banks_4_cache {
	// RAM Box: {[1, 1185], [-8, 1927]}
	// Capacity: 154
	// # of read delays: 4
  // 0, 1, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 75> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 75> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_76() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_77() {
		return f4;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_153() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_merged_banks_4_cache {
	// RAM Box: {[0, 1200], [-8, 1926]}
	// Capacity: 154
	// # of read delays: 5
  // 0, 1, 76, 77, 153
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 75> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_77() {
		return f6;
	}

	inline hw_uint<16> peek_152() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_153() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 75
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 75 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg6_FIFO_buf112_cache {
  // Reader addrs...
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[15 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[15 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[16 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[15 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[14 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[14 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[15 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[14 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[13 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[13 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[14 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[13 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[12 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[12 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[13 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[12 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[11 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[11 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[12 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[11 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[10 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[10 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[11 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[10 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[9 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[9 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[10 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[9 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[8 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[8 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[9 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[8 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[7 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[7 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[8 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[7 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[6 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[6 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[7 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[6 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[5 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[5 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[6 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[5 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[4 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[4 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[5 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[4 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[3 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[3 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[4 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[3 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[2 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[2 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[3 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[2 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[1 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[1 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[2 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[1 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[1 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
    // { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // # of banks: 16
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_merged_banks_4;
  stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_merged_banks_4_cache stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_merged_banks_4;
};



inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446);
}

inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_write(hw_uint<16>& stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
  stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_merged_banks_4.push(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447);
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_368_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_368 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[15 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_369_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_369 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[15 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_370_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_370 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[16 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_merged_banks_4.peek_76();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_371_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_371 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[15 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_372_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_372 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[14 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_373_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_373 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[14 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_374_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_374 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[15 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_375_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_375 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[14 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_376_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_376 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[13 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_377_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_377 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[13 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_378_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_378 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[14 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_379_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_379 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[13 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_380_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_380 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[12 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_381_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_381 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[12 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_382_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_382 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[13 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_383_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_383 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[12 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_384_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_384 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[11 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_385_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_385 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[11 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_386_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_386 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[12 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_387_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_387 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[11 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_388_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_388 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[10 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_389_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_389 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[10 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_390_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_390 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[11 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_391_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_391 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[10 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_392_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_392 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[9 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_393_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_393 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[9 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_394_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_394 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[10 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_395_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_395 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[9 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_396_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_396 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[8 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_397_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_397 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[8 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_398_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_398 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[9 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_399_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_399 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[8 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_400_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_400 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[7 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_401_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_401 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[7 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_402_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_402 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[8 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_403_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_403 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[7 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_404_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_404 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[6 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_405_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_405 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[6 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_406_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_406 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[7 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_407_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_407 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[6 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_408_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_408 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[5 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_409_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_409 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[5 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_410_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_410 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[6 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_411_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_411 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[5 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_412_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_412 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[4 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_413_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_413 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[4 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_414_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_414 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[5 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_415_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_415 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[4 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_416_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_416 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[3 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_417_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_417 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[3 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_418_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_418 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[4 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_419_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_419 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[3 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_420_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_420 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[2 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_421_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_421 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[2 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_422_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_422 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[3 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_423_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_423 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[2 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_424_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_424 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[1 + 16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_425_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_425 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[1 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_426_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_426 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[2 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_427_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_427 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[1 + 16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_428_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_428 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[16stg7_1, -8 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_merged_banks_4.peek_153();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_429_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_429 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_430_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_430 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[1 + 16stg7_1, -7 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_merged_banks_4.peek_77();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446;
  return 0;
}

inline hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_431_select(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg6_FIFO_buf112_stg7_1_merged1817_431 read pattern: { stg7_1_merged1817[root = 0, stg7_0, stg7_1] -> stg6_FIFO_buf112[16stg7_1, -6 + stg7_0] : 0 <= stg7_0 <= 1933 and 0 <= stg7_1 <= 74 }
  // Read schedule : { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
  auto value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447 = stg6_FIFO_buf112.stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_merged_banks_4.peek_1();
  return value_stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447;
  return 0;
}

// # of bundles = 2
// stg6_to_gp_1448_ld113_merged1762_write
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446
//	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447
inline void stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_write_bundle_write(hw_uint<256>& stg6_to_gp_1448_ld113_merged1762_write, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg6_to_gp_1448_ld114, int stg6_to_gp_1448_ld113, int dynamic_address) {
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_res = stg6_to_gp_1448_ld113_merged1762_write.extract<0, 15>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_432_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_res = stg6_to_gp_1448_ld113_merged1762_write.extract<16, 31>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_433_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_res = stg6_to_gp_1448_ld113_merged1762_write.extract<32, 47>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_434_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_res = stg6_to_gp_1448_ld113_merged1762_write.extract<48, 63>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_435_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_res = stg6_to_gp_1448_ld113_merged1762_write.extract<64, 79>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_436_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_res = stg6_to_gp_1448_ld113_merged1762_write.extract<80, 95>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_437_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_res = stg6_to_gp_1448_ld113_merged1762_write.extract<96, 111>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_438_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_res = stg6_to_gp_1448_ld113_merged1762_write.extract<112, 127>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_439_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_res = stg6_to_gp_1448_ld113_merged1762_write.extract<128, 143>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_440_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_res = stg6_to_gp_1448_ld113_merged1762_write.extract<144, 159>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_441_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_res = stg6_to_gp_1448_ld113_merged1762_write.extract<160, 175>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_442_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_res = stg6_to_gp_1448_ld113_merged1762_write.extract<176, 191>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_443_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_res = stg6_to_gp_1448_ld113_merged1762_write.extract<192, 207>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_444_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_res = stg6_to_gp_1448_ld113_merged1762_write.extract<208, 223>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_445_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_res = stg6_to_gp_1448_ld113_merged1762_write.extract<224, 239>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_446_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
	hw_uint<16> stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_res = stg6_to_gp_1448_ld113_merged1762_write.extract<240, 255>();
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_write(stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_447_res, stg6_FIFO_buf112, root, stg6_to_gp_1448_ld114, stg6_to_gp_1448_ld113, dynamic_address);
}

// stg7_1_merged1817_read
//	stg6_FIFO_buf112_stg7_1_merged1817_368
//	stg6_FIFO_buf112_stg7_1_merged1817_369
//	stg6_FIFO_buf112_stg7_1_merged1817_370
//	stg6_FIFO_buf112_stg7_1_merged1817_371
//	stg6_FIFO_buf112_stg7_1_merged1817_372
//	stg6_FIFO_buf112_stg7_1_merged1817_373
//	stg6_FIFO_buf112_stg7_1_merged1817_374
//	stg6_FIFO_buf112_stg7_1_merged1817_375
//	stg6_FIFO_buf112_stg7_1_merged1817_376
//	stg6_FIFO_buf112_stg7_1_merged1817_377
//	stg6_FIFO_buf112_stg7_1_merged1817_378
//	stg6_FIFO_buf112_stg7_1_merged1817_379
//	stg6_FIFO_buf112_stg7_1_merged1817_380
//	stg6_FIFO_buf112_stg7_1_merged1817_381
//	stg6_FIFO_buf112_stg7_1_merged1817_382
//	stg6_FIFO_buf112_stg7_1_merged1817_383
//	stg6_FIFO_buf112_stg7_1_merged1817_384
//	stg6_FIFO_buf112_stg7_1_merged1817_385
//	stg6_FIFO_buf112_stg7_1_merged1817_386
//	stg6_FIFO_buf112_stg7_1_merged1817_387
//	stg6_FIFO_buf112_stg7_1_merged1817_388
//	stg6_FIFO_buf112_stg7_1_merged1817_389
//	stg6_FIFO_buf112_stg7_1_merged1817_390
//	stg6_FIFO_buf112_stg7_1_merged1817_391
//	stg6_FIFO_buf112_stg7_1_merged1817_392
//	stg6_FIFO_buf112_stg7_1_merged1817_393
//	stg6_FIFO_buf112_stg7_1_merged1817_394
//	stg6_FIFO_buf112_stg7_1_merged1817_395
//	stg6_FIFO_buf112_stg7_1_merged1817_396
//	stg6_FIFO_buf112_stg7_1_merged1817_397
//	stg6_FIFO_buf112_stg7_1_merged1817_398
//	stg6_FIFO_buf112_stg7_1_merged1817_399
//	stg6_FIFO_buf112_stg7_1_merged1817_400
//	stg6_FIFO_buf112_stg7_1_merged1817_401
//	stg6_FIFO_buf112_stg7_1_merged1817_402
//	stg6_FIFO_buf112_stg7_1_merged1817_403
//	stg6_FIFO_buf112_stg7_1_merged1817_404
//	stg6_FIFO_buf112_stg7_1_merged1817_405
//	stg6_FIFO_buf112_stg7_1_merged1817_406
//	stg6_FIFO_buf112_stg7_1_merged1817_407
//	stg6_FIFO_buf112_stg7_1_merged1817_408
//	stg6_FIFO_buf112_stg7_1_merged1817_409
//	stg6_FIFO_buf112_stg7_1_merged1817_410
//	stg6_FIFO_buf112_stg7_1_merged1817_411
//	stg6_FIFO_buf112_stg7_1_merged1817_412
//	stg6_FIFO_buf112_stg7_1_merged1817_413
//	stg6_FIFO_buf112_stg7_1_merged1817_414
//	stg6_FIFO_buf112_stg7_1_merged1817_415
//	stg6_FIFO_buf112_stg7_1_merged1817_416
//	stg6_FIFO_buf112_stg7_1_merged1817_417
//	stg6_FIFO_buf112_stg7_1_merged1817_418
//	stg6_FIFO_buf112_stg7_1_merged1817_419
//	stg6_FIFO_buf112_stg7_1_merged1817_420
//	stg6_FIFO_buf112_stg7_1_merged1817_421
//	stg6_FIFO_buf112_stg7_1_merged1817_422
//	stg6_FIFO_buf112_stg7_1_merged1817_423
//	stg6_FIFO_buf112_stg7_1_merged1817_424
//	stg6_FIFO_buf112_stg7_1_merged1817_425
//	stg6_FIFO_buf112_stg7_1_merged1817_426
//	stg6_FIFO_buf112_stg7_1_merged1817_427
//	stg6_FIFO_buf112_stg7_1_merged1817_428
//	stg6_FIFO_buf112_stg7_1_merged1817_429
//	stg6_FIFO_buf112_stg7_1_merged1817_430
//	stg6_FIFO_buf112_stg7_1_merged1817_431
inline hw_uint<1024> stg6_FIFO_buf112_stg7_1_merged1817_read_bundle_read(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int root, int stg7_0, int stg7_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg6_FIFO_buf112_stg7_1_merged1817_368
    // stg6_FIFO_buf112_stg7_1_merged1817_369
    // stg6_FIFO_buf112_stg7_1_merged1817_370
    // stg6_FIFO_buf112_stg7_1_merged1817_371
    // stg6_FIFO_buf112_stg7_1_merged1817_372
    // stg6_FIFO_buf112_stg7_1_merged1817_373
    // stg6_FIFO_buf112_stg7_1_merged1817_374
    // stg6_FIFO_buf112_stg7_1_merged1817_375
    // stg6_FIFO_buf112_stg7_1_merged1817_376
    // stg6_FIFO_buf112_stg7_1_merged1817_377
    // stg6_FIFO_buf112_stg7_1_merged1817_378
    // stg6_FIFO_buf112_stg7_1_merged1817_379
    // stg6_FIFO_buf112_stg7_1_merged1817_380
    // stg6_FIFO_buf112_stg7_1_merged1817_381
    // stg6_FIFO_buf112_stg7_1_merged1817_382
    // stg6_FIFO_buf112_stg7_1_merged1817_383
    // stg6_FIFO_buf112_stg7_1_merged1817_384
    // stg6_FIFO_buf112_stg7_1_merged1817_385
    // stg6_FIFO_buf112_stg7_1_merged1817_386
    // stg6_FIFO_buf112_stg7_1_merged1817_387
    // stg6_FIFO_buf112_stg7_1_merged1817_388
    // stg6_FIFO_buf112_stg7_1_merged1817_389
    // stg6_FIFO_buf112_stg7_1_merged1817_390
    // stg6_FIFO_buf112_stg7_1_merged1817_391
    // stg6_FIFO_buf112_stg7_1_merged1817_392
    // stg6_FIFO_buf112_stg7_1_merged1817_393
    // stg6_FIFO_buf112_stg7_1_merged1817_394
    // stg6_FIFO_buf112_stg7_1_merged1817_395
    // stg6_FIFO_buf112_stg7_1_merged1817_396
    // stg6_FIFO_buf112_stg7_1_merged1817_397
    // stg6_FIFO_buf112_stg7_1_merged1817_398
    // stg6_FIFO_buf112_stg7_1_merged1817_399
    // stg6_FIFO_buf112_stg7_1_merged1817_400
    // stg6_FIFO_buf112_stg7_1_merged1817_401
    // stg6_FIFO_buf112_stg7_1_merged1817_402
    // stg6_FIFO_buf112_stg7_1_merged1817_403
    // stg6_FIFO_buf112_stg7_1_merged1817_404
    // stg6_FIFO_buf112_stg7_1_merged1817_405
    // stg6_FIFO_buf112_stg7_1_merged1817_406
    // stg6_FIFO_buf112_stg7_1_merged1817_407
    // stg6_FIFO_buf112_stg7_1_merged1817_408
    // stg6_FIFO_buf112_stg7_1_merged1817_409
    // stg6_FIFO_buf112_stg7_1_merged1817_410
    // stg6_FIFO_buf112_stg7_1_merged1817_411
    // stg6_FIFO_buf112_stg7_1_merged1817_412
    // stg6_FIFO_buf112_stg7_1_merged1817_413
    // stg6_FIFO_buf112_stg7_1_merged1817_414
    // stg6_FIFO_buf112_stg7_1_merged1817_415
    // stg6_FIFO_buf112_stg7_1_merged1817_416
    // stg6_FIFO_buf112_stg7_1_merged1817_417
    // stg6_FIFO_buf112_stg7_1_merged1817_418
    // stg6_FIFO_buf112_stg7_1_merged1817_419
    // stg6_FIFO_buf112_stg7_1_merged1817_420
    // stg6_FIFO_buf112_stg7_1_merged1817_421
    // stg6_FIFO_buf112_stg7_1_merged1817_422
    // stg6_FIFO_buf112_stg7_1_merged1817_423
    // stg6_FIFO_buf112_stg7_1_merged1817_424
    // stg6_FIFO_buf112_stg7_1_merged1817_425
    // stg6_FIFO_buf112_stg7_1_merged1817_426
    // stg6_FIFO_buf112_stg7_1_merged1817_427
    // stg6_FIFO_buf112_stg7_1_merged1817_428
    // stg6_FIFO_buf112_stg7_1_merged1817_429
    // stg6_FIFO_buf112_stg7_1_merged1817_430
    // stg6_FIFO_buf112_stg7_1_merged1817_431

	hw_uint<1024> result;
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_368_res = stg6_FIFO_buf112_stg7_1_merged1817_368_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<0, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_368_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_369_res = stg6_FIFO_buf112_stg7_1_merged1817_369_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<16, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_369_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_370_res = stg6_FIFO_buf112_stg7_1_merged1817_370_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<32, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_370_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_371_res = stg6_FIFO_buf112_stg7_1_merged1817_371_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<48, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_371_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_372_res = stg6_FIFO_buf112_stg7_1_merged1817_372_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<64, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_372_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_373_res = stg6_FIFO_buf112_stg7_1_merged1817_373_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<80, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_373_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_374_res = stg6_FIFO_buf112_stg7_1_merged1817_374_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<96, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_374_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_375_res = stg6_FIFO_buf112_stg7_1_merged1817_375_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<112, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_375_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_376_res = stg6_FIFO_buf112_stg7_1_merged1817_376_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<128, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_376_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_377_res = stg6_FIFO_buf112_stg7_1_merged1817_377_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<144, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_377_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_378_res = stg6_FIFO_buf112_stg7_1_merged1817_378_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<160, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_378_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_379_res = stg6_FIFO_buf112_stg7_1_merged1817_379_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<176, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_379_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_380_res = stg6_FIFO_buf112_stg7_1_merged1817_380_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<192, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_380_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_381_res = stg6_FIFO_buf112_stg7_1_merged1817_381_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<208, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_381_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_382_res = stg6_FIFO_buf112_stg7_1_merged1817_382_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<224, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_382_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_383_res = stg6_FIFO_buf112_stg7_1_merged1817_383_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<240, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_383_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_384_res = stg6_FIFO_buf112_stg7_1_merged1817_384_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<256, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_384_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_385_res = stg6_FIFO_buf112_stg7_1_merged1817_385_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<272, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_385_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_386_res = stg6_FIFO_buf112_stg7_1_merged1817_386_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<288, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_386_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_387_res = stg6_FIFO_buf112_stg7_1_merged1817_387_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<304, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_387_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_388_res = stg6_FIFO_buf112_stg7_1_merged1817_388_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<320, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_388_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_389_res = stg6_FIFO_buf112_stg7_1_merged1817_389_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<336, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_389_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_390_res = stg6_FIFO_buf112_stg7_1_merged1817_390_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<352, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_390_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_391_res = stg6_FIFO_buf112_stg7_1_merged1817_391_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<368, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_391_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_392_res = stg6_FIFO_buf112_stg7_1_merged1817_392_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<384, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_392_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_393_res = stg6_FIFO_buf112_stg7_1_merged1817_393_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<400, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_393_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_394_res = stg6_FIFO_buf112_stg7_1_merged1817_394_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<416, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_394_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_395_res = stg6_FIFO_buf112_stg7_1_merged1817_395_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<432, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_395_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_396_res = stg6_FIFO_buf112_stg7_1_merged1817_396_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<448, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_396_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_397_res = stg6_FIFO_buf112_stg7_1_merged1817_397_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<464, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_397_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_398_res = stg6_FIFO_buf112_stg7_1_merged1817_398_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<480, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_398_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_399_res = stg6_FIFO_buf112_stg7_1_merged1817_399_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<496, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_399_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_400_res = stg6_FIFO_buf112_stg7_1_merged1817_400_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<512, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_400_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_401_res = stg6_FIFO_buf112_stg7_1_merged1817_401_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<528, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_401_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_402_res = stg6_FIFO_buf112_stg7_1_merged1817_402_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<544, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_402_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_403_res = stg6_FIFO_buf112_stg7_1_merged1817_403_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<560, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_403_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_404_res = stg6_FIFO_buf112_stg7_1_merged1817_404_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<576, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_404_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_405_res = stg6_FIFO_buf112_stg7_1_merged1817_405_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<592, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_405_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_406_res = stg6_FIFO_buf112_stg7_1_merged1817_406_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<608, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_406_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_407_res = stg6_FIFO_buf112_stg7_1_merged1817_407_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<624, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_407_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_408_res = stg6_FIFO_buf112_stg7_1_merged1817_408_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<640, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_408_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_409_res = stg6_FIFO_buf112_stg7_1_merged1817_409_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<656, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_409_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_410_res = stg6_FIFO_buf112_stg7_1_merged1817_410_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<672, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_410_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_411_res = stg6_FIFO_buf112_stg7_1_merged1817_411_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<688, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_411_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_412_res = stg6_FIFO_buf112_stg7_1_merged1817_412_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<704, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_412_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_413_res = stg6_FIFO_buf112_stg7_1_merged1817_413_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<720, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_413_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_414_res = stg6_FIFO_buf112_stg7_1_merged1817_414_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<736, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_414_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_415_res = stg6_FIFO_buf112_stg7_1_merged1817_415_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<752, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_415_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_416_res = stg6_FIFO_buf112_stg7_1_merged1817_416_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<768, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_416_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_417_res = stg6_FIFO_buf112_stg7_1_merged1817_417_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<784, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_417_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_418_res = stg6_FIFO_buf112_stg7_1_merged1817_418_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<800, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_418_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_419_res = stg6_FIFO_buf112_stg7_1_merged1817_419_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<816, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_419_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_420_res = stg6_FIFO_buf112_stg7_1_merged1817_420_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<832, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_420_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_421_res = stg6_FIFO_buf112_stg7_1_merged1817_421_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<848, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_421_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_422_res = stg6_FIFO_buf112_stg7_1_merged1817_422_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<864, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_422_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_423_res = stg6_FIFO_buf112_stg7_1_merged1817_423_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<880, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_423_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_424_res = stg6_FIFO_buf112_stg7_1_merged1817_424_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<896, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_424_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_425_res = stg6_FIFO_buf112_stg7_1_merged1817_425_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<912, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_425_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_426_res = stg6_FIFO_buf112_stg7_1_merged1817_426_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<928, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_426_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_427_res = stg6_FIFO_buf112_stg7_1_merged1817_427_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<944, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_427_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_428_res = stg6_FIFO_buf112_stg7_1_merged1817_428_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<960, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_428_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_429_res = stg6_FIFO_buf112_stg7_1_merged1817_429_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<976, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_429_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_430_res = stg6_FIFO_buf112_stg7_1_merged1817_430_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<992, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_430_res);
	hw_uint<16> stg6_FIFO_buf112_stg7_1_merged1817_431_res = stg6_FIFO_buf112_stg7_1_merged1817_431_select(stg6_FIFO_buf112, root, stg7_0, stg7_1, dynamic_address);
	set_at<1008, 1024>(result, stg6_FIFO_buf112_stg7_1_merged1817_431_res);
	return result;
}

struct stg7_stg7_1_merged1817_352_to_stg7_stg7_ld53_merged1752_336_cache {
	// RAM Box: {[15, 1199], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_353_to_stg7_stg7_ld53_merged1752_337_cache {
	// RAM Box: {[14, 1198], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_354_to_stg7_stg7_ld53_merged1752_338_cache {
	// RAM Box: {[13, 1197], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_355_to_stg7_stg7_ld53_merged1752_339_cache {
	// RAM Box: {[12, 1196], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_356_to_stg7_stg7_ld53_merged1752_340_cache {
	// RAM Box: {[11, 1195], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_357_to_stg7_stg7_ld53_merged1752_341_cache {
	// RAM Box: {[10, 1194], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_358_to_stg7_stg7_ld53_merged1752_342_cache {
	// RAM Box: {[9, 1193], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_359_to_stg7_stg7_ld53_merged1752_343_cache {
	// RAM Box: {[8, 1192], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_360_to_stg7_stg7_ld53_merged1752_344_cache {
	// RAM Box: {[7, 1191], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_361_to_stg7_stg7_ld53_merged1752_345_cache {
	// RAM Box: {[6, 1190], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_362_to_stg7_stg7_ld53_merged1752_346_cache {
	// RAM Box: {[5, 1189], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_363_to_stg7_stg7_ld53_merged1752_347_cache {
	// RAM Box: {[4, 1188], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_364_to_stg7_stg7_ld53_merged1752_348_cache {
	// RAM Box: {[3, 1187], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_365_to_stg7_stg7_ld53_merged1752_349_cache {
	// RAM Box: {[2, 1186], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_366_to_stg7_stg7_ld53_merged1752_350_cache {
	// RAM Box: {[1, 1185], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_stg7_1_merged1817_367_to_stg7_stg7_ld53_merged1752_351_cache {
	// RAM Box: {[0, 1184], [-7, 1926]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg7_cache {
  // Reader addrs...
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[15 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[14 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[13 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[12 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[11 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[10 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[9 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[8 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[7 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[6 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[5 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[4 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[3 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[2 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[1 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
    // { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // # of banks: 16
  stg7_stg7_1_merged1817_352_to_stg7_stg7_ld53_merged1752_336_cache stg7_stg7_1_merged1817_352_to_stg7_stg7_ld53_merged1752_336;
  stg7_stg7_1_merged1817_353_to_stg7_stg7_ld53_merged1752_337_cache stg7_stg7_1_merged1817_353_to_stg7_stg7_ld53_merged1752_337;
  stg7_stg7_1_merged1817_354_to_stg7_stg7_ld53_merged1752_338_cache stg7_stg7_1_merged1817_354_to_stg7_stg7_ld53_merged1752_338;
  stg7_stg7_1_merged1817_355_to_stg7_stg7_ld53_merged1752_339_cache stg7_stg7_1_merged1817_355_to_stg7_stg7_ld53_merged1752_339;
  stg7_stg7_1_merged1817_356_to_stg7_stg7_ld53_merged1752_340_cache stg7_stg7_1_merged1817_356_to_stg7_stg7_ld53_merged1752_340;
  stg7_stg7_1_merged1817_357_to_stg7_stg7_ld53_merged1752_341_cache stg7_stg7_1_merged1817_357_to_stg7_stg7_ld53_merged1752_341;
  stg7_stg7_1_merged1817_358_to_stg7_stg7_ld53_merged1752_342_cache stg7_stg7_1_merged1817_358_to_stg7_stg7_ld53_merged1752_342;
  stg7_stg7_1_merged1817_359_to_stg7_stg7_ld53_merged1752_343_cache stg7_stg7_1_merged1817_359_to_stg7_stg7_ld53_merged1752_343;
  stg7_stg7_1_merged1817_360_to_stg7_stg7_ld53_merged1752_344_cache stg7_stg7_1_merged1817_360_to_stg7_stg7_ld53_merged1752_344;
  stg7_stg7_1_merged1817_361_to_stg7_stg7_ld53_merged1752_345_cache stg7_stg7_1_merged1817_361_to_stg7_stg7_ld53_merged1752_345;
  stg7_stg7_1_merged1817_362_to_stg7_stg7_ld53_merged1752_346_cache stg7_stg7_1_merged1817_362_to_stg7_stg7_ld53_merged1752_346;
  stg7_stg7_1_merged1817_363_to_stg7_stg7_ld53_merged1752_347_cache stg7_stg7_1_merged1817_363_to_stg7_stg7_ld53_merged1752_347;
  stg7_stg7_1_merged1817_364_to_stg7_stg7_ld53_merged1752_348_cache stg7_stg7_1_merged1817_364_to_stg7_stg7_ld53_merged1752_348;
  stg7_stg7_1_merged1817_365_to_stg7_stg7_ld53_merged1752_349_cache stg7_stg7_1_merged1817_365_to_stg7_stg7_ld53_merged1752_349;
  stg7_stg7_1_merged1817_366_to_stg7_stg7_ld53_merged1752_350_cache stg7_stg7_1_merged1817_366_to_stg7_stg7_ld53_merged1752_350;
  stg7_stg7_1_merged1817_367_to_stg7_stg7_ld53_merged1752_351_cache stg7_stg7_1_merged1817_367_to_stg7_stg7_ld53_merged1752_351;
};



inline void stg7_stg7_1_merged1817_352_write(hw_uint<16>& stg7_stg7_1_merged1817_352, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_352_to_stg7_stg7_ld53_merged1752_336.push(stg7_stg7_1_merged1817_352);
}

inline void stg7_stg7_1_merged1817_353_write(hw_uint<16>& stg7_stg7_1_merged1817_353, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_353_to_stg7_stg7_ld53_merged1752_337.push(stg7_stg7_1_merged1817_353);
}

inline void stg7_stg7_1_merged1817_354_write(hw_uint<16>& stg7_stg7_1_merged1817_354, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_354_to_stg7_stg7_ld53_merged1752_338.push(stg7_stg7_1_merged1817_354);
}

inline void stg7_stg7_1_merged1817_355_write(hw_uint<16>& stg7_stg7_1_merged1817_355, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_355_to_stg7_stg7_ld53_merged1752_339.push(stg7_stg7_1_merged1817_355);
}

inline void stg7_stg7_1_merged1817_356_write(hw_uint<16>& stg7_stg7_1_merged1817_356, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_356_to_stg7_stg7_ld53_merged1752_340.push(stg7_stg7_1_merged1817_356);
}

inline void stg7_stg7_1_merged1817_357_write(hw_uint<16>& stg7_stg7_1_merged1817_357, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_357_to_stg7_stg7_ld53_merged1752_341.push(stg7_stg7_1_merged1817_357);
}

inline void stg7_stg7_1_merged1817_358_write(hw_uint<16>& stg7_stg7_1_merged1817_358, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_358_to_stg7_stg7_ld53_merged1752_342.push(stg7_stg7_1_merged1817_358);
}

inline void stg7_stg7_1_merged1817_359_write(hw_uint<16>& stg7_stg7_1_merged1817_359, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_359_to_stg7_stg7_ld53_merged1752_343.push(stg7_stg7_1_merged1817_359);
}

inline void stg7_stg7_1_merged1817_360_write(hw_uint<16>& stg7_stg7_1_merged1817_360, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_360_to_stg7_stg7_ld53_merged1752_344.push(stg7_stg7_1_merged1817_360);
}

inline void stg7_stg7_1_merged1817_361_write(hw_uint<16>& stg7_stg7_1_merged1817_361, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_361_to_stg7_stg7_ld53_merged1752_345.push(stg7_stg7_1_merged1817_361);
}

inline void stg7_stg7_1_merged1817_362_write(hw_uint<16>& stg7_stg7_1_merged1817_362, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_362_to_stg7_stg7_ld53_merged1752_346.push(stg7_stg7_1_merged1817_362);
}

inline void stg7_stg7_1_merged1817_363_write(hw_uint<16>& stg7_stg7_1_merged1817_363, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_363_to_stg7_stg7_ld53_merged1752_347.push(stg7_stg7_1_merged1817_363);
}

inline void stg7_stg7_1_merged1817_364_write(hw_uint<16>& stg7_stg7_1_merged1817_364, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_364_to_stg7_stg7_ld53_merged1752_348.push(stg7_stg7_1_merged1817_364);
}

inline void stg7_stg7_1_merged1817_365_write(hw_uint<16>& stg7_stg7_1_merged1817_365, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_365_to_stg7_stg7_ld53_merged1752_349.push(stg7_stg7_1_merged1817_365);
}

inline void stg7_stg7_1_merged1817_366_write(hw_uint<16>& stg7_stg7_1_merged1817_366, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_366_to_stg7_stg7_ld53_merged1752_350.push(stg7_stg7_1_merged1817_366);
}

inline void stg7_stg7_1_merged1817_367_write(hw_uint<16>& stg7_stg7_1_merged1817_367, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
  stg7.stg7_stg7_1_merged1817_367_to_stg7_stg7_ld53_merged1752_351.push(stg7_stg7_1_merged1817_367);
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_336_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_336 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[15 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_352 = stg7.stg7_stg7_1_merged1817_352_to_stg7_stg7_ld53_merged1752_336.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_352;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_337_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_337 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[14 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_353 = stg7.stg7_stg7_1_merged1817_353_to_stg7_stg7_ld53_merged1752_337.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_353;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_338_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_338 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[13 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_354 = stg7.stg7_stg7_1_merged1817_354_to_stg7_stg7_ld53_merged1752_338.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_354;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_339_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_339 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[12 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_355 = stg7.stg7_stg7_1_merged1817_355_to_stg7_stg7_ld53_merged1752_339.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_355;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_340_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_340 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[11 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_356 = stg7.stg7_stg7_1_merged1817_356_to_stg7_stg7_ld53_merged1752_340.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_356;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_341_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_341 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[10 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_357 = stg7.stg7_stg7_1_merged1817_357_to_stg7_stg7_ld53_merged1752_341.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_357;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_342_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_342 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[9 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_358 = stg7.stg7_stg7_1_merged1817_358_to_stg7_stg7_ld53_merged1752_342.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_358;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_343_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_343 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[8 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_359 = stg7.stg7_stg7_1_merged1817_359_to_stg7_stg7_ld53_merged1752_343.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_359;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_344_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_344 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[7 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_360 = stg7.stg7_stg7_1_merged1817_360_to_stg7_stg7_ld53_merged1752_344.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_360;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_345_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_345 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[6 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_361 = stg7.stg7_stg7_1_merged1817_361_to_stg7_stg7_ld53_merged1752_345.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_361;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_346_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_346 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[5 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_362 = stg7.stg7_stg7_1_merged1817_362_to_stg7_stg7_ld53_merged1752_346.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_362;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_347_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_347 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[4 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_363 = stg7.stg7_stg7_1_merged1817_363_to_stg7_stg7_ld53_merged1752_347.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_363;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_348_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_348 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[3 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_364 = stg7.stg7_stg7_1_merged1817_364_to_stg7_stg7_ld53_merged1752_348.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_364;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_349_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_349 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[2 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_365 = stg7.stg7_stg7_1_merged1817_365_to_stg7_stg7_ld53_merged1752_349.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_365;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_350_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_350 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[1 + 16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_366 = stg7.stg7_stg7_1_merged1817_366_to_stg7_stg7_ld53_merged1752_350.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_366;
  return 0;
}

inline hw_uint<16> stg7_stg7_ld53_merged1752_351_select(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_stg7_ld53_merged1752_351 read pattern: { stg7_ld53_merged1752[root = 0, stg7_ld54, stg7_ld53] -> stg7[16stg7_ld53, -7 + stg7_ld54] : 0 <= stg7_ld54 <= 1933 and 0 <= stg7_ld53 <= 74 }
  // Read schedule : { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  // Write schedule: { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_stg7_1_merged1817_367 = stg7.stg7_stg7_1_merged1817_367_to_stg7_stg7_ld53_merged1752_351.peek(/* one reader or all rams */ 0);
  return value_stg7_stg7_1_merged1817_367;
  return 0;
}

// # of bundles = 2
// stg7_1_merged1817_write
//	stg7_stg7_1_merged1817_352
//	stg7_stg7_1_merged1817_353
//	stg7_stg7_1_merged1817_354
//	stg7_stg7_1_merged1817_355
//	stg7_stg7_1_merged1817_356
//	stg7_stg7_1_merged1817_357
//	stg7_stg7_1_merged1817_358
//	stg7_stg7_1_merged1817_359
//	stg7_stg7_1_merged1817_360
//	stg7_stg7_1_merged1817_361
//	stg7_stg7_1_merged1817_362
//	stg7_stg7_1_merged1817_363
//	stg7_stg7_1_merged1817_364
//	stg7_stg7_1_merged1817_365
//	stg7_stg7_1_merged1817_366
//	stg7_stg7_1_merged1817_367
inline void stg7_stg7_1_merged1817_write_bundle_write(hw_uint<256>& stg7_1_merged1817_write, stg7_cache& stg7, int root, int stg7_0, int stg7_1, int dynamic_address) {
	hw_uint<16> stg7_stg7_1_merged1817_352_res = stg7_1_merged1817_write.extract<0, 15>();
	stg7_stg7_1_merged1817_352_write(stg7_stg7_1_merged1817_352_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_353_res = stg7_1_merged1817_write.extract<16, 31>();
	stg7_stg7_1_merged1817_353_write(stg7_stg7_1_merged1817_353_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_354_res = stg7_1_merged1817_write.extract<32, 47>();
	stg7_stg7_1_merged1817_354_write(stg7_stg7_1_merged1817_354_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_355_res = stg7_1_merged1817_write.extract<48, 63>();
	stg7_stg7_1_merged1817_355_write(stg7_stg7_1_merged1817_355_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_356_res = stg7_1_merged1817_write.extract<64, 79>();
	stg7_stg7_1_merged1817_356_write(stg7_stg7_1_merged1817_356_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_357_res = stg7_1_merged1817_write.extract<80, 95>();
	stg7_stg7_1_merged1817_357_write(stg7_stg7_1_merged1817_357_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_358_res = stg7_1_merged1817_write.extract<96, 111>();
	stg7_stg7_1_merged1817_358_write(stg7_stg7_1_merged1817_358_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_359_res = stg7_1_merged1817_write.extract<112, 127>();
	stg7_stg7_1_merged1817_359_write(stg7_stg7_1_merged1817_359_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_360_res = stg7_1_merged1817_write.extract<128, 143>();
	stg7_stg7_1_merged1817_360_write(stg7_stg7_1_merged1817_360_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_361_res = stg7_1_merged1817_write.extract<144, 159>();
	stg7_stg7_1_merged1817_361_write(stg7_stg7_1_merged1817_361_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_362_res = stg7_1_merged1817_write.extract<160, 175>();
	stg7_stg7_1_merged1817_362_write(stg7_stg7_1_merged1817_362_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_363_res = stg7_1_merged1817_write.extract<176, 191>();
	stg7_stg7_1_merged1817_363_write(stg7_stg7_1_merged1817_363_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_364_res = stg7_1_merged1817_write.extract<192, 207>();
	stg7_stg7_1_merged1817_364_write(stg7_stg7_1_merged1817_364_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_365_res = stg7_1_merged1817_write.extract<208, 223>();
	stg7_stg7_1_merged1817_365_write(stg7_stg7_1_merged1817_365_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_366_res = stg7_1_merged1817_write.extract<224, 239>();
	stg7_stg7_1_merged1817_366_write(stg7_stg7_1_merged1817_366_res, stg7, root, stg7_0, stg7_1, dynamic_address);
	hw_uint<16> stg7_stg7_1_merged1817_367_res = stg7_1_merged1817_write.extract<240, 255>();
	stg7_stg7_1_merged1817_367_write(stg7_stg7_1_merged1817_367_res, stg7, root, stg7_0, stg7_1, dynamic_address);
}

// stg7_ld53_merged1752_read
//	stg7_stg7_ld53_merged1752_336
//	stg7_stg7_ld53_merged1752_337
//	stg7_stg7_ld53_merged1752_338
//	stg7_stg7_ld53_merged1752_339
//	stg7_stg7_ld53_merged1752_340
//	stg7_stg7_ld53_merged1752_341
//	stg7_stg7_ld53_merged1752_342
//	stg7_stg7_ld53_merged1752_343
//	stg7_stg7_ld53_merged1752_344
//	stg7_stg7_ld53_merged1752_345
//	stg7_stg7_ld53_merged1752_346
//	stg7_stg7_ld53_merged1752_347
//	stg7_stg7_ld53_merged1752_348
//	stg7_stg7_ld53_merged1752_349
//	stg7_stg7_ld53_merged1752_350
//	stg7_stg7_ld53_merged1752_351
inline hw_uint<256> stg7_stg7_ld53_merged1752_read_bundle_read(stg7_cache& stg7, int root, int stg7_ld54, int stg7_ld53, int dynamic_address) {
  // # of ports in bundle: 16
    // stg7_stg7_ld53_merged1752_336
    // stg7_stg7_ld53_merged1752_337
    // stg7_stg7_ld53_merged1752_338
    // stg7_stg7_ld53_merged1752_339
    // stg7_stg7_ld53_merged1752_340
    // stg7_stg7_ld53_merged1752_341
    // stg7_stg7_ld53_merged1752_342
    // stg7_stg7_ld53_merged1752_343
    // stg7_stg7_ld53_merged1752_344
    // stg7_stg7_ld53_merged1752_345
    // stg7_stg7_ld53_merged1752_346
    // stg7_stg7_ld53_merged1752_347
    // stg7_stg7_ld53_merged1752_348
    // stg7_stg7_ld53_merged1752_349
    // stg7_stg7_ld53_merged1752_350
    // stg7_stg7_ld53_merged1752_351

	hw_uint<256> result;
	hw_uint<16> stg7_stg7_ld53_merged1752_336_res = stg7_stg7_ld53_merged1752_336_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<0, 256>(result, stg7_stg7_ld53_merged1752_336_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_337_res = stg7_stg7_ld53_merged1752_337_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<16, 256>(result, stg7_stg7_ld53_merged1752_337_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_338_res = stg7_stg7_ld53_merged1752_338_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<32, 256>(result, stg7_stg7_ld53_merged1752_338_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_339_res = stg7_stg7_ld53_merged1752_339_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<48, 256>(result, stg7_stg7_ld53_merged1752_339_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_340_res = stg7_stg7_ld53_merged1752_340_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<64, 256>(result, stg7_stg7_ld53_merged1752_340_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_341_res = stg7_stg7_ld53_merged1752_341_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<80, 256>(result, stg7_stg7_ld53_merged1752_341_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_342_res = stg7_stg7_ld53_merged1752_342_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<96, 256>(result, stg7_stg7_ld53_merged1752_342_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_343_res = stg7_stg7_ld53_merged1752_343_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<112, 256>(result, stg7_stg7_ld53_merged1752_343_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_344_res = stg7_stg7_ld53_merged1752_344_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<128, 256>(result, stg7_stg7_ld53_merged1752_344_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_345_res = stg7_stg7_ld53_merged1752_345_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<144, 256>(result, stg7_stg7_ld53_merged1752_345_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_346_res = stg7_stg7_ld53_merged1752_346_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<160, 256>(result, stg7_stg7_ld53_merged1752_346_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_347_res = stg7_stg7_ld53_merged1752_347_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<176, 256>(result, stg7_stg7_ld53_merged1752_347_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_348_res = stg7_stg7_ld53_merged1752_348_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<192, 256>(result, stg7_stg7_ld53_merged1752_348_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_349_res = stg7_stg7_ld53_merged1752_349_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<208, 256>(result, stg7_stg7_ld53_merged1752_349_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_350_res = stg7_stg7_ld53_merged1752_350_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<224, 256>(result, stg7_stg7_ld53_merged1752_350_res);
	hw_uint<16> stg7_stg7_ld53_merged1752_351_res = stg7_stg7_ld53_merged1752_351_select(stg7, root, stg7_ld54, stg7_ld53, dynamic_address);
	set_at<240, 256>(result, stg7_stg7_ld53_merged1752_351_res);
	return result;
}

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_merged_banks_4_cache {
	// RAM Box: {[15, 1183], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_merged_banks_4_cache {
	// RAM Box: {[14, 1182], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_merged_banks_4_cache {
	// RAM Box: {[13, 1181], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_merged_banks_4_cache {
	// RAM Box: {[12, 1180], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_merged_banks_4_cache {
	// RAM Box: {[11, 1179], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_merged_banks_4_cache {
	// RAM Box: {[10, 1178], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_merged_banks_4_cache {
	// RAM Box: {[9, 1177], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_merged_banks_4_cache {
	// RAM Box: {[8, 1176], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_merged_banks_4_cache {
	// RAM Box: {[7, 1175], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_merged_banks_4_cache {
	// RAM Box: {[6, 1174], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_merged_banks_4_cache {
	// RAM Box: {[5, 1173], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_merged_banks_4_cache {
	// RAM Box: {[4, 1172], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_merged_banks_4_cache {
	// RAM Box: {[3, 1171], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_merged_banks_4_cache {
	// RAM Box: {[2, 1170], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_merged_banks_4_cache {
	// RAM Box: {[1, 1169], [-7, 1926]}
	// Capacity: 152
	// # of read delays: 4
  // 0, 1, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 74> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 74> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_75() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_76() {
		return f4;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_151() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_merged_banks_4_cache {
	// RAM Box: {[0, 1184], [-7, 1925]}
	// Capacity: 152
	// # of read delays: 5
  // 0, 1, 75, 76, 151
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 74> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_76() {
		return f6;
	}

	inline hw_uint<16> peek_150() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_151() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 74
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 74 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg7_FIFO_buf116_cache {
  // Reader addrs...
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[15 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[15 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[16 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[15 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[14 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[14 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[15 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[14 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[13 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[13 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[14 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[13 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[12 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[12 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[13 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[12 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[11 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[11 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[12 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[11 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[10 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[10 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[11 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[10 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[9 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[9 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[10 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[9 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[8 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[8 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[9 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[8 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[7 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[7 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[8 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[7 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[6 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[6 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[7 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[6 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[5 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[5 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[6 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[5 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[4 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[4 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[5 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[4 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[3 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[3 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[4 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[3 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[2 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[2 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[3 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[2 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[1 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[1 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[2 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[1 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[1 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
    // { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // # of banks: 16
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_merged_banks_4;
  stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_merged_banks_4_cache stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_merged_banks_4;
};



inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302);
}

inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_write(hw_uint<16>& stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
  stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_merged_banks_4.push(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303);
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_224_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_224 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[15 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_225_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_225 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[15 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_226_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_226 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[16 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_merged_banks_4.peek_75();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_227_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_227 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[15 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_228_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_228 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[14 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_229_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_229 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[14 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_230_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_230 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[15 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_231_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_231 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[14 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_232_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_232 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[13 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_233_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_233 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[13 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_234_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_234 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[14 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_235_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_235 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[13 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_236_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_236 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[12 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_237_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_237 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[12 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_238_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_238 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[13 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_239_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_239 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[12 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_240_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_240 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[11 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_241_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_241 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[11 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_242_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_242 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[12 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_243_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_243 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[11 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_244_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_244 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[10 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_245_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_245 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[10 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_246_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_246 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[11 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_247_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_247 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[10 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_248_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_248 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[9 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_249_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_249 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[9 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_250_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_250 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[10 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_251_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_251 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[9 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_252_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_252 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[8 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_253_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_253 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[8 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_254_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_254 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[9 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_255_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_255 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[8 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_256_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_256 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[7 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_257_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_257 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[7 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_258_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_258 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[8 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_259_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_259 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[7 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_260_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_260 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[6 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_261_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_261 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[6 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_262_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_262 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[7 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_263_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_263 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[6 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_264_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_264 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[5 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_265_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_265 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[5 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_266_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_266 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[6 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_267_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_267 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[5 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_268_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_268 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[4 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_269_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_269 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[4 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_270_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_270 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[5 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_271_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_271 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[4 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_272_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_272 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[3 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_273_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_273 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[3 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_274_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_274 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[4 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_275_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_275 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[3 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_276_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_276 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[2 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_277_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_277 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[2 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_278_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_278 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[3 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_279_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_279 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[2 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_280_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_280 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[1 + 16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_281_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_281 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[1 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_282_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_282 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[2 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_283_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_283 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[1 + 16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_284_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_284 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[16stg8_1, -7 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_merged_banks_4.peek_151();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_285_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_285 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_286_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_286 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[1 + 16stg8_1, -6 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_merged_banks_4.peek_76();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302;
  return 0;
}

inline hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_287_select(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg7_FIFO_buf116_stg8_1_merged1820_287 read pattern: { stg8_1_merged1820[root = 0, stg8_0, stg8_1] -> stg7_FIFO_buf116[16stg8_1, -5 + stg8_0] : 0 <= stg8_0 <= 1931 and 0 <= stg8_1 <= 73 }
  // Read schedule : { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
  auto value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303 = stg7_FIFO_buf116.stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_merged_banks_4.peek_1();
  return value_stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303;
  return 0;
}

// # of bundles = 2
// stg7_to_gp_1552_ld117_merged1764_write
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302
//	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303
inline void stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_write_bundle_write(hw_uint<256>& stg7_to_gp_1552_ld117_merged1764_write, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg7_to_gp_1552_ld118, int stg7_to_gp_1552_ld117, int dynamic_address) {
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_res = stg7_to_gp_1552_ld117_merged1764_write.extract<0, 15>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_288_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_res = stg7_to_gp_1552_ld117_merged1764_write.extract<16, 31>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_289_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_res = stg7_to_gp_1552_ld117_merged1764_write.extract<32, 47>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_290_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_res = stg7_to_gp_1552_ld117_merged1764_write.extract<48, 63>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_291_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_res = stg7_to_gp_1552_ld117_merged1764_write.extract<64, 79>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_292_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_res = stg7_to_gp_1552_ld117_merged1764_write.extract<80, 95>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_293_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_res = stg7_to_gp_1552_ld117_merged1764_write.extract<96, 111>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_294_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_res = stg7_to_gp_1552_ld117_merged1764_write.extract<112, 127>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_295_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_res = stg7_to_gp_1552_ld117_merged1764_write.extract<128, 143>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_296_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_res = stg7_to_gp_1552_ld117_merged1764_write.extract<144, 159>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_297_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_res = stg7_to_gp_1552_ld117_merged1764_write.extract<160, 175>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_298_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_res = stg7_to_gp_1552_ld117_merged1764_write.extract<176, 191>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_299_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_res = stg7_to_gp_1552_ld117_merged1764_write.extract<192, 207>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_300_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_res = stg7_to_gp_1552_ld117_merged1764_write.extract<208, 223>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_301_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_res = stg7_to_gp_1552_ld117_merged1764_write.extract<224, 239>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_302_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
	hw_uint<16> stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_res = stg7_to_gp_1552_ld117_merged1764_write.extract<240, 255>();
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_write(stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_303_res, stg7_FIFO_buf116, root, stg7_to_gp_1552_ld118, stg7_to_gp_1552_ld117, dynamic_address);
}

// stg8_1_merged1820_read
//	stg7_FIFO_buf116_stg8_1_merged1820_224
//	stg7_FIFO_buf116_stg8_1_merged1820_225
//	stg7_FIFO_buf116_stg8_1_merged1820_226
//	stg7_FIFO_buf116_stg8_1_merged1820_227
//	stg7_FIFO_buf116_stg8_1_merged1820_228
//	stg7_FIFO_buf116_stg8_1_merged1820_229
//	stg7_FIFO_buf116_stg8_1_merged1820_230
//	stg7_FIFO_buf116_stg8_1_merged1820_231
//	stg7_FIFO_buf116_stg8_1_merged1820_232
//	stg7_FIFO_buf116_stg8_1_merged1820_233
//	stg7_FIFO_buf116_stg8_1_merged1820_234
//	stg7_FIFO_buf116_stg8_1_merged1820_235
//	stg7_FIFO_buf116_stg8_1_merged1820_236
//	stg7_FIFO_buf116_stg8_1_merged1820_237
//	stg7_FIFO_buf116_stg8_1_merged1820_238
//	stg7_FIFO_buf116_stg8_1_merged1820_239
//	stg7_FIFO_buf116_stg8_1_merged1820_240
//	stg7_FIFO_buf116_stg8_1_merged1820_241
//	stg7_FIFO_buf116_stg8_1_merged1820_242
//	stg7_FIFO_buf116_stg8_1_merged1820_243
//	stg7_FIFO_buf116_stg8_1_merged1820_244
//	stg7_FIFO_buf116_stg8_1_merged1820_245
//	stg7_FIFO_buf116_stg8_1_merged1820_246
//	stg7_FIFO_buf116_stg8_1_merged1820_247
//	stg7_FIFO_buf116_stg8_1_merged1820_248
//	stg7_FIFO_buf116_stg8_1_merged1820_249
//	stg7_FIFO_buf116_stg8_1_merged1820_250
//	stg7_FIFO_buf116_stg8_1_merged1820_251
//	stg7_FIFO_buf116_stg8_1_merged1820_252
//	stg7_FIFO_buf116_stg8_1_merged1820_253
//	stg7_FIFO_buf116_stg8_1_merged1820_254
//	stg7_FIFO_buf116_stg8_1_merged1820_255
//	stg7_FIFO_buf116_stg8_1_merged1820_256
//	stg7_FIFO_buf116_stg8_1_merged1820_257
//	stg7_FIFO_buf116_stg8_1_merged1820_258
//	stg7_FIFO_buf116_stg8_1_merged1820_259
//	stg7_FIFO_buf116_stg8_1_merged1820_260
//	stg7_FIFO_buf116_stg8_1_merged1820_261
//	stg7_FIFO_buf116_stg8_1_merged1820_262
//	stg7_FIFO_buf116_stg8_1_merged1820_263
//	stg7_FIFO_buf116_stg8_1_merged1820_264
//	stg7_FIFO_buf116_stg8_1_merged1820_265
//	stg7_FIFO_buf116_stg8_1_merged1820_266
//	stg7_FIFO_buf116_stg8_1_merged1820_267
//	stg7_FIFO_buf116_stg8_1_merged1820_268
//	stg7_FIFO_buf116_stg8_1_merged1820_269
//	stg7_FIFO_buf116_stg8_1_merged1820_270
//	stg7_FIFO_buf116_stg8_1_merged1820_271
//	stg7_FIFO_buf116_stg8_1_merged1820_272
//	stg7_FIFO_buf116_stg8_1_merged1820_273
//	stg7_FIFO_buf116_stg8_1_merged1820_274
//	stg7_FIFO_buf116_stg8_1_merged1820_275
//	stg7_FIFO_buf116_stg8_1_merged1820_276
//	stg7_FIFO_buf116_stg8_1_merged1820_277
//	stg7_FIFO_buf116_stg8_1_merged1820_278
//	stg7_FIFO_buf116_stg8_1_merged1820_279
//	stg7_FIFO_buf116_stg8_1_merged1820_280
//	stg7_FIFO_buf116_stg8_1_merged1820_281
//	stg7_FIFO_buf116_stg8_1_merged1820_282
//	stg7_FIFO_buf116_stg8_1_merged1820_283
//	stg7_FIFO_buf116_stg8_1_merged1820_284
//	stg7_FIFO_buf116_stg8_1_merged1820_285
//	stg7_FIFO_buf116_stg8_1_merged1820_286
//	stg7_FIFO_buf116_stg8_1_merged1820_287
inline hw_uint<1024> stg7_FIFO_buf116_stg8_1_merged1820_read_bundle_read(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int root, int stg8_0, int stg8_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg7_FIFO_buf116_stg8_1_merged1820_224
    // stg7_FIFO_buf116_stg8_1_merged1820_225
    // stg7_FIFO_buf116_stg8_1_merged1820_226
    // stg7_FIFO_buf116_stg8_1_merged1820_227
    // stg7_FIFO_buf116_stg8_1_merged1820_228
    // stg7_FIFO_buf116_stg8_1_merged1820_229
    // stg7_FIFO_buf116_stg8_1_merged1820_230
    // stg7_FIFO_buf116_stg8_1_merged1820_231
    // stg7_FIFO_buf116_stg8_1_merged1820_232
    // stg7_FIFO_buf116_stg8_1_merged1820_233
    // stg7_FIFO_buf116_stg8_1_merged1820_234
    // stg7_FIFO_buf116_stg8_1_merged1820_235
    // stg7_FIFO_buf116_stg8_1_merged1820_236
    // stg7_FIFO_buf116_stg8_1_merged1820_237
    // stg7_FIFO_buf116_stg8_1_merged1820_238
    // stg7_FIFO_buf116_stg8_1_merged1820_239
    // stg7_FIFO_buf116_stg8_1_merged1820_240
    // stg7_FIFO_buf116_stg8_1_merged1820_241
    // stg7_FIFO_buf116_stg8_1_merged1820_242
    // stg7_FIFO_buf116_stg8_1_merged1820_243
    // stg7_FIFO_buf116_stg8_1_merged1820_244
    // stg7_FIFO_buf116_stg8_1_merged1820_245
    // stg7_FIFO_buf116_stg8_1_merged1820_246
    // stg7_FIFO_buf116_stg8_1_merged1820_247
    // stg7_FIFO_buf116_stg8_1_merged1820_248
    // stg7_FIFO_buf116_stg8_1_merged1820_249
    // stg7_FIFO_buf116_stg8_1_merged1820_250
    // stg7_FIFO_buf116_stg8_1_merged1820_251
    // stg7_FIFO_buf116_stg8_1_merged1820_252
    // stg7_FIFO_buf116_stg8_1_merged1820_253
    // stg7_FIFO_buf116_stg8_1_merged1820_254
    // stg7_FIFO_buf116_stg8_1_merged1820_255
    // stg7_FIFO_buf116_stg8_1_merged1820_256
    // stg7_FIFO_buf116_stg8_1_merged1820_257
    // stg7_FIFO_buf116_stg8_1_merged1820_258
    // stg7_FIFO_buf116_stg8_1_merged1820_259
    // stg7_FIFO_buf116_stg8_1_merged1820_260
    // stg7_FIFO_buf116_stg8_1_merged1820_261
    // stg7_FIFO_buf116_stg8_1_merged1820_262
    // stg7_FIFO_buf116_stg8_1_merged1820_263
    // stg7_FIFO_buf116_stg8_1_merged1820_264
    // stg7_FIFO_buf116_stg8_1_merged1820_265
    // stg7_FIFO_buf116_stg8_1_merged1820_266
    // stg7_FIFO_buf116_stg8_1_merged1820_267
    // stg7_FIFO_buf116_stg8_1_merged1820_268
    // stg7_FIFO_buf116_stg8_1_merged1820_269
    // stg7_FIFO_buf116_stg8_1_merged1820_270
    // stg7_FIFO_buf116_stg8_1_merged1820_271
    // stg7_FIFO_buf116_stg8_1_merged1820_272
    // stg7_FIFO_buf116_stg8_1_merged1820_273
    // stg7_FIFO_buf116_stg8_1_merged1820_274
    // stg7_FIFO_buf116_stg8_1_merged1820_275
    // stg7_FIFO_buf116_stg8_1_merged1820_276
    // stg7_FIFO_buf116_stg8_1_merged1820_277
    // stg7_FIFO_buf116_stg8_1_merged1820_278
    // stg7_FIFO_buf116_stg8_1_merged1820_279
    // stg7_FIFO_buf116_stg8_1_merged1820_280
    // stg7_FIFO_buf116_stg8_1_merged1820_281
    // stg7_FIFO_buf116_stg8_1_merged1820_282
    // stg7_FIFO_buf116_stg8_1_merged1820_283
    // stg7_FIFO_buf116_stg8_1_merged1820_284
    // stg7_FIFO_buf116_stg8_1_merged1820_285
    // stg7_FIFO_buf116_stg8_1_merged1820_286
    // stg7_FIFO_buf116_stg8_1_merged1820_287

	hw_uint<1024> result;
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_224_res = stg7_FIFO_buf116_stg8_1_merged1820_224_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<0, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_224_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_225_res = stg7_FIFO_buf116_stg8_1_merged1820_225_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<16, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_225_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_226_res = stg7_FIFO_buf116_stg8_1_merged1820_226_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<32, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_226_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_227_res = stg7_FIFO_buf116_stg8_1_merged1820_227_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<48, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_227_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_228_res = stg7_FIFO_buf116_stg8_1_merged1820_228_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<64, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_228_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_229_res = stg7_FIFO_buf116_stg8_1_merged1820_229_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<80, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_229_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_230_res = stg7_FIFO_buf116_stg8_1_merged1820_230_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<96, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_230_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_231_res = stg7_FIFO_buf116_stg8_1_merged1820_231_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<112, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_231_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_232_res = stg7_FIFO_buf116_stg8_1_merged1820_232_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<128, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_232_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_233_res = stg7_FIFO_buf116_stg8_1_merged1820_233_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<144, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_233_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_234_res = stg7_FIFO_buf116_stg8_1_merged1820_234_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<160, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_234_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_235_res = stg7_FIFO_buf116_stg8_1_merged1820_235_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<176, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_235_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_236_res = stg7_FIFO_buf116_stg8_1_merged1820_236_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<192, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_236_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_237_res = stg7_FIFO_buf116_stg8_1_merged1820_237_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<208, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_237_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_238_res = stg7_FIFO_buf116_stg8_1_merged1820_238_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<224, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_238_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_239_res = stg7_FIFO_buf116_stg8_1_merged1820_239_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<240, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_239_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_240_res = stg7_FIFO_buf116_stg8_1_merged1820_240_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<256, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_240_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_241_res = stg7_FIFO_buf116_stg8_1_merged1820_241_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<272, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_241_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_242_res = stg7_FIFO_buf116_stg8_1_merged1820_242_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<288, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_242_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_243_res = stg7_FIFO_buf116_stg8_1_merged1820_243_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<304, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_243_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_244_res = stg7_FIFO_buf116_stg8_1_merged1820_244_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<320, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_244_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_245_res = stg7_FIFO_buf116_stg8_1_merged1820_245_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<336, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_245_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_246_res = stg7_FIFO_buf116_stg8_1_merged1820_246_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<352, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_246_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_247_res = stg7_FIFO_buf116_stg8_1_merged1820_247_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<368, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_247_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_248_res = stg7_FIFO_buf116_stg8_1_merged1820_248_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<384, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_248_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_249_res = stg7_FIFO_buf116_stg8_1_merged1820_249_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<400, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_249_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_250_res = stg7_FIFO_buf116_stg8_1_merged1820_250_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<416, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_250_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_251_res = stg7_FIFO_buf116_stg8_1_merged1820_251_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<432, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_251_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_252_res = stg7_FIFO_buf116_stg8_1_merged1820_252_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<448, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_252_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_253_res = stg7_FIFO_buf116_stg8_1_merged1820_253_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<464, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_253_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_254_res = stg7_FIFO_buf116_stg8_1_merged1820_254_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<480, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_254_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_255_res = stg7_FIFO_buf116_stg8_1_merged1820_255_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<496, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_255_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_256_res = stg7_FIFO_buf116_stg8_1_merged1820_256_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<512, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_256_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_257_res = stg7_FIFO_buf116_stg8_1_merged1820_257_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<528, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_257_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_258_res = stg7_FIFO_buf116_stg8_1_merged1820_258_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<544, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_258_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_259_res = stg7_FIFO_buf116_stg8_1_merged1820_259_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<560, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_259_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_260_res = stg7_FIFO_buf116_stg8_1_merged1820_260_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<576, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_260_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_261_res = stg7_FIFO_buf116_stg8_1_merged1820_261_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<592, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_261_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_262_res = stg7_FIFO_buf116_stg8_1_merged1820_262_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<608, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_262_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_263_res = stg7_FIFO_buf116_stg8_1_merged1820_263_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<624, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_263_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_264_res = stg7_FIFO_buf116_stg8_1_merged1820_264_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<640, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_264_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_265_res = stg7_FIFO_buf116_stg8_1_merged1820_265_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<656, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_265_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_266_res = stg7_FIFO_buf116_stg8_1_merged1820_266_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<672, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_266_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_267_res = stg7_FIFO_buf116_stg8_1_merged1820_267_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<688, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_267_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_268_res = stg7_FIFO_buf116_stg8_1_merged1820_268_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<704, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_268_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_269_res = stg7_FIFO_buf116_stg8_1_merged1820_269_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<720, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_269_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_270_res = stg7_FIFO_buf116_stg8_1_merged1820_270_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<736, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_270_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_271_res = stg7_FIFO_buf116_stg8_1_merged1820_271_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<752, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_271_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_272_res = stg7_FIFO_buf116_stg8_1_merged1820_272_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<768, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_272_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_273_res = stg7_FIFO_buf116_stg8_1_merged1820_273_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<784, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_273_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_274_res = stg7_FIFO_buf116_stg8_1_merged1820_274_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<800, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_274_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_275_res = stg7_FIFO_buf116_stg8_1_merged1820_275_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<816, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_275_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_276_res = stg7_FIFO_buf116_stg8_1_merged1820_276_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<832, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_276_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_277_res = stg7_FIFO_buf116_stg8_1_merged1820_277_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<848, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_277_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_278_res = stg7_FIFO_buf116_stg8_1_merged1820_278_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<864, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_278_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_279_res = stg7_FIFO_buf116_stg8_1_merged1820_279_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<880, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_279_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_280_res = stg7_FIFO_buf116_stg8_1_merged1820_280_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<896, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_280_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_281_res = stg7_FIFO_buf116_stg8_1_merged1820_281_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<912, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_281_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_282_res = stg7_FIFO_buf116_stg8_1_merged1820_282_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<928, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_282_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_283_res = stg7_FIFO_buf116_stg8_1_merged1820_283_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<944, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_283_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_284_res = stg7_FIFO_buf116_stg8_1_merged1820_284_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<960, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_284_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_285_res = stg7_FIFO_buf116_stg8_1_merged1820_285_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<976, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_285_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_286_res = stg7_FIFO_buf116_stg8_1_merged1820_286_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<992, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_286_res);
	hw_uint<16> stg7_FIFO_buf116_stg8_1_merged1820_287_res = stg7_FIFO_buf116_stg8_1_merged1820_287_select(stg7_FIFO_buf116, root, stg8_0, stg8_1, dynamic_address);
	set_at<1008, 1024>(result, stg7_FIFO_buf116_stg8_1_merged1820_287_res);
	return result;
}

struct stg8_stg8_1_merged1820_208_to_stg8_stg8_ld57_merged1786_192_cache {
	// RAM Box: {[15, 1183], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_209_to_stg8_stg8_ld57_merged1786_193_cache {
	// RAM Box: {[14, 1182], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_210_to_stg8_stg8_ld57_merged1786_194_cache {
	// RAM Box: {[13, 1181], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_211_to_stg8_stg8_ld57_merged1786_195_cache {
	// RAM Box: {[12, 1180], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_212_to_stg8_stg8_ld57_merged1786_196_cache {
	// RAM Box: {[11, 1179], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_213_to_stg8_stg8_ld57_merged1786_197_cache {
	// RAM Box: {[10, 1178], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_214_to_stg8_stg8_ld57_merged1786_198_cache {
	// RAM Box: {[9, 1177], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_215_to_stg8_stg8_ld57_merged1786_199_cache {
	// RAM Box: {[8, 1176], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_216_to_stg8_stg8_ld57_merged1786_200_cache {
	// RAM Box: {[7, 1175], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_217_to_stg8_stg8_ld57_merged1786_201_cache {
	// RAM Box: {[6, 1174], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_218_to_stg8_stg8_ld57_merged1786_202_cache {
	// RAM Box: {[5, 1173], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_219_to_stg8_stg8_ld57_merged1786_203_cache {
	// RAM Box: {[4, 1172], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_220_to_stg8_stg8_ld57_merged1786_204_cache {
	// RAM Box: {[3, 1171], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_221_to_stg8_stg8_ld57_merged1786_205_cache {
	// RAM Box: {[2, 1170], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_222_to_stg8_stg8_ld57_merged1786_206_cache {
	// RAM Box: {[1, 1169], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_stg8_1_merged1820_223_to_stg8_stg8_ld57_merged1786_207_cache {
	// RAM Box: {[0, 1168], [-6, 1925]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg8_cache {
  // Reader addrs...
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[15 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[14 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[13 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[12 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[11 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[10 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[9 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[8 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[7 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[6 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[5 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[4 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[3 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[2 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[1 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
    // { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // # of banks: 16
  stg8_stg8_1_merged1820_208_to_stg8_stg8_ld57_merged1786_192_cache stg8_stg8_1_merged1820_208_to_stg8_stg8_ld57_merged1786_192;
  stg8_stg8_1_merged1820_209_to_stg8_stg8_ld57_merged1786_193_cache stg8_stg8_1_merged1820_209_to_stg8_stg8_ld57_merged1786_193;
  stg8_stg8_1_merged1820_210_to_stg8_stg8_ld57_merged1786_194_cache stg8_stg8_1_merged1820_210_to_stg8_stg8_ld57_merged1786_194;
  stg8_stg8_1_merged1820_211_to_stg8_stg8_ld57_merged1786_195_cache stg8_stg8_1_merged1820_211_to_stg8_stg8_ld57_merged1786_195;
  stg8_stg8_1_merged1820_212_to_stg8_stg8_ld57_merged1786_196_cache stg8_stg8_1_merged1820_212_to_stg8_stg8_ld57_merged1786_196;
  stg8_stg8_1_merged1820_213_to_stg8_stg8_ld57_merged1786_197_cache stg8_stg8_1_merged1820_213_to_stg8_stg8_ld57_merged1786_197;
  stg8_stg8_1_merged1820_214_to_stg8_stg8_ld57_merged1786_198_cache stg8_stg8_1_merged1820_214_to_stg8_stg8_ld57_merged1786_198;
  stg8_stg8_1_merged1820_215_to_stg8_stg8_ld57_merged1786_199_cache stg8_stg8_1_merged1820_215_to_stg8_stg8_ld57_merged1786_199;
  stg8_stg8_1_merged1820_216_to_stg8_stg8_ld57_merged1786_200_cache stg8_stg8_1_merged1820_216_to_stg8_stg8_ld57_merged1786_200;
  stg8_stg8_1_merged1820_217_to_stg8_stg8_ld57_merged1786_201_cache stg8_stg8_1_merged1820_217_to_stg8_stg8_ld57_merged1786_201;
  stg8_stg8_1_merged1820_218_to_stg8_stg8_ld57_merged1786_202_cache stg8_stg8_1_merged1820_218_to_stg8_stg8_ld57_merged1786_202;
  stg8_stg8_1_merged1820_219_to_stg8_stg8_ld57_merged1786_203_cache stg8_stg8_1_merged1820_219_to_stg8_stg8_ld57_merged1786_203;
  stg8_stg8_1_merged1820_220_to_stg8_stg8_ld57_merged1786_204_cache stg8_stg8_1_merged1820_220_to_stg8_stg8_ld57_merged1786_204;
  stg8_stg8_1_merged1820_221_to_stg8_stg8_ld57_merged1786_205_cache stg8_stg8_1_merged1820_221_to_stg8_stg8_ld57_merged1786_205;
  stg8_stg8_1_merged1820_222_to_stg8_stg8_ld57_merged1786_206_cache stg8_stg8_1_merged1820_222_to_stg8_stg8_ld57_merged1786_206;
  stg8_stg8_1_merged1820_223_to_stg8_stg8_ld57_merged1786_207_cache stg8_stg8_1_merged1820_223_to_stg8_stg8_ld57_merged1786_207;
};



inline void stg8_stg8_1_merged1820_208_write(hw_uint<16>& stg8_stg8_1_merged1820_208, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_208_to_stg8_stg8_ld57_merged1786_192.push(stg8_stg8_1_merged1820_208);
}

inline void stg8_stg8_1_merged1820_209_write(hw_uint<16>& stg8_stg8_1_merged1820_209, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_209_to_stg8_stg8_ld57_merged1786_193.push(stg8_stg8_1_merged1820_209);
}

inline void stg8_stg8_1_merged1820_210_write(hw_uint<16>& stg8_stg8_1_merged1820_210, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_210_to_stg8_stg8_ld57_merged1786_194.push(stg8_stg8_1_merged1820_210);
}

inline void stg8_stg8_1_merged1820_211_write(hw_uint<16>& stg8_stg8_1_merged1820_211, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_211_to_stg8_stg8_ld57_merged1786_195.push(stg8_stg8_1_merged1820_211);
}

inline void stg8_stg8_1_merged1820_212_write(hw_uint<16>& stg8_stg8_1_merged1820_212, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_212_to_stg8_stg8_ld57_merged1786_196.push(stg8_stg8_1_merged1820_212);
}

inline void stg8_stg8_1_merged1820_213_write(hw_uint<16>& stg8_stg8_1_merged1820_213, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_213_to_stg8_stg8_ld57_merged1786_197.push(stg8_stg8_1_merged1820_213);
}

inline void stg8_stg8_1_merged1820_214_write(hw_uint<16>& stg8_stg8_1_merged1820_214, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_214_to_stg8_stg8_ld57_merged1786_198.push(stg8_stg8_1_merged1820_214);
}

inline void stg8_stg8_1_merged1820_215_write(hw_uint<16>& stg8_stg8_1_merged1820_215, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_215_to_stg8_stg8_ld57_merged1786_199.push(stg8_stg8_1_merged1820_215);
}

inline void stg8_stg8_1_merged1820_216_write(hw_uint<16>& stg8_stg8_1_merged1820_216, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_216_to_stg8_stg8_ld57_merged1786_200.push(stg8_stg8_1_merged1820_216);
}

inline void stg8_stg8_1_merged1820_217_write(hw_uint<16>& stg8_stg8_1_merged1820_217, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_217_to_stg8_stg8_ld57_merged1786_201.push(stg8_stg8_1_merged1820_217);
}

inline void stg8_stg8_1_merged1820_218_write(hw_uint<16>& stg8_stg8_1_merged1820_218, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_218_to_stg8_stg8_ld57_merged1786_202.push(stg8_stg8_1_merged1820_218);
}

inline void stg8_stg8_1_merged1820_219_write(hw_uint<16>& stg8_stg8_1_merged1820_219, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_219_to_stg8_stg8_ld57_merged1786_203.push(stg8_stg8_1_merged1820_219);
}

inline void stg8_stg8_1_merged1820_220_write(hw_uint<16>& stg8_stg8_1_merged1820_220, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_220_to_stg8_stg8_ld57_merged1786_204.push(stg8_stg8_1_merged1820_220);
}

inline void stg8_stg8_1_merged1820_221_write(hw_uint<16>& stg8_stg8_1_merged1820_221, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_221_to_stg8_stg8_ld57_merged1786_205.push(stg8_stg8_1_merged1820_221);
}

inline void stg8_stg8_1_merged1820_222_write(hw_uint<16>& stg8_stg8_1_merged1820_222, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_222_to_stg8_stg8_ld57_merged1786_206.push(stg8_stg8_1_merged1820_222);
}

inline void stg8_stg8_1_merged1820_223_write(hw_uint<16>& stg8_stg8_1_merged1820_223, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
  stg8.stg8_stg8_1_merged1820_223_to_stg8_stg8_ld57_merged1786_207.push(stg8_stg8_1_merged1820_223);
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_192_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_192 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[15 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_208 = stg8.stg8_stg8_1_merged1820_208_to_stg8_stg8_ld57_merged1786_192.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_208;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_193_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_193 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[14 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_209 = stg8.stg8_stg8_1_merged1820_209_to_stg8_stg8_ld57_merged1786_193.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_209;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_194_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_194 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[13 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_210 = stg8.stg8_stg8_1_merged1820_210_to_stg8_stg8_ld57_merged1786_194.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_210;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_195_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_195 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[12 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_211 = stg8.stg8_stg8_1_merged1820_211_to_stg8_stg8_ld57_merged1786_195.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_211;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_196_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_196 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[11 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_212 = stg8.stg8_stg8_1_merged1820_212_to_stg8_stg8_ld57_merged1786_196.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_212;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_197_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_197 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[10 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_213 = stg8.stg8_stg8_1_merged1820_213_to_stg8_stg8_ld57_merged1786_197.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_213;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_198_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_198 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[9 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_214 = stg8.stg8_stg8_1_merged1820_214_to_stg8_stg8_ld57_merged1786_198.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_214;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_199_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_199 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[8 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_215 = stg8.stg8_stg8_1_merged1820_215_to_stg8_stg8_ld57_merged1786_199.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_215;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_200_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_200 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[7 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_216 = stg8.stg8_stg8_1_merged1820_216_to_stg8_stg8_ld57_merged1786_200.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_216;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_201_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_201 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[6 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_217 = stg8.stg8_stg8_1_merged1820_217_to_stg8_stg8_ld57_merged1786_201.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_217;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_202_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_202 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[5 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_218 = stg8.stg8_stg8_1_merged1820_218_to_stg8_stg8_ld57_merged1786_202.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_218;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_203_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_203 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[4 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_219 = stg8.stg8_stg8_1_merged1820_219_to_stg8_stg8_ld57_merged1786_203.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_219;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_204_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_204 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[3 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_220 = stg8.stg8_stg8_1_merged1820_220_to_stg8_stg8_ld57_merged1786_204.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_220;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_205_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_205 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[2 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_221 = stg8.stg8_stg8_1_merged1820_221_to_stg8_stg8_ld57_merged1786_205.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_221;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_206_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_206 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[1 + 16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_222 = stg8.stg8_stg8_1_merged1820_222_to_stg8_stg8_ld57_merged1786_206.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_222;
  return 0;
}

inline hw_uint<16> stg8_stg8_ld57_merged1786_207_select(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_stg8_ld57_merged1786_207 read pattern: { stg8_ld57_merged1786[root = 0, stg8_ld58, stg8_ld57] -> stg8[16stg8_ld57, -6 + stg8_ld58] : 0 <= stg8_ld58 <= 1931 and 0 <= stg8_ld57 <= 73 }
  // Read schedule : { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  // Write schedule: { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_stg8_1_merged1820_223 = stg8.stg8_stg8_1_merged1820_223_to_stg8_stg8_ld57_merged1786_207.peek(/* one reader or all rams */ 0);
  return value_stg8_stg8_1_merged1820_223;
  return 0;
}

// # of bundles = 2
// stg8_1_merged1820_write
//	stg8_stg8_1_merged1820_208
//	stg8_stg8_1_merged1820_209
//	stg8_stg8_1_merged1820_210
//	stg8_stg8_1_merged1820_211
//	stg8_stg8_1_merged1820_212
//	stg8_stg8_1_merged1820_213
//	stg8_stg8_1_merged1820_214
//	stg8_stg8_1_merged1820_215
//	stg8_stg8_1_merged1820_216
//	stg8_stg8_1_merged1820_217
//	stg8_stg8_1_merged1820_218
//	stg8_stg8_1_merged1820_219
//	stg8_stg8_1_merged1820_220
//	stg8_stg8_1_merged1820_221
//	stg8_stg8_1_merged1820_222
//	stg8_stg8_1_merged1820_223
inline void stg8_stg8_1_merged1820_write_bundle_write(hw_uint<256>& stg8_1_merged1820_write, stg8_cache& stg8, int root, int stg8_0, int stg8_1, int dynamic_address) {
	hw_uint<16> stg8_stg8_1_merged1820_208_res = stg8_1_merged1820_write.extract<0, 15>();
	stg8_stg8_1_merged1820_208_write(stg8_stg8_1_merged1820_208_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_209_res = stg8_1_merged1820_write.extract<16, 31>();
	stg8_stg8_1_merged1820_209_write(stg8_stg8_1_merged1820_209_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_210_res = stg8_1_merged1820_write.extract<32, 47>();
	stg8_stg8_1_merged1820_210_write(stg8_stg8_1_merged1820_210_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_211_res = stg8_1_merged1820_write.extract<48, 63>();
	stg8_stg8_1_merged1820_211_write(stg8_stg8_1_merged1820_211_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_212_res = stg8_1_merged1820_write.extract<64, 79>();
	stg8_stg8_1_merged1820_212_write(stg8_stg8_1_merged1820_212_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_213_res = stg8_1_merged1820_write.extract<80, 95>();
	stg8_stg8_1_merged1820_213_write(stg8_stg8_1_merged1820_213_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_214_res = stg8_1_merged1820_write.extract<96, 111>();
	stg8_stg8_1_merged1820_214_write(stg8_stg8_1_merged1820_214_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_215_res = stg8_1_merged1820_write.extract<112, 127>();
	stg8_stg8_1_merged1820_215_write(stg8_stg8_1_merged1820_215_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_216_res = stg8_1_merged1820_write.extract<128, 143>();
	stg8_stg8_1_merged1820_216_write(stg8_stg8_1_merged1820_216_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_217_res = stg8_1_merged1820_write.extract<144, 159>();
	stg8_stg8_1_merged1820_217_write(stg8_stg8_1_merged1820_217_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_218_res = stg8_1_merged1820_write.extract<160, 175>();
	stg8_stg8_1_merged1820_218_write(stg8_stg8_1_merged1820_218_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_219_res = stg8_1_merged1820_write.extract<176, 191>();
	stg8_stg8_1_merged1820_219_write(stg8_stg8_1_merged1820_219_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_220_res = stg8_1_merged1820_write.extract<192, 207>();
	stg8_stg8_1_merged1820_220_write(stg8_stg8_1_merged1820_220_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_221_res = stg8_1_merged1820_write.extract<208, 223>();
	stg8_stg8_1_merged1820_221_write(stg8_stg8_1_merged1820_221_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_222_res = stg8_1_merged1820_write.extract<224, 239>();
	stg8_stg8_1_merged1820_222_write(stg8_stg8_1_merged1820_222_res, stg8, root, stg8_0, stg8_1, dynamic_address);
	hw_uint<16> stg8_stg8_1_merged1820_223_res = stg8_1_merged1820_write.extract<240, 255>();
	stg8_stg8_1_merged1820_223_write(stg8_stg8_1_merged1820_223_res, stg8, root, stg8_0, stg8_1, dynamic_address);
}

// stg8_ld57_merged1786_read
//	stg8_stg8_ld57_merged1786_192
//	stg8_stg8_ld57_merged1786_193
//	stg8_stg8_ld57_merged1786_194
//	stg8_stg8_ld57_merged1786_195
//	stg8_stg8_ld57_merged1786_196
//	stg8_stg8_ld57_merged1786_197
//	stg8_stg8_ld57_merged1786_198
//	stg8_stg8_ld57_merged1786_199
//	stg8_stg8_ld57_merged1786_200
//	stg8_stg8_ld57_merged1786_201
//	stg8_stg8_ld57_merged1786_202
//	stg8_stg8_ld57_merged1786_203
//	stg8_stg8_ld57_merged1786_204
//	stg8_stg8_ld57_merged1786_205
//	stg8_stg8_ld57_merged1786_206
//	stg8_stg8_ld57_merged1786_207
inline hw_uint<256> stg8_stg8_ld57_merged1786_read_bundle_read(stg8_cache& stg8, int root, int stg8_ld58, int stg8_ld57, int dynamic_address) {
  // # of ports in bundle: 16
    // stg8_stg8_ld57_merged1786_192
    // stg8_stg8_ld57_merged1786_193
    // stg8_stg8_ld57_merged1786_194
    // stg8_stg8_ld57_merged1786_195
    // stg8_stg8_ld57_merged1786_196
    // stg8_stg8_ld57_merged1786_197
    // stg8_stg8_ld57_merged1786_198
    // stg8_stg8_ld57_merged1786_199
    // stg8_stg8_ld57_merged1786_200
    // stg8_stg8_ld57_merged1786_201
    // stg8_stg8_ld57_merged1786_202
    // stg8_stg8_ld57_merged1786_203
    // stg8_stg8_ld57_merged1786_204
    // stg8_stg8_ld57_merged1786_205
    // stg8_stg8_ld57_merged1786_206
    // stg8_stg8_ld57_merged1786_207

	hw_uint<256> result;
	hw_uint<16> stg8_stg8_ld57_merged1786_192_res = stg8_stg8_ld57_merged1786_192_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<0, 256>(result, stg8_stg8_ld57_merged1786_192_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_193_res = stg8_stg8_ld57_merged1786_193_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<16, 256>(result, stg8_stg8_ld57_merged1786_193_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_194_res = stg8_stg8_ld57_merged1786_194_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<32, 256>(result, stg8_stg8_ld57_merged1786_194_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_195_res = stg8_stg8_ld57_merged1786_195_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<48, 256>(result, stg8_stg8_ld57_merged1786_195_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_196_res = stg8_stg8_ld57_merged1786_196_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<64, 256>(result, stg8_stg8_ld57_merged1786_196_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_197_res = stg8_stg8_ld57_merged1786_197_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<80, 256>(result, stg8_stg8_ld57_merged1786_197_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_198_res = stg8_stg8_ld57_merged1786_198_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<96, 256>(result, stg8_stg8_ld57_merged1786_198_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_199_res = stg8_stg8_ld57_merged1786_199_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<112, 256>(result, stg8_stg8_ld57_merged1786_199_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_200_res = stg8_stg8_ld57_merged1786_200_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<128, 256>(result, stg8_stg8_ld57_merged1786_200_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_201_res = stg8_stg8_ld57_merged1786_201_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<144, 256>(result, stg8_stg8_ld57_merged1786_201_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_202_res = stg8_stg8_ld57_merged1786_202_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<160, 256>(result, stg8_stg8_ld57_merged1786_202_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_203_res = stg8_stg8_ld57_merged1786_203_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<176, 256>(result, stg8_stg8_ld57_merged1786_203_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_204_res = stg8_stg8_ld57_merged1786_204_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<192, 256>(result, stg8_stg8_ld57_merged1786_204_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_205_res = stg8_stg8_ld57_merged1786_205_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<208, 256>(result, stg8_stg8_ld57_merged1786_205_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_206_res = stg8_stg8_ld57_merged1786_206_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<224, 256>(result, stg8_stg8_ld57_merged1786_206_res);
	hw_uint<16> stg8_stg8_ld57_merged1786_207_res = stg8_stg8_ld57_merged1786_207_select(stg8, root, stg8_ld58, stg8_ld57, dynamic_address);
	set_at<240, 256>(result, stg8_stg8_ld57_merged1786_207_res);
	return result;
}

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_merged_banks_4_cache {
	// RAM Box: {[15, 1167], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_merged_banks_4_cache {
	// RAM Box: {[14, 1166], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_merged_banks_4_cache {
	// RAM Box: {[13, 1165], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_merged_banks_4_cache {
	// RAM Box: {[12, 1164], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_merged_banks_4_cache {
	// RAM Box: {[11, 1163], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_merged_banks_4_cache {
	// RAM Box: {[10, 1162], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_merged_banks_4_cache {
	// RAM Box: {[9, 1161], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_merged_banks_4_cache {
	// RAM Box: {[8, 1160], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_merged_banks_4_cache {
	// RAM Box: {[7, 1159], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_merged_banks_4_cache {
	// RAM Box: {[6, 1158], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_merged_banks_4_cache {
	// RAM Box: {[5, 1157], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_merged_banks_4_cache {
	// RAM Box: {[4, 1156], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_merged_banks_4_cache {
	// RAM Box: {[3, 1155], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_merged_banks_4_cache {
	// RAM Box: {[2, 1154], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_merged_banks_4_cache {
	// RAM Box: {[1, 1153], [-6, 1925]}
	// Capacity: 150
	// # of read delays: 4
  // 0, 1, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 73> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 73> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_74() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_75() {
		return f4;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_149() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_merged_banks_4_cache {
	// RAM Box: {[0, 1168], [-6, 1924]}
	// Capacity: 150
	// # of read delays: 5
  // 0, 1, 74, 75, 149
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 73> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_75() {
		return f6;
	}

	inline hw_uint<16> peek_148() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_149() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 73
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 73 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg8_FIFO_buf120_cache {
  // Reader addrs...
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[10 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[10 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[11 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[10 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[9 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[9 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[10 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[9 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[8 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[8 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[9 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[8 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[7 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[7 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[8 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[7 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[6 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[6 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[7 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[6 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[5 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[5 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[6 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[5 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[4 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[4 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[5 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[4 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[3 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[3 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[4 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[3 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[2 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[2 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[3 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[2 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[1 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[1 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[2 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[1 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[1 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[15 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[15 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[16 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[15 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[14 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[14 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[15 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[14 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[13 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[13 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[14 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[13 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[12 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[12 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[13 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[12 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[11 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[11 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[12 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
    // { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[11 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // # of banks: 16
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_merged_banks_4;
  stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_merged_banks_4_cache stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_merged_banks_4;
};



inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158);
}

inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_write(hw_uint<16>& stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
  stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_merged_banks_4.push(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159);
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_100_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_100 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[10 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_101_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_101 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[10 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_102_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_102 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[11 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_103_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_103 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[10 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_104_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_104 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[9 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_105_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_105 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[9 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_106_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_106 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[10 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_107_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_107 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[9 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_108_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_108 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[8 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_109_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_109 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[8 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_110_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_110 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[9 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_111_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_111 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[8 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_112_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_112 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[7 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_113_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_113 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[7 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_114_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_114 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[8 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_115_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_115 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[7 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_116_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_116 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[6 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_117_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_117 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[6 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_118_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_118 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[7 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_119_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_119 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[6 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_120_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_120 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[5 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_121_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_121 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[5 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_122_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_122 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[6 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_123_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_123 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[5 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_124_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_124 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[4 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_125_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_125 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[4 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_126_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_126 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[5 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_127_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_127 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[4 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_128_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_128 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[3 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_129_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_129 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[3 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_130_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_130 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[4 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_131_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_131 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[3 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_132_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_132 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[2 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_133_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_133 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[2 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_134_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_134 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[3 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_135_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_135 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[2 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_136_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_136 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[1 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_137_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_137 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[1 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_138_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_138 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[2 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_139_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_139 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[1 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_140_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_140 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_141_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_141 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_142_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_142 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[1 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_143_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_143 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_80_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_80 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[15 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_81_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_81 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[15 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_82_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_82 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[16 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_merged_banks_4.peek_74();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_83_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_83 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[15 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_84_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_84 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[14 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_85_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_85 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[14 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_86_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_86 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[15 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_87_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_87 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[14 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_88_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_88 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[13 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_89_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_89 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[13 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_90_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_90 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[14 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_91_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_91 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[13 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_92_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_92 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[12 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_93_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_93 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[12 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_94_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_94 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[13 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_95_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_95 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[12 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_96_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_96 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[11 + 16stg9_1, -6 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_merged_banks_4.peek_149();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_97_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_97 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[11 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_98_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_98 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[12 + 16stg9_1, -5 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_merged_banks_4.peek_75();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147;
  return 0;
}

inline hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_99_select(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg8_FIFO_buf120_stg9_1_merged1823_99 read pattern: { stg9_1_merged1823[root = 0, stg9_0, stg9_1] -> stg8_FIFO_buf120[11 + 16stg9_1, -4 + stg9_0] : 0 <= stg9_0 <= 1929 and 0 <= stg9_1 <= 72 }
  // Read schedule : { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
  auto value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148 = stg8_FIFO_buf120.stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_merged_banks_4.peek_1();
  return value_stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148;
  return 0;
}

// # of bundles = 2
// stg8_to_gp_1656_ld121_merged1748_write
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158
//	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159
inline void stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_write_bundle_write(hw_uint<256>& stg8_to_gp_1656_ld121_merged1748_write, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg8_to_gp_1656_ld122, int stg8_to_gp_1656_ld121, int dynamic_address) {
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_res = stg8_to_gp_1656_ld121_merged1748_write.extract<0, 15>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_144_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_res = stg8_to_gp_1656_ld121_merged1748_write.extract<16, 31>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_145_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_res = stg8_to_gp_1656_ld121_merged1748_write.extract<32, 47>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_146_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_res = stg8_to_gp_1656_ld121_merged1748_write.extract<48, 63>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_147_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_res = stg8_to_gp_1656_ld121_merged1748_write.extract<64, 79>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_148_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_res = stg8_to_gp_1656_ld121_merged1748_write.extract<80, 95>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_149_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_res = stg8_to_gp_1656_ld121_merged1748_write.extract<96, 111>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_150_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_res = stg8_to_gp_1656_ld121_merged1748_write.extract<112, 127>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_151_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_res = stg8_to_gp_1656_ld121_merged1748_write.extract<128, 143>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_152_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_res = stg8_to_gp_1656_ld121_merged1748_write.extract<144, 159>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_153_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_res = stg8_to_gp_1656_ld121_merged1748_write.extract<160, 175>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_154_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_res = stg8_to_gp_1656_ld121_merged1748_write.extract<176, 191>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_155_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_res = stg8_to_gp_1656_ld121_merged1748_write.extract<192, 207>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_156_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_res = stg8_to_gp_1656_ld121_merged1748_write.extract<208, 223>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_157_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_res = stg8_to_gp_1656_ld121_merged1748_write.extract<224, 239>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_158_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
	hw_uint<16> stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_res = stg8_to_gp_1656_ld121_merged1748_write.extract<240, 255>();
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_write(stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_159_res, stg8_FIFO_buf120, root, stg8_to_gp_1656_ld122, stg8_to_gp_1656_ld121, dynamic_address);
}

// stg9_1_merged1823_read
//	stg8_FIFO_buf120_stg9_1_merged1823_80
//	stg8_FIFO_buf120_stg9_1_merged1823_81
//	stg8_FIFO_buf120_stg9_1_merged1823_82
//	stg8_FIFO_buf120_stg9_1_merged1823_83
//	stg8_FIFO_buf120_stg9_1_merged1823_84
//	stg8_FIFO_buf120_stg9_1_merged1823_85
//	stg8_FIFO_buf120_stg9_1_merged1823_86
//	stg8_FIFO_buf120_stg9_1_merged1823_87
//	stg8_FIFO_buf120_stg9_1_merged1823_88
//	stg8_FIFO_buf120_stg9_1_merged1823_89
//	stg8_FIFO_buf120_stg9_1_merged1823_90
//	stg8_FIFO_buf120_stg9_1_merged1823_91
//	stg8_FIFO_buf120_stg9_1_merged1823_92
//	stg8_FIFO_buf120_stg9_1_merged1823_93
//	stg8_FIFO_buf120_stg9_1_merged1823_94
//	stg8_FIFO_buf120_stg9_1_merged1823_95
//	stg8_FIFO_buf120_stg9_1_merged1823_96
//	stg8_FIFO_buf120_stg9_1_merged1823_97
//	stg8_FIFO_buf120_stg9_1_merged1823_98
//	stg8_FIFO_buf120_stg9_1_merged1823_99
//	stg8_FIFO_buf120_stg9_1_merged1823_100
//	stg8_FIFO_buf120_stg9_1_merged1823_101
//	stg8_FIFO_buf120_stg9_1_merged1823_102
//	stg8_FIFO_buf120_stg9_1_merged1823_103
//	stg8_FIFO_buf120_stg9_1_merged1823_104
//	stg8_FIFO_buf120_stg9_1_merged1823_105
//	stg8_FIFO_buf120_stg9_1_merged1823_106
//	stg8_FIFO_buf120_stg9_1_merged1823_107
//	stg8_FIFO_buf120_stg9_1_merged1823_108
//	stg8_FIFO_buf120_stg9_1_merged1823_109
//	stg8_FIFO_buf120_stg9_1_merged1823_110
//	stg8_FIFO_buf120_stg9_1_merged1823_111
//	stg8_FIFO_buf120_stg9_1_merged1823_112
//	stg8_FIFO_buf120_stg9_1_merged1823_113
//	stg8_FIFO_buf120_stg9_1_merged1823_114
//	stg8_FIFO_buf120_stg9_1_merged1823_115
//	stg8_FIFO_buf120_stg9_1_merged1823_116
//	stg8_FIFO_buf120_stg9_1_merged1823_117
//	stg8_FIFO_buf120_stg9_1_merged1823_118
//	stg8_FIFO_buf120_stg9_1_merged1823_119
//	stg8_FIFO_buf120_stg9_1_merged1823_120
//	stg8_FIFO_buf120_stg9_1_merged1823_121
//	stg8_FIFO_buf120_stg9_1_merged1823_122
//	stg8_FIFO_buf120_stg9_1_merged1823_123
//	stg8_FIFO_buf120_stg9_1_merged1823_124
//	stg8_FIFO_buf120_stg9_1_merged1823_125
//	stg8_FIFO_buf120_stg9_1_merged1823_126
//	stg8_FIFO_buf120_stg9_1_merged1823_127
//	stg8_FIFO_buf120_stg9_1_merged1823_128
//	stg8_FIFO_buf120_stg9_1_merged1823_129
//	stg8_FIFO_buf120_stg9_1_merged1823_130
//	stg8_FIFO_buf120_stg9_1_merged1823_131
//	stg8_FIFO_buf120_stg9_1_merged1823_132
//	stg8_FIFO_buf120_stg9_1_merged1823_133
//	stg8_FIFO_buf120_stg9_1_merged1823_134
//	stg8_FIFO_buf120_stg9_1_merged1823_135
//	stg8_FIFO_buf120_stg9_1_merged1823_136
//	stg8_FIFO_buf120_stg9_1_merged1823_137
//	stg8_FIFO_buf120_stg9_1_merged1823_138
//	stg8_FIFO_buf120_stg9_1_merged1823_139
//	stg8_FIFO_buf120_stg9_1_merged1823_140
//	stg8_FIFO_buf120_stg9_1_merged1823_141
//	stg8_FIFO_buf120_stg9_1_merged1823_142
//	stg8_FIFO_buf120_stg9_1_merged1823_143
inline hw_uint<1024> stg8_FIFO_buf120_stg9_1_merged1823_read_bundle_read(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int root, int stg9_0, int stg9_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg8_FIFO_buf120_stg9_1_merged1823_80
    // stg8_FIFO_buf120_stg9_1_merged1823_81
    // stg8_FIFO_buf120_stg9_1_merged1823_82
    // stg8_FIFO_buf120_stg9_1_merged1823_83
    // stg8_FIFO_buf120_stg9_1_merged1823_84
    // stg8_FIFO_buf120_stg9_1_merged1823_85
    // stg8_FIFO_buf120_stg9_1_merged1823_86
    // stg8_FIFO_buf120_stg9_1_merged1823_87
    // stg8_FIFO_buf120_stg9_1_merged1823_88
    // stg8_FIFO_buf120_stg9_1_merged1823_89
    // stg8_FIFO_buf120_stg9_1_merged1823_90
    // stg8_FIFO_buf120_stg9_1_merged1823_91
    // stg8_FIFO_buf120_stg9_1_merged1823_92
    // stg8_FIFO_buf120_stg9_1_merged1823_93
    // stg8_FIFO_buf120_stg9_1_merged1823_94
    // stg8_FIFO_buf120_stg9_1_merged1823_95
    // stg8_FIFO_buf120_stg9_1_merged1823_96
    // stg8_FIFO_buf120_stg9_1_merged1823_97
    // stg8_FIFO_buf120_stg9_1_merged1823_98
    // stg8_FIFO_buf120_stg9_1_merged1823_99
    // stg8_FIFO_buf120_stg9_1_merged1823_100
    // stg8_FIFO_buf120_stg9_1_merged1823_101
    // stg8_FIFO_buf120_stg9_1_merged1823_102
    // stg8_FIFO_buf120_stg9_1_merged1823_103
    // stg8_FIFO_buf120_stg9_1_merged1823_104
    // stg8_FIFO_buf120_stg9_1_merged1823_105
    // stg8_FIFO_buf120_stg9_1_merged1823_106
    // stg8_FIFO_buf120_stg9_1_merged1823_107
    // stg8_FIFO_buf120_stg9_1_merged1823_108
    // stg8_FIFO_buf120_stg9_1_merged1823_109
    // stg8_FIFO_buf120_stg9_1_merged1823_110
    // stg8_FIFO_buf120_stg9_1_merged1823_111
    // stg8_FIFO_buf120_stg9_1_merged1823_112
    // stg8_FIFO_buf120_stg9_1_merged1823_113
    // stg8_FIFO_buf120_stg9_1_merged1823_114
    // stg8_FIFO_buf120_stg9_1_merged1823_115
    // stg8_FIFO_buf120_stg9_1_merged1823_116
    // stg8_FIFO_buf120_stg9_1_merged1823_117
    // stg8_FIFO_buf120_stg9_1_merged1823_118
    // stg8_FIFO_buf120_stg9_1_merged1823_119
    // stg8_FIFO_buf120_stg9_1_merged1823_120
    // stg8_FIFO_buf120_stg9_1_merged1823_121
    // stg8_FIFO_buf120_stg9_1_merged1823_122
    // stg8_FIFO_buf120_stg9_1_merged1823_123
    // stg8_FIFO_buf120_stg9_1_merged1823_124
    // stg8_FIFO_buf120_stg9_1_merged1823_125
    // stg8_FIFO_buf120_stg9_1_merged1823_126
    // stg8_FIFO_buf120_stg9_1_merged1823_127
    // stg8_FIFO_buf120_stg9_1_merged1823_128
    // stg8_FIFO_buf120_stg9_1_merged1823_129
    // stg8_FIFO_buf120_stg9_1_merged1823_130
    // stg8_FIFO_buf120_stg9_1_merged1823_131
    // stg8_FIFO_buf120_stg9_1_merged1823_132
    // stg8_FIFO_buf120_stg9_1_merged1823_133
    // stg8_FIFO_buf120_stg9_1_merged1823_134
    // stg8_FIFO_buf120_stg9_1_merged1823_135
    // stg8_FIFO_buf120_stg9_1_merged1823_136
    // stg8_FIFO_buf120_stg9_1_merged1823_137
    // stg8_FIFO_buf120_stg9_1_merged1823_138
    // stg8_FIFO_buf120_stg9_1_merged1823_139
    // stg8_FIFO_buf120_stg9_1_merged1823_140
    // stg8_FIFO_buf120_stg9_1_merged1823_141
    // stg8_FIFO_buf120_stg9_1_merged1823_142
    // stg8_FIFO_buf120_stg9_1_merged1823_143

	hw_uint<1024> result;
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_80_res = stg8_FIFO_buf120_stg9_1_merged1823_80_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<0, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_80_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_81_res = stg8_FIFO_buf120_stg9_1_merged1823_81_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<16, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_81_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_82_res = stg8_FIFO_buf120_stg9_1_merged1823_82_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<32, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_82_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_83_res = stg8_FIFO_buf120_stg9_1_merged1823_83_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<48, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_83_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_84_res = stg8_FIFO_buf120_stg9_1_merged1823_84_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<64, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_84_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_85_res = stg8_FIFO_buf120_stg9_1_merged1823_85_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<80, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_85_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_86_res = stg8_FIFO_buf120_stg9_1_merged1823_86_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<96, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_86_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_87_res = stg8_FIFO_buf120_stg9_1_merged1823_87_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<112, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_87_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_88_res = stg8_FIFO_buf120_stg9_1_merged1823_88_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<128, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_88_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_89_res = stg8_FIFO_buf120_stg9_1_merged1823_89_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<144, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_89_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_90_res = stg8_FIFO_buf120_stg9_1_merged1823_90_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<160, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_90_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_91_res = stg8_FIFO_buf120_stg9_1_merged1823_91_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<176, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_91_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_92_res = stg8_FIFO_buf120_stg9_1_merged1823_92_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<192, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_92_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_93_res = stg8_FIFO_buf120_stg9_1_merged1823_93_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<208, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_93_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_94_res = stg8_FIFO_buf120_stg9_1_merged1823_94_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<224, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_94_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_95_res = stg8_FIFO_buf120_stg9_1_merged1823_95_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<240, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_95_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_96_res = stg8_FIFO_buf120_stg9_1_merged1823_96_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<256, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_96_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_97_res = stg8_FIFO_buf120_stg9_1_merged1823_97_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<272, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_97_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_98_res = stg8_FIFO_buf120_stg9_1_merged1823_98_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<288, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_98_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_99_res = stg8_FIFO_buf120_stg9_1_merged1823_99_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<304, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_99_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_100_res = stg8_FIFO_buf120_stg9_1_merged1823_100_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<320, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_100_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_101_res = stg8_FIFO_buf120_stg9_1_merged1823_101_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<336, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_101_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_102_res = stg8_FIFO_buf120_stg9_1_merged1823_102_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<352, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_102_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_103_res = stg8_FIFO_buf120_stg9_1_merged1823_103_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<368, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_103_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_104_res = stg8_FIFO_buf120_stg9_1_merged1823_104_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<384, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_104_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_105_res = stg8_FIFO_buf120_stg9_1_merged1823_105_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<400, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_105_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_106_res = stg8_FIFO_buf120_stg9_1_merged1823_106_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<416, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_106_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_107_res = stg8_FIFO_buf120_stg9_1_merged1823_107_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<432, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_107_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_108_res = stg8_FIFO_buf120_stg9_1_merged1823_108_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<448, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_108_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_109_res = stg8_FIFO_buf120_stg9_1_merged1823_109_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<464, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_109_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_110_res = stg8_FIFO_buf120_stg9_1_merged1823_110_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<480, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_110_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_111_res = stg8_FIFO_buf120_stg9_1_merged1823_111_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<496, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_111_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_112_res = stg8_FIFO_buf120_stg9_1_merged1823_112_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<512, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_112_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_113_res = stg8_FIFO_buf120_stg9_1_merged1823_113_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<528, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_113_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_114_res = stg8_FIFO_buf120_stg9_1_merged1823_114_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<544, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_114_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_115_res = stg8_FIFO_buf120_stg9_1_merged1823_115_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<560, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_115_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_116_res = stg8_FIFO_buf120_stg9_1_merged1823_116_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<576, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_116_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_117_res = stg8_FIFO_buf120_stg9_1_merged1823_117_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<592, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_117_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_118_res = stg8_FIFO_buf120_stg9_1_merged1823_118_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<608, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_118_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_119_res = stg8_FIFO_buf120_stg9_1_merged1823_119_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<624, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_119_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_120_res = stg8_FIFO_buf120_stg9_1_merged1823_120_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<640, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_120_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_121_res = stg8_FIFO_buf120_stg9_1_merged1823_121_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<656, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_121_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_122_res = stg8_FIFO_buf120_stg9_1_merged1823_122_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<672, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_122_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_123_res = stg8_FIFO_buf120_stg9_1_merged1823_123_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<688, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_123_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_124_res = stg8_FIFO_buf120_stg9_1_merged1823_124_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<704, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_124_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_125_res = stg8_FIFO_buf120_stg9_1_merged1823_125_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<720, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_125_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_126_res = stg8_FIFO_buf120_stg9_1_merged1823_126_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<736, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_126_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_127_res = stg8_FIFO_buf120_stg9_1_merged1823_127_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<752, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_127_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_128_res = stg8_FIFO_buf120_stg9_1_merged1823_128_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<768, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_128_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_129_res = stg8_FIFO_buf120_stg9_1_merged1823_129_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<784, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_129_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_130_res = stg8_FIFO_buf120_stg9_1_merged1823_130_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<800, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_130_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_131_res = stg8_FIFO_buf120_stg9_1_merged1823_131_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<816, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_131_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_132_res = stg8_FIFO_buf120_stg9_1_merged1823_132_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<832, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_132_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_133_res = stg8_FIFO_buf120_stg9_1_merged1823_133_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<848, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_133_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_134_res = stg8_FIFO_buf120_stg9_1_merged1823_134_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<864, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_134_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_135_res = stg8_FIFO_buf120_stg9_1_merged1823_135_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<880, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_135_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_136_res = stg8_FIFO_buf120_stg9_1_merged1823_136_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<896, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_136_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_137_res = stg8_FIFO_buf120_stg9_1_merged1823_137_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<912, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_137_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_138_res = stg8_FIFO_buf120_stg9_1_merged1823_138_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<928, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_138_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_139_res = stg8_FIFO_buf120_stg9_1_merged1823_139_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<944, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_139_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_140_res = stg8_FIFO_buf120_stg9_1_merged1823_140_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<960, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_140_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_141_res = stg8_FIFO_buf120_stg9_1_merged1823_141_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<976, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_141_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_142_res = stg8_FIFO_buf120_stg9_1_merged1823_142_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<992, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_142_res);
	hw_uint<16> stg8_FIFO_buf120_stg9_1_merged1823_143_res = stg8_FIFO_buf120_stg9_1_merged1823_143_select(stg8_FIFO_buf120, root, stg9_0, stg9_1, dynamic_address);
	set_at<1008, 1024>(result, stg8_FIFO_buf120_stg9_1_merged1823_143_res);
	return result;
}

struct stg9_stg9_1_merged1823_64_to_stg9_stg9_ld61_merged1754_48_cache {
	// RAM Box: {[15, 1167], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_65_to_stg9_stg9_ld61_merged1754_49_cache {
	// RAM Box: {[14, 1166], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_66_to_stg9_stg9_ld61_merged1754_50_cache {
	// RAM Box: {[13, 1165], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_67_to_stg9_stg9_ld61_merged1754_51_cache {
	// RAM Box: {[12, 1164], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_68_to_stg9_stg9_ld61_merged1754_52_cache {
	// RAM Box: {[11, 1163], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_69_to_stg9_stg9_ld61_merged1754_53_cache {
	// RAM Box: {[10, 1162], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_70_to_stg9_stg9_ld61_merged1754_54_cache {
	// RAM Box: {[9, 1161], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_71_to_stg9_stg9_ld61_merged1754_55_cache {
	// RAM Box: {[8, 1160], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_72_to_stg9_stg9_ld61_merged1754_56_cache {
	// RAM Box: {[7, 1159], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_73_to_stg9_stg9_ld61_merged1754_57_cache {
	// RAM Box: {[6, 1158], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_74_to_stg9_stg9_ld61_merged1754_58_cache {
	// RAM Box: {[5, 1157], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_75_to_stg9_stg9_ld61_merged1754_59_cache {
	// RAM Box: {[4, 1156], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_76_to_stg9_stg9_ld61_merged1754_60_cache {
	// RAM Box: {[3, 1155], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_77_to_stg9_stg9_ld61_merged1754_61_cache {
	// RAM Box: {[2, 1154], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_78_to_stg9_stg9_ld61_merged1754_62_cache {
	// RAM Box: {[1, 1153], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_stg9_1_merged1823_79_to_stg9_stg9_ld61_merged1754_63_cache {
	// RAM Box: {[0, 1152], [-5, 1924]}
	// Capacity: 1
	// # of read delays: 2
  // 0, 0
	fifo<hw_uint<16>, 1> f;
	inline hw_uint<16> peek(const int offset) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.peek(0 - offset);
  }



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    return f.push(value);
  }

};

struct stg9_cache {
  // Reader addrs...
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[15 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[14 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[13 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[12 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[11 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[10 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[9 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[8 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[7 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[6 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[5 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[4 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[3 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[2 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[1 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
    // { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // # of banks: 16
  stg9_stg9_1_merged1823_64_to_stg9_stg9_ld61_merged1754_48_cache stg9_stg9_1_merged1823_64_to_stg9_stg9_ld61_merged1754_48;
  stg9_stg9_1_merged1823_65_to_stg9_stg9_ld61_merged1754_49_cache stg9_stg9_1_merged1823_65_to_stg9_stg9_ld61_merged1754_49;
  stg9_stg9_1_merged1823_66_to_stg9_stg9_ld61_merged1754_50_cache stg9_stg9_1_merged1823_66_to_stg9_stg9_ld61_merged1754_50;
  stg9_stg9_1_merged1823_67_to_stg9_stg9_ld61_merged1754_51_cache stg9_stg9_1_merged1823_67_to_stg9_stg9_ld61_merged1754_51;
  stg9_stg9_1_merged1823_68_to_stg9_stg9_ld61_merged1754_52_cache stg9_stg9_1_merged1823_68_to_stg9_stg9_ld61_merged1754_52;
  stg9_stg9_1_merged1823_69_to_stg9_stg9_ld61_merged1754_53_cache stg9_stg9_1_merged1823_69_to_stg9_stg9_ld61_merged1754_53;
  stg9_stg9_1_merged1823_70_to_stg9_stg9_ld61_merged1754_54_cache stg9_stg9_1_merged1823_70_to_stg9_stg9_ld61_merged1754_54;
  stg9_stg9_1_merged1823_71_to_stg9_stg9_ld61_merged1754_55_cache stg9_stg9_1_merged1823_71_to_stg9_stg9_ld61_merged1754_55;
  stg9_stg9_1_merged1823_72_to_stg9_stg9_ld61_merged1754_56_cache stg9_stg9_1_merged1823_72_to_stg9_stg9_ld61_merged1754_56;
  stg9_stg9_1_merged1823_73_to_stg9_stg9_ld61_merged1754_57_cache stg9_stg9_1_merged1823_73_to_stg9_stg9_ld61_merged1754_57;
  stg9_stg9_1_merged1823_74_to_stg9_stg9_ld61_merged1754_58_cache stg9_stg9_1_merged1823_74_to_stg9_stg9_ld61_merged1754_58;
  stg9_stg9_1_merged1823_75_to_stg9_stg9_ld61_merged1754_59_cache stg9_stg9_1_merged1823_75_to_stg9_stg9_ld61_merged1754_59;
  stg9_stg9_1_merged1823_76_to_stg9_stg9_ld61_merged1754_60_cache stg9_stg9_1_merged1823_76_to_stg9_stg9_ld61_merged1754_60;
  stg9_stg9_1_merged1823_77_to_stg9_stg9_ld61_merged1754_61_cache stg9_stg9_1_merged1823_77_to_stg9_stg9_ld61_merged1754_61;
  stg9_stg9_1_merged1823_78_to_stg9_stg9_ld61_merged1754_62_cache stg9_stg9_1_merged1823_78_to_stg9_stg9_ld61_merged1754_62;
  stg9_stg9_1_merged1823_79_to_stg9_stg9_ld61_merged1754_63_cache stg9_stg9_1_merged1823_79_to_stg9_stg9_ld61_merged1754_63;
};



inline void stg9_stg9_1_merged1823_64_write(hw_uint<16>& stg9_stg9_1_merged1823_64, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_64_to_stg9_stg9_ld61_merged1754_48.push(stg9_stg9_1_merged1823_64);
}

inline void stg9_stg9_1_merged1823_65_write(hw_uint<16>& stg9_stg9_1_merged1823_65, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_65_to_stg9_stg9_ld61_merged1754_49.push(stg9_stg9_1_merged1823_65);
}

inline void stg9_stg9_1_merged1823_66_write(hw_uint<16>& stg9_stg9_1_merged1823_66, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_66_to_stg9_stg9_ld61_merged1754_50.push(stg9_stg9_1_merged1823_66);
}

inline void stg9_stg9_1_merged1823_67_write(hw_uint<16>& stg9_stg9_1_merged1823_67, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_67_to_stg9_stg9_ld61_merged1754_51.push(stg9_stg9_1_merged1823_67);
}

inline void stg9_stg9_1_merged1823_68_write(hw_uint<16>& stg9_stg9_1_merged1823_68, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_68_to_stg9_stg9_ld61_merged1754_52.push(stg9_stg9_1_merged1823_68);
}

inline void stg9_stg9_1_merged1823_69_write(hw_uint<16>& stg9_stg9_1_merged1823_69, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_69_to_stg9_stg9_ld61_merged1754_53.push(stg9_stg9_1_merged1823_69);
}

inline void stg9_stg9_1_merged1823_70_write(hw_uint<16>& stg9_stg9_1_merged1823_70, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_70_to_stg9_stg9_ld61_merged1754_54.push(stg9_stg9_1_merged1823_70);
}

inline void stg9_stg9_1_merged1823_71_write(hw_uint<16>& stg9_stg9_1_merged1823_71, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_71_to_stg9_stg9_ld61_merged1754_55.push(stg9_stg9_1_merged1823_71);
}

inline void stg9_stg9_1_merged1823_72_write(hw_uint<16>& stg9_stg9_1_merged1823_72, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_72_to_stg9_stg9_ld61_merged1754_56.push(stg9_stg9_1_merged1823_72);
}

inline void stg9_stg9_1_merged1823_73_write(hw_uint<16>& stg9_stg9_1_merged1823_73, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_73_to_stg9_stg9_ld61_merged1754_57.push(stg9_stg9_1_merged1823_73);
}

inline void stg9_stg9_1_merged1823_74_write(hw_uint<16>& stg9_stg9_1_merged1823_74, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_74_to_stg9_stg9_ld61_merged1754_58.push(stg9_stg9_1_merged1823_74);
}

inline void stg9_stg9_1_merged1823_75_write(hw_uint<16>& stg9_stg9_1_merged1823_75, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_75_to_stg9_stg9_ld61_merged1754_59.push(stg9_stg9_1_merged1823_75);
}

inline void stg9_stg9_1_merged1823_76_write(hw_uint<16>& stg9_stg9_1_merged1823_76, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_76_to_stg9_stg9_ld61_merged1754_60.push(stg9_stg9_1_merged1823_76);
}

inline void stg9_stg9_1_merged1823_77_write(hw_uint<16>& stg9_stg9_1_merged1823_77, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_77_to_stg9_stg9_ld61_merged1754_61.push(stg9_stg9_1_merged1823_77);
}

inline void stg9_stg9_1_merged1823_78_write(hw_uint<16>& stg9_stg9_1_merged1823_78, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_78_to_stg9_stg9_ld61_merged1754_62.push(stg9_stg9_1_merged1823_78);
}

inline void stg9_stg9_1_merged1823_79_write(hw_uint<16>& stg9_stg9_1_merged1823_79, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
  stg9.stg9_stg9_1_merged1823_79_to_stg9_stg9_ld61_merged1754_63.push(stg9_stg9_1_merged1823_79);
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_48_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_48 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[15 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_64 = stg9.stg9_stg9_1_merged1823_64_to_stg9_stg9_ld61_merged1754_48.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_64;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_49_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_49 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[14 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_65 = stg9.stg9_stg9_1_merged1823_65_to_stg9_stg9_ld61_merged1754_49.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_65;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_50_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_50 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[13 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_66 = stg9.stg9_stg9_1_merged1823_66_to_stg9_stg9_ld61_merged1754_50.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_66;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_51_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_51 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[12 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_67 = stg9.stg9_stg9_1_merged1823_67_to_stg9_stg9_ld61_merged1754_51.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_67;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_52_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_52 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[11 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_68 = stg9.stg9_stg9_1_merged1823_68_to_stg9_stg9_ld61_merged1754_52.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_68;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_53_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_53 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[10 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_69 = stg9.stg9_stg9_1_merged1823_69_to_stg9_stg9_ld61_merged1754_53.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_69;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_54_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_54 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[9 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_70 = stg9.stg9_stg9_1_merged1823_70_to_stg9_stg9_ld61_merged1754_54.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_70;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_55_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_55 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[8 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_71 = stg9.stg9_stg9_1_merged1823_71_to_stg9_stg9_ld61_merged1754_55.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_71;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_56_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_56 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[7 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_72 = stg9.stg9_stg9_1_merged1823_72_to_stg9_stg9_ld61_merged1754_56.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_72;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_57_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_57 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[6 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_73 = stg9.stg9_stg9_1_merged1823_73_to_stg9_stg9_ld61_merged1754_57.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_73;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_58_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_58 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[5 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_74 = stg9.stg9_stg9_1_merged1823_74_to_stg9_stg9_ld61_merged1754_58.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_74;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_59_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_59 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[4 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_75 = stg9.stg9_stg9_1_merged1823_75_to_stg9_stg9_ld61_merged1754_59.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_75;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_60_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_60 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[3 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_76 = stg9.stg9_stg9_1_merged1823_76_to_stg9_stg9_ld61_merged1754_60.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_76;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_61_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_61 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[2 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_77 = stg9.stg9_stg9_1_merged1823_77_to_stg9_stg9_ld61_merged1754_61.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_77;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_62_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_62 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[1 + 16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_78 = stg9.stg9_stg9_1_merged1823_78_to_stg9_stg9_ld61_merged1754_62.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_78;
  return 0;
}

inline hw_uint<16> stg9_stg9_ld61_merged1754_63_select(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_stg9_ld61_merged1754_63 read pattern: { stg9_ld61_merged1754[root = 0, stg9_ld62, stg9_ld61] -> stg9[16stg9_ld61, -5 + stg9_ld62] : 0 <= stg9_ld62 <= 1929 and 0 <= stg9_ld61 <= 72 }
  // Read schedule : { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  // Write schedule: { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_stg9_1_merged1823_79 = stg9.stg9_stg9_1_merged1823_79_to_stg9_stg9_ld61_merged1754_63.peek(/* one reader or all rams */ 0);
  return value_stg9_stg9_1_merged1823_79;
  return 0;
}

// # of bundles = 2
// stg9_1_merged1823_write
//	stg9_stg9_1_merged1823_64
//	stg9_stg9_1_merged1823_65
//	stg9_stg9_1_merged1823_66
//	stg9_stg9_1_merged1823_67
//	stg9_stg9_1_merged1823_68
//	stg9_stg9_1_merged1823_69
//	stg9_stg9_1_merged1823_70
//	stg9_stg9_1_merged1823_71
//	stg9_stg9_1_merged1823_72
//	stg9_stg9_1_merged1823_73
//	stg9_stg9_1_merged1823_74
//	stg9_stg9_1_merged1823_75
//	stg9_stg9_1_merged1823_76
//	stg9_stg9_1_merged1823_77
//	stg9_stg9_1_merged1823_78
//	stg9_stg9_1_merged1823_79
inline void stg9_stg9_1_merged1823_write_bundle_write(hw_uint<256>& stg9_1_merged1823_write, stg9_cache& stg9, int root, int stg9_0, int stg9_1, int dynamic_address) {
	hw_uint<16> stg9_stg9_1_merged1823_64_res = stg9_1_merged1823_write.extract<0, 15>();
	stg9_stg9_1_merged1823_64_write(stg9_stg9_1_merged1823_64_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_65_res = stg9_1_merged1823_write.extract<16, 31>();
	stg9_stg9_1_merged1823_65_write(stg9_stg9_1_merged1823_65_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_66_res = stg9_1_merged1823_write.extract<32, 47>();
	stg9_stg9_1_merged1823_66_write(stg9_stg9_1_merged1823_66_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_67_res = stg9_1_merged1823_write.extract<48, 63>();
	stg9_stg9_1_merged1823_67_write(stg9_stg9_1_merged1823_67_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_68_res = stg9_1_merged1823_write.extract<64, 79>();
	stg9_stg9_1_merged1823_68_write(stg9_stg9_1_merged1823_68_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_69_res = stg9_1_merged1823_write.extract<80, 95>();
	stg9_stg9_1_merged1823_69_write(stg9_stg9_1_merged1823_69_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_70_res = stg9_1_merged1823_write.extract<96, 111>();
	stg9_stg9_1_merged1823_70_write(stg9_stg9_1_merged1823_70_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_71_res = stg9_1_merged1823_write.extract<112, 127>();
	stg9_stg9_1_merged1823_71_write(stg9_stg9_1_merged1823_71_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_72_res = stg9_1_merged1823_write.extract<128, 143>();
	stg9_stg9_1_merged1823_72_write(stg9_stg9_1_merged1823_72_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_73_res = stg9_1_merged1823_write.extract<144, 159>();
	stg9_stg9_1_merged1823_73_write(stg9_stg9_1_merged1823_73_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_74_res = stg9_1_merged1823_write.extract<160, 175>();
	stg9_stg9_1_merged1823_74_write(stg9_stg9_1_merged1823_74_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_75_res = stg9_1_merged1823_write.extract<176, 191>();
	stg9_stg9_1_merged1823_75_write(stg9_stg9_1_merged1823_75_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_76_res = stg9_1_merged1823_write.extract<192, 207>();
	stg9_stg9_1_merged1823_76_write(stg9_stg9_1_merged1823_76_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_77_res = stg9_1_merged1823_write.extract<208, 223>();
	stg9_stg9_1_merged1823_77_write(stg9_stg9_1_merged1823_77_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_78_res = stg9_1_merged1823_write.extract<224, 239>();
	stg9_stg9_1_merged1823_78_write(stg9_stg9_1_merged1823_78_res, stg9, root, stg9_0, stg9_1, dynamic_address);
	hw_uint<16> stg9_stg9_1_merged1823_79_res = stg9_1_merged1823_write.extract<240, 255>();
	stg9_stg9_1_merged1823_79_write(stg9_stg9_1_merged1823_79_res, stg9, root, stg9_0, stg9_1, dynamic_address);
}

// stg9_ld61_merged1754_read
//	stg9_stg9_ld61_merged1754_48
//	stg9_stg9_ld61_merged1754_49
//	stg9_stg9_ld61_merged1754_50
//	stg9_stg9_ld61_merged1754_51
//	stg9_stg9_ld61_merged1754_52
//	stg9_stg9_ld61_merged1754_53
//	stg9_stg9_ld61_merged1754_54
//	stg9_stg9_ld61_merged1754_55
//	stg9_stg9_ld61_merged1754_56
//	stg9_stg9_ld61_merged1754_57
//	stg9_stg9_ld61_merged1754_58
//	stg9_stg9_ld61_merged1754_59
//	stg9_stg9_ld61_merged1754_60
//	stg9_stg9_ld61_merged1754_61
//	stg9_stg9_ld61_merged1754_62
//	stg9_stg9_ld61_merged1754_63
inline hw_uint<256> stg9_stg9_ld61_merged1754_read_bundle_read(stg9_cache& stg9, int root, int stg9_ld62, int stg9_ld61, int dynamic_address) {
  // # of ports in bundle: 16
    // stg9_stg9_ld61_merged1754_48
    // stg9_stg9_ld61_merged1754_49
    // stg9_stg9_ld61_merged1754_50
    // stg9_stg9_ld61_merged1754_51
    // stg9_stg9_ld61_merged1754_52
    // stg9_stg9_ld61_merged1754_53
    // stg9_stg9_ld61_merged1754_54
    // stg9_stg9_ld61_merged1754_55
    // stg9_stg9_ld61_merged1754_56
    // stg9_stg9_ld61_merged1754_57
    // stg9_stg9_ld61_merged1754_58
    // stg9_stg9_ld61_merged1754_59
    // stg9_stg9_ld61_merged1754_60
    // stg9_stg9_ld61_merged1754_61
    // stg9_stg9_ld61_merged1754_62
    // stg9_stg9_ld61_merged1754_63

	hw_uint<256> result;
	hw_uint<16> stg9_stg9_ld61_merged1754_48_res = stg9_stg9_ld61_merged1754_48_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<0, 256>(result, stg9_stg9_ld61_merged1754_48_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_49_res = stg9_stg9_ld61_merged1754_49_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<16, 256>(result, stg9_stg9_ld61_merged1754_49_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_50_res = stg9_stg9_ld61_merged1754_50_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<32, 256>(result, stg9_stg9_ld61_merged1754_50_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_51_res = stg9_stg9_ld61_merged1754_51_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<48, 256>(result, stg9_stg9_ld61_merged1754_51_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_52_res = stg9_stg9_ld61_merged1754_52_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<64, 256>(result, stg9_stg9_ld61_merged1754_52_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_53_res = stg9_stg9_ld61_merged1754_53_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<80, 256>(result, stg9_stg9_ld61_merged1754_53_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_54_res = stg9_stg9_ld61_merged1754_54_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<96, 256>(result, stg9_stg9_ld61_merged1754_54_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_55_res = stg9_stg9_ld61_merged1754_55_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<112, 256>(result, stg9_stg9_ld61_merged1754_55_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_56_res = stg9_stg9_ld61_merged1754_56_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<128, 256>(result, stg9_stg9_ld61_merged1754_56_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_57_res = stg9_stg9_ld61_merged1754_57_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<144, 256>(result, stg9_stg9_ld61_merged1754_57_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_58_res = stg9_stg9_ld61_merged1754_58_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<160, 256>(result, stg9_stg9_ld61_merged1754_58_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_59_res = stg9_stg9_ld61_merged1754_59_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<176, 256>(result, stg9_stg9_ld61_merged1754_59_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_60_res = stg9_stg9_ld61_merged1754_60_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<192, 256>(result, stg9_stg9_ld61_merged1754_60_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_61_res = stg9_stg9_ld61_merged1754_61_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<208, 256>(result, stg9_stg9_ld61_merged1754_61_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_62_res = stg9_stg9_ld61_merged1754_62_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<224, 256>(result, stg9_stg9_ld61_merged1754_62_res);
	hw_uint<16> stg9_stg9_ld61_merged1754_63_res = stg9_stg9_ld61_merged1754_63_select(stg9, root, stg9_ld62, stg9_ld61, dynamic_address);
	set_at<240, 256>(result, stg9_stg9_ld61_merged1754_63_res);
	return result;
}

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_merged_banks_4_cache {
	// RAM Box: {[15, 1151], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_merged_banks_4_cache {
	// RAM Box: {[14, 1150], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_merged_banks_4_cache {
	// RAM Box: {[5, 1141], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_merged_banks_4_cache {
	// RAM Box: {[4, 1140], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_merged_banks_4_cache {
	// RAM Box: {[3, 1139], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_merged_banks_4_cache {
	// RAM Box: {[2, 1138], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_merged_banks_4_cache {
	// RAM Box: {[1, 1137], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_merged_banks_4_cache {
	// RAM Box: {[0, 1152], [-5, 1923]}
	// Capacity: 148
	// # of read delays: 5
  // 0, 1, 73, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 71> f3;
	hw_uint<16> f4;
	hw_uint<16> f6;
	fifo<hw_uint<16>, 72> f7;
	hw_uint<16> f8;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_72() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_73() {
		return f4;
	}

	inline hw_uint<16> peek_74() {
		return f6;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f7.back();
	}

	inline hw_uint<16> peek_147() {
		return f8;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f8 = f7.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f7.push(f6);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f6 = f4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 71
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 71 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_merged_banks_4_cache {
	// RAM Box: {[13, 1149], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_merged_banks_4_cache {
	// RAM Box: {[12, 1148], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_merged_banks_4_cache {
	// RAM Box: {[11, 1147], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_merged_banks_4_cache {
	// RAM Box: {[10, 1146], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_merged_banks_4_cache {
	// RAM Box: {[9, 1145], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_merged_banks_4_cache {
	// RAM Box: {[8, 1144], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_merged_banks_4_cache {
	// RAM Box: {[7, 1143], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_merged_banks_4_cache {
	// RAM Box: {[6, 1142], [-5, 1924]}
	// Capacity: 148
	// # of read delays: 4
  // 0, 1, 74, 147
	hw_uint<16> f0;
	hw_uint<16> f2;
	fifo<hw_uint<16>, 72> f3;
	hw_uint<16> f4;
	fifo<hw_uint<16>, 72> f5;
	hw_uint<16> f6;


	inline hw_uint<16> peek_0() {
		return f0;
	}

	inline hw_uint<16> peek_1() {
		return f2;
	}

	inline hw_uint<16> peek_73() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f3.back();
	}

	inline hw_uint<16> peek_74() {
		return f4;
	}

	inline hw_uint<16> peek_146() {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
		return f5.back();
	}

	inline hw_uint<16> peek_147() {
		return f6;
	}



	inline void push(const hw_uint<16> value) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f6 = f5.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f5.push(f4);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 72
    f4 = f3.back();
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 72 reading from capacity: 1
    f3.push(f2);
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
    // cap: 1 reading from capacity: 1
    f2 = f0;
    // cap: 1
    f0 = value;
	}

};

struct stg9_FIFO_buf124_cache {
  // Reader addrs...
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[15 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[15 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[16 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[15 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[14 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[14 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[15 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[14 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[13 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[13 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[14 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[13 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[12 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[12 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[13 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[12 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[11 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[11 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[12 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[11 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[10 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[10 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[11 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[10 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[9 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[9 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[10 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[9 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[8 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[8 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[9 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[8 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[7 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[7 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[8 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[7 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[6 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[6 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[7 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[6 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[5 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[5 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[6 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[5 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[4 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[4 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[5 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[4 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[3 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[3 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[4 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[3 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[2 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[2 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[3 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[2 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[1 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[1 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[2 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[1 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[1 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
    // { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // # of banks: 16
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_merged_banks_4;
  stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_merged_banks_4_cache stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_merged_banks_4;
};



inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8);
}

inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_write(hw_uint<16>& stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
  stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_merged_banks_4.push(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9);
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1952_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1952 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[15 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1953_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1953 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[15 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1954_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1954 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[16 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_merged_banks_4.peek_73();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1955_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1955 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[15 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1956_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1956 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[14 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1957_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1957 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[14 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1958_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1958 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[15 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1959_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1959 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[14 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1960_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1960 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[13 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1961_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1961 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[13 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1962_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1962 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[14 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1963_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1963 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[13 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1964_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1964 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[12 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1965_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1965 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[12 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1966_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1966 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[13 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1967_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1967 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[12 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1968_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1968 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[11 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1969_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1969 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[11 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1970_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1970 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[12 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1971_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1971 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[11 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1972_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1972 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[10 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1973_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1973 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[10 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1974_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1974 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[11 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1975_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1975 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[10 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1976_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1976 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[9 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1977_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1977 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[9 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1978_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1978 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[10 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1979_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1979 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[9 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1980_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1980 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[8 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1981_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1981 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[8 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1982_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1982 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[9 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1983_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1983 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[8 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1984_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1984 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[7 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1985_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1985 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[7 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1986_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1986 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[8 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1987_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1987 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[7 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1988_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1988 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[6 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1989_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1989 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[6 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1990_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1990 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[7 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1991_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1991 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[6 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1992_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1992 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[5 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1993_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1993 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[5 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1994_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1994 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[6 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1995_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1995 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[5 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1996_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1996 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[4 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1997_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1997 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[4 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1998_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1998 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[5 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1999_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_1999 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[4 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2000_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2000 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[3 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2001_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2001 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[3 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2002_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2002 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[4 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2003_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2003 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[3 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2004_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2004 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[2 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2005_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2005 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[2 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2006_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2006 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[3 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2007_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2007 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[2 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2008_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2008 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[1 + 16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2009_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2009 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[1 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2010_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2010 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[2 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2011_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2011 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[1 + 16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2012_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2012 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[16stg10_1, -5 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_merged_banks_4.peek_147();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2013_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2013 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2014_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2014 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[1 + 16stg10_1, -4 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_merged_banks_4.peek_74();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14;
  return 0;
}

inline hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2015_select(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  // stg9_FIFO_buf124_stg10_1_merged1826_2015 read pattern: { stg10_1_merged1826[root = 0, stg10_0, stg10_1] -> stg9_FIFO_buf124[16stg10_1, -3 + stg10_0] : 0 <= stg10_0 <= 1927 and 0 <= stg10_1 <= 71 }
  // Read schedule : { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
  // Write schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
  auto value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15 = stg9_FIFO_buf124.stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_merged_banks_4.peek_1();
  return value_stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15;
  return 0;
}

// # of bundles = 2
// stg10_1_merged1826_read
//	stg9_FIFO_buf124_stg10_1_merged1826_1952
//	stg9_FIFO_buf124_stg10_1_merged1826_1953
//	stg9_FIFO_buf124_stg10_1_merged1826_1954
//	stg9_FIFO_buf124_stg10_1_merged1826_1955
//	stg9_FIFO_buf124_stg10_1_merged1826_1956
//	stg9_FIFO_buf124_stg10_1_merged1826_1957
//	stg9_FIFO_buf124_stg10_1_merged1826_1958
//	stg9_FIFO_buf124_stg10_1_merged1826_1959
//	stg9_FIFO_buf124_stg10_1_merged1826_1960
//	stg9_FIFO_buf124_stg10_1_merged1826_1961
//	stg9_FIFO_buf124_stg10_1_merged1826_1962
//	stg9_FIFO_buf124_stg10_1_merged1826_1963
//	stg9_FIFO_buf124_stg10_1_merged1826_1964
//	stg9_FIFO_buf124_stg10_1_merged1826_1965
//	stg9_FIFO_buf124_stg10_1_merged1826_1966
//	stg9_FIFO_buf124_stg10_1_merged1826_1967
//	stg9_FIFO_buf124_stg10_1_merged1826_1968
//	stg9_FIFO_buf124_stg10_1_merged1826_1969
//	stg9_FIFO_buf124_stg10_1_merged1826_1970
//	stg9_FIFO_buf124_stg10_1_merged1826_1971
//	stg9_FIFO_buf124_stg10_1_merged1826_1972
//	stg9_FIFO_buf124_stg10_1_merged1826_1973
//	stg9_FIFO_buf124_stg10_1_merged1826_1974
//	stg9_FIFO_buf124_stg10_1_merged1826_1975
//	stg9_FIFO_buf124_stg10_1_merged1826_1976
//	stg9_FIFO_buf124_stg10_1_merged1826_1977
//	stg9_FIFO_buf124_stg10_1_merged1826_1978
//	stg9_FIFO_buf124_stg10_1_merged1826_1979
//	stg9_FIFO_buf124_stg10_1_merged1826_1980
//	stg9_FIFO_buf124_stg10_1_merged1826_1981
//	stg9_FIFO_buf124_stg10_1_merged1826_1982
//	stg9_FIFO_buf124_stg10_1_merged1826_1983
//	stg9_FIFO_buf124_stg10_1_merged1826_1984
//	stg9_FIFO_buf124_stg10_1_merged1826_1985
//	stg9_FIFO_buf124_stg10_1_merged1826_1986
//	stg9_FIFO_buf124_stg10_1_merged1826_1987
//	stg9_FIFO_buf124_stg10_1_merged1826_1988
//	stg9_FIFO_buf124_stg10_1_merged1826_1989
//	stg9_FIFO_buf124_stg10_1_merged1826_1990
//	stg9_FIFO_buf124_stg10_1_merged1826_1991
//	stg9_FIFO_buf124_stg10_1_merged1826_1992
//	stg9_FIFO_buf124_stg10_1_merged1826_1993
//	stg9_FIFO_buf124_stg10_1_merged1826_1994
//	stg9_FIFO_buf124_stg10_1_merged1826_1995
//	stg9_FIFO_buf124_stg10_1_merged1826_1996
//	stg9_FIFO_buf124_stg10_1_merged1826_1997
//	stg9_FIFO_buf124_stg10_1_merged1826_1998
//	stg9_FIFO_buf124_stg10_1_merged1826_1999
//	stg9_FIFO_buf124_stg10_1_merged1826_2000
//	stg9_FIFO_buf124_stg10_1_merged1826_2001
//	stg9_FIFO_buf124_stg10_1_merged1826_2002
//	stg9_FIFO_buf124_stg10_1_merged1826_2003
//	stg9_FIFO_buf124_stg10_1_merged1826_2004
//	stg9_FIFO_buf124_stg10_1_merged1826_2005
//	stg9_FIFO_buf124_stg10_1_merged1826_2006
//	stg9_FIFO_buf124_stg10_1_merged1826_2007
//	stg9_FIFO_buf124_stg10_1_merged1826_2008
//	stg9_FIFO_buf124_stg10_1_merged1826_2009
//	stg9_FIFO_buf124_stg10_1_merged1826_2010
//	stg9_FIFO_buf124_stg10_1_merged1826_2011
//	stg9_FIFO_buf124_stg10_1_merged1826_2012
//	stg9_FIFO_buf124_stg10_1_merged1826_2013
//	stg9_FIFO_buf124_stg10_1_merged1826_2014
//	stg9_FIFO_buf124_stg10_1_merged1826_2015
inline hw_uint<1024> stg9_FIFO_buf124_stg10_1_merged1826_read_bundle_read(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg10_0, int stg10_1, int dynamic_address) {
  // # of ports in bundle: 64
    // stg9_FIFO_buf124_stg10_1_merged1826_1952
    // stg9_FIFO_buf124_stg10_1_merged1826_1953
    // stg9_FIFO_buf124_stg10_1_merged1826_1954
    // stg9_FIFO_buf124_stg10_1_merged1826_1955
    // stg9_FIFO_buf124_stg10_1_merged1826_1956
    // stg9_FIFO_buf124_stg10_1_merged1826_1957
    // stg9_FIFO_buf124_stg10_1_merged1826_1958
    // stg9_FIFO_buf124_stg10_1_merged1826_1959
    // stg9_FIFO_buf124_stg10_1_merged1826_1960
    // stg9_FIFO_buf124_stg10_1_merged1826_1961
    // stg9_FIFO_buf124_stg10_1_merged1826_1962
    // stg9_FIFO_buf124_stg10_1_merged1826_1963
    // stg9_FIFO_buf124_stg10_1_merged1826_1964
    // stg9_FIFO_buf124_stg10_1_merged1826_1965
    // stg9_FIFO_buf124_stg10_1_merged1826_1966
    // stg9_FIFO_buf124_stg10_1_merged1826_1967
    // stg9_FIFO_buf124_stg10_1_merged1826_1968
    // stg9_FIFO_buf124_stg10_1_merged1826_1969
    // stg9_FIFO_buf124_stg10_1_merged1826_1970
    // stg9_FIFO_buf124_stg10_1_merged1826_1971
    // stg9_FIFO_buf124_stg10_1_merged1826_1972
    // stg9_FIFO_buf124_stg10_1_merged1826_1973
    // stg9_FIFO_buf124_stg10_1_merged1826_1974
    // stg9_FIFO_buf124_stg10_1_merged1826_1975
    // stg9_FIFO_buf124_stg10_1_merged1826_1976
    // stg9_FIFO_buf124_stg10_1_merged1826_1977
    // stg9_FIFO_buf124_stg10_1_merged1826_1978
    // stg9_FIFO_buf124_stg10_1_merged1826_1979
    // stg9_FIFO_buf124_stg10_1_merged1826_1980
    // stg9_FIFO_buf124_stg10_1_merged1826_1981
    // stg9_FIFO_buf124_stg10_1_merged1826_1982
    // stg9_FIFO_buf124_stg10_1_merged1826_1983
    // stg9_FIFO_buf124_stg10_1_merged1826_1984
    // stg9_FIFO_buf124_stg10_1_merged1826_1985
    // stg9_FIFO_buf124_stg10_1_merged1826_1986
    // stg9_FIFO_buf124_stg10_1_merged1826_1987
    // stg9_FIFO_buf124_stg10_1_merged1826_1988
    // stg9_FIFO_buf124_stg10_1_merged1826_1989
    // stg9_FIFO_buf124_stg10_1_merged1826_1990
    // stg9_FIFO_buf124_stg10_1_merged1826_1991
    // stg9_FIFO_buf124_stg10_1_merged1826_1992
    // stg9_FIFO_buf124_stg10_1_merged1826_1993
    // stg9_FIFO_buf124_stg10_1_merged1826_1994
    // stg9_FIFO_buf124_stg10_1_merged1826_1995
    // stg9_FIFO_buf124_stg10_1_merged1826_1996
    // stg9_FIFO_buf124_stg10_1_merged1826_1997
    // stg9_FIFO_buf124_stg10_1_merged1826_1998
    // stg9_FIFO_buf124_stg10_1_merged1826_1999
    // stg9_FIFO_buf124_stg10_1_merged1826_2000
    // stg9_FIFO_buf124_stg10_1_merged1826_2001
    // stg9_FIFO_buf124_stg10_1_merged1826_2002
    // stg9_FIFO_buf124_stg10_1_merged1826_2003
    // stg9_FIFO_buf124_stg10_1_merged1826_2004
    // stg9_FIFO_buf124_stg10_1_merged1826_2005
    // stg9_FIFO_buf124_stg10_1_merged1826_2006
    // stg9_FIFO_buf124_stg10_1_merged1826_2007
    // stg9_FIFO_buf124_stg10_1_merged1826_2008
    // stg9_FIFO_buf124_stg10_1_merged1826_2009
    // stg9_FIFO_buf124_stg10_1_merged1826_2010
    // stg9_FIFO_buf124_stg10_1_merged1826_2011
    // stg9_FIFO_buf124_stg10_1_merged1826_2012
    // stg9_FIFO_buf124_stg10_1_merged1826_2013
    // stg9_FIFO_buf124_stg10_1_merged1826_2014
    // stg9_FIFO_buf124_stg10_1_merged1826_2015

	hw_uint<1024> result;
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1952_res = stg9_FIFO_buf124_stg10_1_merged1826_1952_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<0, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1952_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1953_res = stg9_FIFO_buf124_stg10_1_merged1826_1953_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<16, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1953_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1954_res = stg9_FIFO_buf124_stg10_1_merged1826_1954_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<32, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1954_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1955_res = stg9_FIFO_buf124_stg10_1_merged1826_1955_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<48, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1955_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1956_res = stg9_FIFO_buf124_stg10_1_merged1826_1956_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<64, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1956_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1957_res = stg9_FIFO_buf124_stg10_1_merged1826_1957_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<80, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1957_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1958_res = stg9_FIFO_buf124_stg10_1_merged1826_1958_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<96, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1958_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1959_res = stg9_FIFO_buf124_stg10_1_merged1826_1959_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<112, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1959_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1960_res = stg9_FIFO_buf124_stg10_1_merged1826_1960_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<128, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1960_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1961_res = stg9_FIFO_buf124_stg10_1_merged1826_1961_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<144, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1961_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1962_res = stg9_FIFO_buf124_stg10_1_merged1826_1962_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<160, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1962_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1963_res = stg9_FIFO_buf124_stg10_1_merged1826_1963_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<176, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1963_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1964_res = stg9_FIFO_buf124_stg10_1_merged1826_1964_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<192, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1964_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1965_res = stg9_FIFO_buf124_stg10_1_merged1826_1965_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<208, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1965_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1966_res = stg9_FIFO_buf124_stg10_1_merged1826_1966_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<224, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1966_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1967_res = stg9_FIFO_buf124_stg10_1_merged1826_1967_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<240, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1967_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1968_res = stg9_FIFO_buf124_stg10_1_merged1826_1968_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<256, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1968_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1969_res = stg9_FIFO_buf124_stg10_1_merged1826_1969_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<272, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1969_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1970_res = stg9_FIFO_buf124_stg10_1_merged1826_1970_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<288, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1970_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1971_res = stg9_FIFO_buf124_stg10_1_merged1826_1971_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<304, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1971_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1972_res = stg9_FIFO_buf124_stg10_1_merged1826_1972_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<320, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1972_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1973_res = stg9_FIFO_buf124_stg10_1_merged1826_1973_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<336, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1973_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1974_res = stg9_FIFO_buf124_stg10_1_merged1826_1974_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<352, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1974_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1975_res = stg9_FIFO_buf124_stg10_1_merged1826_1975_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<368, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1975_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1976_res = stg9_FIFO_buf124_stg10_1_merged1826_1976_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<384, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1976_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1977_res = stg9_FIFO_buf124_stg10_1_merged1826_1977_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<400, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1977_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1978_res = stg9_FIFO_buf124_stg10_1_merged1826_1978_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<416, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1978_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1979_res = stg9_FIFO_buf124_stg10_1_merged1826_1979_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<432, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1979_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1980_res = stg9_FIFO_buf124_stg10_1_merged1826_1980_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<448, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1980_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1981_res = stg9_FIFO_buf124_stg10_1_merged1826_1981_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<464, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1981_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1982_res = stg9_FIFO_buf124_stg10_1_merged1826_1982_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<480, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1982_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1983_res = stg9_FIFO_buf124_stg10_1_merged1826_1983_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<496, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1983_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1984_res = stg9_FIFO_buf124_stg10_1_merged1826_1984_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<512, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1984_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1985_res = stg9_FIFO_buf124_stg10_1_merged1826_1985_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<528, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1985_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1986_res = stg9_FIFO_buf124_stg10_1_merged1826_1986_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<544, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1986_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1987_res = stg9_FIFO_buf124_stg10_1_merged1826_1987_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<560, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1987_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1988_res = stg9_FIFO_buf124_stg10_1_merged1826_1988_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<576, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1988_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1989_res = stg9_FIFO_buf124_stg10_1_merged1826_1989_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<592, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1989_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1990_res = stg9_FIFO_buf124_stg10_1_merged1826_1990_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<608, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1990_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1991_res = stg9_FIFO_buf124_stg10_1_merged1826_1991_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<624, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1991_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1992_res = stg9_FIFO_buf124_stg10_1_merged1826_1992_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<640, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1992_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1993_res = stg9_FIFO_buf124_stg10_1_merged1826_1993_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<656, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1993_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1994_res = stg9_FIFO_buf124_stg10_1_merged1826_1994_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<672, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1994_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1995_res = stg9_FIFO_buf124_stg10_1_merged1826_1995_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<688, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1995_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1996_res = stg9_FIFO_buf124_stg10_1_merged1826_1996_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<704, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1996_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1997_res = stg9_FIFO_buf124_stg10_1_merged1826_1997_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<720, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1997_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1998_res = stg9_FIFO_buf124_stg10_1_merged1826_1998_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<736, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1998_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_1999_res = stg9_FIFO_buf124_stg10_1_merged1826_1999_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<752, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_1999_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2000_res = stg9_FIFO_buf124_stg10_1_merged1826_2000_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<768, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2000_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2001_res = stg9_FIFO_buf124_stg10_1_merged1826_2001_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<784, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2001_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2002_res = stg9_FIFO_buf124_stg10_1_merged1826_2002_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<800, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2002_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2003_res = stg9_FIFO_buf124_stg10_1_merged1826_2003_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<816, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2003_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2004_res = stg9_FIFO_buf124_stg10_1_merged1826_2004_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<832, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2004_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2005_res = stg9_FIFO_buf124_stg10_1_merged1826_2005_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<848, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2005_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2006_res = stg9_FIFO_buf124_stg10_1_merged1826_2006_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<864, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2006_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2007_res = stg9_FIFO_buf124_stg10_1_merged1826_2007_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<880, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2007_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2008_res = stg9_FIFO_buf124_stg10_1_merged1826_2008_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<896, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2008_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2009_res = stg9_FIFO_buf124_stg10_1_merged1826_2009_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<912, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2009_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2010_res = stg9_FIFO_buf124_stg10_1_merged1826_2010_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<928, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2010_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2011_res = stg9_FIFO_buf124_stg10_1_merged1826_2011_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<944, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2011_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2012_res = stg9_FIFO_buf124_stg10_1_merged1826_2012_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<960, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2012_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2013_res = stg9_FIFO_buf124_stg10_1_merged1826_2013_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<976, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2013_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2014_res = stg9_FIFO_buf124_stg10_1_merged1826_2014_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<992, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2014_res);
	hw_uint<16> stg9_FIFO_buf124_stg10_1_merged1826_2015_res = stg9_FIFO_buf124_stg10_1_merged1826_2015_select(stg9_FIFO_buf124, root, stg10_0, stg10_1, dynamic_address);
	set_at<1008, 1024>(result, stg9_FIFO_buf124_stg10_1_merged1826_2015_res);
	return result;
}

// stg9_to_gp_360_ld125_merged1790_write
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14
//	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15
inline void stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_write_bundle_write(hw_uint<256>& stg9_to_gp_360_ld125_merged1790_write, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int root, int stg9_to_gp_360_ld126, int stg9_to_gp_360_ld125, int dynamic_address) {
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_res = stg9_to_gp_360_ld125_merged1790_write.extract<0, 15>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_0_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_res = stg9_to_gp_360_ld125_merged1790_write.extract<16, 31>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_1_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_res = stg9_to_gp_360_ld125_merged1790_write.extract<32, 47>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_2_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_res = stg9_to_gp_360_ld125_merged1790_write.extract<48, 63>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_3_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_res = stg9_to_gp_360_ld125_merged1790_write.extract<64, 79>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_4_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_res = stg9_to_gp_360_ld125_merged1790_write.extract<80, 95>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_5_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_res = stg9_to_gp_360_ld125_merged1790_write.extract<96, 111>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_6_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_res = stg9_to_gp_360_ld125_merged1790_write.extract<112, 127>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_7_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_res = stg9_to_gp_360_ld125_merged1790_write.extract<128, 143>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_8_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_res = stg9_to_gp_360_ld125_merged1790_write.extract<144, 159>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_9_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_res = stg9_to_gp_360_ld125_merged1790_write.extract<160, 175>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_10_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_res = stg9_to_gp_360_ld125_merged1790_write.extract<176, 191>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_11_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_res = stg9_to_gp_360_ld125_merged1790_write.extract<192, 207>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_12_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_res = stg9_to_gp_360_ld125_merged1790_write.extract<208, 223>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_13_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_res = stg9_to_gp_360_ld125_merged1790_write.extract<224, 239>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_14_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
	hw_uint<16> stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_res = stg9_to_gp_360_ld125_merged1790_write.extract<240, 255>();
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_write(stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_15_res, stg9_FIFO_buf124, root, stg9_to_gp_360_ld126, stg9_to_gp_360_ld125, dynamic_address);
}

// Operation logic
inline void in_1_merged1793(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */in_off_chip, in_cache& in, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: in_off_chip
	auto in_off_chip_1_m__lp_16_m_in_1__p__15_rp___p__0_c_____1_m__lp_in_0__p___m_15_rp___p__0_value = in_off_chip.read();
	auto compute_result = in_1_cu1791(in_off_chip_1_m__lp_16_m_in_1__p__15_rp___p__0_c_____1_m__lp_in_0__p___m_15_rp___p__0_value);
	// Produce: in
	in_in_1_merged1793_write_bundle_write(/* arg names */compute_result, in, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void in_ld1_merged1847(in_cache& in, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */in_to_gp_20, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: in
	auto in__lp_16_m_in_ld1__p__15_rp__c______lp_in_ld2__p___m_15_rp__value = in_in_ld1_merged1847_read_bundle_read(in/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = in_ld1_cu1846(in__lp_16_m_in_ld1__p__15_rp__c______lp_in_ld2__p___m_15_rp__value);
	// Produce: in_to_gp_20
	in_to_gp_20.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_in_0_in_ld2_(HWStream<hw_uint<256> >& /* no bundle get_args num ports = 16 */in_off_chip, HWStream<hw_uint<256> >& /* get_args num ports = 16 */in_to_gp_20) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_in_0_in_ld2__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  in_cache in;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82; in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
//   { in_ld1_merged1847[d0 = 0, d1, d2] -> [0, d1, d2, 1] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
// Condition for in_ld1_merged1847(((((-1 + 1*i3)) == 0) && (((1*i0)) == 0) && (((1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { in_1_merged1793[d0 = 0, d1, d2] -> [0, d1, d2, 0] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
// Condition for in_1_merged1793(((((1*i3)) == 0) && (((1*i0)) == 0) && (((1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 0 <= i1 <= 1949 and 0 <= i2 <= 82 and 0 <= i3 <= 1 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 0; i1 <= 1949; i1++) {
	    for (int i2 = 0; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          in_1_merged1793(in_off_chip /* buf name */, in, 0, ((1*i1)), ((1*i2)));
	        }
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          in_ld1_merged1847(in /* buf name */, in_to_gp_20, 0, ((1*i1)), ((1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg14_to_gp_128_ld93_merged1780(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg14_to_gp_128, stg14_FIFO_buf92_cache& stg14_FIFO_buf92, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg14_to_gp_128
	auto stg14_to_gp_128__lp_16_m_stg14_to_gp_128_ld93__p__15_rp__c____stg14_to_gp_128_ld94_value = stg14_to_gp_128.read();
	auto compute_result = stg14_to_gp_128_ld93_cu1779(stg14_to_gp_128__lp_16_m_stg14_to_gp_128_ld93__p__15_rp__c____stg14_to_gp_128_ld94_value);
	// Produce: stg14_FIFO_buf92
	stg14_FIFO_buf92_stg14_to_gp_128_ld93_merged1780_write_bundle_write(/* arg names */compute_result, stg14_FIFO_buf92, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void jacdyn_16_1_merged1841(stg14_FIFO_buf92_cache& stg14_FIFO_buf92, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */jacdyn_16, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg14_FIFO_buf92
	auto stg14_FIFO_buf92_1_m__lp_16_m_jacdyn_16_1__p__15_rp___p__0_c____1_m_jacdyn_16_0__p__0_value = stg14_FIFO_buf92_jacdyn_16_1_merged1841_read_bundle_read(stg14_FIFO_buf92/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = jacdyn_16_1_cu1839(stg14_FIFO_buf92_1_m__lp_16_m_jacdyn_16_1__p__15_rp___p__0_c____1_m_jacdyn_16_0__p__0_value);
	// Produce: jacdyn_16
	jacdyn_16.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_jacdyn_16_0_stg14_to_gp_128_ld94_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg14_to_gp_128, HWStream<hw_uint<256> >& /* get_args num ports = 16 */jacdyn_16) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_jacdyn_16_0_stg14_to_gp_128_ld94__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg14_FIFO_buf92_cache stg14_FIFO_buf92;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67; jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
//   { stg14_to_gp_128_ld93_merged1780[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 47] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
// Condition for stg14_to_gp_128_ld93_merged1780(((((-47 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-30 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-15 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { jacdyn_16_1_merged1841[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 48] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
// Condition for jacdyn_16_1_merged1841(((((-48 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-30 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-15 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 30 <= i1 <= 1949 and 15 <= i2 <= 82 and 47 <= i3 <= 48 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 30; i1 <= 1949; i1++) {
	    for (int i2 = 15; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg14_to_gp_128_ld93_merged1780(stg14_to_gp_128 /* buf name */, stg14_FIFO_buf92, 0, ((-30 + 1*i1)), ((-15 + 1*i2)));
	        }
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          jacdyn_16_1_merged1841(stg14_FIFO_buf92 /* buf name */, jacdyn_16, 0, ((-30 + 1*i1)), ((-15 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg2_to_gp_1032_ld97_merged1788(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg2_to_gp_1032, stg2_FIFO_buf96_cache& stg2_FIFO_buf96, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg2_to_gp_1032
	auto stg2_to_gp_1032__lp_16_m_stg2_to_gp_1032_ld97__p__15_rp__c______lp_stg2_to_gp_1032_ld98__p___m_12_rp__value = stg2_to_gp_1032.read();
	auto compute_result = stg2_to_gp_1032_ld97_cu1787(stg2_to_gp_1032__lp_16_m_stg2_to_gp_1032_ld97__p__15_rp__c______lp_stg2_to_gp_1032_ld98__p___m_12_rp__value);
	// Produce: stg2_FIFO_buf96
	stg2_FIFO_buf96_stg2_to_gp_1032_ld97_merged1788_write_bundle_write(/* arg names */compute_result, stg2_FIFO_buf96, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg3_1_merged1805(stg2_FIFO_buf96_cache& stg2_FIFO_buf96, stg3_cache& stg3, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg2_FIFO_buf96
	auto stg2_FIFO_buf96_1_m__lp_16_m_stg3_1__p__15_rp___p__0_c_____1_m__lp_stg3_0__p___m_11_rp___p___m_1_value = stg2_FIFO_buf96_stg3_1_merged1805_read_bundle_read(stg2_FIFO_buf96/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg3_1_cu1803(stg2_FIFO_buf96_1_m__lp_16_m_stg3_1__p__15_rp___p__0_c_____1_m__lp_stg3_0__p___m_11_rp___p___m_1_value);
	// Produce: stg3
	stg3_stg3_1_merged1805_write_bundle_write(/* arg names */compute_result, stg3, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg3_ld37_merged1766(stg3_cache& stg3, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg3_to_gp_1136, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg3
	auto stg3__lp_16_m_stg3_ld37__p__15_rp__c______lp_stg3_ld38__p___m_11_rp__value = stg3_stg3_ld37_merged1766_read_bundle_read(stg3/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg3_ld37_cu1765(stg3__lp_16_m_stg3_ld37__p__15_rp__c______lp_stg3_ld38__p___m_11_rp__value);
	// Produce: stg3_to_gp_1136
	stg3_to_gp_1136.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg2_to_gp_1032_ld98_stg3_0_stg3_ld38_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg2_to_gp_1032, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg3_to_gp_1136) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg2_to_gp_1032_ld98_stg3_0_stg3_ld38__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg2_FIFO_buf96_cache stg2_FIFO_buf96;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg3_cache stg3;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78; stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78; stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
//   { stg3_1_merged1805[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 12] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
// Condition for stg3_1_merged1805(((((-12 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-8 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-4 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg3_ld37_merged1766[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 13] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
// Condition for stg3_ld37_merged1766(((((-13 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-8 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-4 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg2_to_gp_1032_ld97_merged1788[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 11] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
// Condition for stg2_to_gp_1032_ld97_merged1788(((((-11 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-6 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-3 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 8 <= i1 <= 1949 and 4 <= i2 <= 82 and 12 <= i3 <= 13; [0, i1, i2, 11] : 6 <= i1 <= 1949 and 3 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 6; i1 <= 1949; i1++) {
	    for (int i2 = 3; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg2_to_gp_1032_ld97_merged1788(stg2_to_gp_1032 /* buf name */, stg2_FIFO_buf96, 0, ((-6 + 1*i1)), ((-3 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 8 and i2 >= 4 }
	        // { [i0, i1, i2] : i1 >= 8 and i2 >= 4 }
	          // { [i0, i1, i2] : -8 + i1 >= 0 }
	          // { [i0, i1, i2] : -4 + i2 >= 0 }
	        if ((((((-8 + 1*i1)) >= 0) && (((-4 + 1*i2)) >= 0)))) {
	          stg3_1_merged1805(stg2_FIFO_buf96 /* buf name */, stg3, 0, ((-8 + 1*i1)), ((-4 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 8 and i2 >= 4 }
	        // { [i0, i1, i2] : i1 >= 8 and i2 >= 4 }
	          // { [i0, i1, i2] : -8 + i1 >= 0 }
	          // { [i0, i1, i2] : -4 + i2 >= 0 }
	        if ((((((-8 + 1*i1)) >= 0) && (((-4 + 1*i2)) >= 0)))) {
	          stg3_ld37_merged1766(stg3 /* buf name */, stg3_to_gp_1136, 0, ((-8 + 1*i1)), ((-4 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg3_to_gp_1136_ld101_merged1746(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg3_to_gp_1136, stg3_FIFO_buf100_cache& stg3_FIFO_buf100, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg3_to_gp_1136
	auto stg3_to_gp_1136__lp_16_m_stg3_to_gp_1136_ld101__p__15_rp__c______lp_stg3_to_gp_1136_ld102__p___m_11_rp__value = stg3_to_gp_1136.read();
	auto compute_result = stg3_to_gp_1136_ld101_cu1745(stg3_to_gp_1136__lp_16_m_stg3_to_gp_1136_ld101__p__15_rp__c______lp_stg3_to_gp_1136_ld102__p___m_11_rp__value);
	// Produce: stg3_FIFO_buf100
	stg3_FIFO_buf100_stg3_to_gp_1136_ld101_merged1746_write_bundle_write(/* arg names */compute_result, stg3_FIFO_buf100, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg4_1_merged1808(stg3_FIFO_buf100_cache& stg3_FIFO_buf100, stg4_cache& stg4, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg3_FIFO_buf100
	auto stg3_FIFO_buf100_1_m__lp_16_m_stg4_1__p__15_rp___p__0_c_____1_m__lp_stg4_0__p___m_10_rp___p___m_1_value = stg3_FIFO_buf100_stg4_1_merged1808_read_bundle_read(stg3_FIFO_buf100/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg4_1_cu1806(stg3_FIFO_buf100_1_m__lp_16_m_stg4_1__p__15_rp___p__0_c_____1_m__lp_stg4_0__p___m_10_rp___p___m_1_value);
	// Produce: stg4
	stg4_stg4_1_merged1808_write_bundle_write(/* arg names */compute_result, stg4, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg4_ld41_merged1784(stg4_cache& stg4, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg4_to_gp_1240, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg4
	auto stg4__lp_16_m_stg4_ld41__p__15_rp__c______lp_stg4_ld42__p___m_10_rp__value = stg4_stg4_ld41_merged1784_read_bundle_read(stg4/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg4_ld41_cu1783(stg4__lp_16_m_stg4_ld41__p__15_rp__c______lp_stg4_ld42__p___m_10_rp__value);
	// Produce: stg4_to_gp_1240
	stg4_to_gp_1240.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg3_to_gp_1136_ld102_stg4_0_stg4_ld42_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg3_to_gp_1136, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg4_to_gp_1240) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg3_to_gp_1136_ld102_stg4_0_stg4_ld42__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg3_FIFO_buf100_cache stg3_FIFO_buf100;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg4_cache stg4;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77; stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78; stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
//   { stg4_ld41_merged1784[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 16] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
// Condition for stg4_ld41_merged1784(((((-16 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-10 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-5 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg3_to_gp_1136_ld101_merged1746[d0 = 0, d1, d2] -> [0, 8 + d1, 4 + d2, 14] : 0 <= d1 <= 1941 and 0 <= d2 <= 78 }
// Condition for stg3_to_gp_1136_ld101_merged1746(((((-14 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-8 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-4 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg4_1_merged1808[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 15] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
// Condition for stg4_1_merged1808(((((-15 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-10 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-5 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 10 <= i1 <= 1949 and 5 <= i2 <= 82 and 15 <= i3 <= 16; [0, i1, i2, 14] : 8 <= i1 <= 1949 and 4 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 8; i1 <= 1949; i1++) {
	    for (int i2 = 4; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg3_to_gp_1136_ld101_merged1746(stg3_to_gp_1136 /* buf name */, stg3_FIFO_buf100, 0, ((-8 + 1*i1)), ((-4 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 10 and i2 >= 5 }
	        // { [i0, i1, i2] : i1 >= 10 and i2 >= 5 }
	          // { [i0, i1, i2] : -10 + i1 >= 0 }
	          // { [i0, i1, i2] : -5 + i2 >= 0 }
	        if ((((((-10 + 1*i1)) >= 0) && (((-5 + 1*i2)) >= 0)))) {
	          stg4_1_merged1808(stg3_FIFO_buf100 /* buf name */, stg4, 0, ((-10 + 1*i1)), ((-5 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 10 and i2 >= 5 }
	        // { [i0, i1, i2] : i1 >= 10 and i2 >= 5 }
	          // { [i0, i1, i2] : -10 + i1 >= 0 }
	          // { [i0, i1, i2] : -5 + i2 >= 0 }
	        if ((((((-10 + 1*i1)) >= 0) && (((-5 + 1*i2)) >= 0)))) {
	          stg4_ld41_merged1784(stg4 /* buf name */, stg4_to_gp_1240, 0, ((-10 + 1*i1)), ((-5 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg5_1_merged1811(stg4_FIFO_buf104_cache& stg4_FIFO_buf104, stg5_cache& stg5, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg4_FIFO_buf104
	auto stg4_FIFO_buf104_1_m__lp_16_m_stg5_1__p__15_rp___p__0_c_____1_m__lp_stg5_0__p___m_9_rp___p___m_1_value = stg4_FIFO_buf104_stg5_1_merged1811_read_bundle_read(stg4_FIFO_buf104/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg5_1_cu1809(stg4_FIFO_buf104_1_m__lp_16_m_stg5_1__p__15_rp___p__0_c_____1_m__lp_stg5_0__p___m_9_rp___p___m_1_value);
	// Produce: stg5
	stg5_stg5_1_merged1811_write_bundle_write(/* arg names */compute_result, stg5, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg4_to_gp_1240_ld105_merged1758(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg4_to_gp_1240, stg4_FIFO_buf104_cache& stg4_FIFO_buf104, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg4_to_gp_1240
	auto stg4_to_gp_1240__lp_16_m_stg4_to_gp_1240_ld105__p__15_rp__c______lp_stg4_to_gp_1240_ld106__p___m_10_rp__value = stg4_to_gp_1240.read();
	auto compute_result = stg4_to_gp_1240_ld105_cu1757(stg4_to_gp_1240__lp_16_m_stg4_to_gp_1240_ld105__p__15_rp__c______lp_stg4_to_gp_1240_ld106__p___m_10_rp__value);
	// Produce: stg4_FIFO_buf104
	stg4_FIFO_buf104_stg4_to_gp_1240_ld105_merged1758_write_bundle_write(/* arg names */compute_result, stg4_FIFO_buf104, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg5_ld45_merged1853(stg5_cache& stg5, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg5_to_gp_1344, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg5
	auto stg5__lp_16_m_stg5_ld45__p__15_rp__c______lp_stg5_ld46__p___m_9_rp__value = stg5_stg5_ld45_merged1853_read_bundle_read(stg5/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg5_ld45_cu1852(stg5__lp_16_m_stg5_ld45__p__15_rp__c______lp_stg5_ld46__p___m_9_rp__value);
	// Produce: stg5_to_gp_1344
	stg5_to_gp_1344.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg4_to_gp_1240_ld106_stg5_0_stg5_ld46_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg4_to_gp_1240, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg5_to_gp_1344) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg4_to_gp_1240_ld106_stg5_0_stg5_ld46__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg4_FIFO_buf104_cache stg4_FIFO_buf104;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg5_cache stg5;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77; stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76; stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
//   { stg4_to_gp_1240_ld105_merged1758[d0 = 0, d1, d2] -> [0, 10 + d1, 5 + d2, 17] : 0 <= d1 <= 1939 and 0 <= d2 <= 77 }
// Condition for stg4_to_gp_1240_ld105_merged1758(((((-17 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-10 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-5 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg5_ld45_merged1853[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 19] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
// Condition for stg5_ld45_merged1853(((((-19 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-12 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-6 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg5_1_merged1811[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 18] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
// Condition for stg5_1_merged1811(((((-18 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-12 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-6 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 12 <= i1 <= 1949 and 6 <= i2 <= 82 and 18 <= i3 <= 19; [0, i1, i2, 17] : 10 <= i1 <= 1949 and 5 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 10; i1 <= 1949; i1++) {
	    for (int i2 = 5; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg4_to_gp_1240_ld105_merged1758(stg4_to_gp_1240 /* buf name */, stg4_FIFO_buf104, 0, ((-10 + 1*i1)), ((-5 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 12 and i2 >= 6 }
	        // { [i0, i1, i2] : i1 >= 12 and i2 >= 6 }
	          // { [i0, i1, i2] : -12 + i1 >= 0 }
	          // { [i0, i1, i2] : -6 + i2 >= 0 }
	        if ((((((-12 + 1*i1)) >= 0) && (((-6 + 1*i2)) >= 0)))) {
	          stg5_1_merged1811(stg4_FIFO_buf104 /* buf name */, stg5, 0, ((-12 + 1*i1)), ((-6 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 12 and i2 >= 6 }
	        // { [i0, i1, i2] : i1 >= 12 and i2 >= 6 }
	          // { [i0, i1, i2] : -12 + i1 >= 0 }
	          // { [i0, i1, i2] : -6 + i2 >= 0 }
	        if ((((((-12 + 1*i1)) >= 0) && (((-6 + 1*i2)) >= 0)))) {
	          stg5_ld45_merged1853(stg5 /* buf name */, stg5_to_gp_1344, 0, ((-12 + 1*i1)), ((-6 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg5_to_gp_1344_ld109_merged1760(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg5_to_gp_1344, stg5_FIFO_buf108_cache& stg5_FIFO_buf108, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg5_to_gp_1344
	auto stg5_to_gp_1344__lp_16_m_stg5_to_gp_1344_ld109__p__15_rp__c______lp_stg5_to_gp_1344_ld110__p___m_9_rp__value = stg5_to_gp_1344.read();
	auto compute_result = stg5_to_gp_1344_ld109_cu1759(stg5_to_gp_1344__lp_16_m_stg5_to_gp_1344_ld109__p__15_rp__c______lp_stg5_to_gp_1344_ld110__p___m_9_rp__value);
	// Produce: stg5_FIFO_buf108
	stg5_FIFO_buf108_stg5_to_gp_1344_ld109_merged1760_write_bundle_write(/* arg names */compute_result, stg5_FIFO_buf108, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg6_1_merged1814(stg5_FIFO_buf108_cache& stg5_FIFO_buf108, stg6_cache& stg6, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg5_FIFO_buf108
	auto stg5_FIFO_buf108_1_m__lp_16_m_stg6_1__p__15_rp___p__0_c_____1_m__lp_stg6_0__p___m_8_rp___p___m_1_value = stg5_FIFO_buf108_stg6_1_merged1814_read_bundle_read(stg5_FIFO_buf108/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg6_1_cu1812(stg5_FIFO_buf108_1_m__lp_16_m_stg6_1__p__15_rp___p__0_c_____1_m__lp_stg6_0__p___m_8_rp___p___m_1_value);
	// Produce: stg6
	stg6_stg6_1_merged1814_write_bundle_write(/* arg names */compute_result, stg6, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg6_ld49_merged1855(stg6_cache& stg6, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg6_to_gp_1448, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg6
	auto stg6__lp_16_m_stg6_ld49__p__15_rp__c______lp_stg6_ld50__p___m_8_rp__value = stg6_stg6_ld49_merged1855_read_bundle_read(stg6/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg6_ld49_cu1854(stg6__lp_16_m_stg6_ld49__p__15_rp__c______lp_stg6_ld50__p___m_8_rp__value);
	// Produce: stg6_to_gp_1448
	stg6_to_gp_1448.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg5_to_gp_1344_ld110_stg6_0_stg6_ld50_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg5_to_gp_1344, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg6_to_gp_1448) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg5_to_gp_1344_ld110_stg6_0_stg6_ld50__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg5_FIFO_buf108_cache stg5_FIFO_buf108;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg6_cache stg6;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75; stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75; stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
//   { stg6_1_merged1814[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 21] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
// Condition for stg6_1_merged1814(((((-21 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-14 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-7 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg6_ld49_merged1855[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 22] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
// Condition for stg6_ld49_merged1855(((((-22 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-14 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-7 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg5_to_gp_1344_ld109_merged1760[d0 = 0, d1, d2] -> [0, 12 + d1, 6 + d2, 20] : 0 <= d1 <= 1937 and 0 <= d2 <= 76 }
// Condition for stg5_to_gp_1344_ld109_merged1760(((((-20 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-12 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-6 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 14 <= i1 <= 1949 and 7 <= i2 <= 82 and 21 <= i3 <= 22; [0, i1, i2, 20] : 12 <= i1 <= 1949 and 6 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 12; i1 <= 1949; i1++) {
	    for (int i2 = 6; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg5_to_gp_1344_ld109_merged1760(stg5_to_gp_1344 /* buf name */, stg5_FIFO_buf108, 0, ((-12 + 1*i1)), ((-6 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 14 and i2 >= 7 }
	        // { [i0, i1, i2] : i1 >= 14 and i2 >= 7 }
	          // { [i0, i1, i2] : -14 + i1 >= 0 }
	          // { [i0, i1, i2] : -7 + i2 >= 0 }
	        if ((((((-14 + 1*i1)) >= 0) && (((-7 + 1*i2)) >= 0)))) {
	          stg6_1_merged1814(stg5_FIFO_buf108 /* buf name */, stg6, 0, ((-14 + 1*i1)), ((-7 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 14 and i2 >= 7 }
	        // { [i0, i1, i2] : i1 >= 14 and i2 >= 7 }
	          // { [i0, i1, i2] : -14 + i1 >= 0 }
	          // { [i0, i1, i2] : -7 + i2 >= 0 }
	        if ((((((-14 + 1*i1)) >= 0) && (((-7 + 1*i2)) >= 0)))) {
	          stg6_ld49_merged1855(stg6 /* buf name */, stg6_to_gp_1448, 0, ((-14 + 1*i1)), ((-7 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg6_to_gp_1448_ld113_merged1762(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg6_to_gp_1448, stg6_FIFO_buf112_cache& stg6_FIFO_buf112, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg6_to_gp_1448
	auto stg6_to_gp_1448__lp_16_m_stg6_to_gp_1448_ld113__p__15_rp__c______lp_stg6_to_gp_1448_ld114__p___m_8_rp__value = stg6_to_gp_1448.read();
	auto compute_result = stg6_to_gp_1448_ld113_cu1761(stg6_to_gp_1448__lp_16_m_stg6_to_gp_1448_ld113__p__15_rp__c______lp_stg6_to_gp_1448_ld114__p___m_8_rp__value);
	// Produce: stg6_FIFO_buf112
	stg6_FIFO_buf112_stg6_to_gp_1448_ld113_merged1762_write_bundle_write(/* arg names */compute_result, stg6_FIFO_buf112, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg7_1_merged1817(stg6_FIFO_buf112_cache& stg6_FIFO_buf112, stg7_cache& stg7, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg6_FIFO_buf112
	auto stg6_FIFO_buf112_1_m__lp_16_m_stg7_1__p__15_rp___p__0_c_____1_m__lp_stg7_0__p___m_7_rp___p___m_1_value = stg6_FIFO_buf112_stg7_1_merged1817_read_bundle_read(stg6_FIFO_buf112/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg7_1_cu1815(stg6_FIFO_buf112_1_m__lp_16_m_stg7_1__p__15_rp___p__0_c_____1_m__lp_stg7_0__p___m_7_rp___p___m_1_value);
	// Produce: stg7
	stg7_stg7_1_merged1817_write_bundle_write(/* arg names */compute_result, stg7, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg7_ld53_merged1752(stg7_cache& stg7, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg7_to_gp_1552, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg7
	auto stg7__lp_16_m_stg7_ld53__p__15_rp__c______lp_stg7_ld54__p___m_7_rp__value = stg7_stg7_ld53_merged1752_read_bundle_read(stg7/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg7_ld53_cu1751(stg7__lp_16_m_stg7_ld53__p__15_rp__c______lp_stg7_ld54__p___m_7_rp__value);
	// Produce: stg7_to_gp_1552
	stg7_to_gp_1552.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg6_to_gp_1448_ld114_stg7_0_stg7_ld54_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg6_to_gp_1448, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg7_to_gp_1552) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg6_to_gp_1448_ld114_stg7_0_stg7_ld54__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg6_FIFO_buf112_cache stg6_FIFO_buf112;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg7_cache stg7;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74; stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75; stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
//   { stg7_ld53_merged1752[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 25] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
// Condition for stg7_ld53_merged1752(((((-25 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-16 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-8 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg6_to_gp_1448_ld113_merged1762[d0 = 0, d1, d2] -> [0, 14 + d1, 7 + d2, 23] : 0 <= d1 <= 1935 and 0 <= d2 <= 75 }
// Condition for stg6_to_gp_1448_ld113_merged1762(((((-23 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-14 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-7 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg7_1_merged1817[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 24] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
// Condition for stg7_1_merged1817(((((-24 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-16 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-8 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 16 <= i1 <= 1949 and 8 <= i2 <= 82 and 24 <= i3 <= 25; [0, i1, i2, 23] : 14 <= i1 <= 1949 and 7 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 14; i1 <= 1949; i1++) {
	    for (int i2 = 7; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg6_to_gp_1448_ld113_merged1762(stg6_to_gp_1448 /* buf name */, stg6_FIFO_buf112, 0, ((-14 + 1*i1)), ((-7 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 16 and i2 >= 8 }
	        // { [i0, i1, i2] : i1 >= 16 and i2 >= 8 }
	          // { [i0, i1, i2] : -16 + i1 >= 0 }
	          // { [i0, i1, i2] : -8 + i2 >= 0 }
	        if ((((((-16 + 1*i1)) >= 0) && (((-8 + 1*i2)) >= 0)))) {
	          stg7_1_merged1817(stg6_FIFO_buf112 /* buf name */, stg7, 0, ((-16 + 1*i1)), ((-8 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 16 and i2 >= 8 }
	        // { [i0, i1, i2] : i1 >= 16 and i2 >= 8 }
	          // { [i0, i1, i2] : -16 + i1 >= 0 }
	          // { [i0, i1, i2] : -8 + i2 >= 0 }
	        if ((((((-16 + 1*i1)) >= 0) && (((-8 + 1*i2)) >= 0)))) {
	          stg7_ld53_merged1752(stg7 /* buf name */, stg7_to_gp_1552, 0, ((-16 + 1*i1)), ((-8 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg7_to_gp_1552_ld117_merged1764(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg7_to_gp_1552, stg7_FIFO_buf116_cache& stg7_FIFO_buf116, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg7_to_gp_1552
	auto stg7_to_gp_1552__lp_16_m_stg7_to_gp_1552_ld117__p__15_rp__c______lp_stg7_to_gp_1552_ld118__p___m_7_rp__value = stg7_to_gp_1552.read();
	auto compute_result = stg7_to_gp_1552_ld117_cu1763(stg7_to_gp_1552__lp_16_m_stg7_to_gp_1552_ld117__p__15_rp__c______lp_stg7_to_gp_1552_ld118__p___m_7_rp__value);
	// Produce: stg7_FIFO_buf116
	stg7_FIFO_buf116_stg7_to_gp_1552_ld117_merged1764_write_bundle_write(/* arg names */compute_result, stg7_FIFO_buf116, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg8_1_merged1820(stg7_FIFO_buf116_cache& stg7_FIFO_buf116, stg8_cache& stg8, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg7_FIFO_buf116
	auto stg7_FIFO_buf116_1_m__lp_16_m_stg8_1__p__15_rp___p__0_c_____1_m__lp_stg8_0__p___m_6_rp___p___m_1_value = stg7_FIFO_buf116_stg8_1_merged1820_read_bundle_read(stg7_FIFO_buf116/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg8_1_cu1818(stg7_FIFO_buf116_1_m__lp_16_m_stg8_1__p__15_rp___p__0_c_____1_m__lp_stg8_0__p___m_6_rp___p___m_1_value);
	// Produce: stg8
	stg8_stg8_1_merged1820_write_bundle_write(/* arg names */compute_result, stg8, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg8_ld57_merged1786(stg8_cache& stg8, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg8_to_gp_1656, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg8
	auto stg8__lp_16_m_stg8_ld57__p__15_rp__c______lp_stg8_ld58__p___m_6_rp__value = stg8_stg8_ld57_merged1786_read_bundle_read(stg8/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg8_ld57_cu1785(stg8__lp_16_m_stg8_ld57__p__15_rp__c______lp_stg8_ld58__p___m_6_rp__value);
	// Produce: stg8_to_gp_1656
	stg8_to_gp_1656.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg7_to_gp_1552_ld118_stg8_0_stg8_ld58_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg7_to_gp_1552, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg8_to_gp_1656) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg7_to_gp_1552_ld118_stg8_0_stg8_ld58__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg7_FIFO_buf116_cache stg7_FIFO_buf116;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg8_cache stg8;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73; stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73; stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
//   { stg8_ld57_merged1786[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 28] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
// Condition for stg8_ld57_merged1786(((((-28 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-18 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-9 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg8_1_merged1820[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 27] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
// Condition for stg8_1_merged1820(((((-27 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-18 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-9 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg7_to_gp_1552_ld117_merged1764[d0 = 0, d1, d2] -> [0, 16 + d1, 8 + d2, 26] : 0 <= d1 <= 1933 and 0 <= d2 <= 74 }
// Condition for stg7_to_gp_1552_ld117_merged1764(((((-26 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-16 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-8 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 18 <= i1 <= 1949 and 9 <= i2 <= 82 and 27 <= i3 <= 28; [0, i1, i2, 26] : 16 <= i1 <= 1949 and 8 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 16; i1 <= 1949; i1++) {
	    for (int i2 = 8; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg7_to_gp_1552_ld117_merged1764(stg7_to_gp_1552 /* buf name */, stg7_FIFO_buf116, 0, ((-16 + 1*i1)), ((-8 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 18 and i2 >= 9 }
	        // { [i0, i1, i2] : i1 >= 18 and i2 >= 9 }
	          // { [i0, i1, i2] : -18 + i1 >= 0 }
	          // { [i0, i1, i2] : -9 + i2 >= 0 }
	        if ((((((-18 + 1*i1)) >= 0) && (((-9 + 1*i2)) >= 0)))) {
	          stg8_1_merged1820(stg7_FIFO_buf116 /* buf name */, stg8, 0, ((-18 + 1*i1)), ((-9 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 18 and i2 >= 9 }
	        // { [i0, i1, i2] : i1 >= 18 and i2 >= 9 }
	          // { [i0, i1, i2] : -18 + i1 >= 0 }
	          // { [i0, i1, i2] : -9 + i2 >= 0 }
	        if ((((((-18 + 1*i1)) >= 0) && (((-9 + 1*i2)) >= 0)))) {
	          stg8_ld57_merged1786(stg8 /* buf name */, stg8_to_gp_1656, 0, ((-18 + 1*i1)), ((-9 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg8_to_gp_1656_ld121_merged1748(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg8_to_gp_1656, stg8_FIFO_buf120_cache& stg8_FIFO_buf120, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg8_to_gp_1656
	auto stg8_to_gp_1656__lp_16_m_stg8_to_gp_1656_ld121__p__15_rp__c______lp_stg8_to_gp_1656_ld122__p___m_6_rp__value = stg8_to_gp_1656.read();
	auto compute_result = stg8_to_gp_1656_ld121_cu1747(stg8_to_gp_1656__lp_16_m_stg8_to_gp_1656_ld121__p__15_rp__c______lp_stg8_to_gp_1656_ld122__p___m_6_rp__value);
	// Produce: stg8_FIFO_buf120
	stg8_FIFO_buf120_stg8_to_gp_1656_ld121_merged1748_write_bundle_write(/* arg names */compute_result, stg8_FIFO_buf120, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg9_1_merged1823(stg8_FIFO_buf120_cache& stg8_FIFO_buf120, stg9_cache& stg9, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg8_FIFO_buf120
	auto stg8_FIFO_buf120_1_m__lp_16_m_stg9_1__p__15_rp___p__0_c_____1_m__lp_stg9_0__p___m_5_rp___p___m_1_value = stg8_FIFO_buf120_stg9_1_merged1823_read_bundle_read(stg8_FIFO_buf120/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg9_1_cu1821(stg8_FIFO_buf120_1_m__lp_16_m_stg9_1__p__15_rp___p__0_c_____1_m__lp_stg9_0__p___m_5_rp___p___m_1_value);
	// Produce: stg9
	stg9_stg9_1_merged1823_write_bundle_write(/* arg names */compute_result, stg9, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg9_ld61_merged1754(stg9_cache& stg9, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg9_to_gp_360, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg9
	auto stg9__lp_16_m_stg9_ld61__p__15_rp__c______lp_stg9_ld62__p___m_5_rp__value = stg9_stg9_ld61_merged1754_read_bundle_read(stg9/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg9_ld61_cu1753(stg9__lp_16_m_stg9_ld61__p__15_rp__c______lp_stg9_ld62__p___m_5_rp__value);
	// Produce: stg9_to_gp_360
	stg9_to_gp_360.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg8_to_gp_1656_ld122_stg9_0_stg9_ld62_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg8_to_gp_1656, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg9_to_gp_360) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg8_to_gp_1656_ld122_stg9_0_stg9_ld62__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg8_FIFO_buf120_cache stg8_FIFO_buf120;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg9_cache stg9;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73; stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72; stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
//   { stg8_to_gp_1656_ld121_merged1748[d0 = 0, d1, d2] -> [0, 18 + d1, 9 + d2, 29] : 0 <= d1 <= 1931 and 0 <= d2 <= 73 }
// Condition for stg8_to_gp_1656_ld121_merged1748(((((-29 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-18 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-9 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg9_1_merged1823[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 30] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
// Condition for stg9_1_merged1823(((((-30 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-20 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-10 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg9_ld61_merged1754[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 31] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
// Condition for stg9_ld61_merged1754(((((-31 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-20 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-10 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 20 <= i1 <= 1949 and 10 <= i2 <= 82 and 30 <= i3 <= 31; [0, i1, i2, 29] : 18 <= i1 <= 1949 and 9 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 18; i1 <= 1949; i1++) {
	    for (int i2 = 9; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg8_to_gp_1656_ld121_merged1748(stg8_to_gp_1656 /* buf name */, stg8_FIFO_buf120, 0, ((-18 + 1*i1)), ((-9 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 20 and i2 >= 10 }
	        // { [i0, i1, i2] : i1 >= 20 and i2 >= 10 }
	          // { [i0, i1, i2] : -20 + i1 >= 0 }
	          // { [i0, i1, i2] : -10 + i2 >= 0 }
	        if ((((((-20 + 1*i1)) >= 0) && (((-10 + 1*i2)) >= 0)))) {
	          stg9_1_merged1823(stg8_FIFO_buf120 /* buf name */, stg9, 0, ((-20 + 1*i1)), ((-10 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 20 and i2 >= 10 }
	        // { [i0, i1, i2] : i1 >= 20 and i2 >= 10 }
	          // { [i0, i1, i2] : -20 + i1 >= 0 }
	          // { [i0, i1, i2] : -10 + i2 >= 0 }
	        if ((((((-20 + 1*i1)) >= 0) && (((-10 + 1*i2)) >= 0)))) {
	          stg9_ld61_merged1754(stg9 /* buf name */, stg9_to_gp_360, 0, ((-20 + 1*i1)), ((-10 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void in_to_gp_20_ld65_merged1774(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */in_to_gp_20, in_FIFO_buf64_cache& in_FIFO_buf64, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: in_to_gp_20
	auto in_to_gp_20__lp_16_m_in_to_gp_20_ld65__p__15_rp__c______lp_in_to_gp_20_ld66__p___m_15_rp__value = in_to_gp_20.read();
	auto compute_result = in_to_gp_20_ld65_cu1773(in_to_gp_20__lp_16_m_in_to_gp_20_ld65__p__15_rp__c______lp_in_to_gp_20_ld66__p___m_15_rp__value);
	// Produce: in_FIFO_buf64
	in_FIFO_buf64_in_to_gp_20_ld65_merged1774_write_bundle_write(/* arg names */compute_result, in_FIFO_buf64, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg0_1_merged1796(in_FIFO_buf64_cache& in_FIFO_buf64, stg0_cache& stg0, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: in_FIFO_buf64
	auto in_FIFO_buf64_1_m__lp_16_m_stg0_1__p__15_rp___p__0_c_____1_m__lp_stg0_0__p___m_14_rp___p___m_1_value = in_FIFO_buf64_stg0_1_merged1796_read_bundle_read(in_FIFO_buf64/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg0_1_cu1794(in_FIFO_buf64_1_m__lp_16_m_stg0_1__p__15_rp___p__0_c_____1_m__lp_stg0_0__p___m_14_rp___p___m_1_value);
	// Produce: stg0
	stg0_stg0_1_merged1796_write_bundle_write(/* arg names */compute_result, stg0, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg0_ld5_merged1857(stg0_cache& stg0, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg0_to_gp_84, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg0
	auto stg0__lp_16_m_stg0_ld5__p__15_rp__c______lp_stg0_ld6__p___m_14_rp__value = stg0_stg0_ld5_merged1857_read_bundle_read(stg0/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg0_ld5_cu1856(stg0__lp_16_m_stg0_ld5__p__15_rp__c______lp_stg0_ld6__p___m_14_rp__value);
	// Produce: stg0_to_gp_84
	stg0_to_gp_84.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_in_to_gp_20_ld66_stg0_0_stg0_ld6_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */in_to_gp_20, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg0_to_gp_84) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_in_to_gp_20_ld66_stg0_0_stg0_ld6__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  in_FIFO_buf64_cache in_FIFO_buf64;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg0_cache stg0;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81; in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82; stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
//   { stg0_1_merged1796[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 3] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
// Condition for stg0_1_merged1796(((((-3 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-2 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-1 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { in_to_gp_20_ld65_merged1774[d0 = 0, d1, d2] -> [0, d1, d2, 2] : 0 <= d1 <= 1949 and 0 <= d2 <= 82 }
// Condition for in_to_gp_20_ld65_merged1774(((((-2 + 1*i3)) == 0) && (((1*i0)) == 0) && (((1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg0_ld5_merged1857[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 4] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
// Condition for stg0_ld5_merged1857(((((-4 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-2 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-1 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 2 <= i1 <= 1949 and 0 < i2 <= 82 and 3 <= i3 <= 4; [0, i1, i2, 2] : 0 <= i1 <= 1949 and 0 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 0; i1 <= 1949; i1++) {
	    for (int i2 = 0; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          in_to_gp_20_ld65_merged1774(in_to_gp_20 /* buf name */, in_FIFO_buf64, 0, ((1*i1)), ((1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 2 and i2 > 0 }
	        // { [i0, i1, i2] : i1 >= 2 and i2 > 0 }
	          // { [i0, i1, i2] : -2 + i1 >= 0 }
	          // { [i0, i1, i2] : -1 + i2 >= 0 }
	        if ((((((-2 + 1*i1)) >= 0) && (((-1 + 1*i2)) >= 0)))) {
	          stg0_1_merged1796(in_FIFO_buf64 /* buf name */, stg0, 0, ((-2 + 1*i1)), ((-1 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 2 and i2 > 0 }
	        // { [i0, i1, i2] : i1 >= 2 and i2 > 0 }
	          // { [i0, i1, i2] : -2 + i1 >= 0 }
	          // { [i0, i1, i2] : -1 + i2 >= 0 }
	        if ((((((-2 + 1*i1)) >= 0) && (((-1 + 1*i2)) >= 0)))) {
	          stg0_ld5_merged1857(stg0 /* buf name */, stg0_to_gp_84, 0, ((-2 + 1*i1)), ((-1 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg9_to_gp_360_ld125_merged1790(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg9_to_gp_360, stg9_FIFO_buf124_cache& stg9_FIFO_buf124, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg9_to_gp_360
	auto stg9_to_gp_360__lp_16_m_stg9_to_gp_360_ld125__p__15_rp__c______lp_stg9_to_gp_360_ld126__p___m_5_rp__value = stg9_to_gp_360.read();
	auto compute_result = stg9_to_gp_360_ld125_cu1789(stg9_to_gp_360__lp_16_m_stg9_to_gp_360_ld125__p__15_rp__c______lp_stg9_to_gp_360_ld126__p___m_5_rp__value);
	// Produce: stg9_FIFO_buf124
	stg9_FIFO_buf124_stg9_to_gp_360_ld125_merged1790_write_bundle_write(/* arg names */compute_result, stg9_FIFO_buf124, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg10_1_merged1826(stg9_FIFO_buf124_cache& stg9_FIFO_buf124, stg10_cache& stg10, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg9_FIFO_buf124
	auto stg9_FIFO_buf124_1_m__lp_16_m_stg10_1__p__15_rp___p__0_c_____1_m__lp_stg10_0__p___m_4_rp___p___m_1_value = stg9_FIFO_buf124_stg10_1_merged1826_read_bundle_read(stg9_FIFO_buf124/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg10_1_cu1824(stg9_FIFO_buf124_1_m__lp_16_m_stg10_1__p__15_rp___p__0_c_____1_m__lp_stg10_0__p___m_4_rp___p___m_1_value);
	// Produce: stg10
	stg10_stg10_1_merged1826_write_bundle_write(/* arg names */compute_result, stg10, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg10_ld13_merged1849(stg10_cache& stg10, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg10_to_gp_412, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg10
	auto stg10__lp_16_m_stg10_ld13__p__15_rp__c______lp_stg10_ld14__p___m_4_rp__value = stg10_stg10_ld13_merged1849_read_bundle_read(stg10/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg10_ld13_cu1848(stg10__lp_16_m_stg10_ld13__p__15_rp__c______lp_stg10_ld14__p___m_4_rp__value);
	// Produce: stg10_to_gp_412
	stg10_to_gp_412.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg10_0_stg10_ld14_stg9_to_gp_360_ld126_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg9_to_gp_360, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg10_to_gp_412) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg10_0_stg10_ld14_stg9_to_gp_360_ld126__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg10_cache stg10;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg9_FIFO_buf124_cache stg9_FIFO_buf124;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72; stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71; stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
//   { stg9_to_gp_360_ld125_merged1790[d0 = 0, d1, d2] -> [0, 20 + d1, 10 + d2, 32] : 0 <= d1 <= 1929 and 0 <= d2 <= 72 }
// Condition for stg9_to_gp_360_ld125_merged1790(((((-32 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-20 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-10 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg10_1_merged1826[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 33] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
// Condition for stg10_1_merged1826(((((-33 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-22 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-11 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg10_ld13_merged1849[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 34] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
// Condition for stg10_ld13_merged1849(((((-34 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-22 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-11 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 22 <= i1 <= 1949 and 11 <= i2 <= 82 and 33 <= i3 <= 34; [0, i1, i2, 32] : 20 <= i1 <= 1949 and 10 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 20; i1 <= 1949; i1++) {
	    for (int i2 = 10; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg9_to_gp_360_ld125_merged1790(stg9_to_gp_360 /* buf name */, stg9_FIFO_buf124, 0, ((-20 + 1*i1)), ((-10 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 22 and i2 >= 11 }
	        // { [i0, i1, i2] : i1 >= 22 and i2 >= 11 }
	          // { [i0, i1, i2] : -22 + i1 >= 0 }
	          // { [i0, i1, i2] : -11 + i2 >= 0 }
	        if ((((((-22 + 1*i1)) >= 0) && (((-11 + 1*i2)) >= 0)))) {
	          stg10_1_merged1826(stg9_FIFO_buf124 /* buf name */, stg10, 0, ((-22 + 1*i1)), ((-11 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 22 and i2 >= 11 }
	        // { [i0, i1, i2] : i1 >= 22 and i2 >= 11 }
	          // { [i0, i1, i2] : -22 + i1 >= 0 }
	          // { [i0, i1, i2] : -11 + i2 >= 0 }
	        if ((((((-22 + 1*i1)) >= 0) && (((-11 + 1*i2)) >= 0)))) {
	          stg10_ld13_merged1849(stg10 /* buf name */, stg10_to_gp_412, 0, ((-22 + 1*i1)), ((-11 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg10_to_gp_412_ld77_merged1768(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg10_to_gp_412, stg10_FIFO_buf76_cache& stg10_FIFO_buf76, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg10_to_gp_412
	auto stg10_to_gp_412__lp_16_m_stg10_to_gp_412_ld77__p__15_rp__c______lp_stg10_to_gp_412_ld78__p___m_4_rp__value = stg10_to_gp_412.read();
	auto compute_result = stg10_to_gp_412_ld77_cu1767(stg10_to_gp_412__lp_16_m_stg10_to_gp_412_ld77__p__15_rp__c______lp_stg10_to_gp_412_ld78__p___m_4_rp__value);
	// Produce: stg10_FIFO_buf76
	stg10_FIFO_buf76_stg10_to_gp_412_ld77_merged1768_write_bundle_write(/* arg names */compute_result, stg10_FIFO_buf76, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg11_1_merged1829(stg10_FIFO_buf76_cache& stg10_FIFO_buf76, stg11_cache& stg11, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg10_FIFO_buf76
	auto stg10_FIFO_buf76_1_m__lp_16_m_stg11_1__p__15_rp___p__0_c_____1_m__lp_stg11_0__p___m_3_rp___p___m_1_value = stg10_FIFO_buf76_stg11_1_merged1829_read_bundle_read(stg10_FIFO_buf76/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg11_1_cu1827(stg10_FIFO_buf76_1_m__lp_16_m_stg11_1__p__15_rp___p__0_c_____1_m__lp_stg11_0__p___m_3_rp___p___m_1_value);
	// Produce: stg11
	stg11_stg11_1_merged1829_write_bundle_write(/* arg names */compute_result, stg11, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg11_ld17_merged1770(stg11_cache& stg11, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg11_to_gp_516, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg11
	auto stg11__lp_16_m_stg11_ld17__p__15_rp__c______lp_stg11_ld18__p___m_3_rp__value = stg11_stg11_ld17_merged1770_read_bundle_read(stg11/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg11_ld17_cu1769(stg11__lp_16_m_stg11_ld17__p__15_rp__c______lp_stg11_ld18__p___m_3_rp__value);
	// Produce: stg11_to_gp_516
	stg11_to_gp_516.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg10_to_gp_412_ld78_stg11_0_stg11_ld18_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg10_to_gp_412, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg11_to_gp_516) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg10_to_gp_412_ld78_stg11_0_stg11_ld18__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg10_FIFO_buf76_cache stg10_FIFO_buf76;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg11_cache stg11;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70; stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70; stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
//   { stg11_ld17_merged1770[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 37] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
// Condition for stg11_ld17_merged1770(((((-37 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-24 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-12 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg11_1_merged1829[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 36] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
// Condition for stg11_1_merged1829(((((-36 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-24 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-12 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg10_to_gp_412_ld77_merged1768[d0 = 0, d1, d2] -> [0, 22 + d1, 11 + d2, 35] : 0 <= d1 <= 1927 and 0 <= d2 <= 71 }
// Condition for stg10_to_gp_412_ld77_merged1768(((((-35 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-22 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-11 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 24 <= i1 <= 1949 and 12 <= i2 <= 82 and 36 <= i3 <= 37; [0, i1, i2, 35] : 22 <= i1 <= 1949 and 11 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 22; i1 <= 1949; i1++) {
	    for (int i2 = 11; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg10_to_gp_412_ld77_merged1768(stg10_to_gp_412 /* buf name */, stg10_FIFO_buf76, 0, ((-22 + 1*i1)), ((-11 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 24 and i2 >= 12 }
	        // { [i0, i1, i2] : i1 >= 24 and i2 >= 12 }
	          // { [i0, i1, i2] : -24 + i1 >= 0 }
	          // { [i0, i1, i2] : -12 + i2 >= 0 }
	        if ((((((-24 + 1*i1)) >= 0) && (((-12 + 1*i2)) >= 0)))) {
	          stg11_1_merged1829(stg10_FIFO_buf76 /* buf name */, stg11, 0, ((-24 + 1*i1)), ((-12 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 24 and i2 >= 12 }
	        // { [i0, i1, i2] : i1 >= 24 and i2 >= 12 }
	          // { [i0, i1, i2] : -24 + i1 >= 0 }
	          // { [i0, i1, i2] : -12 + i2 >= 0 }
	        if ((((((-24 + 1*i1)) >= 0) && (((-12 + 1*i2)) >= 0)))) {
	          stg11_ld17_merged1770(stg11 /* buf name */, stg11_to_gp_516, 0, ((-24 + 1*i1)), ((-12 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg11_to_gp_516_ld81_merged1778(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg11_to_gp_516, stg11_FIFO_buf80_cache& stg11_FIFO_buf80, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg11_to_gp_516
	auto stg11_to_gp_516__lp_16_m_stg11_to_gp_516_ld81__p__15_rp__c______lp_stg11_to_gp_516_ld82__p___m_3_rp__value = stg11_to_gp_516.read();
	auto compute_result = stg11_to_gp_516_ld81_cu1777(stg11_to_gp_516__lp_16_m_stg11_to_gp_516_ld81__p__15_rp__c______lp_stg11_to_gp_516_ld82__p___m_3_rp__value);
	// Produce: stg11_FIFO_buf80
	stg11_FIFO_buf80_stg11_to_gp_516_ld81_merged1778_write_bundle_write(/* arg names */compute_result, stg11_FIFO_buf80, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg12_1_merged1832(stg11_FIFO_buf80_cache& stg11_FIFO_buf80, stg12_cache& stg12, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg11_FIFO_buf80
	auto stg11_FIFO_buf80_1_m__lp_16_m_stg12_1__p__15_rp___p__0_c_____1_m__lp_stg12_0__p___m_2_rp___p___m_1_value = stg11_FIFO_buf80_stg12_1_merged1832_read_bundle_read(stg11_FIFO_buf80/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg12_1_cu1830(stg11_FIFO_buf80_1_m__lp_16_m_stg12_1__p__15_rp___p__0_c_____1_m__lp_stg12_0__p___m_2_rp___p___m_1_value);
	// Produce: stg12
	stg12_stg12_1_merged1832_write_bundle_write(/* arg names */compute_result, stg12, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg12_ld21_merged1772(stg12_cache& stg12, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg12_to_gp_620, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg12
	auto stg12__lp_16_m_stg12_ld21__p__15_rp__c______lp_stg12_ld22__p___m_2_rp__value = stg12_stg12_ld21_merged1772_read_bundle_read(stg12/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg12_ld21_cu1771(stg12__lp_16_m_stg12_ld21__p__15_rp__c______lp_stg12_ld22__p___m_2_rp__value);
	// Produce: stg12_to_gp_620
	stg12_to_gp_620.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg11_to_gp_516_ld82_stg12_0_stg12_ld22_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg11_to_gp_516, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg12_to_gp_620) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg11_to_gp_516_ld82_stg12_0_stg12_ld22__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg11_FIFO_buf80_cache stg11_FIFO_buf80;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg12_cache stg12;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69; stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70; stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
//   { stg12_1_merged1832[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 39] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
// Condition for stg12_1_merged1832(((((-39 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-26 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-13 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg11_to_gp_516_ld81_merged1778[d0 = 0, d1, d2] -> [0, 24 + d1, 12 + d2, 38] : 0 <= d1 <= 1925 and 0 <= d2 <= 70 }
// Condition for stg11_to_gp_516_ld81_merged1778(((((-38 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-24 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-12 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg12_ld21_merged1772[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 40] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
// Condition for stg12_ld21_merged1772(((((-40 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-26 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-13 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 26 <= i1 <= 1949 and 13 <= i2 <= 82 and 39 <= i3 <= 40; [0, i1, i2, 38] : 24 <= i1 <= 1949 and 12 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 24; i1 <= 1949; i1++) {
	    for (int i2 = 12; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg11_to_gp_516_ld81_merged1778(stg11_to_gp_516 /* buf name */, stg11_FIFO_buf80, 0, ((-24 + 1*i1)), ((-12 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 26 and i2 >= 13 }
	        // { [i0, i1, i2] : i1 >= 26 and i2 >= 13 }
	          // { [i0, i1, i2] : -26 + i1 >= 0 }
	          // { [i0, i1, i2] : -13 + i2 >= 0 }
	        if ((((((-26 + 1*i1)) >= 0) && (((-13 + 1*i2)) >= 0)))) {
	          stg12_1_merged1832(stg11_FIFO_buf80 /* buf name */, stg12, 0, ((-26 + 1*i1)), ((-13 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 26 and i2 >= 13 }
	        // { [i0, i1, i2] : i1 >= 26 and i2 >= 13 }
	          // { [i0, i1, i2] : -26 + i1 >= 0 }
	          // { [i0, i1, i2] : -13 + i2 >= 0 }
	        if ((((((-26 + 1*i1)) >= 0) && (((-13 + 1*i2)) >= 0)))) {
	          stg12_ld21_merged1772(stg12 /* buf name */, stg12_to_gp_620, 0, ((-26 + 1*i1)), ((-13 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg12_to_gp_620_ld85_merged1756(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg12_to_gp_620, stg12_FIFO_buf84_cache& stg12_FIFO_buf84, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg12_to_gp_620
	auto stg12_to_gp_620__lp_16_m_stg12_to_gp_620_ld85__p__15_rp__c______lp_stg12_to_gp_620_ld86__p___m_2_rp__value = stg12_to_gp_620.read();
	auto compute_result = stg12_to_gp_620_ld85_cu1755(stg12_to_gp_620__lp_16_m_stg12_to_gp_620_ld85__p__15_rp__c______lp_stg12_to_gp_620_ld86__p___m_2_rp__value);
	// Produce: stg12_FIFO_buf84
	stg12_FIFO_buf84_stg12_to_gp_620_ld85_merged1756_write_bundle_write(/* arg names */compute_result, stg12_FIFO_buf84, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg13_1_merged1835(stg12_FIFO_buf84_cache& stg12_FIFO_buf84, stg13_cache& stg13, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg12_FIFO_buf84
	auto stg12_FIFO_buf84_1_m__lp_16_m_stg13_1__p__15_rp___p__0_c_____1_m__lp_stg13_0__p___m_1_rp___p___m_1_value = stg12_FIFO_buf84_stg13_1_merged1835_read_bundle_read(stg12_FIFO_buf84/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg13_1_cu1833(stg12_FIFO_buf84_1_m__lp_16_m_stg13_1__p__15_rp___p__0_c_____1_m__lp_stg13_0__p___m_1_rp___p___m_1_value);
	// Produce: stg13
	stg13_stg13_1_merged1835_write_bundle_write(/* arg names */compute_result, stg13, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg13_ld25_merged1851(stg13_cache& stg13, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg13_to_gp_724, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg13
	auto stg13__lp_16_m_stg13_ld25__p__15_rp__c______lp_stg13_ld26__p___m_1_rp__value = stg13_stg13_ld25_merged1851_read_bundle_read(stg13/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg13_ld25_cu1850(stg13__lp_16_m_stg13_ld25__p__15_rp__c______lp_stg13_ld26__p___m_1_rp__value);
	// Produce: stg13_to_gp_724
	stg13_to_gp_724.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg12_to_gp_620_ld86_stg13_0_stg13_ld26_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg12_to_gp_620, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg13_to_gp_724) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg12_to_gp_620_ld86_stg13_0_stg13_ld26__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg12_FIFO_buf84_cache stg12_FIFO_buf84;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg13_cache stg13;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68; stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68; stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
//   { stg13_1_merged1835[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 42] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
// Condition for stg13_1_merged1835(((((-42 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-28 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-14 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg13_ld25_merged1851[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 43] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
// Condition for stg13_ld25_merged1851(((((-43 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-28 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-14 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg12_to_gp_620_ld85_merged1756[d0 = 0, d1, d2] -> [0, 26 + d1, 13 + d2, 41] : 0 <= d1 <= 1923 and 0 <= d2 <= 69 }
// Condition for stg12_to_gp_620_ld85_merged1756(((((-41 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-26 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-13 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 28 <= i1 <= 1949 and 14 <= i2 <= 82 and 42 <= i3 <= 43; [0, i1, i2, 41] : 26 <= i1 <= 1949 and 13 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 26; i1 <= 1949; i1++) {
	    for (int i2 = 13; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg12_to_gp_620_ld85_merged1756(stg12_to_gp_620 /* buf name */, stg12_FIFO_buf84, 0, ((-26 + 1*i1)), ((-13 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 28 and i2 >= 14 }
	        // { [i0, i1, i2] : i1 >= 28 and i2 >= 14 }
	          // { [i0, i1, i2] : -28 + i1 >= 0 }
	          // { [i0, i1, i2] : -14 + i2 >= 0 }
	        if ((((((-28 + 1*i1)) >= 0) && (((-14 + 1*i2)) >= 0)))) {
	          stg13_1_merged1835(stg12_FIFO_buf84 /* buf name */, stg13, 0, ((-28 + 1*i1)), ((-14 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 28 and i2 >= 14 }
	        // { [i0, i1, i2] : i1 >= 28 and i2 >= 14 }
	          // { [i0, i1, i2] : -28 + i1 >= 0 }
	          // { [i0, i1, i2] : -14 + i2 >= 0 }
	        if ((((((-28 + 1*i1)) >= 0) && (((-14 + 1*i2)) >= 0)))) {
	          stg13_ld25_merged1851(stg13 /* buf name */, stg13_to_gp_724, 0, ((-28 + 1*i1)), ((-14 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg13_to_gp_724_ld89_merged1750(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg13_to_gp_724, stg13_FIFO_buf88_cache& stg13_FIFO_buf88, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg13_to_gp_724
	auto stg13_to_gp_724__lp_16_m_stg13_to_gp_724_ld89__p__15_rp__c______lp_stg13_to_gp_724_ld90__p___m_1_rp__value = stg13_to_gp_724.read();
	auto compute_result = stg13_to_gp_724_ld89_cu1749(stg13_to_gp_724__lp_16_m_stg13_to_gp_724_ld89__p__15_rp__c______lp_stg13_to_gp_724_ld90__p___m_1_rp__value);
	// Produce: stg13_FIFO_buf88
	stg13_FIFO_buf88_stg13_to_gp_724_ld89_merged1750_write_bundle_write(/* arg names */compute_result, stg13_FIFO_buf88, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg14_1_merged1838(stg13_FIFO_buf88_cache& stg13_FIFO_buf88, stg14_cache& stg14, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg13_FIFO_buf88
	auto stg13_FIFO_buf88_1_m__lp_16_m_stg14_1__p__15_rp___p__0_c____1_m_stg14_0__p___m_1_value = stg13_FIFO_buf88_stg14_1_merged1838_read_bundle_read(stg13_FIFO_buf88/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg14_1_cu1836(stg13_FIFO_buf88_1_m__lp_16_m_stg14_1__p__15_rp___p__0_c____1_m_stg14_0__p___m_1_value);
	// Produce: stg14
	stg14_stg14_1_merged1838_write_bundle_write(/* arg names */compute_result, stg14, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg14_ld29_merged1845(stg14_cache& stg14, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg14_to_gp_128, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg14
	auto stg14__lp_16_m_stg14_ld29__p__15_rp__c____stg14_ld30_value = stg14_stg14_ld29_merged1845_read_bundle_read(stg14/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg14_ld29_cu1844(stg14__lp_16_m_stg14_ld29__p__15_rp__c____stg14_ld30_value);
	// Produce: stg14_to_gp_128
	stg14_to_gp_128.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg13_to_gp_724_ld90_stg14_0_stg14_ld30_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg13_to_gp_724, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg14_to_gp_128) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg13_to_gp_724_ld90_stg14_0_stg14_ld30__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg13_FIFO_buf88_cache stg13_FIFO_buf88;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg14_cache stg14;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68; stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67; stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
//   { stg13_to_gp_724_ld89_merged1750[d0 = 0, d1, d2] -> [0, 28 + d1, 14 + d2, 44] : 0 <= d1 <= 1921 and 0 <= d2 <= 68 }
// Condition for stg13_to_gp_724_ld89_merged1750(((((-44 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-28 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-14 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg14_1_merged1838[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 45] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
// Condition for stg14_1_merged1838(((((-45 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-30 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-15 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg14_ld29_merged1845[d0 = 0, d1, d2] -> [0, 30 + d1, 15 + d2, 46] : 0 <= d1 <= 1919 and 0 <= d2 <= 67 }
// Condition for stg14_ld29_merged1845(((((-46 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-30 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-15 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 30 <= i1 <= 1949 and 15 <= i2 <= 82 and 45 <= i3 <= 46; [0, i1, i2, 44] : 28 <= i1 <= 1949 and 14 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 28; i1 <= 1949; i1++) {
	    for (int i2 = 14; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg13_to_gp_724_ld89_merged1750(stg13_to_gp_724 /* buf name */, stg13_FIFO_buf88, 0, ((-28 + 1*i1)), ((-14 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 30 and i2 >= 15 }
	        // { [i0, i1, i2] : i1 >= 30 and i2 >= 15 }
	          // { [i0, i1, i2] : -30 + i1 >= 0 }
	          // { [i0, i1, i2] : -15 + i2 >= 0 }
	        if ((((((-30 + 1*i1)) >= 0) && (((-15 + 1*i2)) >= 0)))) {
	          stg14_1_merged1838(stg13_FIFO_buf88 /* buf name */, stg14, 0, ((-30 + 1*i1)), ((-15 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 30 and i2 >= 15 }
	        // { [i0, i1, i2] : i1 >= 30 and i2 >= 15 }
	          // { [i0, i1, i2] : -30 + i1 >= 0 }
	          // { [i0, i1, i2] : -15 + i2 >= 0 }
	        if ((((((-30 + 1*i1)) >= 0) && (((-15 + 1*i2)) >= 0)))) {
	          stg14_ld29_merged1845(stg14 /* buf name */, stg14_to_gp_128, 0, ((-30 + 1*i1)), ((-15 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg0_to_gp_84_ld69_merged1782(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg0_to_gp_84, stg0_FIFO_buf68_cache& stg0_FIFO_buf68, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg0_to_gp_84
	auto stg0_to_gp_84__lp_16_m_stg0_to_gp_84_ld69__p__15_rp__c______lp_stg0_to_gp_84_ld70__p___m_14_rp__value = stg0_to_gp_84.read();
	auto compute_result = stg0_to_gp_84_ld69_cu1781(stg0_to_gp_84__lp_16_m_stg0_to_gp_84_ld69__p__15_rp__c______lp_stg0_to_gp_84_ld70__p___m_14_rp__value);
	// Produce: stg0_FIFO_buf68
	stg0_FIFO_buf68_stg0_to_gp_84_ld69_merged1782_write_bundle_write(/* arg names */compute_result, stg0_FIFO_buf68, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg1_1_merged1799(stg0_FIFO_buf68_cache& stg0_FIFO_buf68, stg1_cache& stg1, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg0_FIFO_buf68
	auto stg0_FIFO_buf68_1_m__lp_16_m_stg1_1__p__15_rp___p__0_c_____1_m__lp_stg1_0__p___m_13_rp___p___m_1_value = stg0_FIFO_buf68_stg1_1_merged1799_read_bundle_read(stg0_FIFO_buf68/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg1_1_cu1797(stg0_FIFO_buf68_1_m__lp_16_m_stg1_1__p__15_rp___p__0_c_____1_m__lp_stg1_0__p___m_13_rp___p___m_1_value);
	// Produce: stg1
	stg1_stg1_1_merged1799_write_bundle_write(/* arg names */compute_result, stg1, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg1_ld9_merged1843(stg1_cache& stg1, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg1_to_gp_98, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg1
	auto stg1__lp_16_m_stg1_ld9__p__15_rp__c______lp_stg1_ld10__p___m_13_rp__value = stg1_stg1_ld9_merged1843_read_bundle_read(stg1/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg1_ld9_cu1842(stg1__lp_16_m_stg1_ld9__p__15_rp__c______lp_stg1_ld10__p___m_13_rp__value);
	// Produce: stg1_to_gp_98
	stg1_to_gp_98.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg0_to_gp_84_ld70_stg1_0_stg1_ld10_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg0_to_gp_84, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg1_to_gp_98) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg0_to_gp_84_ld70_stg1_0_stg1_ld10__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg0_FIFO_buf68_cache stg0_FIFO_buf68;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg1_cache stg1;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81; stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80; stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
//   { stg0_to_gp_84_ld69_merged1782[d0 = 0, d1, d2] -> [0, 2 + d1, 1 + d2, 5] : 0 <= d1 <= 1947 and 0 <= d2 <= 81 }
// Condition for stg0_to_gp_84_ld69_merged1782(((((-5 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-2 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-1 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg1_ld9_merged1843[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 7] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
// Condition for stg1_ld9_merged1843(((((-7 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-4 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-2 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg1_1_merged1799[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 6] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
// Condition for stg1_1_merged1799(((((-6 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-4 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-2 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 4 <= i1 <= 1949 and 2 <= i2 <= 82 and 6 <= i3 <= 7; [0, i1, i2, 5] : 2 <= i1 <= 1949 and 0 < i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 2; i1 <= 1949; i1++) {
	    for (int i2 = 1; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg0_to_gp_84_ld69_merged1782(stg0_to_gp_84 /* buf name */, stg0_FIFO_buf68, 0, ((-2 + 1*i1)), ((-1 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 4 and i2 >= 2 }
	        // { [i0, i1, i2] : i1 >= 4 and i2 >= 2 }
	          // { [i0, i1, i2] : -4 + i1 >= 0 }
	          // { [i0, i1, i2] : -2 + i2 >= 0 }
	        if ((((((-4 + 1*i1)) >= 0) && (((-2 + 1*i2)) >= 0)))) {
	          stg1_1_merged1799(stg0_FIFO_buf68 /* buf name */, stg1, 0, ((-4 + 1*i1)), ((-2 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 4 and i2 >= 2 }
	        // { [i0, i1, i2] : i1 >= 4 and i2 >= 2 }
	          // { [i0, i1, i2] : -4 + i1 >= 0 }
	          // { [i0, i1, i2] : -2 + i2 >= 0 }
	        if ((((((-4 + 1*i1)) >= 0) && (((-2 + 1*i2)) >= 0)))) {
	          stg1_ld9_merged1843(stg1 /* buf name */, stg1_to_gp_98, 0, ((-4 + 1*i1)), ((-2 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Operation logic
inline void stg2_1_merged1802(stg1_FIFO_buf72_cache& stg1_FIFO_buf72, stg2_cache& stg2, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg1_FIFO_buf72
	auto stg1_FIFO_buf72_1_m__lp_16_m_stg2_1__p__15_rp___p__0_c_____1_m__lp_stg2_0__p___m_12_rp___p___m_1_value = stg1_FIFO_buf72_stg2_1_merged1802_read_bundle_read(stg1_FIFO_buf72/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg2_1_cu1800(stg1_FIFO_buf72_1_m__lp_16_m_stg2_1__p__15_rp___p__0_c_____1_m__lp_stg2_0__p___m_12_rp___p___m_1_value);
	// Produce: stg2
	stg2_stg2_1_merged1802_write_bundle_write(/* arg names */compute_result, stg2, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg2_ld33_merged1859(stg2_cache& stg2, HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg2_to_gp_1032, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg2
	auto stg2__lp_16_m_stg2_ld33__p__15_rp__c______lp_stg2_ld34__p___m_12_rp__value = stg2_stg2_ld33_merged1859_read_bundle_read(stg2/* source_delay */, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

	auto compute_result = stg2_ld33_cu1858(stg2__lp_16_m_stg2_ld33__p__15_rp__c______lp_stg2_ld34__p___m_12_rp__value);
	// Produce: stg2_to_gp_1032
	stg2_to_gp_1032.write(compute_result);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

inline void stg1_to_gp_98_ld73_merged1776(HWStream<hw_uint<256> >& /* buffer_args num ports = 16 */stg1_to_gp_98, stg1_FIFO_buf72_cache& stg1_FIFO_buf72, int d0, int d1, int d2) {
  // Dynamic address computation

	// Consume: stg1_to_gp_98
	auto stg1_to_gp_98__lp_16_m_stg1_to_gp_98_ld73__p__15_rp__c______lp_stg1_to_gp_98_ld74__p___m_13_rp__value = stg1_to_gp_98.read();
	auto compute_result = stg1_to_gp_98_ld73_cu1775(stg1_to_gp_98__lp_16_m_stg1_to_gp_98_ld73__p__15_rp__c______lp_stg1_to_gp_98_ld74__p___m_13_rp__value);
	// Produce: stg1_FIFO_buf72
	stg1_FIFO_buf72_stg1_to_gp_98_ld73_merged1776_write_bundle_write(/* arg names */compute_result, stg1_FIFO_buf72, d0, d1, d2, 0);

#ifndef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__

}

// Driver function
void Extracted_stg1_to_gp_98_ld74_stg2_0_stg2_ld34_(HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg1_to_gp_98, HWStream<hw_uint<256> >& /* get_args num ports = 16 */stg2_to_gp_1032) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("Extracted_stg1_to_gp_98_ld74_stg2_0_stg2_ld34__debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__
  stg1_FIFO_buf72_cache stg1_FIFO_buf72;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
  stg2_cache stg2;
#ifdef __VIVADO_SYNTH__
#endif //__VIVADO_SYNTH__
#ifdef __VIVADO_SYNTH__
#pragma HLS inline recursive
#endif // __VIVADO_SYNTH__

// schedule: { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79; stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80; stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
//   { stg2_1_merged1802[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 9] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
// Condition for stg2_1_merged1802(((((-9 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-6 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-3 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg1_to_gp_98_ld73_merged1776[d0 = 0, d1, d2] -> [0, 4 + d1, 2 + d2, 8] : 0 <= d1 <= 1945 and 0 <= d2 <= 80 }
// Condition for stg1_to_gp_98_ld73_merged1776(((((-8 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-4 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-2 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))
//   { stg2_ld33_merged1859[d0 = 0, d1, d2] -> [0, 6 + d1, 3 + d2, 10] : 0 <= d1 <= 1943 and 0 <= d2 <= 79 }
// Condition for stg2_ld33_merged1859(((((-10 + 1*i3)) == 0) && (((1*i0)) == 0) && (((-6 + 1*i1)) >= 0) && (((1949 + -1*i1)) >= 0) && (((-3 + 1*i2)) >= 0) && (((82 + -1*i2)) >= 0)))

	// time range: { [0, i1, i2, i3] : 6 <= i1 <= 1949 and 3 <= i2 <= 82 and 9 <= i3 <= 10; [0, i1, i2, 8] : 4 <= i1 <= 1949 and 2 <= i2 <= 82 }
	// # sets: 1
	for (int i0 = 0; i0 <= 0; i0++) {
	  for (int i1 = 4; i1 <= 1949; i1++) {
	    for (int i2 = 2; i2 <= 82; i2++) {
	#pragma HLS pipeline II=1
	        // { [i0, i1, i2] }
	        // { [i0, i1, i2] :  }
	        if ((true)) {
	          stg1_to_gp_98_ld73_merged1776(stg1_to_gp_98 /* buf name */, stg1_FIFO_buf72, 0, ((-4 + 1*i1)), ((-2 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 6 and i2 >= 3 }
	        // { [i0, i1, i2] : i1 >= 6 and i2 >= 3 }
	          // { [i0, i1, i2] : -6 + i1 >= 0 }
	          // { [i0, i1, i2] : -3 + i2 >= 0 }
	        if ((((((-6 + 1*i1)) >= 0) && (((-3 + 1*i2)) >= 0)))) {
	          stg2_1_merged1802(stg1_FIFO_buf72 /* buf name */, stg2, 0, ((-6 + 1*i1)), ((-3 + 1*i2)));
	        }
	        // { [i0, i1, i2] : i1 >= 6 and i2 >= 3 }
	        // { [i0, i1, i2] : i1 >= 6 and i2 >= 3 }
	          // { [i0, i1, i2] : -6 + i1 >= 0 }
	          // { [i0, i1, i2] : -3 + i2 >= 0 }
	        if ((((((-6 + 1*i1)) >= 0) && (((-3 + 1*i2)) >= 0)))) {
	          stg2_ld33_merged1859(stg2 /* buf name */, stg2_to_gp_1032, 0, ((-6 + 1*i1)), ((-3 + 1*i2)));
	        }
	      }
	    }
	  }
	
#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

// Driver function
void jacdyn_16_opt(HWStream<hw_uint<256> >& /* no bundle get_args num ports = 16 */in_off_chip, HWStream<hw_uint<256> >& /* get_args num ports = 16 */jacdyn_16) {

#ifndef __VIVADO_SYNTH__
  ofstream debug_file("jacdyn_16_opt_debug.csv");
  global_debug_handle = &debug_file;
#endif //__VIVADO_SYNTH__

#ifdef __VIVADO_SYNTH__
#pragma HLS dataflow
#endif //__VIVADO_SYNTH__

  HWStream< hw_uint<256> > in_to_gp_20;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=in_to_gp_20.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg14_to_gp_128;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg14_to_gp_128.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg2_to_gp_1032;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg2_to_gp_1032.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg3_to_gp_1136;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg3_to_gp_1136.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg4_to_gp_1240;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg4_to_gp_1240.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg5_to_gp_1344;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg5_to_gp_1344.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg6_to_gp_1448;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg6_to_gp_1448.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg7_to_gp_1552;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg7_to_gp_1552.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg8_to_gp_1656;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg8_to_gp_1656.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg9_to_gp_360;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg9_to_gp_360.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg0_to_gp_84;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg0_to_gp_84.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg10_to_gp_412;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg10_to_gp_412.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg11_to_gp_516;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg11_to_gp_516.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg12_to_gp_620;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg12_to_gp_620.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg13_to_gp_724;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg13_to_gp_724.values depth=32
#endif //__VIVADO_SYNTH__
  HWStream< hw_uint<256> > stg1_to_gp_98;
#ifdef __VIVADO_SYNTH__
#pragma HLS stream variable=stg1_to_gp_98.values depth=32
#endif //__VIVADO_SYNTH__


  Extracted_in_0_in_ld2_(in_off_chip, in_to_gp_20);
  Extracted_in_to_gp_20_ld66_stg0_0_stg0_ld6_(in_to_gp_20, stg0_to_gp_84);
  Extracted_stg0_to_gp_84_ld70_stg1_0_stg1_ld10_(stg0_to_gp_84, stg1_to_gp_98);
  Extracted_stg1_to_gp_98_ld74_stg2_0_stg2_ld34_(stg1_to_gp_98, stg2_to_gp_1032);
  Extracted_stg2_to_gp_1032_ld98_stg3_0_stg3_ld38_(stg2_to_gp_1032, stg3_to_gp_1136);
  Extracted_stg3_to_gp_1136_ld102_stg4_0_stg4_ld42_(stg3_to_gp_1136, stg4_to_gp_1240);
  Extracted_stg4_to_gp_1240_ld106_stg5_0_stg5_ld46_(stg4_to_gp_1240, stg5_to_gp_1344);
  Extracted_stg5_to_gp_1344_ld110_stg6_0_stg6_ld50_(stg5_to_gp_1344, stg6_to_gp_1448);
  Extracted_stg6_to_gp_1448_ld114_stg7_0_stg7_ld54_(stg6_to_gp_1448, stg7_to_gp_1552);
  Extracted_stg7_to_gp_1552_ld118_stg8_0_stg8_ld58_(stg7_to_gp_1552, stg8_to_gp_1656);
  Extracted_stg8_to_gp_1656_ld122_stg9_0_stg9_ld62_(stg8_to_gp_1656, stg9_to_gp_360);
  Extracted_stg10_0_stg10_ld14_stg9_to_gp_360_ld126_(stg9_to_gp_360, stg10_to_gp_412);
  Extracted_stg10_to_gp_412_ld78_stg11_0_stg11_ld18_(stg10_to_gp_412, stg11_to_gp_516);
  Extracted_stg11_to_gp_516_ld82_stg12_0_stg12_ld22_(stg11_to_gp_516, stg12_to_gp_620);
  Extracted_stg12_to_gp_620_ld86_stg13_0_stg13_ld26_(stg12_to_gp_620, stg13_to_gp_724);
  Extracted_stg13_to_gp_724_ld90_stg14_0_stg14_ld30_(stg13_to_gp_724, stg14_to_gp_128);
  Extracted_jacdyn_16_0_stg14_to_gp_128_ld94_(stg14_to_gp_128, jacdyn_16);

#ifndef __VIVADO_SYNTH__
  debug_file.close();
#endif //__VIVADO_SYNTH__
}

void jacdyn_16_opt_wrapper(HWStream<hw_uint<256> >& /* no bundle get_args num ports = 16 */in_off_chip, HWStream<hw_uint<256> >& /* get_args num ports = 16 */jacdyn_16, const int num_epochs) {

  for (int epoch = 0; epoch < num_epochs; epoch++) {
    jacdyn_16_opt(in_off_chip, jacdyn_16);
  }
}
#ifdef __VIVADO_SYNTH__
  // { in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[15 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[14 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[13 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[12 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[11 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[10 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[9 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[8 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[7 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[6 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[5 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[4 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[3 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[2 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[1 + 16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82; in_1_merged1793[root = 0, in_0, in_1] -> in_off_chip[16in_1, -15 + in_0] : 0 <= in_0 <= 1949 and 0 <= in_1 <= 82 }
const int in_1_merged1793_read_pipe0_num_transfers = 161850;
  // { jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[15 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[14 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[13 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[12 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[11 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[10 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[9 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[8 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[7 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[6 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[5 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[4 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[3 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[2 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[1 + 16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67; jacdyn_16_1_merged1841[root = 0, jacdyn_16_0, jacdyn_16_1] -> jacdyn_16[16jacdyn_16_1, jacdyn_16_0] : 0 <= jacdyn_16_0 <= 1919 and 0 <= jacdyn_16_1 <= 67 }
const int jacdyn_16_1_merged1841_write_pipe0_num_transfers = 130560;


extern "C" {

void jacdyn_16_opt_accel(hw_uint<256>* in_1_merged1793_read_pipe0, hw_uint<256>* jacdyn_16_1_merged1841_write_pipe0, const int size) { 
#pragma HLS dataflow
#pragma HLS INTERFACE m_axi port = in_1_merged1793_read_pipe0 offset = slave depth = 65536 bundle = gmem0
#pragma HLS INTERFACE m_axi port = jacdyn_16_1_merged1841_write_pipe0 offset = slave depth = 65536 bundle = gmem1

#pragma HLS INTERFACE s_axilite port = in_1_merged1793_read_pipe0 bundle = control
#pragma HLS INTERFACE s_axilite port = jacdyn_16_1_merged1841_write_pipe0 bundle = control
#pragma HLS INTERFACE s_axilite port = size bundle = control
#pragma HLS INTERFACE s_axilite port = return bundle = control


  // Pipeline # 0
  static HWStream<hw_uint<256> > in_1_merged1793_read_pipe0_channel;
  static HWStream<hw_uint<256> > jacdyn_16_1_merged1841_write_pipe0_channel;

  burst_read<256>(in_1_merged1793_read_pipe0, in_1_merged1793_read_pipe0_channel, in_1_merged1793_read_pipe0_num_transfers*size);

  jacdyn_16_opt_wrapper(in_1_merged1793_read_pipe0_channel, jacdyn_16_1_merged1841_write_pipe0_channel, size);

  burst_write<256>(jacdyn_16_1_merged1841_write_pipe0, jacdyn_16_1_merged1841_write_pipe0_channel, jacdyn_16_1_merged1841_write_pipe0_num_transfers*size);
}

}
extern "C" {

void jacdyn_16_opt_rdai(HWStream<hw_uint<256> >& in_1_merged1793_read_pipe0, HWStream<hw_uint<256> >&  jacdyn_16_1_merged1841_write_pipe0) { 
#pragma HLS dataflow
#pragma HLS INTERFACE axis register port = in_1_merged1793_read_pipe0
#pragma HLS INTERFACE axis register port = jacdyn_16_1_merged1841_write_pipe0

#pragma HLS INTERFACE ap_ctrl_none port = return


  // Pipeline # 0

  jacdyn_16_opt(in_1_merged1793_read_pipe0, jacdyn_16_1_merged1841_write_pipe0);

}

}
#endif //__VIVADO_SYNTH__

