Я боролся с небольшим тестовым кодом, который я сделал для записи данных в файл формата netcdf. Код должен записывать две переменные с одинаковыми значениями, но память распределяется по-разному. Код следующий:
int main(int argc, char** argv)
{
int i, j, k;
char filen2[80];
int ncid, err, cmode;
int dimid[2],varid[2];
printf("Creating Netcdf Output file\n");
int mx=5, my=5, mz=5;
printf("mx my mz: %d %d %d %i \n", mx , my, mz, rank);
sprintf(filen2, "test.nc");
printf("Writing file: %s \n",filen2);
cmode = NC_CLOBBER;
err = nc_create(filen2, cmode, &ncid); ERR
/* free info object */
if (MInfo != MPI_INFO_NULL) MPI_Info_free(&MInfo);
/* define dimensions */
err = nc_def_dim(ncid, "MZ", mz, &dimid[0]); ERR
err = nc_def_dim(ncid, "MY", my, &dimid[1]); ERR
err = nc_def_var(ncid, "Z", NC_DOUBLE, 2, dimid, &varid[0]); ERR
err = nc_def_var(ncid, "Y", NC_DOUBLE, 2, dimid, &varid[1]); ERR
/* exit define mode */
err = nc_enddef(ncid); ERR
size_t start2[2], count2[2];
start2[0] = 0;
start2[1] = 0;
count2[0] = mz;
count2[1] = my;
printf("Start: %d %d %i \n", start2[0], start2[1], rank);
printf("Count: %d %d %i \n", count[0], count[1], rank);
double **buffertmp2=NULL;
double buffertmp3[mz][my];
buffertmp2 = (double **) malloc( sizeof(double *) * mz);
for(k=0; k<mz; k++){
buffertmp2[k] = (double *) malloc( sizeof(double) * my);
for(j=0; j<my; j++){
buffertmp2[k][j] = k;
buffertmp3[k][j] = k;
}
}
err = nc_put_vara_double(ncid, varid[0], start2, count2, &buffertmp2[0][0]); ERR
err = nc_put_vara_double(ncid, varid[1], start2, count2, &buffertmp3[0][0]); ERR
err = nc_close(ncid); ERR
for(k=0; k<mz; k++){
for(j=0; j<my; j++){
printf("bff2 %le \n", buffertmp2[k][j]);
}
}
for(k=0; k<mz; k++){
for(j=0; j<my; j++){
printf("bff3 %le \n", buffertmp3[k][j]);
} }
printf("The End \n");
}
Вывод, считанный на MATLAB, дает:
X =
0 0 1.0000 0.0000 2.0000
0 0 1.0000 2.0000 0
0 0.0000 1.0000 2.0000 0
0 1.0000 0 2.0000 0.0000
0 1.0000 0 2.0000 3.0000
Y =
0 1 2 3 4
0 1 2 3 4
0 1 2 3 4
0 1 2 3 4
0 1 2 3 4
Вывод Y - это то, что я действительно ожидал, но вывод X полностью неправильно. Мне было интересно, если кто-то может указать, как распределение памяти изменить весь вывод. Что я могу сделать, чтобы записать данные в файл netcdf, если выделение памяти было сделано для циклов for, как для buffertmp2, без необходимости создания промежуточной переменной.
Спасибо, Крис