Как отправить (MPI_Send) вложенную структуру, имеющую поля указателя в MPI, используя C - PullRequest
3 голосов
/ 12 мая 2011

У меня есть структура:

    struct vertex 
    {  
     double a; double b;
    }      

    struct polygon
    {
     int numofVertex;
     vertex *v;
    }

Как отправить эту вложенную структуру в MPI, используя MPI_Send? Проблема состоит в том, что структура содержит поле указателя "v", из-за которого происходит сбой MPI_Send. Я попытался MPI_Datatype, чтобы определить новый тип данных, он не работает. Я читал, что сериализация является единственным решением, но C не обеспечивает такую ​​реализацию. Любые предложения, как обойти эту проблему?

1 Ответ

6 голосов
/ 12 мая 2011

Вам нужно будет отправить его в двух сообщениях:

// 'p' is a pointer to your polygon
vertex *tmp = p->v;
p->v = NULL;
MPI_Send(p, sizeof(struct polygon), MPI_BYTES, dest, 1, ...);
MPI_Send(tmp, sizeof(struct vertex), MPI_BYTES, dest, 2, ...);
p->v = tmp;

На принимающей стороне вы просто получаете структуру в два этапа:

polygon p;
MPI_Recv(&p, sizeof(struct polygon), MPI_BYTES, src, 1, ...);
p.vertex = malloc(sizeof(struct vertex));
MPI_Recv(p.vertex, sizeof(struct vertex), MPI_BYTES, src, 2, ...);

Очевидно, что это не очень хорошо, поэтому будет проще, если вы оставите свой struct без указателя, чтобы вы могли отправить его сразу.

...