test group_sort

This commit is contained in:
RonaldoCMP 2021-06-22 01:13:40 +01:00
parent f2613ccda2
commit b924eaa303
2 changed files with 22 additions and 12 deletions

View file

@ -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]]

View file

@ -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();