matrix_vector_mult()
行列とベクトルを乗算するものを頻繁に使用する必要があります。以下はその実装です。
質問:それを大幅に、少なくとも2回、速くする簡単な方法はありますか?
備考:1)行列のサイズは約300x50です。実行中は変更されません。2)WindowsとLinuxの両方で動作する必要があります。
double vectors_dot_prod(const double *x, const double *y, int n)
{
double res = 0.0;
int i;
for (i = 0; i < n; i++)
{
res += x[i] * y[i];
}
return res;
}
void matrix_vector_mult(const double **mat, const double *vec, double *result, int rows, int cols)
{ // in matrix form: result = mat * vec;
int i;
for (i = 0; i < rows; i++)
{
result[i] = vectors_dot_prod(mat[i], vec, cols);
}
}