Вывод пользовательского типа данных в файл

Учитывая структуру Pixel и ее эквивалент MPI_Type mpiPixel, я создаю массив пикселей и записываю его в файл. Все работает правильно, за исключением того, что вывод в файле заканчивается каким-то битовым шаблоном (который интерпретируется как целое число). Файл выводится в бинарном виде, поэтому для просмотра он был написан правильно, я использую hexdump -v -e '7/4 "%10d "' -e '"\n"' pixelsx

КОД

struct Pixel
{
    int red; int green; int blue;

    Pixel() {}

    Pixel(int r, int g, int b)
    {
        red = r; green = g; blue = b;
    }
};


int main(int argc, char **argv)
{
    int rank, size;
    MPI_File   file;
    MPI_Offset offset;
    MPI_Status status;
    MPI_Datatype mpiPixel;

    Pixel pixels[10];

    MPI_Init(&argc, &argv);
    MPI_Comm_size(MPI_COMM_WORLD, &size);
    MPI_Comm_rank(MPI_COMM_WORLD, &rank);

    /* fill local data */
    for (int i = 0; i < 10; i++)
        pixels[i] = Pixel(i, i, i);

    int blockcounts[1];
    MPI_Aint offsets[1];
    MPI_Datatype oldtypes[1];

    //Pixel Description {starting pos, element count, element type}
    offsets[0] = 0;
    blockcounts[0] = 3;
    oldtypes[0] = MPI_INT;

    /* Now define structured type and commit it */
    MPI_Type_struct(1, blockcounts, offsets, oldtypes, &mpiPixel);
    MPI_Type_commit(&mpiPixel);

    /* open the file, and set the view */
    MPI_File_open(MPI_COMM_WORLD, "pixels",
                  MPI_MODE_CREATE | MPI_MODE_WRONLY,
                  MPI_INFO_NULL, &file);

    MPI_File_seek(file, 0, MPI_SEEK_SET);
    MPI_File_set_view(file, 0,  MPI_CHAR, mpiPixel, "native", MPI_INFO_NULL);
    MPI_File_write_all(file, pixels, 10, mpiPixel, &status);
    MPI_File_close(&file);

    MPI_Finalize();
    return 0;
}

ВЫХОД

     0          0          0          1          1          1          2
     2          2          3          3          3          4          4
     4          5          5          5          6          6          6
     7          7          7          8          8          8          9
     9          9    4228656          0          0          0    4228656
     0          0          0 -1795965243      32585   

Строка, которой там быть не должно (если я не ошибаюсь)

4228656          0          0          0    4228656         0          0          0 -1795965243      32585

Почему последний печатается в файле. Это проблема распределения памяти (массива?)?

P.S. Код запускается только с одним процессом. Причина в том, что мне сначала нужно заставить работать функцию записи. Затем я добавлю смещение для других процессов.


person Aiden Strydom    schedule 22.04.2014    source источник
comment
так в чем вопрос?   -  person Walter    schedule 23.04.2014


Ответы (1)


Тип данных MPI вообще не соответствует структуре C++. Ваша структура Pixel состоит из трех элементов int. Вы регистрируете тип данных MPI для четырех элементов float и используете его для записи массива структур в файл. Так как int и float имеют одинаковый размер на большинстве 32- и 64-битных архитектур и так как между элементами структуры не добавляется заполнение, MPI заканчивает тем, что считывает (4*sizeof(float) - sizeof(Pixel))*10 = 40 байтов после конца массива pixels. Это отображается как 10 (40/4) дополнительных случайных значений в содержимом файла.

person Hristo Iliev    schedule 24.04.2014
comment
Спасибо, что указали на то, что я разместил старую версию кода... Но, увы, я сам это заметил - изменил - и все те же результаты. Несмотря на плохое исправить пост. - person Aiden Strydom; 25.04.2014