嗨,任何人都可以为我提供一个从 C++ 调用 ScaLAPACK 的示例 Makefile,我遇到了困难。
我正确编译了最新版本,并通过了所有测试。我在 Fedora 上使用 GCC 和 OpenMPI 编译它,我还尝试使用存储库中的预构建二进制文件,但没有成功。
我对 ScaLAPACK 过程使用了以下声明:
extern "C" void pdgesvd_(char *jobu, char *jobvt, int *M, int *N, double *A, int *ia, int *ja, int *desca, double *s, double *u, int *iu, int *ju,
int *descu, double *vt, int *ivt, int *jvt, int *descvt, double *work, int *lwork, int *info);
extern "C" void pdgemv_(char *t, int *M, int *N, double *alpha, double *A, int *ia, int *ja, int *desca, double *X, int *ix, int *jx,int *descx,
int *incx, double *beta, double *Y, int *iy, int *jy, int *descy, int *incy);
extern "C" void pdgemm_(char *transa, char *transb, int *M, int *N, int *K, double *alpha, double *A, int *ia, int *ja, int *desca, double *B,
int *ib, int *jb, int *descb, double *beta, double *C, int *ic, int *jc, int *descc);
BLACS 程序的声明方式相同:
extern "C" void blacs_get_(/*in*/int *icontxt, /*in*/int *what, /*out*/int *val);
我将“_”字符附加到过程名称,因为 BLAS 和 ScaLAPACK 是使用 -DAdd_ 编译器选项构建的。对于您的系统,这可能会有所不同。如果是这样,请尝试objdump -t
使用libscalapack.a
其他静态库文件来确定实际的过程名称。
您的带有 ScaLAPACK 调用的程序可能会使用以下内容进行编译:
mpicxx -o your_binary_name -O2 your_source.cpp -lscalapack -lblacs -lcblacs -lblacs -llapack -lblas -lgfortran
请注意,g++ 调用行 ( -lblacs -lcblacs -lblacs -llapack -lblas -lgfortran
) 中静态库的顺序很重要!还要检查库目录中是否存在所有这些静态库文件(libblas.a
等等libcblacs.a
)。不要忘记 Fortran 包 (for -lgfortran
)。