/* This software was developed by Bruce Hendrickson and Robert Leland   *
 * at Sandia National Laboratories under US Department of Energy        *
 * contract DE-AC04-76DP00789 and is copyrighted by Sandia Corporation. */

#include	<stdio.h>
#include	"defs.h"
#include	"refine_map.h"

struct refine_edata *find_edge_mesh(vertex, dim, edata, mesh_dims, 
     vtx2node)
int       vertex;		/* vertex in comm_graph */
int       dim;			/* direction of edge from node */
struct refine_edata *edata;/* data structure for edge preferences */
int      *mesh_dims;		/* dimensions of mesh */
short    *vtx2node;		/* maps comm_graph vtxs to processors */
{
    struct refine_edata *eguy;	/* returned pointer to edge info */
    int       dir;		/* higher or lower direction? */
    int       my_node;		/* processor vertex assigned to */
    short     my_loc[3];	/* location of my processor */
    int       index;		/* computed index into edata */

    if (dim < 0) {
	dir = -1;
	dim = -(dim + 1);
    }
    else
	dir = 1;

    my_node = vtx2node[vertex];
    my_loc[0] = my_node % mesh_dims[0];
    my_loc[1] = (my_node / mesh_dims[0]) % mesh_dims[1];
    my_loc[2] = my_node / (mesh_dims[0] * mesh_dims[1]);

    if ((my_loc[dim] == 0 && dir == -1) ||
	(my_loc[dim] == mesh_dims[dim] - 1 && dir == 1)) {
	eguy = NULL;
    }

    else {			/* Figure out where edge is in data structure. */
	/* Note: indexing must match with that in init_mesh_edata. */
	if (dir < 0) --my_loc[dim];

	if (dim == 0) {		/* Edge in x-direction. */
	    index = (mesh_dims[0] - 1) * mesh_dims[1] * my_loc[2] +
	       (mesh_dims[0] - 1) * my_loc[1] + my_loc[0];
	}

	else if (dim == 1) {	/* Edge in y-direction. */
	    index = (mesh_dims[0] - 1) * mesh_dims[1] * mesh_dims[2] +
	       mesh_dims[0] * (mesh_dims[1] - 1) * my_loc[2] +
	       mesh_dims[0] * my_loc[1] + my_loc[0];

	}
	else if (dim == 2) {	/* Edge in z-direction. */
	    index = (mesh_dims[0] - 1) * mesh_dims[1] * mesh_dims[2] +
	       mesh_dims[0] * (mesh_dims[1] - 1) * mesh_dims[2] +
	       mesh_dims[0] * mesh_dims[1] * my_loc[2] +
	       mesh_dims[0] * my_loc[1] + my_loc[0];

	}
	eguy = &(edata[index]);

    }

    return (eguy);
}


syntax highlighted by Code2HTML, v. 0.9.1