Индексирование нерегулярной сетки координат X, Y, Z в одномерном массиве - PullRequest
0 голосов
/ 22 февраля 2012

Как и в моем предыдущем вопросе , я работаю над загрузкой одномерного массива с объемными данными .raw-файла.Ответ Джонатана Леффлера оказался полезным, но сейчас я работаю с набором объемных данных разных размеров (X, Y, Z не совпадают).How would the formula be generalized?

pVolume[((x * 256) + y) * 256 + z] // works when all dims are 256


int XDIM=256, YDIM=256, ZDIM=256; // I want this sizes to be arbitrary
const int size = XDIM*YDIM*ZDIM;
bool LoadVolumeFromFile(const char* fileName) {

    FILE *pFile = fopen(fileName,"rb");
   if(NULL == pFile) {
    return false;
   }

   GLubyte* pVolume=new GLubyte[size]; //<- here pVolume is a 1D byte array 
   fread(pVolume,sizeof(GLubyte),size,pFile);
   fclose(pFile);

1 Ответ

2 голосов
/ 22 февраля 2012

Доступ по шагам следует простому принципу:

A[i][j][k] = B[k + j * Dim3 + i * Dim3 * Dim2];

// k = 1..Dim3,  (or 0 <= k < Dim3, as one does in C)
// j = 1..Dim2,
// i = 1..Dim1.

Здесь B - это одномерный массив размером Dim1 * Dim2 * Dim3.Формула явно обобщает на сколь угодно много измерений.Если вы хотите мнемонику, начните сумму с индекса с ускорением, и в каждом слагаемом вы умножаете дальше на экстент предыдущего измерения.

...