molstar
Version:
A comprehensive macromolecular library.
164 lines • 4.97 kB
JavaScript
/**
* Copyright (c) 2017 mol* contributors, licensed under MIT, See LICENSE file for more info.
*
* @author David Sehnal <david.sehnal@gmail.com>
*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.sort = exports.sortArrayRange = exports.sortArray = exports.arraySwap = exports.arrayLess = void 0;
function arrayLess(arr, i, j) {
return arr[i] - arr[j];
}
exports.arrayLess = arrayLess;
function arraySwap(arr, i, j) {
var temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
exports.arraySwap = arraySwap;
function medianPivotIndex(data, cmp, l, r) {
var m = (l + r) >> 1;
if (cmp(data, l, r) > 0)
return cmp(data, l, m) > 0 ? cmp(data, m, r) > 0 ? m : r : l;
else
return cmp(data, r, m) > 0 ? cmp(data, m, l) > 0 ? m : l : r;
}
function partition(ctx, l, r) {
var cmp = ctx.cmp, swap = ctx.swap, data = ctx.data, parts = ctx.parts;
var equals = l + 1, tail = r;
// move the median to the 1st spot
swap(data, l, medianPivotIndex(data, cmp, l, r));
while (cmp(data, tail, l) > 0) {
--tail;
}
for (var i = l + 1; i <= tail; i++) {
var c = cmp(data, i, l);
if (c > 0) {
swap(data, i, tail);
--tail;
while (cmp(data, tail, l) > 0) {
--tail;
}
i--;
}
else if (c === 0) {
swap(data, i, equals);
equals++;
}
}
// move the medians to the correct spots
for (var i = l; i < equals; i++) {
swap(data, i, l + tail - i);
}
parts[0] = tail - equals + l + 1;
parts[1] = tail;
}
function insertionSort(_a, start, end) {
var data = _a.data, cmp = _a.cmp, swap = _a.swap;
for (var i = start + 1; i <= end; i++) {
var j = i - 1;
while (j >= start && cmp(data, j, j + 1) > 0) {
swap(data, j, j + 1);
j = j - 1;
}
}
}
function quickSort(ctx, low, high) {
var parts = ctx.parts;
while (low < high) {
if (high - low < 16) {
insertionSort(ctx, low, high);
return;
}
partition(ctx, low, high);
var li = parts[0], ri = parts[1];
if (li - low < high - ri) {
quickSort(ctx, low, li - 1);
low = ri + 1;
}
else {
quickSort(ctx, ri + 1, high);
high = li - 1;
}
}
}
function partitionArrayAsc(data, parts, l, r) {
var equals = l + 1, tail = r;
// move the median to the 1st spot
arraySwap(data, l, medianPivotIndex(data, arrayLess, l, r));
var pivot = data[l];
while (data[tail] > pivot) {
--tail;
}
for (var i = l + 1; i <= tail; i++) {
var v = data[i];
if (v > pivot) {
arraySwap(data, i, tail);
--tail;
while (data[tail] > pivot) {
--tail;
}
i--;
}
else if (v === pivot) {
arraySwap(data, i, equals);
++equals;
}
}
// move all medians to the correct spots
for (var i = l; i < equals; i++) {
arraySwap(data, i, l + tail - i);
}
parts[0] = tail - equals + l + 1;
parts[1] = tail;
}
function insertionSortArrayAsc(data, start, end) {
for (var i = start + 1; i <= end; i++) {
var key = data[i];
var j = i - 1;
while (j >= start && data[j] > key) {
data[j + 1] = data[j];
j = j - 1;
}
data[j + 1] = key;
}
}
function quickSortArrayAsc(data, parts, low, high) {
while (low < high) {
if (high - low < 16) {
insertionSortArrayAsc(data, low, high);
return;
}
partitionArrayAsc(data, parts, low, high);
var li = parts[0], ri = parts[1];
if (li - low < high - ri) {
quickSortArrayAsc(data, parts, low, li - 1);
low = ri + 1;
}
else {
quickSortArrayAsc(data, parts, ri + 1, high);
high = li - 1;
}
}
}
function sortArray(data, cmp) {
if (cmp === void 0) { cmp = arrayLess; }
return sortArrayRange(data, 0, data.length, cmp);
}
exports.sortArray = sortArray;
function sortArrayRange(data, start, end, cmp) {
if (cmp === void 0) { cmp = arrayLess; }
if (cmp === arrayLess)
quickSortArrayAsc(data, [0, 0], start, end - 1);
else
quickSort({ data: data, cmp: cmp, swap: arraySwap, parts: [0, 0] }, start, end - 1);
return data;
}
exports.sortArrayRange = sortArrayRange;
function sort(data, start, end, cmp, swap) {
var ctx = { data: data, cmp: cmp, swap: swap, parts: [0, 0] };
quickSort(ctx, start, end - 1);
return data;
}
exports.sort = sort;
//# sourceMappingURL=sort.js.map
;