私は、行列に何らかの作業を必要とするアルゴリズムを調査しており、Linux マシンで動作する単純なコードをいくつか取得しました。ここに抜粋があります:
extern "C" {
// link w/ LAPACK
extern void dpptrf_(const char *uplo, const int *n, double *ap, int *info);
extern void dpptri_(const char *uplo, const int *n, double *ap, int *info);
// BLAS todo: get sse2 up in here (ATLAS?)
extern void dgemm_(const char *transa, const char *transb, const int *m,
const int *n, const int *k, const double *alpha, const double *a,
const int *lda, const double *b, const int *ldb, const double *beta,
double *c, const int *ldc);
}
// in-place: be sure that (N*(N+1)/2) doubles have been initialized
inline void invert_mat_sym_packed(double *vd, int n) {
int out = 0;
dpptrf_("U",&n,vd,&out);
ASSERT(!out);
dpptri_("U",&n,vd,&out);
ASSERT(!out);
}
// use with col-major ordering!!!
inline void mult_cm(double *a, double *b, double alpha, int m, int k, int n, double *c) {
int lda = m, ldb = k, ldc = m; double beta = 1.0;
dgemm_("N","N",&m,&n,&k,&alpha,a,&lda,b,&ldb,&beta,c,&ldc);
}
私がしなければならなかったのはsudo apt-get install liblapack
、ライブラリにリンクすることだけでした。
ここから 32 ビット dll を使用して MinGW からこのコードを動作させようとしていますが、セグメンテーション違反と無効な出力が表示されます。エラーの場所を特定するために gdb を使用しますが、これを行うには、より適切で、クリーンで、移植性の高い方法があると思います。
コンパイルするために私がしたことは、mingw( mingw-get install fortran
) 用の fortran をインストールし、以前のリンクから 32 ビット BLAS および LAPACK dll にリンクすることでした。
ここでどれだけ欠けているかわかりません... gcc for win32でコーディングするとき、他の人はどのようにLAPACKを動かしていますか?
私が探しているのは、使いやすい C インターフェイスです。あちこちにラッパー クラスは必要ありません。
インテル® MKL のダウンロードを探してみました... フリー・ソフトウェアでさえありません!?