1

我的最后一个问题不是很清楚。所以再发一次。我正在尝试使用 BLAS 例程 dgemm 进行矩阵乘法。由于我希望输入到 dgemm 的数组大小不固定,因此我正在创建一个可变大小的数组。但这似乎不起作用,因为我不断收到异常错误。我的代码如下:

#include "stdafx.h"
#include<iostream>

using namespace std;

extern "C" void dgemm_(const char *TRANSA, const char *TRANSB, const int *M, const int *N, const int *K, double *ALPHA, double **A, const int *LDA, double **B, const int *LDB, double *BETA, double **C, const int *LDC);

int main(void)
{
    int MatSize = 2;
    double **A= new double *[MatSize];
    double **B= new double *[MatSize]; 
    double **C= new double *[MatSize];
    for (int i=0; i<MatSize; i++)
    {
        A[i] = new double[MatSize];
        B[i] = new double[MatSize];
        C[i] = new double[MatSize];
    }
    A[0][0] =  1;
    A[0][1]= 2;
    A[1][0] = 1;
    A[1][1]=2;
    B[0][0] = -2;
    B[0][1]= 3;
    B[1][0]= 2;
    B[1][1]= 2;
    char TRANS = 'N';
    char TRANS2 = 'N';
    double ALPHA = 1;
    double BETA = 0;
    dgemm_(&TRANS, &TRANS, &MatSize, &MatSize, &MatSize, &ALPHA, A, &MatSize, B, &MatSize, &BETA, C, &MatSize);
    cout << C[0][0] << C[0][1] << endl;
    cout << C[1][0] << C[1][1] << endl;
    getchar();
    return 0;
}

任何输入都会有很大帮助。

4

1 回答 1

3

您尝试将数组数组传递给 dgemm,即指针数组(指向数组)。当然这是不可能的,你必须传递一个双精度数组。

请参阅此处了解 dgemm 标头,它需要 double*,而不是 double**。

于 2013-04-17T05:48:23.810 回答