#include "MatrixMul.h"
#include "tb_var.h"
#include <stdio.h>

using namespace std;

int main(){

	hls::stream<TOUT> C_stream;

	TOUT C_buffer;
	ap_int<OW> C[HO * WO][CO];

	int errcnt = 0;
	int i, j, k, pi, po;

	top(A, B, C);

	for (i = 0; i < HO*WO; i++)
	{
		for (j = 0; j < CO/PO; j++)
		{
			C_buffer = C_stream.read();
			for (po = 0; po < PO; po++)
			{
				cout << i << " " << j * PO + po << ": ";
				cout << C[i][PO * j + po] << " " << RefC[i][PO * j + po];
				cout << "\n";
				if (C[i][PO * j + po] != RefC[i][PO * j + po])
					errcnt++;
			}
		}
	}
	if (errcnt == 0)
		cout << "PASS!";
	else
		cout << "FAIL!";
}
