Mercurial > repos > public > sbplib
annotate +blockmatrix/isBlockmatrixTest.m @ 205:f0ef314e2070 feature/grids
blockmatrix: added function to calculate the block division for a given blockmatrix.
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Wed, 15 Jun 2016 16:28:22 +0200 |
parents | 4ce0af75d2f4 |
children | f0f4ca946068 |
rev | line source |
---|---|
203
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
1 function tests = isBlockmatrixTest() |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
2 tests = functiontests(localfunctions); |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
3 end |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
4 |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
5 function testIsBlockmatrix(testCase) |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
6 cases = { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
7 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
8 magic(3), |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
9 false % Must be a cell array |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
10 } |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
11 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
12 {[2 2 2];{1,2}}, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
13 false % All elements of the cell matrix must be regular matrices |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
14 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
15 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
16 {[2 2 2];[1 2]}, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
17 false % Row dimensions must match |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
18 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
19 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
20 {[2; 2; 2], [1; 2]}, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
21 false % Column dimensions must match |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
22 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
23 { |
204 | 24 {}, |
25 true % An empty matrix is a matrix too | |
26 }, | |
27 { | |
203
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
28 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
29 [2 2; 2 1], [1; 2]; |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
30 [2 2], [1] |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
31 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
32 true % A simple valid one |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
33 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
34 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
35 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
36 [2 2; 2 1], []; |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
37 [2 2], [1] |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
38 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
39 true % Empty blocks assumed to be zero and match dimensions |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
40 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
41 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
42 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
43 [2 2; 2 1], []; |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
44 [2 2], [] |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
45 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
46 true % Empty blocks allowed. |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
47 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
48 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
49 { |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
50 [2 2; 2 1], [1; 2]; |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
51 [], [] |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
52 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
53 true % Empty blocks allowed. |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
54 }, |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
55 }; |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
56 |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
57 for i = 1:length(cases) |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
58 in = cases{i}{1}; |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
59 out = blockmatrix.isBlockmatrix(in); |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
60 expected = cases{i}{2}; |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
61 testCase.verifyEqual(out, expected, sprintf('Should return %d for %s', expected, toString(in))); |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
62 end |
764438b52541
blockmatrix: Added functions to test for block matrcies and divisions.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
63 end |