2020-07-22 00:05:21 +00:00
|
|
|
include <../std.scad>
|
2019-05-01 06:45:05 +00:00
|
|
|
|
|
|
|
|
2020-07-24 21:54:34 +00:00
|
|
|
// Section: List Query Operations
|
|
|
|
|
2020-08-30 11:12:36 +00:00
|
|
|
module test_is_homogeneous(){
|
|
|
|
assert(is_homogeneous([[1,["a"]], [2,["b"]]])==true);
|
|
|
|
assert(is_homogeneous([[1,["a"]], [2,[true]]])==false);
|
|
|
|
assert(is_homogeneous([[1,["a"]], [2,[true]]],1)==true);
|
|
|
|
assert(is_homogeneous([[1,["a"]], [2,[true]]],2)==false);
|
2020-10-04 02:50:29 +00:00
|
|
|
assert(is_homogeneous([[1,["a"]], [true,["b"]]])==false);
|
2020-08-30 11:12:36 +00:00
|
|
|
}
|
|
|
|
test_is_homogeneous();
|
|
|
|
|
|
|
|
|
2020-07-24 21:54:34 +00:00
|
|
|
module test_select() {
|
|
|
|
l = [3,4,5,6,7,8,9];
|
|
|
|
assert(select(l, 5, 6) == [8,9]);
|
|
|
|
assert(select(l, 5, 8) == [8,9,3,4]);
|
|
|
|
assert(select(l, 5, 2) == [8,9,3,4,5]);
|
|
|
|
assert(select(l, -3, -1) == [7,8,9]);
|
|
|
|
assert(select(l, 3, 3) == [6]);
|
|
|
|
assert(select(l, 4) == 7);
|
|
|
|
assert(select(l, -2) == 8);
|
|
|
|
assert(select(l, [1:3]) == [4,5,6]);
|
|
|
|
assert(select(l, [1,3]) == [4,6]);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
2020-07-24 21:54:34 +00:00
|
|
|
test_select();
|
|
|
|
|
2021-03-25 07:23:36 +00:00
|
|
|
|
|
|
|
module test_slice() {
|
2021-03-30 07:46:59 +00:00
|
|
|
l = [3,4,5,6,7,8,9];
|
|
|
|
assert(slice(l, 5, 6) == [8,9]);
|
|
|
|
assert(slice(l, 5, 8) == [8,9]);
|
|
|
|
assert(slice(l, 5, 2) == []);
|
|
|
|
assert(slice(l, -3, -1) == [7,8,9]);
|
|
|
|
assert(slice(l, 3, 3) == [6]);
|
|
|
|
assert(slice(l, 4) == [7,8,9]);
|
|
|
|
assert(slice(l, -2) == [8,9]);
|
2021-03-25 07:23:36 +00:00
|
|
|
}
|
|
|
|
test_slice();
|
|
|
|
|
|
|
|
|
2020-12-13 02:15:33 +00:00
|
|
|
module test_last() {
|
|
|
|
list = [1,2,3,4];
|
|
|
|
assert(last(list)==4);
|
|
|
|
assert(last([])==undef);
|
|
|
|
}
|
|
|
|
test_last();
|
|
|
|
|
2021-03-25 07:23:36 +00:00
|
|
|
|
|
|
|
module test_list_head() {
|
2020-12-13 02:15:33 +00:00
|
|
|
list = [1,2,3,4];
|
2021-03-25 07:23:36 +00:00
|
|
|
assert_equal(list_head(list), [1,2,3]);
|
|
|
|
assert_equal(list_head([1]), []);
|
|
|
|
assert_equal(list_head([]), []);
|
|
|
|
assert_equal(list_head(list,-3), [1,2]);
|
|
|
|
assert_equal(list_head(list,1), [1,2]);
|
|
|
|
assert_equal(list_head(list,2), [1,2,3]);
|
|
|
|
assert_equal(list_head(list,6), [1,2,3,4]);
|
|
|
|
assert_equal(list_head(list,-6), []);
|
2020-12-13 02:15:33 +00:00
|
|
|
}
|
2021-03-25 07:23:36 +00:00
|
|
|
test_list_head();
|
2020-12-13 02:15:33 +00:00
|
|
|
|
2020-07-24 21:54:34 +00:00
|
|
|
|
2021-03-25 07:23:36 +00:00
|
|
|
module test_list_tail() {
|
|
|
|
list = [1,2,3,4];
|
|
|
|
assert_equal(list_tail(list), [2,3,4]);
|
|
|
|
assert_equal(list_tail([1]), []);
|
|
|
|
assert_equal(list_tail([]), []);
|
|
|
|
assert_equal(list_tail(list,-3), [2,3,4]);
|
|
|
|
assert_equal(list_tail(list,2), [3,4]);
|
|
|
|
assert_equal(list_tail(list,3), [4]);
|
|
|
|
assert_equal(list_tail(list,6), []);
|
|
|
|
assert_equal(list_tail(list,-6), [1,2,3,4]);
|
2020-07-24 21:54:34 +00:00
|
|
|
}
|
2021-03-25 07:23:36 +00:00
|
|
|
test_list_tail();
|
2019-05-01 06:45:05 +00:00
|
|
|
|
|
|
|
|
|
|
|
module test_in_list() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(in_list("bar", ["foo", "bar", "baz"]));
|
|
|
|
assert(!in_list("bee", ["foo", "bar", "baz"]));
|
|
|
|
assert(in_list("bar", [[2,"foo"], [4,"bar"], [3,"baz"]], idx=1));
|
2020-07-24 21:54:34 +00:00
|
|
|
assert(!in_list("bee", ["foo", "bar", ["bee"]]));
|
|
|
|
assert(in_list(NAN, [NAN])==false);
|
2020-07-21 23:55:05 +00:00
|
|
|
assert(!in_list(undef, [3,4,5]));
|
|
|
|
assert(in_list(undef,[3,4,undef,5]));
|
|
|
|
assert(!in_list(3,[]));
|
|
|
|
assert(!in_list(3,[4,5,[3]]));
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_in_list();
|
|
|
|
|
|
|
|
|
2021-10-17 03:01:52 +00:00
|
|
|
module test_is_increasing() {
|
|
|
|
assert(is_increasing([1,2,3,4]) == true);
|
|
|
|
assert(is_increasing([1,2,2,2]) == true);
|
|
|
|
assert(is_increasing([1,3,2,4]) == false);
|
|
|
|
assert(is_increasing([4,3,2,1]) == false);
|
|
|
|
assert(is_increasing([1,2,3,4],strict=true) == true);
|
|
|
|
assert(is_increasing([1,2,2,2],strict=true) == false);
|
|
|
|
assert(is_increasing([1,3,2,4],strict=true) == false);
|
|
|
|
assert(is_increasing([4,3,2,1],strict=true) == false);
|
|
|
|
assert(is_increasing(["AB","BC","DF"]) == true);
|
|
|
|
assert(is_increasing(["AB","DC","CF"]) == false);
|
|
|
|
assert(is_increasing([[1,2],[1,4],[2,3],[2,2]])==false);
|
|
|
|
assert(is_increasing([[1,2],[1,4],[2,3],[2,3]])==true);
|
|
|
|
assert(is_increasing([[1,2],[1,4],[2,3],[2,3]],strict=true)==false);
|
|
|
|
assert(is_increasing("ABCFZ")==true);
|
|
|
|
assert(is_increasing("ZYWRA")==false);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
2021-10-17 03:01:52 +00:00
|
|
|
test_is_increasing();
|
|
|
|
|
|
|
|
|
|
|
|
module test_is_decreasing() {
|
|
|
|
assert(is_decreasing([1,2,3,4]) == false);
|
|
|
|
assert(is_decreasing([4,2,3,1]) == false);
|
|
|
|
assert(is_decreasing([4,2,2,1]) == true);
|
|
|
|
assert(is_decreasing([4,3,2,1]) == true);
|
|
|
|
assert(is_decreasing([1,2,3,4],strict=true) == false);
|
|
|
|
assert(is_decreasing([4,2,3,1],strict=true) == false);
|
|
|
|
assert(is_decreasing([4,2,2,1],strict=true) == false);
|
|
|
|
assert(is_decreasing([4,3,2,1],strict=true) == true);
|
|
|
|
assert(is_decreasing(reverse(["AB","BC","DF"])) == true);
|
|
|
|
assert(is_decreasing(reverse(["AB","DC","CF"])) == false);
|
|
|
|
assert(is_decreasing(reverse([[1,2],[1,4],[2,3],[2,2]]))==false);
|
|
|
|
assert(is_decreasing(reverse([[1,2],[1,4],[2,3],[2,3]]))==true);
|
|
|
|
assert(is_decreasing(reverse([[1,2],[1,4],[2,3],[2,3]]),strict=true)==false);
|
|
|
|
assert(is_decreasing("ABCFZ")==false);
|
|
|
|
assert(is_decreasing("ZYWRA")==true);
|
2020-07-24 21:54:34 +00:00
|
|
|
}
|
2021-10-17 03:01:52 +00:00
|
|
|
test_is_decreasing();
|
2020-07-24 21:54:34 +00:00
|
|
|
|
|
|
|
|
2021-10-17 03:01:52 +00:00
|
|
|
module test_find_approx() {
|
|
|
|
assert(find_approx(1, [2,3,1.05,4,1,2,.99], eps=.1)==2);
|
|
|
|
assert(find_approx(1, [2,3,1.05,4,1,2,.99], all=true, eps=.1)==[2,4,6]);
|
2020-07-24 21:54:34 +00:00
|
|
|
}
|
2021-10-17 03:01:52 +00:00
|
|
|
test_find_approx();
|
|
|
|
|
2020-07-24 21:54:34 +00:00
|
|
|
|
2020-08-30 11:12:36 +00:00
|
|
|
|
2020-07-24 21:54:34 +00:00
|
|
|
// Section: Basic List Generation
|
|
|
|
|
|
|
|
module test_repeat() {
|
|
|
|
assert(repeat(1, 4) == [1,1,1,1]);
|
|
|
|
assert(repeat(8, [2,3]) == [[8,8,8], [8,8,8]]);
|
|
|
|
assert(repeat(0, [2,2,3]) == [[[0,0,0],[0,0,0]], [[0,0,0],[0,0,0]]]);
|
|
|
|
assert(repeat([1,2,3],3) == [[1,2,3], [1,2,3], [1,2,3]]);
|
|
|
|
assert(repeat(4, [2,-1]) == [[], []]);
|
|
|
|
}
|
|
|
|
test_repeat();
|
2019-05-01 06:45:05 +00:00
|
|
|
|
|
|
|
|
2021-04-08 03:57:45 +00:00
|
|
|
module test_count() {
|
|
|
|
assert_equal(count(5), [0,1,2,3,4]);
|
|
|
|
assert_equal(count(5,3), [3,4,5,6,7]);
|
|
|
|
assert_equal(count(4,3,2), [3,5,7,9]);
|
|
|
|
assert_equal(count(5,0,0.25), [0, 0.25, 0.5, 0.75, 1.0]);
|
2021-03-30 07:46:59 +00:00
|
|
|
}
|
2021-04-08 03:57:45 +00:00
|
|
|
test_count();
|
2019-05-01 06:45:05 +00:00
|
|
|
|
|
|
|
|
|
|
|
module test_reverse() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(reverse([3,4,5,6]) == [6,5,4,3]);
|
2020-09-29 02:12:07 +00:00
|
|
|
assert(reverse("abcd") == "dcba");
|
2020-07-24 21:54:34 +00:00
|
|
|
assert(reverse([]) == []);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_reverse();
|
|
|
|
|
|
|
|
|
2019-10-30 05:42:41 +00:00
|
|
|
module test_list_rotate() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(list_rotate([1,2,3,4,5],-2) == [4,5,1,2,3]);
|
|
|
|
assert(list_rotate([1,2,3,4,5],-1) == [5,1,2,3,4]);
|
|
|
|
assert(list_rotate([1,2,3,4,5],0) == [1,2,3,4,5]);
|
|
|
|
assert(list_rotate([1,2,3,4,5],1) == [2,3,4,5,1]);
|
|
|
|
assert(list_rotate([1,2,3,4,5],2) == [3,4,5,1,2]);
|
|
|
|
assert(list_rotate([1,2,3,4,5],3) == [4,5,1,2,3]);
|
|
|
|
assert(list_rotate([1,2,3,4,5],4) == [5,1,2,3,4]);
|
|
|
|
assert(list_rotate([1,2,3,4,5],5) == [1,2,3,4,5]);
|
|
|
|
assert(list_rotate([1,2,3,4,5],6) == [2,3,4,5,1]);
|
|
|
|
assert(list_rotate([],3) == []);
|
2019-10-30 05:42:41 +00:00
|
|
|
}
|
|
|
|
test_list_rotate();
|
|
|
|
|
|
|
|
|
2019-10-23 00:10:04 +00:00
|
|
|
module test_deduplicate() {
|
2020-10-04 02:50:29 +00:00
|
|
|
assert_equal(deduplicate([8,3,4,4,4,8,2,3,3,8,8]), [8,3,4,8,2,3,8]);
|
|
|
|
assert_equal(deduplicate(closed=true, [8,3,4,4,4,8,2,3,3,8,8]), [8,3,4,8,2,3]);
|
|
|
|
assert_equal(deduplicate("Hello"), "Helo");
|
|
|
|
assert_equal(deduplicate([[3,4],[7,1.99],[7,2],[1,4]],eps=0.1), [[3,4],[7,2],[1,4]]);
|
|
|
|
assert_equal(deduplicate([], closed=true), []);
|
|
|
|
assert_equal(deduplicate([[1,[1,[undef]]],[1,[1,[undef]]],[1,[2]],[1,[2,[0]]]]), [[1, [1,[undef]]],[1,[2]],[1,[2,[0]]]]);
|
2019-10-23 00:10:04 +00:00
|
|
|
}
|
|
|
|
test_deduplicate();
|
|
|
|
|
|
|
|
|
2020-03-24 21:51:37 +00:00
|
|
|
module test_deduplicate_indexed() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(deduplicate_indexed([8,6,4,6,3], [1,4,3,1,2,2,0,1]) == [1,4,1,2,0,1]);
|
|
|
|
assert(deduplicate_indexed([8,6,4,6,3], [1,4,3,1,2,2,0,1], closed=true) == [1,4,1,2,0]);
|
2020-03-24 21:51:37 +00:00
|
|
|
}
|
|
|
|
test_deduplicate_indexed();
|
|
|
|
|
|
|
|
|
2019-10-23 00:10:04 +00:00
|
|
|
module test_list_set() {
|
2020-12-31 14:32:47 +00:00
|
|
|
assert_equal(list_set([2,3,4,5], 2, 21), [2,3,21,5]);
|
|
|
|
assert_equal(list_set([2,3,4,5], [1,3], [81,47]), [2,81,4,47]);
|
|
|
|
assert_equal(list_set([2,3,4,5], [2], [21]), [2,3,21,5]);
|
|
|
|
assert_equal(list_set([1,2,3], [], []), [1,2,3]);
|
|
|
|
assert_equal(list_set([1,2,3], [1,5], [4,4]), [1,4,3,0,0,4]);
|
|
|
|
assert_equal(list_set([1,2,3], [1,5], [4,4],dflt=12), [1,4,3,12,12,4]);
|
|
|
|
assert_equal(list_set([1,2,3], [1,2], [4,4],dflt=12, minlen=5), [1,4,4,12,12]);
|
|
|
|
assert_equal(list_set([1,2,3], 1, 4, dflt=12, minlen=5), [1,4,3,12,12]);
|
|
|
|
assert_equal(list_set([1,2,3], [],[],dflt=12, minlen=5), [1,2,3,12,12]);
|
|
|
|
assert_equal(list_set([1,2,3], 5,9), [1,2,3,0,0,9]);
|
|
|
|
assert_equal(list_set([1,2,3], 5,9,dflt=12), [1,2,3,12,12,9]);
|
2019-10-23 00:10:04 +00:00
|
|
|
}
|
|
|
|
test_list_set();
|
|
|
|
|
|
|
|
|
|
|
|
module test_list_remove() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(list_remove([3,6,9,12],1) == [3,9,12]);
|
|
|
|
assert(list_remove([3,6,9,12],[1,3]) == [3,9]);
|
2020-12-31 14:32:47 +00:00
|
|
|
assert(list_remove([3,6,9],[]) == [3,6,9]);
|
|
|
|
assert(list_remove([],[]) == []);
|
2019-10-23 00:10:04 +00:00
|
|
|
}
|
|
|
|
test_list_remove();
|
|
|
|
|
|
|
|
module test_list_remove_values() {
|
2020-05-30 02:04:34 +00:00
|
|
|
animals = ["bat", "cat", "rat", "dog", "bat", "rat"];
|
|
|
|
assert(list_remove_values(animals, "rat") == ["bat","cat","dog","bat","rat"]);
|
|
|
|
assert(list_remove_values(animals, "bat", all=true) == ["cat","rat","dog","rat"]);
|
|
|
|
assert(list_remove_values(animals, ["bat","rat"]) == ["cat","dog","bat","rat"]);
|
|
|
|
assert(list_remove_values(animals, ["bat","rat"], all=true) == ["cat","dog"]);
|
|
|
|
assert(list_remove_values(animals, ["tucan","rat"], all=true) == ["bat","cat","dog","bat"]);
|
2019-10-23 00:10:04 +00:00
|
|
|
}
|
|
|
|
test_list_remove_values();
|
|
|
|
|
|
|
|
|
|
|
|
module test_list_insert() {
|
2020-12-31 14:32:47 +00:00
|
|
|
assert_equal(list_insert([3,6,9,12],1,5),[3,5,6,9,12]);
|
|
|
|
assert_equal(list_insert([3,6,9,12],[1,3],[5,11]),[3,5,6,9,11,12]);
|
|
|
|
assert_equal(list_insert([3],1,4), [3,4]);
|
|
|
|
assert_equal(list_insert([3],[0,1], [1,2]), [1,3,2]);
|
|
|
|
assert_equal(list_insert([1,2,3],[],[]),[1,2,3]);
|
|
|
|
assert_equal(list_insert([], 0, 4),[4]);
|
2019-10-23 00:10:04 +00:00
|
|
|
}
|
|
|
|
test_list_insert();
|
|
|
|
|
|
|
|
|
|
|
|
module test_bselect() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(bselect([3,4,5,6,7], [false,false,false,false,false]) == []);
|
|
|
|
assert(bselect([3,4,5,6,7], [false,true,true,false,true]) == [4,5,7]);
|
|
|
|
assert(bselect([3,4,5,6,7], [true,true,true,true,true]) == [3,4,5,6,7]);
|
2019-10-23 00:10:04 +00:00
|
|
|
}
|
|
|
|
test_bselect();
|
|
|
|
|
|
|
|
|
2019-11-07 07:40:05 +00:00
|
|
|
module test_list_bset() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(list_bset([false,true,false,true,false], [3,4]) == [0,3,0,4,0]);
|
|
|
|
assert(list_bset([false,true,false,true,false], [3,4], dflt=1) == [1,3,1,4,1]);
|
2019-10-23 00:10:04 +00:00
|
|
|
}
|
2019-11-07 07:40:05 +00:00
|
|
|
test_list_bset();
|
2019-10-23 00:10:04 +00:00
|
|
|
|
|
|
|
|
2021-10-17 03:01:52 +00:00
|
|
|
module test_min_length() {
|
|
|
|
assert(min_length(["foobar", "bazquxx", "abcd"]) == 4);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
2021-10-17 03:01:52 +00:00
|
|
|
test_min_length();
|
2019-05-01 06:45:05 +00:00
|
|
|
|
|
|
|
|
2021-10-17 03:01:52 +00:00
|
|
|
module test_max_length() {
|
|
|
|
assert(max_length(["foobar", "bazquxx", "abcd"]) == 7);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
2021-10-17 03:01:52 +00:00
|
|
|
test_max_length();
|
2019-05-01 06:45:05 +00:00
|
|
|
|
|
|
|
|
|
|
|
module test_list_pad() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(list_pad([4,5,6], 5, 8) == [4,5,6,8,8]);
|
|
|
|
assert(list_pad([4,5,6,7,8], 5, 8) == [4,5,6,7,8]);
|
|
|
|
assert(list_pad([4,5,6,7,8,9], 5, 8) == [4,5,6,7,8,9]);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_list_pad();
|
|
|
|
|
|
|
|
|
|
|
|
module test_list_trim() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(list_trim([4,5,6], 5) == [4,5,6]);
|
|
|
|
assert(list_trim([4,5,6,7,8], 5) == [4,5,6,7,8]);
|
|
|
|
assert(list_trim([3,4,5,6,7,8,9], 5) == [3,4,5,6,7]);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_list_trim();
|
|
|
|
|
|
|
|
|
|
|
|
module test_list_fit() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(list_fit([4,5,6], 5, 8) == [4,5,6,8,8]);
|
|
|
|
assert(list_fit([4,5,6,7,8], 5, 8) == [4,5,6,7,8]);
|
|
|
|
assert(list_fit([3,4,5,6,7,8,9], 5, 8) == [3,4,5,6,7]);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_list_fit();
|
|
|
|
|
|
|
|
|
2019-10-23 00:10:04 +00:00
|
|
|
module test_idx() {
|
2020-05-30 02:04:34 +00:00
|
|
|
colors = ["red", "green", "blue", "cyan"];
|
|
|
|
assert([for (i=idx(colors)) i] == [0,1,2,3]);
|
2021-01-25 07:26:39 +00:00
|
|
|
assert([for (i=idx(colors,e=-2)) i] == [0,1,2]);
|
|
|
|
assert([for (i=idx(colors,s=1)) i] == [1,2,3]);
|
|
|
|
assert([for (i=idx(colors,s=1,e=-2)) i] == [1,2]);
|
2019-10-23 00:10:04 +00:00
|
|
|
}
|
|
|
|
test_idx();
|
|
|
|
|
|
|
|
|
2019-05-01 06:45:05 +00:00
|
|
|
module test_enumerate() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(enumerate(["a","b","c"]) == [[0,"a"], [1,"b"], [2,"c"]]);
|
|
|
|
assert(enumerate([[88,"a"],[76,"b"],[21,"c"]], idx=1) == [[0,"a"], [1,"b"], [2,"c"]]);
|
|
|
|
assert(enumerate([["cat","a",12],["dog","b",10],["log","c",14]], idx=[1:2]) == [[0,"a",12], [1,"b",10], [2,"c",14]]);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_enumerate();
|
|
|
|
|
|
|
|
|
2019-11-07 07:40:05 +00:00
|
|
|
module test_shuffle() {
|
2021-04-08 03:57:45 +00:00
|
|
|
nums1 = count(100);
|
2020-12-22 23:15:25 +00:00
|
|
|
nums2 = shuffle(nums1,33);
|
|
|
|
nums3 = shuffle(nums2,99);
|
|
|
|
assert(sort(nums2)==nums1);
|
|
|
|
assert(sort(nums3)==nums1);
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(nums1!=nums2);
|
|
|
|
assert(nums2!=nums3);
|
|
|
|
assert(nums1!=nums3);
|
2020-12-22 23:15:25 +00:00
|
|
|
str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
|
|
|
|
shufstr = shuffle(str,12);
|
|
|
|
assert(shufstr != str && sort(shufstr)==str);
|
2019-11-07 07:40:05 +00:00
|
|
|
}
|
|
|
|
test_shuffle();
|
2019-10-23 00:10:04 +00:00
|
|
|
|
|
|
|
|
2019-05-01 06:45:05 +00:00
|
|
|
module test_sort() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(sort([7,3,9,4,3,1,8]) == [1,3,3,4,7,8,9]);
|
2020-08-30 11:12:36 +00:00
|
|
|
assert(sort([[4,0],[7],[3,9],20,[4],[3,1],[8]]) == [20,[3,1],[3,9],[4],[4,0],[7],[8]]);
|
|
|
|
assert(sort([[4,0],[7],[3,9],20,[4],[3,1],[8]],idx=1) == [[7],20,[4],[8],[4,0],[3,1],[3,9]]);
|
|
|
|
assert(sort([[8,6],[3,1],[9,2],[4,3],[3,4],[1,5],[8,0]]) == [[1,5],[3,1],[3,4],[4,3],[8,0],[8,6],[9,2]]);
|
|
|
|
assert(sort([[8,0],[3,1],[9,2],[4,3],[3,4],[1,5],[8,6]],idx=1) == [[8,0],[3,1],[9,2],[4,3],[3,4],[1,5],[8,6]]);
|
|
|
|
assert(sort(["cat", "oat", "sat", "bat", "vat", "rat", "pat", "mat", "fat", "hat", "eat"])
|
|
|
|
== ["bat", "cat", "eat", "fat", "hat", "mat", "oat", "pat", "rat", "sat", "vat"]);
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(sort(enumerate([[2,3,4],[1,2,3],[2,4,3]]),idx=1)==[[1,[1,2,3]], [0,[2,3,4]], [2,[2,4,3]]]);
|
2020-08-30 11:12:36 +00:00
|
|
|
assert(sort([0,"1",[1,0],2,"a",[1]])== [0,2,"1","a",[1],[1,0]]);
|
|
|
|
assert(sort([["oat",0], ["cat",1], ["bat",3], ["bat",2], ["fat",3]])== [["bat",2],["bat",3],["cat",1],["fat",3],["oat",0]]);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_sort();
|
|
|
|
|
|
|
|
|
|
|
|
module test_sortidx() {
|
2020-08-30 11:12:36 +00:00
|
|
|
lst1 = ["da","bax","eaw","cav"];
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(sortidx(lst1) == [1,3,0,2]);
|
2020-08-30 11:12:36 +00:00
|
|
|
lst5 = [3,5,1,7];
|
|
|
|
assert(sortidx(lst5) == [2,0,1,3]);
|
2020-05-30 02:04:34 +00:00
|
|
|
lst2 = [
|
|
|
|
["foo", 88, [0,0,1], false],
|
|
|
|
["bar", 90, [0,1,0], true],
|
|
|
|
["baz", 89, [1,0,0], false],
|
|
|
|
["qux", 23, [1,1,1], true]
|
|
|
|
];
|
|
|
|
assert(sortidx(lst2, idx=1) == [3,0,2,1]);
|
|
|
|
assert(sortidx(lst2, idx=0) == [1,2,0,3]);
|
|
|
|
assert(sortidx(lst2, idx=[1,3]) == [3,0,2,1]);
|
2020-08-30 11:12:36 +00:00
|
|
|
lst3 = [[-4,0,0],[0,0,-4],[0,-4,0],[-4,0,0],[0,-4,0],[0,0,4],
|
|
|
|
[0,0,-4],[0,4,0],[4,0,0],[0,0,4],[0,4,0],[4,0,0]];
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(sortidx(lst3)==[0,3,2,4,1,6,5,9,7,10,8,11]);
|
2020-08-30 11:12:36 +00:00
|
|
|
assert(sortidx([[4,0],[7],[3,9],20,[4],[3,1],[8]]) == [3,5,2,4,0,1,6]);
|
|
|
|
assert(sortidx([[4,0],[7],[3,9],20,[4],[3,1],[8]],idx=1) == [1,3,4,6,0,5,2]);
|
|
|
|
lst4=[0,"1",[1,0],2,"a",[1]];
|
|
|
|
assert(sortidx(lst4)== [0,3,1,4,5,2]);
|
|
|
|
assert(sortidx(["cat","oat","sat","bat","vat","rat","pat","mat","fat","hat","eat"])
|
|
|
|
== [3,0,10,8,9,7,1,6,5,2,4]);
|
|
|
|
assert(sortidx([["oat",0], ["cat",1], ["bat",3], ["bat",2], ["fat",3]])== [3,2,1,4,0]);
|
|
|
|
assert(sortidx(["Belfry", "OpenScad", "Library", "Documentation"])==[0,3,2,1]);
|
|
|
|
assert(sortidx(["x",1,[],0,"abc",true])==[5,3,1,4,0,2]);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_sortidx();
|
|
|
|
|
2021-06-22 00:13:40 +00:00
|
|
|
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();
|
|
|
|
|
2020-08-30 11:12:36 +00:00
|
|
|
|
2019-05-01 06:45:05 +00:00
|
|
|
module test_unique() {
|
2021-06-22 00:13:40 +00:00
|
|
|
assert_equal(unique([]), []);
|
|
|
|
assert_equal(unique([8]), [8]);
|
|
|
|
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"]);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_unique();
|
|
|
|
|
|
|
|
|
2020-07-03 22:23:03 +00:00
|
|
|
module test_unique_count() {
|
|
|
|
assert_equal(
|
|
|
|
unique_count([3,1,4,1,5,9,2,6,5,3,5,8,9,7,9,3,2,3,6]),
|
|
|
|
[[1,2,3,4,5,6,7,8,9],[2,2,4,1,3,2,1,1,3]]
|
|
|
|
);
|
|
|
|
assert_equal(
|
|
|
|
unique_count(["A","B","R","A","C","A","D","A","B","R","A"]),
|
|
|
|
[["A","B","C","D","R"],[5,2,1,1,2]]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
test_unique_count();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Sets
|
|
|
|
|
|
|
|
module test_set_union() {
|
|
|
|
assert_equal(
|
|
|
|
set_union([2,3,5,7,11], [1,2,3,5,8]),
|
|
|
|
[2,3,5,7,11,1,8]
|
|
|
|
);
|
|
|
|
assert_equal(
|
|
|
|
set_union([2,3,5,7,11], [1,2,3,5,8], get_indices=true),
|
|
|
|
[[5,0,1,2,6],[2,3,5,7,11,1,8]]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
test_set_union();
|
|
|
|
|
|
|
|
|
|
|
|
module test_set_difference() {
|
|
|
|
assert_equal(
|
|
|
|
set_difference([2,3,5,7,11], [1,2,3,5,8]),
|
|
|
|
[7,11]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
test_set_difference();
|
|
|
|
|
|
|
|
|
|
|
|
module test_set_intersection() {
|
|
|
|
assert_equal(
|
|
|
|
set_intersection([2,3,5,7,11], [1,2,3,5,8]),
|
|
|
|
[2,3,5]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
test_set_intersection();
|
|
|
|
|
|
|
|
|
2019-05-01 06:45:05 +00:00
|
|
|
// Arrays
|
|
|
|
|
2020-07-24 21:54:34 +00:00
|
|
|
module test_add_scalar() {
|
|
|
|
assert(add_scalar([1,2,3],3) == [4,5,6]);
|
|
|
|
assert(add_scalar([[1,2,3],[3,4,5]],3) == [[4,5,6],[6,7,8]]);
|
|
|
|
}
|
|
|
|
test_add_scalar();
|
|
|
|
|
|
|
|
|
2020-08-03 23:49:22 +00:00
|
|
|
|
2020-07-03 22:23:03 +00:00
|
|
|
module test_force_list() {
|
|
|
|
assert_equal(force_list([3,4,5]), [3,4,5]);
|
|
|
|
assert_equal(force_list(5), [5]);
|
|
|
|
assert_equal(force_list(7, n=3), [7,7,7]);
|
|
|
|
assert_equal(force_list(4, n=3, fill=1), [4,1,1]);
|
|
|
|
}
|
|
|
|
test_force_list();
|
|
|
|
|
|
|
|
|
2019-05-10 09:59:12 +00:00
|
|
|
module test_pair() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(pair([3,4,5,6]) == [[3,4], [4,5], [5,6]]);
|
|
|
|
assert(pair("ABCD") == [["A","B"], ["B","C"], ["C","D"]]);
|
2021-01-25 07:26:39 +00:00
|
|
|
assert(pair([3,4,5,6],true) == [[3,4], [4,5], [5,6], [6,3]]);
|
|
|
|
assert(pair("ABCD",true) == [["A","B"], ["B","C"], ["C","D"], ["D","A"]]);
|
|
|
|
assert(pair([3,4,5,6],wrap=true) == [[3,4], [4,5], [5,6], [6,3]]);
|
|
|
|
assert(pair("ABCD",wrap=true) == [["A","B"], ["B","C"], ["C","D"], ["D","A"]]);
|
2019-05-10 09:59:12 +00:00
|
|
|
}
|
|
|
|
test_pair();
|
|
|
|
|
|
|
|
|
2019-10-23 00:10:04 +00:00
|
|
|
module test_triplet() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(triplet([3,4,5,6,7]) == [[3,4,5], [4,5,6], [5,6,7]]);
|
|
|
|
assert(triplet("ABCDE") == [["A","B","C"], ["B","C","D"], ["C","D","E"]]);
|
2021-01-25 07:26:39 +00:00
|
|
|
assert(triplet([3,4,5,6],true) == [[3,4,5], [4,5,6], [5,6,3], [6,3,4]]);
|
|
|
|
assert(triplet("ABCD",true) == [["A","B","C"], ["B","C","D"], ["C","D","A"], ["D","A","B"]]);
|
|
|
|
assert(triplet([3,4,5,6],wrap=true) == [[3,4,5], [4,5,6], [5,6,3], [6,3,4]]);
|
|
|
|
assert(triplet("ABCD",wrap=true) == [["A","B","C"], ["B","C","D"], ["C","D","A"], ["D","A","B"]]);
|
2019-10-23 00:10:04 +00:00
|
|
|
}
|
|
|
|
test_triplet();
|
|
|
|
|
|
|
|
|
2021-03-10 22:49:39 +00:00
|
|
|
module test_combinations() {
|
|
|
|
assert(combinations([3,4,5,6]) == [[3,4],[3,5],[3,6],[4,5],[4,6],[5,6]]);
|
|
|
|
assert(combinations([3,4,5,6],n=3) == [[3,4,5],[3,4,6],[3,5,6],[4,5,6]]);
|
2020-01-16 21:01:41 +00:00
|
|
|
}
|
2021-03-10 22:49:39 +00:00
|
|
|
test_combinations();
|
2020-01-16 21:01:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
module test_repeat_entries() {
|
2020-05-30 02:04:34 +00:00
|
|
|
list = [0,1,2,3];
|
|
|
|
assert(repeat_entries(list, 6) == [0,0,1,2,2,3]);
|
|
|
|
assert(repeat_entries(list, 6, exact=false) == [0,0,1,1,2,2,3,3]);
|
|
|
|
assert(repeat_entries(list, [1,1,2,1], exact=false) == [0,1,2,2,3]);
|
2020-01-16 21:01:41 +00:00
|
|
|
}
|
|
|
|
test_repeat_entries();
|
|
|
|
|
|
|
|
|
2019-05-10 09:59:12 +00:00
|
|
|
module test_zip() {
|
2020-05-30 02:04:34 +00:00
|
|
|
v1 = [1,2,3,4];
|
|
|
|
v2 = [5,6,7];
|
|
|
|
v3 = [8,9,10,11];
|
|
|
|
assert(zip(v1,v3) == [[1,8],[2,9],[3,10],[4,11]]);
|
|
|
|
assert(zip([v1,v3]) == [[1,8],[2,9],[3,10],[4,11]]);
|
2019-05-10 09:59:12 +00:00
|
|
|
}
|
2021-10-26 20:45:14 +00:00
|
|
|
test_zip();
|
2020-09-01 20:42:47 +00:00
|
|
|
|
2019-05-01 06:45:05 +00:00
|
|
|
|
|
|
|
module test_array_group() {
|
2020-05-30 02:04:34 +00:00
|
|
|
v = [1,2,3,4,5,6];
|
|
|
|
assert(array_group(v,2) == [[1,2], [3,4], [5,6]]);
|
|
|
|
assert(array_group(v,3) == [[1,2,3], [4,5,6]]);
|
|
|
|
assert(array_group(v,4,0) == [[1,2,3,4], [5,6,0,0]]);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_array_group();
|
|
|
|
|
|
|
|
|
2021-07-01 02:57:03 +00:00
|
|
|
module test_group_data() {
|
|
|
|
assert_equal(group_data([1,2,0], ["A","B","C"]), [["C"],["A"],["B"]]);
|
|
|
|
assert_equal(group_data([1,3,0], ["A","B","C"]), [["C"],["A"],[],["B"]]);
|
|
|
|
assert_equal(group_data([5,3,1], ["A","B","C"]), [[],["C"],[],["B"],[],["A"]]);
|
|
|
|
assert_equal(group_data([1,3,1], ["A","B","C"]), [[],["A","C"],[],["B"]]);
|
|
|
|
}
|
|
|
|
test_group_data();
|
|
|
|
|
|
|
|
|
2019-05-01 06:45:05 +00:00
|
|
|
module test_flatten() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(flatten([[1,2,3], [4,5,[6,7,8]]]) == [1,2,3,4,5,[6,7,8]]);
|
2020-07-28 18:02:35 +00:00
|
|
|
assert(flatten([]) == []);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_flatten();
|
|
|
|
|
|
|
|
|
2020-07-28 18:02:35 +00:00
|
|
|
module test_full_flatten() {
|
|
|
|
assert(full_flatten([[1,2,3], [4,5,[6,[7],8]]]) == [1,2,3,4,5,6,7,8]);
|
|
|
|
assert(full_flatten([]) == []);
|
|
|
|
}
|
|
|
|
test_full_flatten();
|
|
|
|
|
|
|
|
|
2019-05-01 06:45:05 +00:00
|
|
|
module test_array_dim() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(array_dim([[[1,2,3],[4,5,6]],[[7,8,9],[10,11,12]]]) == [2,2,3]);
|
|
|
|
assert(array_dim([[[1,2,3],[4,5,6]],[[7,8,9],[10,11,12]]], 0) == 2);
|
|
|
|
assert(array_dim([[[1,2,3],[4,5,6]],[[7,8,9],[10,11,12]]], 2) == 3);
|
|
|
|
assert(array_dim([[[1,2,3],[4,5,6]],[[7,8,9]]]) == [2,undef,3]);
|
2020-08-30 11:12:36 +00:00
|
|
|
assert(array_dim([1,2,3,4,5,6,7,8,9]) == [9]);
|
|
|
|
assert(array_dim([[1],[2],[3],[4],[5],[6],[7],[8],[9]]) == [9,1]);
|
|
|
|
assert(array_dim([]) == [0]);
|
|
|
|
assert(array_dim([[]]) == [1,0]);
|
|
|
|
assert(array_dim([[],[]]) == [2,0]);
|
|
|
|
assert(array_dim([[],[1]]) == [2,undef]);
|
2019-05-01 06:45:05 +00:00
|
|
|
}
|
|
|
|
test_array_dim();
|
|
|
|
|
|
|
|
|
2020-05-30 02:04:34 +00:00
|
|
|
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|