/* 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 #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]; } }