0
ARPACK'den fortran işlevi dsaupd aramaya çalışıyorum. Ben,Arran için c'den fortran 77 arama
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");
}
kod derler ve ilk "İşte" çıktıda bunu yapar ile dsaupd çağırmadan önce netlib-java
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);
sonra
bir int önceki programda olduğu gibi numcols tanımlanan C beyanı kullanılır ama bundan sonra duruyor. Yanlış yaptığım veya bu aramanın nasıl hata ayıklandığı hakkında bir fikrin var mı?
1) 'malloc' ve arkadaşlarının sonucunu C olarak yazmayın. 2) Bileşik türleri için başlatıcıların sabit olması gerekir. – Olaf
Her ikisini de denedim, ama hala bir duraklama yapıyorum. başlatıcı mantıklıdır (burada maksimal sabittir, bu yüzden bir sorun olmamalıdır), fakat neden malloğu doğru türlere vermemeliyim? – AatG
"Maksitre" kesinlikle bir sabit değil, bir değişkendir. “Const” nitelikli olsa bile, sabit olmayacaktır. C C++ değildir, çok sınırlı _enum-sabitleri_ dışındaki sembolik sabitleri yoktur. – Olaf