include <../std.scad> seed = floor(rands(0,10000,1)[0]); module test_is_vector() { assert(is_vector([1,2,3]) == true); assert(is_vector([[1,2,3]]) == false); assert(is_vector([[1,2,3,4],[5,6,7,8]]) == false); assert(is_vector([[1,2,3,4],[5,6]]) == false); assert(is_vector(["foo"]) == false); assert(is_vector([]) == false); assert(is_vector(1) == false); assert(is_vector("foo") == false); assert(is_vector(true) == false); assert(is_vector([3,4,"foo"]) == false); assert(is_vector([3,4,[4,5]]) == false); assert(is_vector([3,4,undef]) == false); assert(is_vector(["foo","bar"]) == false); assert(is_vector([0,0,0],zero=true) == true); assert(is_vector([0,0,0],zero=false) == false); assert(is_vector([0,1,0],zero=true) == false); assert(is_vector([0,0,1],zero=false) == true); assert(is_vector([1,1,1],zero=false) == true); assert(is_vector([0,0,0],all_nonzero=true) == false); assert(is_vector([0,1,0],all_nonzero=true) == false); assert(is_vector([0,0,1],all_nonzero=true) == false); assert(is_vector([1,1,1],all_nonzero=true) == true); assert(is_vector([-1,1,1],all_nonzero=true) == true); assert(is_vector([-1,-1,-1],all_nonzero=true) == true); } test_is_vector(); module test_v_floor() { assert_equal(v_floor([2.0, 3.14, 18.9, 7]), [2,3,18,7]); assert_equal(v_floor([-2.0, -3.14, -18.9, -7]), [-2,-4,-19,-7]); } test_v_floor(); module test_v_ceil() { assert_equal(v_ceil([2.0, 3.14, 18.9, 7]), [2,4,19,7]); assert_equal(v_ceil([-2.0, -3.14, -18.9, -7]), [-2,-3,-18,-7]); } test_v_ceil(); module test_v_lookup() { lup = [[4, [3,4,5]], [5, [5,6,7]], [6, [4,5,6]]]; assert_equal(v_lookup(3,lup), [3,4,5]); assert_equal(v_lookup(3.5,lup), [3,4,5]); assert_equal(v_lookup(4,lup), [3,4,5]); assert_approx(v_lookup(4.2,lup), [3.4,4.4,5.4]); assert_equal(v_lookup(4.5,lup), [4,5,6]); assert_equal(v_lookup(5,lup), [5,6,7]); assert_approx(v_lookup(5.2,lup), [4.8,5.8,6.8]); assert_equal(v_lookup(5.5,lup), [4.5,5.5,6.5]); assert_equal(v_lookup(6,lup), [4,5,6]); assert_equal(v_lookup(6.5,lup), [4,5,6]); assert_equal(v_lookup(7,lup), [4,5,6]); } test_v_lookup(); module test_v_mul() { assert_equal(v_mul([3,4,5], [8,7,6]), [24,28,30]); assert_equal(v_mul([1,2,3], [4,5,6]), [4,10,18]); assert_equal(v_mul([[1,2,3],[4,5,6],[7,8,9]], [[4,5,6],[3,2,1],[5,9,3]]), [32,28,134]); } test_v_mul(); module test_v_div() { assert(v_div([24,28,30], [8,7,6]) == [3, 4, 5]); } test_v_div(); module test_v_abs() { assert(v_abs([2,4,8]) == [2,4,8]); assert(v_abs([-2,-4,-8]) == [2,4,8]); assert(v_abs([-2,4,8]) == [2,4,8]); assert(v_abs([2,-4,8]) == [2,4,8]); assert(v_abs([2,4,-8]) == [2,4,8]); } test_v_abs(); include <../strings.scad> module test_v_theta() { assert_approx(v_theta([0,0]), 0); assert_approx(v_theta([1,0]), 0); assert_approx(v_theta([0,1]), 90); assert_approx(v_theta([-1,0]), 180); assert_approx(v_theta([0,-1]), -90); assert_approx(v_theta([1,1]), 45); assert_approx(v_theta([-1,1]), 135); assert_approx(v_theta([1,-1]), -45); assert_approx(v_theta([-1,-1]), -135); assert_approx(v_theta([0,0,1]), 0); assert_approx(v_theta([0,1,1]), 90); assert_approx(v_theta([0,1,-1]), 90); assert_approx(v_theta([1,0,0]), 0); assert_approx(v_theta([0,1,0]), 90); assert_approx(v_theta([0,-1,0]), -90); assert_approx(v_theta([-1,0,0]), 180); assert_approx(v_theta([1,0,1]), 0); assert_approx(v_theta([0,1,1]), 90); assert_approx(v_theta([0,-1,1]), -90); assert_approx(v_theta([1,1,1]), 45); } test_v_theta(); module test_unit() { assert(unit([10,0,0]) == [1,0,0]); assert(unit([0,10,0]) == [0,1,0]); assert(unit([0,0,10]) == [0,0,1]); assert(abs(norm(unit([10,10,10]))-1) < EPSILON); assert(abs(norm(unit([-10,-10,-10]))-1) < EPSILON); assert(abs(norm(unit([-10,0,0]))-1) < EPSILON); assert(abs(norm(unit([0,-10,0]))-1) < EPSILON); assert(abs(norm(unit([0,0,-10]))-1) < EPSILON); } test_unit(); module test_vector_angle() { vecs = [[10,0,0], [-10,0,0], [0,10,0], [0,-10,0], [0,0,10], [0,0,-10]]; for (a=vecs, b=vecs) { if(a==b) { assert(vector_angle(a,b)==0); assert(vector_angle([a,b])==0); } else if(a==-b) { assert(vector_angle(a,b)==180); assert(vector_angle([a,b])==180); } else { assert(vector_angle(a,b)==90); assert(vector_angle([a,b])==90); } } assert(abs(vector_angle([10,10,0],[10,0,0])-45) < EPSILON); assert(abs(vector_angle([[10,10,0],[10,0,0]])-45) < EPSILON); assert(abs(vector_angle([11,11,1],[1,1,1],[11,-9,1])-90) < EPSILON); assert(abs(vector_angle([[11,11,1],[1,1,1],[11,-9,1]])-90) < EPSILON); } test_vector_angle(); module test_vector_axis() { assert(norm(vector_axis([10,0,0],[10,10,0]) - [0,0,1]) < EPSILON); assert(norm(vector_axis([[10,0,0],[10,10,0]]) - [0,0,1]) < EPSILON); assert(norm(vector_axis([10,0,0],[0,10,0]) - [0,0,1]) < EPSILON); assert(norm(vector_axis([[10,0,0],[0,10,0]]) - [0,0,1]) < EPSILON); assert(norm(vector_axis([0,10,0],[10,0,0]) - [0,0,-1]) < EPSILON); assert(norm(vector_axis([[0,10,0],[10,0,0]]) - [0,0,-1]) < EPSILON); assert(norm(vector_axis([0,0,10],[10,0,0]) - [0,1,0]) < EPSILON); assert(norm(vector_axis([[0,0,10],[10,0,0]]) - [0,1,0]) < EPSILON); assert(norm(vector_axis([10,0,0],[0,0,10]) - [0,-1,0]) < EPSILON); assert(norm(vector_axis([[10,0,0],[0,0,10]]) - [0,-1,0]) < EPSILON); assert(norm(vector_axis([10,0,10],[0,-10,0]) - [sin(45),0,-sin(45)]) < EPSILON); assert(norm(vector_axis([[10,0,10],[0,-10,0]]) - [sin(45),0,-sin(45)]) < EPSILON); assert(norm(vector_axis([11,1,11],[1,1,1],[1,-9,1]) - [sin(45),0,-sin(45)]) < EPSILON); assert(norm(vector_axis([[11,1,11],[1,1,1],[1,-9,1]]) - [sin(45),0,-sin(45)]) < EPSILON); } test_vector_axis(); module test_vector_search(){ points = [for(i=[0:9], j=[0:9], k=[1:5]) [i,j,k] ]; ind = vector_search([5,5,1],1,points); assert(ind== [225, 270, 275, 276, 280, 325]); assert([for(i=ind) if(norm(points[i]-[5,5,1])>1) i ]==[]); assert([for(i=idx(points)) if(norm(points[i]-[5,5,1])<=1) i]==sort(ind)); } test_vector_search(); module test_vector_search_tree(){ points1 = [ [0,1,2], [1,2,3], [2,3,4] ]; tree1 = vector_search_tree(points1); assert(tree1 == points1); points2 = [for(i=[0:9], j=[0:9], k=[1:5]) [i,j,k] ]; tree2 = vector_search_tree(points2); assert(tree2[0]==points2); ind = vector_search([5,5,1],1,tree2); assert(ind== [225, 270, 275, 276, 280, 325]); rpts = array_group(rands(0,10,50*3,seed=seed),3); rtree = vector_search_tree(rpts); radius = 3; found0 = vector_search([0,0,0],radius,rpts); found1 = vector_search([0,0,0],radius,rtree); found2 = [for(i=idx(rpts)) if(norm(rpts[i])<=radius) i]; assert(sort(found0)==sort(found1), str("Seed = ",seed)); assert(sort(found1)==sort(found2), str("Seed = ",seed)); } test_vector_search_tree(); module test_vector_nearest(){ points = [for(i=[0:9], j=[0:9], k=[1:5]) [i,j,k] ]; ind1 = vector_nearest([5,5,1], 4, points); assert(ind1==[275, 225, 270, 276]); pts = array_group(rands(0,10,50*3,seed=seed),3); tree = vector_search_tree(pts); nearest = vector_nearest([0,0,0], 4, tree); closest = select(sortidx([for(p=pts) norm(p)]), [0:3]); assert(closest==nearest,str("Seed = ",seed)); } test_vector_nearest(); module test_min_index() { assert(min_index([5,3,9,6,2,7,8,2,1])==8); assert(min_index([5,3,9,6,2,7,8,2,7],all=true)==[4,7]); } test_min_index(); module test_max_index() { assert(max_index([5,3,9,6,2,7,8,9,1])==2); assert(max_index([5,3,9,6,2,7,8,9,7],all=true)==[2,7]); } test_max_index(); module test_pointlist_bounds() { pts = [ [-53,27,12], [-63,97,36], [84,-32,-5], [63,-24,42], [23,57,-42] ]; assert(pointlist_bounds(pts) == [[-63,-32,-42], [84,97,42]]); pts2d = [ [-53,12], [-63,36], [84,-5], [63,42], [23,-42] ]; assert(pointlist_bounds(pts2d) == [[-63,-42],[84,42]]); pts5d = [ [-53, 27, 12,-53, 12], [-63, 97, 36,-63, 36], [ 84,-32, -5, 84, -5], [ 63,-24, 42, 63, 42], [ 23, 57,-42, 23,-42] ]; assert(pointlist_bounds(pts5d) == [[-63,-32,-42,-63,-42],[84,97,42,84,42]]); assert(pointlist_bounds([[3,4,5,6]]), [[3,4,5,6],[3,4,5,6]]); } test_pointlist_bounds(); module test_closest_point() { ptlist = [for (i=count(100)) rands(-100,100,2,seed_value=8463+i)]; testpts = [for (i=count(100)) rands(-100,100,2,seed_value=6834+i)]; for (pt = testpts) { pidx = closest_point(pt,ptlist); dists = [for (p=ptlist) norm(pt-p)]; mindist = min(dists); assert(mindist == dists[pidx]); } } test_closest_point(); module test_furthest_point() { ptlist = [for (i=count(100)) rands(-100,100,2,seed_value=8463+i)]; testpts = [for (i=count(100)) rands(-100,100,2,seed_value=6834+i)]; for (pt = testpts) { pidx = furthest_point(pt,ptlist); dists = [for (p=ptlist) norm(pt-p)]; mindist = max(dists); assert(mindist == dists[pidx]); } } test_furthest_point(); // vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap