1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-02-24 09:33:26 +01:00
This commit is contained in:
Justin Lin 2020-03-13 12:57:04 +08:00
parent cd0a24e17f
commit 4b12e00759
3 changed files with 11 additions and 16 deletions

View File

@ -1,11 +1,4 @@
function _greaterThan(elem1, elem2, i) =
i == -1 ? false :
elem1[i] > elem2[i] ? true :
elem1[i] == elem2[i] ? _greaterThan(elem1, elem2, i - 1) : false;
function greaterThan(elem1, elem2) = _greaterThan(elem1, elem2, len(elem1));
function lessThan(elem1, elem2) = !greaterThan(elem1, elem2) && elem1 != elem2;
use <util/_impl/_vt_default_comparator.scad>;
function _default_sort(lt) =
let(leng = len(lt))

View File

@ -0,0 +1,8 @@
function _greaterThan(elem1, elem2, i) =
i == -1 ? false :
elem1[i] > elem2[i] ? true :
elem1[i] == elem2[i] ? _greaterThan(elem1, elem2, i - 1) : false;
function greaterThan(elem1, elem2) = _greaterThan(elem1, elem2, len(elem1));
function lessThan(elem1, elem2) = !greaterThan(elem1, elem2) && elem1 != elem2;

View File

@ -1,11 +1,4 @@
function _greaterThan(elem1, elem2, i) =
i == -1 ? false :
elem1[i] > elem2[i] ? true :
elem1[i] == elem2[i] ? _greaterThan(elem1, elem2, i - 1) : false;
function greaterThan(elem1, elem2) = _greaterThan(elem1, elem2, len(elem1));
function lessThan(elem1, elem2) = !greaterThan(elem1, elem2) && elem1 != elem2;
use <util/_impl/_vt_default_comparator.scad>;
function _binary_search(sorted, elem, low, upper) =
low > upper ? -1 :
@ -13,4 +6,5 @@ function _binary_search(sorted, elem, low, upper) =
lessThan(sorted[mid], elem) ? _binary_search(sorted, elem, mid + 1, upper) :
greaterThan(sorted[mid], elem) ? _binary_search(sorted, elem, low, mid - 1) : mid;
// for example, `sorted` is by zyx
function bsearch(sorted, elem) = _binary_search(sorted, elem, 0, len(sorted) - 1);