2020-07-22 00:05:21 +00:00
|
|
|
include <../std.scad>
|
2019-11-06 02:16:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
module test_is_edge_array() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(is_edge_array([[0,0,0,0],[0,0,0,0],[0,0,0,0]]));
|
|
|
|
assert(is_edge_array([[1,1,1,1],[1,1,1,1],[1,1,1,1]]));
|
|
|
|
assert(!is_edge_array([[1,1,1],[1,1,1],[1,1,1]]));
|
|
|
|
assert(!is_edge_array([[1,1,1,1,1],[1,1,1,1,1],[1,1,1,1,1]]));
|
|
|
|
assert(!is_edge_array([[1,1,1,1],[1,1,1,1]]));
|
|
|
|
assert(!is_edge_array([1,1,1,1]));
|
|
|
|
assert(!is_edge_array("foo"));
|
|
|
|
assert(!is_edge_array(42));
|
|
|
|
assert(!is_edge_array(true));
|
|
|
|
assert(is_edge_array(edges(["X","Y"])));
|
2019-11-06 02:16:00 +00:00
|
|
|
}
|
|
|
|
test_is_edge_array();
|
|
|
|
|
|
|
|
|
2019-11-12 22:14:15 +00:00
|
|
|
module test__edge_set() {
|
2020-05-30 02:04:34 +00:00
|
|
|
// Edge set pass through
|
|
|
|
assert(_edge_set([[1,1,1,1],[0,1,0,1],[0,0,0,0]]) == [[1,1,1,1],[0,1,0,1],[0,0,0,0]]);
|
|
|
|
|
|
|
|
// Vectors towards corners
|
|
|
|
assert(_edge_set([-1,-1,-1]) == [[1,0,0,0],[1,0,0,0],[1,0,0,0]]);
|
|
|
|
assert(_edge_set([-1,-1, 1]) == [[0,0,1,0],[0,0,1,0],[1,0,0,0]]);
|
|
|
|
assert(_edge_set([-1, 1,-1]) == [[0,1,0,0],[1,0,0,0],[0,0,1,0]]);
|
|
|
|
assert(_edge_set([-1, 1, 1]) == [[0,0,0,1],[0,0,1,0],[0,0,1,0]]);
|
|
|
|
assert(_edge_set([ 1,-1,-1]) == [[1,0,0,0],[0,1,0,0],[0,1,0,0]]);
|
|
|
|
assert(_edge_set([ 1,-1, 1]) == [[0,0,1,0],[0,0,0,1],[0,1,0,0]]);
|
|
|
|
assert(_edge_set([ 1, 1,-1]) == [[0,1,0,0],[0,1,0,0],[0,0,0,1]]);
|
|
|
|
assert(_edge_set([ 1, 1, 1]) == [[0,0,0,1],[0,0,0,1],[0,0,0,1]]);
|
|
|
|
|
|
|
|
// Vectors towards edges
|
|
|
|
assert(_edge_set([ 0,-1,-1]) == [[1,0,0,0],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(_edge_set([ 0, 1,-1]) == [[0,1,0,0],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(_edge_set([ 0,-1, 1]) == [[0,0,1,0],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(_edge_set([ 0, 1, 1]) == [[0,0,0,1],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(_edge_set([-1, 0,-1]) == [[0,0,0,0],[1,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(_edge_set([ 1, 0,-1]) == [[0,0,0,0],[0,1,0,0],[0,0,0,0]]);
|
|
|
|
assert(_edge_set([-1, 0, 1]) == [[0,0,0,0],[0,0,1,0],[0,0,0,0]]);
|
|
|
|
assert(_edge_set([ 1, 0, 1]) == [[0,0,0,0],[0,0,0,1],[0,0,0,0]]);
|
|
|
|
assert(_edge_set([-1,-1, 0]) == [[0,0,0,0],[0,0,0,0],[1,0,0,0]]);
|
|
|
|
assert(_edge_set([ 1,-1, 0]) == [[0,0,0,0],[0,0,0,0],[0,1,0,0]]);
|
|
|
|
assert(_edge_set([-1, 1, 0]) == [[0,0,0,0],[0,0,0,0],[0,0,1,0]]);
|
|
|
|
assert(_edge_set([ 1, 1, 0]) == [[0,0,0,0],[0,0,0,0],[0,0,0,1]]);
|
|
|
|
|
|
|
|
// Vectors towards faces
|
|
|
|
assert(_edge_set([ 0, 0,-1]) == [[1,1,0,0],[1,1,0,0],[0,0,0,0]]);
|
|
|
|
assert(_edge_set([ 0, 0, 1]) == [[0,0,1,1],[0,0,1,1],[0,0,0,0]]);
|
|
|
|
assert(_edge_set([ 0,-1, 0]) == [[1,0,1,0],[0,0,0,0],[1,1,0,0]]);
|
|
|
|
assert(_edge_set([ 0, 1, 0]) == [[0,1,0,1],[0,0,0,0],[0,0,1,1]]);
|
|
|
|
assert(_edge_set([-1, 0, 0]) == [[0,0,0,0],[1,0,1,0],[1,0,1,0]]);
|
|
|
|
assert(_edge_set([ 1, 0, 0]) == [[0,0,0,0],[0,1,0,1],[0,1,0,1]]);
|
|
|
|
|
|
|
|
// Named edge sets
|
|
|
|
assert(_edge_set("X") == [[1,1,1,1],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(_edge_set("Y") == [[0,0,0,0],[1,1,1,1],[0,0,0,0]]);
|
|
|
|
assert(_edge_set("Z") == [[0,0,0,0],[0,0,0,0],[1,1,1,1]]);
|
|
|
|
assert(_edge_set("NONE") == [[0,0,0,0],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(_edge_set("ALL") == [[1,1,1,1],[1,1,1,1],[1,1,1,1]]);
|
2019-11-06 02:16:00 +00:00
|
|
|
}
|
2019-11-12 22:14:15 +00:00
|
|
|
test__edge_set();
|
2019-11-06 02:16:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
module test_normalize_edges() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(normalize_edges([[-2,-2,-2,-2],[-2,-2,-2,-2],[-2,-2,-2,-2]]) == [[0,0,0,0],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(normalize_edges([[-1,-1,-1,-1],[-1,-1,-1,-1],[-1,-1,-1,-1]]) == [[0,0,0,0],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(normalize_edges([[0,0,0,0],[0,0,0,0],[0,0,0,0]]) == [[0,0,0,0],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(normalize_edges([[1,1,1,1],[1,1,1,1],[1,1,1,1]]) == [[1,1,1,1],[1,1,1,1],[1,1,1,1]]);
|
|
|
|
assert(normalize_edges([[2,2,2,2],[2,2,2,2],[2,2,2,2]]) == [[1,1,1,1],[1,1,1,1],[1,1,1,1]]);
|
2019-11-06 02:16:00 +00:00
|
|
|
}
|
|
|
|
test_normalize_edges();
|
|
|
|
|
|
|
|
|
|
|
|
module test_edges() {
|
2020-05-30 02:04:34 +00:00
|
|
|
assert(edges("X")==[[1,1,1,1],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(edges("Y")==[[0,0,0,0],[1,1,1,1],[0,0,0,0]]);
|
|
|
|
assert(edges("Z")==[[0,0,0,0],[0,0,0,0],[1,1,1,1]]);
|
|
|
|
assert(edges(["X"])==[[1,1,1,1],[0,0,0,0],[0,0,0,0]]);
|
|
|
|
assert(edges(["Y"])==[[0,0,0,0],[1,1,1,1],[0,0,0,0]]);
|
|
|
|
assert(edges(["Z"])==[[0,0,0,0],[0,0,0,0],[1,1,1,1]]);
|
|
|
|
assert(edges(["X","Y"])==[[1,1,1,1],[1,1,1,1],[0,0,0,0]]);
|
|
|
|
assert(edges(["X","Z"])==[[1,1,1,1],[0,0,0,0],[1,1,1,1]]);
|
|
|
|
assert(edges(["Y","Z"])==[[0,0,0,0],[1,1,1,1],[1,1,1,1]]);
|
|
|
|
assert(edges("ALL",except="X")==[[0,0,0,0],[1,1,1,1],[1,1,1,1]]);
|
|
|
|
assert(edges("ALL",except="Y")==[[1,1,1,1],[0,0,0,0],[1,1,1,1]]);
|
|
|
|
assert(edges("ALL",except="Z")==[[1,1,1,1],[1,1,1,1],[0,0,0,0]]);
|
|
|
|
assert(edges(["Y","Z"],except=[FRONT+RIGHT,FRONT+LEFT])==[[0,0,0,0],[1,1,1,1],[0,0,1,1]]);
|
2019-11-06 02:16:00 +00:00
|
|
|
}
|
|
|
|
test_edges();
|
|
|
|
|
|
|
|
|
|
|
|
module test_corner_edge_count() {
|
2020-05-30 02:04:34 +00:00
|
|
|
edges = edges([TOP,FRONT+RIGHT]);
|
|
|
|
assert(corner_edge_count(edges,TOP+FRONT+RIGHT) == 3);
|
|
|
|
assert(corner_edge_count(edges,TOP+FRONT+LEFT) == 2);
|
|
|
|
assert(corner_edge_count(edges,BOTTOM+FRONT+RIGHT) == 1);
|
|
|
|
assert(corner_edge_count(edges,BOTTOM+FRONT+LEFT) == 0);
|
2019-11-06 02:16:00 +00:00
|
|
|
}
|
|
|
|
test_corner_edge_count();
|
|
|
|
|
|
|
|
|
2020-09-23 03:33:50 +00:00
|
|
|
module test_corner_edges() {
|
|
|
|
edges = edges([TOP,FRONT+RIGHT]);
|
|
|
|
assert_equal(corner_edges(edges,TOP+FRONT+RIGHT), [1,1,1]);
|
|
|
|
assert_equal(corner_edges(edges,TOP+FRONT+LEFT), [1,1,0]);
|
|
|
|
assert_equal(corner_edges(edges,BOTTOM+FRONT+RIGHT), [0,0,1]);
|
|
|
|
assert_equal(corner_edges(edges,BOTTOM+FRONT+LEFT), [0,0,0]);
|
|
|
|
}
|
|
|
|
test_corner_edges();
|
|
|
|
|
|
|
|
|
|
|
|
module test_corners() {
|
|
|
|
assert_equal(corners(BOT + FRONT + LEFT ), [1,0,0,0,0,0,0,0]);
|
|
|
|
assert_equal(corners(BOT + FRONT + RIGHT), [0,1,0,0,0,0,0,0]);
|
|
|
|
assert_equal(corners(BOT + BACK + LEFT ), [0,0,1,0,0,0,0,0]);
|
|
|
|
assert_equal(corners(BOT + BACK + RIGHT), [0,0,0,1,0,0,0,0]);
|
|
|
|
assert_equal(corners(TOP + FRONT + LEFT ), [0,0,0,0,1,0,0,0]);
|
|
|
|
assert_equal(corners(TOP + FRONT + RIGHT), [0,0,0,0,0,1,0,0]);
|
|
|
|
assert_equal(corners(TOP + BACK + LEFT ), [0,0,0,0,0,0,1,0]);
|
|
|
|
assert_equal(corners(TOP + BACK + RIGHT), [0,0,0,0,0,0,0,1]);
|
|
|
|
|
|
|
|
assert_equal(corners(BOT + FRONT), [1,1,0,0,0,0,0,0]);
|
|
|
|
assert_equal(corners(BOT + BACK ), [0,0,1,1,0,0,0,0]);
|
|
|
|
assert_equal(corners(TOP + FRONT), [0,0,0,0,1,1,0,0]);
|
|
|
|
assert_equal(corners(TOP + BACK ), [0,0,0,0,0,0,1,1]);
|
|
|
|
assert_equal(corners(BOT + LEFT ), [1,0,1,0,0,0,0,0]);
|
|
|
|
assert_equal(corners(BOT + RIGHT), [0,1,0,1,0,0,0,0]);
|
|
|
|
assert_equal(corners(TOP + LEFT ), [0,0,0,0,1,0,1,0]);
|
|
|
|
assert_equal(corners(TOP + RIGHT), [0,0,0,0,0,1,0,1]);
|
|
|
|
assert_equal(corners(FRONT + LEFT ), [1,0,0,0,1,0,0,0]);
|
|
|
|
assert_equal(corners(FRONT + RIGHT), [0,1,0,0,0,1,0,0]);
|
|
|
|
assert_equal(corners(BACK + LEFT ), [0,0,1,0,0,0,1,0]);
|
|
|
|
assert_equal(corners(BACK + RIGHT), [0,0,0,1,0,0,0,1]);
|
|
|
|
|
|
|
|
assert_equal(corners(LEFT), [1,0,1,0,1,0,1,0]);
|
|
|
|
assert_equal(corners(RIGHT), [0,1,0,1,0,1,0,1]);
|
|
|
|
assert_equal(corners(FRONT), [1,1,0,0,1,1,0,0]);
|
|
|
|
assert_equal(corners(BACK), [0,0,1,1,0,0,1,1]);
|
|
|
|
assert_equal(corners(BOT), [1,1,1,1,0,0,0,0]);
|
|
|
|
assert_equal(corners(TOP), [0,0,0,0,1,1,1,1]);
|
|
|
|
|
|
|
|
assert_equal(corners([BOT + FRONT + LEFT ]), [1,0,0,0,0,0,0,0]);
|
|
|
|
assert_equal(corners([BOT + FRONT + RIGHT]), [0,1,0,0,0,0,0,0]);
|
|
|
|
assert_equal(corners([BOT + BACK + LEFT ]), [0,0,1,0,0,0,0,0]);
|
|
|
|
assert_equal(corners([BOT + BACK + RIGHT]), [0,0,0,1,0,0,0,0]);
|
|
|
|
assert_equal(corners([TOP + FRONT + LEFT ]), [0,0,0,0,1,0,0,0]);
|
|
|
|
assert_equal(corners([TOP + FRONT + RIGHT]), [0,0,0,0,0,1,0,0]);
|
|
|
|
assert_equal(corners([TOP + BACK + LEFT ]), [0,0,0,0,0,0,1,0]);
|
|
|
|
assert_equal(corners([TOP + BACK + RIGHT]), [0,0,0,0,0,0,0,1]);
|
|
|
|
|
|
|
|
assert_equal(corners([BOT + FRONT]), [1,1,0,0,0,0,0,0]);
|
|
|
|
assert_equal(corners([BOT + BACK ]), [0,0,1,1,0,0,0,0]);
|
|
|
|
assert_equal(corners([TOP + FRONT]), [0,0,0,0,1,1,0,0]);
|
|
|
|
assert_equal(corners([TOP + BACK ]), [0,0,0,0,0,0,1,1]);
|
|
|
|
assert_equal(corners([BOT + LEFT ]), [1,0,1,0,0,0,0,0]);
|
|
|
|
assert_equal(corners([BOT + RIGHT]), [0,1,0,1,0,0,0,0]);
|
|
|
|
assert_equal(corners([TOP + LEFT ]), [0,0,0,0,1,0,1,0]);
|
|
|
|
assert_equal(corners([TOP + RIGHT]), [0,0,0,0,0,1,0,1]);
|
|
|
|
assert_equal(corners([FRONT + LEFT ]), [1,0,0,0,1,0,0,0]);
|
|
|
|
assert_equal(corners([FRONT + RIGHT]), [0,1,0,0,0,1,0,0]);
|
|
|
|
assert_equal(corners([BACK + LEFT ]), [0,0,1,0,0,0,1,0]);
|
|
|
|
assert_equal(corners([BACK + RIGHT]), [0,0,0,1,0,0,0,1]);
|
|
|
|
|
|
|
|
assert_equal(corners([LEFT]), [1,0,1,0,1,0,1,0]);
|
|
|
|
assert_equal(corners([RIGHT]), [0,1,0,1,0,1,0,1]);
|
|
|
|
assert_equal(corners([FRONT]), [1,1,0,0,1,1,0,0]);
|
|
|
|
assert_equal(corners([BACK]), [0,0,1,1,0,0,1,1]);
|
|
|
|
assert_equal(corners([BOT]), [1,1,1,1,0,0,0,0]);
|
|
|
|
assert_equal(corners([TOP]), [0,0,0,0,1,1,1,1]);
|
|
|
|
|
|
|
|
assert_equal(corners([TOP,FRONT+RIGHT]), [0,1,0,0,1,1,1,1]);
|
|
|
|
}
|
|
|
|
test_corners();
|
|
|
|
|
|
|
|
|
|
|
|
module test_is_corner_array() {
|
|
|
|
edges = edges([TOP,FRONT+RIGHT]);
|
|
|
|
corners = corners([TOP,FRONT+RIGHT]);
|
|
|
|
assert(!is_corner_array(undef));
|
|
|
|
assert(!is_corner_array(true));
|
|
|
|
assert(!is_corner_array(false));
|
|
|
|
assert(!is_corner_array(INF));
|
|
|
|
assert(!is_corner_array(-INF));
|
|
|
|
assert(!is_corner_array(NAN));
|
|
|
|
assert(!is_corner_array(-4));
|
|
|
|
assert(!is_corner_array(0));
|
|
|
|
assert(!is_corner_array(4));
|
|
|
|
assert(!is_corner_array("foo"));
|
|
|
|
assert(!is_corner_array([]));
|
|
|
|
assert(!is_corner_array([4,5,6]));
|
|
|
|
assert(!is_corner_array([2:3:9]));
|
|
|
|
assert(!is_corner_array(edges));
|
|
|
|
assert(is_corner_array(corners));
|
|
|
|
}
|
|
|
|
test_is_corner_array();
|
|
|
|
|
|
|
|
|
|
|
|
module test_normalize_corners() {
|
|
|
|
assert_equal(normalize_corners([-2,-2,-2,-2,-2,-2,-2,-2]), [0,0,0,0,0,0,0,0]);
|
|
|
|
assert_equal(normalize_corners([-1,-1,-1,-1,-1,-1,-1,-1]), [0,0,0,0,0,0,0,0]);
|
|
|
|
assert_equal(normalize_corners([0,0,0,0,0,0,0,0]), [0,0,0,0,0,0,0,0]);
|
|
|
|
assert_equal(normalize_corners([1,1,1,1,1,1,1,1]), [1,1,1,1,1,1,1,1]);
|
|
|
|
assert_equal(normalize_corners([2,2,2,2,2,2,2,2]), [1,1,1,1,1,1,1,1]);
|
|
|
|
}
|
|
|
|
test_normalize_corners();
|
|
|
|
|
|
|
|
|
2019-11-06 02:16:00 +00:00
|
|
|
|
2020-05-30 02:04:34 +00:00
|
|
|
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|