#include #include #include using namespace std; #include // Inner product double benchmark_A(const vector &x, const vector &y) { return cblas_ddot(x.size(),x.data(),1,y.data(),1); } //Matrix-vector product vector benchmark_B(const vector &A, const vector &x) { unsigned int N = x.size(); unsigned int M = A.size() / N; vector b(M, 0.0); cblas_dgemv(CblasRowMajor,CblasNoTrans,M,N,1,A.data(),N,x.data(),1,0.0,b.data(),1); return b; } //Matrix-Matrix product vector benchmark_C(const vector &A, const vector &B, unsigned int M) { unsigned int L = A.size()/M; unsigned int N = B.size()/L; vector C(M*N,0.0); cblas_dgemm(CblasRowMajor,CblasNoTrans,CblasNoTrans,M,N,L,1.0,A.data(),L,B.data(),N,0.0,C.data(),N); return C; }