/* 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	"structs.h"
#include	"defs.h"
#include	"refine_map.h"


double    compute_mesh_edata(edata, vdata, mesh_dims, comm_graph, node2vtx)
struct refine_edata *edata;	/* desire data for current edge */
struct refine_vdata *vdata;	/* data for all vertices */
int       mesh_dims[3];		/* dimensions of processor mesh */
struct vtx_data **comm_graph;	/* communication graph */
short    *node2vtx;		/* maps mesh nodes to graph vertices */
{
    double    desire;		/* edge's interest in flipping */
    float     ewgt;		/* edge weight */
    int       vtx1, vtx2;	/* vertices on either side of wire */
    int       off;		/* index into vdata */
    int       is_an_edge();

    vtx1 = node2vtx[edata->node1];
    vtx2 = node2vtx[edata->node2];

    off = edata->dim * mesh_dims[0] * mesh_dims[1] * mesh_dims[2];

    desire =
       (vdata[off + vtx1].above - vdata[off + vtx1].below - vdata[off + vtx1].same) +
       (vdata[off + vtx2].below - vdata[off + vtx2].above - vdata[off + vtx2].same);

    /* Subtract off potential doubly counted edge. */
    if (is_an_edge(comm_graph[vtx1], vtx2, &ewgt))
	desire -= 2 * ewgt;

    return (desire);
}


syntax highlighted by Code2HTML, v. 0.9.1