source: CIVL/examples/messagePassing/ring1.cvl@ 67da504

1.23 2.0 main test-branch
Last change on this file since 67da504 was e6b02c8, checked in by Manchun Zheng <zmanchun@…>, 12 years ago

updates CIVL to use the new ABC FrontEnd. tests updated accordingly when necessary.

git-svn-id: svn://vsl.cis.udel.edu/civl/trunk@1380 fb995dde-84ed-4084-dfe6-e5aef3e2452c

  • Property mode set to 100644
File size: 479 bytes
RevLine 
[69bf2e6]1/* Create nprocs processes. Have them exchange data in a cycle.
2 * Commandline example:
3 * civl verify -inputNPROCS=3 ring.cvl -simplify=false
4 */
[e6b02c8]5#include<comm.cvh>
[69bf2e6]6#include "mp_root.cvh"
7
8void MPI_Process (int rank) {
[b7bd088]9 #include "mp_proc.cvh"
[e689ae5]10 $comm comm = $comm_create($here, COMM_WORLD, rank);
[69bf2e6]11 double x=rank, y;
[e689ae5]12
[b7bd088]13 send(&x, 1, (rank+1)%NPROCS, 0, comm);
14 recv(&y, 1, (rank+NPROCS-1)%NPROCS, 0, comm);
[69bf2e6]15 $assert(y==(rank+NPROCS-1)%NPROCS);
[48bfab9]16 $comm_destroy(comm);
[69bf2e6]17}
Note: See TracBrowser for help on using the repository browser.