00001 #include <parmetislib.h>
00002
00003
00004
00005 #define QSSWAP(a, b, stmp) do { stmp = (a); (a) = (b); (b) = stmp; } while (0)
00006
00007
00008
00009 #define MAX_THRESH 20
00010
00011
00012 typedef struct {
00013 int *lo;
00014 int *hi;
00015 } stack_node;
00016
00017
00018
00019 #define STACK_SIZE (8 * sizeof(unsigned long int))
00020 #define PUSH(low, high) ((void) ((top->lo = (low)), (top->hi = (high)), ++top))
00021 #define POP(low, high) ((void) (--top, (low = top->lo), (high = top->hi)))
00022 #define STACK_NOT_EMPTY (stack < top)
00023
00024
00025 void iintsort(int total_elems, int *pbase)
00026 {
00027 int pivot, stmp;
00028
00029 if (total_elems == 0)
00030
00031 return;
00032
00033 if (total_elems > MAX_THRESH) {
00034 int *lo = pbase;
00035 int *hi = &lo[total_elems - 1];
00036 stack_node stack[STACK_SIZE];
00037 stack_node *top = stack + 1;
00038
00039 while (STACK_NOT_EMPTY) {
00040 int *left_ptr;
00041 int *right_ptr;
00042
00043
00044
00045
00046
00047
00048 int *mid = lo + ((hi - lo) >> 1);
00049
00050 if (*mid < *lo)
00051 QSSWAP(*mid, *lo, stmp);
00052 if (*hi < *mid)
00053 QSSWAP(*mid, *hi, stmp);
00054 else
00055 goto jump_over;
00056 if (*mid < *lo)
00057 QSSWAP(*mid, *lo, stmp);
00058
00059 jump_over:;
00060 pivot = *mid;
00061 left_ptr = lo + 1;
00062 right_ptr = hi - 1;
00063
00064
00065
00066
00067 do {
00068 while (*left_ptr < pivot)
00069 left_ptr++;
00070
00071 while (pivot < *right_ptr)
00072 right_ptr--;
00073
00074 if (left_ptr < right_ptr) {
00075 QSSWAP (*left_ptr, *right_ptr, stmp);
00076 left_ptr++;
00077 right_ptr--;
00078 }
00079 else if (left_ptr == right_ptr) {
00080 left_ptr++;
00081 right_ptr--;
00082 break;
00083 }
00084 } while (left_ptr <= right_ptr);
00085
00086
00087
00088
00089
00090
00091 if ((size_t) (right_ptr - lo) <= MAX_THRESH) {
00092 if ((size_t) (hi - left_ptr) <= MAX_THRESH)
00093
00094 POP (lo, hi);
00095 else
00096
00097 lo = left_ptr;
00098 }
00099 else if ((size_t) (hi - left_ptr) <= MAX_THRESH)
00100
00101 hi = right_ptr;
00102 else if ((right_ptr - lo) > (hi - left_ptr)) {
00103
00104 PUSH (lo, right_ptr);
00105 lo = left_ptr;
00106 }
00107 else {
00108
00109 PUSH (left_ptr, hi);
00110 hi = right_ptr;
00111 }
00112 }
00113 }
00114
00115
00116
00117
00118
00119
00120
00121 {
00122 int *end_ptr = &pbase[total_elems - 1];
00123 int *tmp_ptr = pbase;
00124 int *thresh = (end_ptr < pbase + MAX_THRESH ? end_ptr : pbase + MAX_THRESH);
00125 register int *run_ptr;
00126
00127
00128
00129
00130
00131
00132 for (run_ptr = tmp_ptr + 1; run_ptr <= thresh; run_ptr++)
00133 if (*run_ptr < *tmp_ptr)
00134 tmp_ptr = run_ptr;
00135
00136 if (tmp_ptr != pbase)
00137 QSSWAP(*tmp_ptr, *pbase, stmp);
00138
00139
00140 run_ptr = pbase + 1;
00141 while (++run_ptr <= end_ptr) {
00142 tmp_ptr = run_ptr - 1;
00143 while (*run_ptr < *tmp_ptr)
00144 tmp_ptr--;
00145
00146 tmp_ptr++;
00147 if (tmp_ptr != run_ptr) {
00148 int elmnt = *run_ptr;
00149 int *mptr;
00150
00151 for (mptr=run_ptr; mptr>tmp_ptr; mptr--)
00152 *mptr = *(mptr-1);
00153 *mptr = elmnt;
00154 }
00155 }
00156 }
00157 }