source:
CIVL/mods/dev.civl.com/examples/contracts/contractsMPI/simpleMpiRegion.c@
cb4d4f4
| Last change on this file since cb4d4f4 was aad342c, checked in by , 3 years ago | |
|---|---|
|
|
| File size: 348 bytes | |
| Rev | Line | |
|---|---|---|
| [7bbef04] | 1 | #include<mpi.h> |
| 2 | #include<assert.h> | |
| 3 | ||
| 4 | ||
| 5 | #define comm MPI_COMM_WORLD | |
| 6 | ||
| 7 | /*@ \mpi_collective(comm, P2P): | |
| 8 | @ ensures \mpi_agree(\mpi_region(x, 2, MPI_DOUBLE)); | |
| 9 | @*/ | |
| 10 | int bcast(void * x) { | |
| 11 | return 0; | |
| 12 | } | |
| 13 | ||
| 14 | ||
| 15 | /*@ | |
| 16 | @ \mpi_collective(comm, P2P): | |
| 17 | @ ensures \mpi_agree(\result); | |
| 18 | @*/ | |
| 19 | double target() { | |
| 20 | double data[2]; | |
| 21 | ||
| 22 | bcast(data); | |
| 23 | return data[1]; | |
| 24 | } |
Note:
See TracBrowser
for help on using the repository browser.
