2008-04-10 01:58:42 +04:00
|
|
|
/* -*- C -*-
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*
|
|
|
|
* The most basic of MPI applications
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "orte_config.h"
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include "opal/util/bit_ops.h"
|
|
|
|
#include "opal/class/opal_list.h"
|
2008-10-03 00:08:27 +04:00
|
|
|
#include "opal/class/opal_bitmap.h"
|
2008-04-10 01:58:42 +04:00
|
|
|
|
2009-05-04 15:07:40 +04:00
|
|
|
#include "orte/util/proc_info.h"
|
2008-04-10 01:58:42 +04:00
|
|
|
#include "orte/runtime/runtime.h"
|
|
|
|
|
2008-10-03 00:08:27 +04:00
|
|
|
typedef struct {
|
|
|
|
opal_list_item_t super;
|
|
|
|
orte_vpid_t vpid;
|
|
|
|
opal_bitmap_t relatives;
|
|
|
|
} orte_routed_tree_t;
|
|
|
|
|
|
|
|
static void construct(orte_routed_tree_t *rt)
|
2008-04-10 01:58:42 +04:00
|
|
|
{
|
2008-10-03 00:08:27 +04:00
|
|
|
rt->vpid = ORTE_VPID_INVALID;
|
|
|
|
OBJ_CONSTRUCT(&rt->relatives, opal_bitmap_t);
|
|
|
|
}
|
2015-07-23 16:18:43 +03:00
|
|
|
static void destruct(orte_routed_tree_t *rt)
|
2008-10-03 00:08:27 +04:00
|
|
|
{
|
|
|
|
OBJ_DESTRUCT(&rt->relatives);
|
2008-04-10 01:58:42 +04:00
|
|
|
}
|
2008-10-03 00:08:27 +04:00
|
|
|
OBJ_CLASS_INSTANCE(orte_routed_tree_t, opal_list_item_t,
|
|
|
|
construct, destruct);
|
2008-04-10 01:58:42 +04:00
|
|
|
|
2008-10-03 00:08:27 +04:00
|
|
|
|
|
|
|
int down_search(int rank, int parent, int me, int num_procs,
|
|
|
|
int *num_children, opal_list_t *children, opal_bitmap_t *relatives)
|
2008-04-10 01:58:42 +04:00
|
|
|
{
|
|
|
|
int i, bitmap, peer, hibit, mask, found;
|
2008-10-03 00:08:27 +04:00
|
|
|
orte_routed_tree_t *child;
|
|
|
|
opal_bitmap_t *relations;
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2008-04-10 01:58:42 +04:00
|
|
|
/* is this me? */
|
|
|
|
if (me == rank) {
|
|
|
|
bitmap = opal_cube_dim(num_procs);
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2008-04-10 01:58:42 +04:00
|
|
|
hibit = opal_hibit(rank, bitmap);
|
|
|
|
--bitmap;
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2008-04-10 01:58:42 +04:00
|
|
|
for (i = hibit + 1, mask = 1 << i; i <= bitmap; ++i, mask <<= 1) {
|
|
|
|
peer = rank | mask;
|
|
|
|
if (peer < num_procs) {
|
2008-10-03 00:08:27 +04:00
|
|
|
child = OBJ_NEW(orte_routed_tree_t);
|
|
|
|
child->vpid = peer;
|
|
|
|
if (NULL != children) {
|
|
|
|
/* this is a direct child - add it to my list */
|
|
|
|
opal_list_append(children, &child->super);
|
|
|
|
(*num_children)++;
|
|
|
|
/* setup the relatives bitmap */
|
|
|
|
opal_bitmap_init(&child->relatives, num_procs);
|
|
|
|
/* point to the relatives */
|
|
|
|
relations = &child->relatives;
|
|
|
|
} else {
|
|
|
|
/* we are recording someone's relatives - set the bit */
|
|
|
|
opal_bitmap_set_bit(relatives, peer);
|
|
|
|
/* point to this relations */
|
|
|
|
relations = relatives;
|
|
|
|
}
|
|
|
|
/* search for this child's relatives */
|
|
|
|
down_search(0, 0, peer, num_procs, NULL, NULL, relations);
|
2008-04-10 01:58:42 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return parent;
|
|
|
|
}
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2008-04-10 01:58:42 +04:00
|
|
|
/* find the children of this rank */
|
|
|
|
bitmap = opal_cube_dim(num_procs);
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2008-04-10 01:58:42 +04:00
|
|
|
hibit = opal_hibit(rank, bitmap);
|
|
|
|
--bitmap;
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2008-04-10 01:58:42 +04:00
|
|
|
for (i = hibit + 1, mask = 1 << i; i <= bitmap; ++i, mask <<= 1) {
|
|
|
|
peer = rank | mask;
|
|
|
|
if (peer < num_procs) {
|
|
|
|
/* execute compute on this child */
|
2008-10-03 00:08:27 +04:00
|
|
|
if (0 <= (found = down_search(peer, rank, me, num_procs, num_children, children, relatives))) {
|
2008-04-10 01:58:42 +04:00
|
|
|
return found;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char* argv[])
|
|
|
|
{
|
2008-10-03 00:08:27 +04:00
|
|
|
int i, j;
|
2008-04-10 01:58:42 +04:00
|
|
|
int found;
|
|
|
|
opal_list_t children;
|
|
|
|
opal_list_item_t *item;
|
|
|
|
int num_children;
|
|
|
|
int num_procs;
|
2008-10-03 00:08:27 +04:00
|
|
|
orte_routed_tree_t *child;
|
|
|
|
opal_bitmap_t *relations;
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2008-10-03 00:08:27 +04:00
|
|
|
if (2 != argc) {
|
|
|
|
printf("usage: binom x, where x=number of procs\n");
|
|
|
|
exit(1);
|
|
|
|
}
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2009-12-04 07:31:06 +03:00
|
|
|
orte_init(&argc, &argv, ORTE_PROC_TOOL);
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2008-10-03 00:08:27 +04:00
|
|
|
num_procs = atoi(argv[1]);
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2008-04-10 01:58:42 +04:00
|
|
|
for (i=0; i < num_procs; i++) {
|
|
|
|
OBJ_CONSTRUCT(&children, opal_list_t);
|
|
|
|
num_children = 0;
|
|
|
|
printf("i am %d:", i);
|
2008-10-03 00:08:27 +04:00
|
|
|
found = down_search(0, 0, i, num_procs, &num_children, &children, NULL);
|
2008-04-10 01:58:42 +04:00
|
|
|
printf("\tparent %d num_children %d\n", found, num_children);
|
|
|
|
while (NULL != (item = opal_list_remove_first(&children))) {
|
2008-10-03 00:08:27 +04:00
|
|
|
child = (orte_routed_tree_t*)item;
|
|
|
|
printf("\tchild %d\n", child->vpid);
|
|
|
|
for (j=0; j < num_procs; j++) {
|
|
|
|
if (opal_bitmap_is_set_bit(&child->relatives, j)) {
|
|
|
|
printf("\t\trelation %d\n", j);
|
|
|
|
}
|
|
|
|
}
|
2008-04-10 01:58:42 +04:00
|
|
|
OBJ_RELEASE(item);
|
|
|
|
}
|
|
|
|
OBJ_DESTRUCT(&children);
|
|
|
|
}
|
2015-06-24 06:59:57 +03:00
|
|
|
|
2008-04-10 01:58:42 +04:00
|
|
|
orte_finalize();
|
|
|
|
}
|