/* 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	"params.h"


void      sorts3d(vals, indices, nvtxs)
/* Sort the lists needed to find the splitter. */
double   *vals[8][MAXSETS];	/* lists of values to sort */
int      *indices[8][MAXSETS];	/* indices of sorted lists */
int       nvtxs;		/* number of vertices */
{
    int      *space;		/* space for mergesort routine */
    int       nsets = 8;	/* number of sets */
    int       nlists = 13;	/* number of directions to sort */
    int      *temp[13];		/* place holders for indices */
    int       i, j;		/* loop counter */
    double   *smalloc();
    int       sfree();
    void      mergesort();

    space = (int *) smalloc((unsigned) nvtxs * sizeof(int));

    for (i = 0; i < nlists; i++) {
	temp[i] = (int *) smalloc((unsigned) nvtxs * sizeof(int));
    }

    mergesort(vals[0][1], nvtxs, temp[0], space);
    mergesort(vals[0][2], nvtxs, temp[1], space);
    mergesort(vals[0][4], nvtxs, temp[2], space);
    mergesort(vals[0][3], nvtxs, temp[3], space);
    mergesort(vals[1][2], nvtxs, temp[4], space);
    mergesort(vals[0][5], nvtxs, temp[5], space);
    mergesort(vals[1][4], nvtxs, temp[6], space);
    mergesort(vals[0][6], nvtxs, temp[7], space);
    mergesort(vals[2][4], nvtxs, temp[8], space);
    mergesort(vals[0][7], nvtxs, temp[9], space);
    mergesort(vals[1][6], nvtxs, temp[10], space);
    mergesort(vals[2][5], nvtxs, temp[11], space);
    mergesort(vals[3][4], nvtxs, temp[12], space);

    sfree((char *) space);

    indices[0][1] = indices[2][3] = indices[4][5] = indices[6][7] = temp[0];
    indices[0][2] = indices[1][3] = indices[4][6] = indices[5][7] = temp[1];
    indices[0][4] = indices[1][5] = indices[2][6] = indices[3][7] = temp[2];
    indices[0][3] = indices[4][7] = temp[3];
    indices[1][2] = indices[5][6] = temp[4];
    indices[0][5] = indices[2][7] = temp[5];
    indices[1][4] = indices[3][6] = temp[6];
    indices[0][6] = indices[1][7] = temp[7];
    indices[2][4] = indices[3][5] = temp[8];
    indices[0][7] = temp[9];
    indices[1][6] = temp[10];
    indices[2][5] = temp[11];
    indices[3][4] = temp[12];

    for (i = 0; i < nsets; i++) {
	for (j = i + 1; j < nsets; j++)
	    indices[j][i] = indices[i][j];
    }
}


syntax highlighted by Code2HTML, v. 0.9.1