Mercurial > repos > public > sbplib
view +grid/CartesianTest.m @ 154:c7b2f645101f feature/grids
Added classes and functions for Cartesian and equidistant grids.
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Thu, 18 Feb 2016 16:46:02 +0100 |
parents | |
children | ba1ae5b2c45e |
line wrap: on
line source
function tests = CartesianTest() tests = functiontests(localfunctions); end function testWarningEmptyGrid(testCase) in = { {[]}, {[],[1]}, {[1],[2], []}, }; for i = 1:length(in) testCase.verifyError(@()grid.Cartesian(in{i}{:}),'grid:Cartesian:EmptyGrid'); end end function testN(testCase) in = { {[1 2 3]}, {[1 2 3],[1 2]}, {[1 2 3],[1 2 3]}, {[1 2 3],[1 2 3], [1]}, {[1 2 3],[1 2 3], [1 3 4]}, }; out = [3,6,9,9,27]; for i = 1:length(in) g = grid.Cartesian(in{i}{:}); testCase.verifyEqual(g.N(),out(i)); end end function testD(testCase) in = { {[1 2 3]}, {[1 2 3],[1 2]}, {[1 2 3],[1 2 3]}, {[1 2 3],[1 2 3], [1]}, {[1 2 3],[1 2 3], [1 3 4]}, }; out = [1,2,2,3,3]; for i = 1:length(in) g = grid.Cartesian(in{i}{:}); testCase.verifyEqual(g.D(),out(i)); end end function testPoints(testCase) in = { {[1 2]}, {[1 2],[3 4]}, {[1 2],[3 4], [5 6]}, }; out = { [[1; 2]], [[1; 1; 2; 2],[3; 4; 3; 4]], [[1; 1; 1; 1; 2; 2; 2; 2],[3; 3; 4; 4; 3; 3; 4; 4],[ 5; 6; 5; 6; 5; 6; 5; 6]], }; for i = 1:length(in) g = grid.Cartesian(in{i}{:}); testCase.verifyEqual(g.points(),out{i}); end end function testMatrices(testCase) in = { {[1 2]}, {[1 2],[3 4]}, {[1 2],[3 4], [5 6]}, }; out{1}{1} = [1; 2]; out{2}{1} = [1, 1; 2, 2]; out{2}{2} = [3, 4; 3, 4]; out{3}{1}(:,:,1) = [1, 1; 2, 2]; out{3}{1}(:,:,2) = [1, 1; 2, 2]; out{3}{2}(:,:,1) = [3, 4; 3, 4]; out{3}{2}(:,:,2) = [3, 4; 3, 4]; out{3}{3}(:,:,1) = [5, 5; 5, 5]; out{3}{3}(:,:,2) = [6, 6; 6, 6]; for i = 1:length(in) g = grid.Cartesian(in{i}{:}); testCase.verifyEqual(g.matrices(),out{i}); end end