mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
test group_sort
This commit is contained in:
parent
f2613ccda2
commit
b924eaa303
2 changed files with 22 additions and 12 deletions
18
arrays.scad
18
arrays.scad
|
@ -68,8 +68,8 @@ function _same_type(a,b, depth) =
|
||||||
// list = select(list,start,end);
|
// list = select(list,start,end);
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// list = The list to get the portion of.
|
// list = The list to get the portion of.
|
||||||
// start = The index of the first item or an index range or a list of indices.
|
// start = Either the index of the first item or an index range or a list of indices.
|
||||||
// end = The index of the last item.
|
// end = The index of the last item when `start` is a number. When `start` is a list or a range, `end` should not be given.
|
||||||
// See Also: slice(), subindex(), last()
|
// See Also: slice(), subindex(), last()
|
||||||
// Example:
|
// Example:
|
||||||
// l = [3,4,5,6,7,8,9];
|
// l = [3,4,5,6,7,8,9];
|
||||||
|
@ -92,7 +92,7 @@ function select(list, start, end) =
|
||||||
? list[ (start%l+l)%l ]
|
? list[ (start%l+l)%l ]
|
||||||
: assert( is_list(start) || is_range(start), "Invalid start parameter")
|
: assert( is_list(start) || is_range(start), "Invalid start parameter")
|
||||||
[for (i=start) list[ (i%l+l)%l ] ]
|
[for (i=start) list[ (i%l+l)%l ] ]
|
||||||
: assert(is_finite(start), "Invalid start parameter.")
|
: assert(is_finite(start), "When `end` is given, `start` parameter should be a number.")
|
||||||
assert(is_finite(end), "Invalid end parameter.")
|
assert(is_finite(end), "Invalid end parameter.")
|
||||||
let( s = (start%l+l)%l, e = (end%l+l)%l )
|
let( s = (start%l+l)%l, e = (end%l+l)%l )
|
||||||
(s <= e)
|
(s <= e)
|
||||||
|
@ -1062,7 +1062,7 @@ function _indexed_sort(arrind) =
|
||||||
// Usage:
|
// Usage:
|
||||||
// slist = sort(list, <idx>);
|
// slist = sort(list, <idx>);
|
||||||
// Topics: List Handling
|
// Topics: List Handling
|
||||||
// See Also: shuffle(), sortidx(), unique(), unique_count()
|
// See Also: shuffle(), sortidx(), unique(), unique_count(), group_sort()
|
||||||
// Description:
|
// Description:
|
||||||
// Sorts the given list in lexicographic order. If the input is a homogeneous simple list or a homogeneous
|
// Sorts the given list in lexicographic order. If the input is a homogeneous simple list or a homogeneous
|
||||||
// list of vectors (see function is_homogeneous), the sorting method uses the native comparison operator and is faster.
|
// list of vectors (see function is_homogeneous), the sorting method uses the native comparison operator and is faster.
|
||||||
|
@ -1103,7 +1103,7 @@ function sort(list, idx=undef) =
|
||||||
// Usage:
|
// Usage:
|
||||||
// idxlist = sortidx(list, <idx>);
|
// idxlist = sortidx(list, <idx>);
|
||||||
// Topics: List Handling
|
// Topics: List Handling
|
||||||
// See Also: shuffle(), sort(), unique(), unique_count()
|
// See Also: shuffle(), sort(), group_sort(), unique(), unique_count()
|
||||||
// Description:
|
// Description:
|
||||||
// Given a list, sort it as function `sort()`, and returns
|
// Given a list, sort it as function `sort()`, and returns
|
||||||
// a list of indexes into the original list in that sorted order.
|
// a list of indexes into the original list in that sorted order.
|
||||||
|
@ -1167,13 +1167,13 @@ function sortidx(list, idx=undef) =
|
||||||
// Example:
|
// Example:
|
||||||
// sorted = group_sort([5,2,8,3,1,3,8,7,5]); // Returns: [[1],[2],[3,3],[5,5],[7],[8,8]]
|
// sorted = group_sort([5,2,8,3,1,3,8,7,5]); // Returns: [[1],[2],[3,3],[5,5],[7],[8,8]]
|
||||||
// sorted2 = group_sort([[5,"a"],[2,"b"], [5,"c"], [3,"d"], [2,"e"] ], idx=0); // Returns: [[[2,"b"],[2,"e"]], [[5,"a"],[5,"c"]], [[3,"d"]] ]
|
// sorted2 = group_sort([[5,"a"],[2,"b"], [5,"c"], [3,"d"], [2,"e"] ], idx=0); // Returns: [[[2,"b"],[2,"e"]], [[5,"a"],[5,"c"]], [[3,"d"]] ]
|
||||||
function group_sort(list, idx=undef) =
|
function group_sort(list, idx) =
|
||||||
assert(is_list(list), "Input should be a list." )
|
assert(is_list(list), "Input should be a list." )
|
||||||
assert(is_undef(idx) || (is_finite(idx) && idx>=0) , "Invalid index." )
|
assert(is_undef(idx) || (is_finite(idx) && idx>=0) , "Invalid index." )
|
||||||
len(list)<=1 ? [list] :
|
len(list)<=1 ? [list] :
|
||||||
is_vector(list)? _group_sort(list) :
|
is_vector(list)? _group_sort(list) :
|
||||||
let( idx = is_undef(idx) ? 0 : idx )
|
let( idx = is_undef(idx) ? 0 : idx )
|
||||||
assert( [for(i=idx(list)) if(!is_list(list[i]) || len(list[i])>=idx || !is_num(list[idx])) 1]==[],
|
assert( [for(entry=list) if(!is_list(entry) || len(entry)<idx || !is_num(entry[idx]) ) 1]==[],
|
||||||
"Some entry of the list is a list shorter than `idx` or the indexed entry of it is not a number." )
|
"Some entry of the list is a list shorter than `idx` or the indexed entry of it is not a number." )
|
||||||
_group_sort_by_index(list,idx);
|
_group_sort_by_index(list,idx);
|
||||||
|
|
||||||
|
@ -1232,7 +1232,7 @@ function unique_count(list) =
|
||||||
assert(is_list(list) || is_string(list), "Invalid input." )
|
assert(is_list(list) || is_string(list), "Invalid input." )
|
||||||
list == [] ? [[],[]] :
|
list == [] ? [[],[]] :
|
||||||
is_homogeneous(list,1) && ! is_list(list[0])
|
is_homogeneous(list,1) && ! is_list(list[0])
|
||||||
? let( sorted = _group_sort_scalars(list) )
|
? let( sorted = _group_sort(list) )
|
||||||
[ [for(s=sorted) s[0] ], [for(s=sorted) len(s) ] ]
|
[ [for(s=sorted) s[0] ], [for(s=sorted) len(s) ] ]
|
||||||
: let( list=sort(list) )
|
: let( list=sort(list) )
|
||||||
let( ind = [0, for(i=[1:1:len(list)-1]) if (list[i]!=list[i-1]) i] )
|
let( ind = [0, for(i=[1:1:len(list)-1]) if (list[i]!=list[i-1]) i] )
|
||||||
|
@ -1766,7 +1766,7 @@ function submatrix_set(M,A,m=0,n=0) =
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// v = The list of items to group.
|
// v = The list of items to group.
|
||||||
// cnt = The number of items to put in each grouping. Default:2
|
// cnt = The number of items to put in each grouping. Default:2
|
||||||
// dflt = The default value to fill in with is the list is not a multiple of `cnt` items long. Default: 0
|
// dflt = The default value to fill in with if the list is not a multiple of `cnt` items long. Default: 0
|
||||||
// Example:
|
// Example:
|
||||||
// v = [1,2,3,4,5,6];
|
// v = [1,2,3,4,5,6];
|
||||||
// a = array_group(v,2) returns [[1,2], [3,4], [5,6]]
|
// a = array_group(v,2) returns [[1,2], [3,4], [5,6]]
|
||||||
|
|
|
@ -358,11 +358,21 @@ module test_sortidx() {
|
||||||
}
|
}
|
||||||
test_sortidx();
|
test_sortidx();
|
||||||
|
|
||||||
|
module test_group_sort() {
|
||||||
|
assert_equal(group_sort([]), [[]]);
|
||||||
|
assert_equal(group_sort([8]), [[8]]);
|
||||||
|
assert_equal(group_sort([7,3,9,4,3,1,8]), [[1], [3, 3], [4], [7], [8], [9]]);
|
||||||
|
assert_equal(group_sort([[5,"a"],[2,"b"], [5,"c"], [3,"d"], [2,"e"] ], idx=0), [[[2, "b"], [2, "e"]], [[3, "d"]], [[5, "a"], [5, "c"]]]);
|
||||||
|
assert_equal(group_sort([["a",5],["b",6], ["c",1], ["d",2], ["e",6] ], idx=1), [[["c", 1]], [["d", 2]], [["a", 5]], [["b", 6], ["e", 6]]] );
|
||||||
|
}
|
||||||
|
test_group_sort();
|
||||||
|
|
||||||
|
|
||||||
module test_unique() {
|
module test_unique() {
|
||||||
assert(unique([]) == []);
|
assert_equal(unique([]), []);
|
||||||
assert(unique([8]) == [8]);
|
assert_equal(unique([8]), [8]);
|
||||||
assert(unique([7,3,9,4,3,1,8]) == [1,3,4,7,8,9]);
|
assert_equal(unique([7,3,9,4,3,1,8]), [1,3,4,7,8,9]);
|
||||||
|
assert_equal(unique(["A","B","R","A","C","A","D","A","B","R","A"]), ["A", "B", "C", "D", "R"]);
|
||||||
}
|
}
|
||||||
test_unique();
|
test_unique();
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue