我试图从ARPACK调用fortran函数dsaupd。我使用了来自netlib-java的C声明
extern void dsaupd_(int *ido, char *bmat, int *n, char *which,
int *nev, double *tol, double *resid,
int *ncv, double *V, int *ldv,
int *iparam, int *ipntr, double *workd,
double *workl, int *lworkl, int *info);然后,我将numcols定义为程序前面的int,然后再调用dsaupd
int ido = 0;
int ncv = 2*numeigs;
int maxiter = 30;
double tol = 1e-13;
double * v = (double *) malloc(numcols * ncv *sizeof(double));
int iparam[11] = {1, 0, maxiter, 1, 0, 0, 1, 0, 0, 0, 0};
int ipntr[11];
double * workd = (double *) malloc(3*numcols*sizeof(double));
int lworkl = ncv*(ncv + 8);
double * workl = (double *) malloc(lworkl*sizeof(double));
int arpack_info = 0;
char bmat = 'I';
char which[2] = {'L', 'M'};
MPI_Barrier(comm);
if (mpi_rank == 0) {
printf("Here!\n");
dsaupd_(&ido, &bmat, &numcols, which,
&numeigs, &tol, vector,
&ncv, v, &numcols,
iparam, ipntr, workd,
workl, &lworkl, &arpack_info);
printf("Here!\n");
}该代码编译并使其成为第一个“此处”打印输出,但在此之后停止。知道我做错了什么,或者如何调试这个调用吗?
发布于 2016-03-21 03:35:53
我认为即使arpack在我的系统上编译,它的链接也是不正确的。切换到阿帕克解决了这个问题。
https://stackoverflow.com/questions/36121499
复制相似问题