50 #include <sys/types.h> 55 #define NUM_COMMANDS 10 61 char *cmd1 =
"maxprocs=1 /bin/sleep 1";
62 char *cmd2 =
"maxprocs=1 /bin/sleep 5";
63 char *cmd3 =
"maxprocs=1 /bin/sleep 10";
64 int vlen = (int)strlen(cmd2) + 1;
65 for (
int i = 0; i < NUM_COMMANDS; i++) {
69 }
else if (i % 3 == 1) {
74 struct kmr_kv_box nkv = { .klen =
sizeof(long),
75 .vlen = vlen * (
int)
sizeof(char),
87 struct kmr_kv_box nkv = { .klen =
sizeof(long),
96 main(
int argc,
char **argv)
98 MPI_Init(&argc, &argv);
102 MPI_Comm_rank(MPI_COMM_WORLD, &rank);
104 MPI_Barrier(MPI_COMM_WORLD);
106 fprintf(stderr,
"Start\n");
108 MPI_Barrier(MPI_COMM_WORLD);
111 int ret =
kmr_map_once(kvs_commands, 0, kmr_noopt, 1, gen_cmdkvs);
112 if (ret != MPI_SUCCESS) {
113 MPI_Abort(MPI_COMM_WORLD, 1);
117 MPI_Barrier(MPI_COMM_WORLD);
119 fprintf(stderr,
"MAP_ONCE DONE\n");
121 MPI_Barrier(MPI_COMM_WORLD);
124 ret =
kmr_shuffle(kvs_commands, kvs_runcmds, kmr_noopt);
125 if (ret != MPI_SUCCESS) {
126 MPI_Abort(MPI_COMM_WORLD, 1);
130 MPI_Barrier(MPI_COMM_WORLD);
132 fprintf(stderr,
"SHUFFLE DONE\n");
134 MPI_Barrier(MPI_COMM_WORLD);
140 sopt_sepsp, output_result);
144 MPI_Barrier(MPI_COMM_WORLD);
146 fprintf(stderr,
"MAP_SPAWN DONE\n");
148 MPI_Barrier(MPI_COMM_WORLD);
151 fprintf(stderr,
"Finish\n");
int kmr_map_serial_processes(KMR_KVS *kvi, KMR_KVS *kvo, void *arg, MPI_Info info, struct kmr_spawn_option opt, kmr_mapfn_t mapfn)
Maps on processes started by MPI_Comm_spawn() to run serial processes.
Key-Value Stream (abstract).
int kmr_add_kv(KMR_KVS *kvs, const struct kmr_kv_box kv)
Adds a key-value pair.
int kmr_map_once(KMR_KVS *kvo, void *arg, struct kmr_option opt, _Bool rank_zero_only, kmr_mapfn_t m)
Maps once.
#define kmr_create_kvs(MR, KF, VF)
Makes a new key-value stream (of type KMR_KVS) with the specified field datatypes.
int kmr_shuffle(KMR_KVS *kvi, KMR_KVS *kvo, struct kmr_option opt)
Shuffles key-value pairs to the appropriate destination ranks.
int kmr_free_kvs(KMR_KVS *kvs)
Releases a key-value stream (type KMR_KVS).
Handy Copy of a Key-Value Field.
int kmr_dump_kvs(KMR_KVS *kvs, int flag)
Dumps contents of a key-value stream to stdout.
Options to Mapping by Spawns.
int kmr_fin(void)
Clears the environment.
#define kmr_init()
Sets up the environment.
int kmr_free_context(KMR *mr)
Releases a context created with kmr_create_context().
KMR * kmr_create_context(const MPI_Comm comm, const MPI_Info conf, const char *name)
Makes a new KMR context (a context has type KMR).