view +blockmatrix/zeroTest.m @ 1223:9fddc8749445 rv_diffOp_test

Closing branch
author Vidar Stiernström <vidar.stiernstrom@it.uu.se>
date Mon, 05 Aug 2019 10:48:37 +0200
parents a5f1b0267dba
children
line wrap: on
line source

function tests = zeroTest()
    tests = functiontests(localfunctions);
end

function testZero(testCase)
    cases = {
        {
            {[],[]},
            {},
        },
        {
            {0,0},
            {[]};
        },
        {
            {1,1},
            {0};
        },
        {
            {2,1},
            {[0; 0]};
        },
        {
            {1,2},
            {[0 0]};
        },
        {
            {[1 2],2},
            {[0 0];[0 0; 0 0]};
        },
        {
            {[1 2],[2 1]},
            {[0 0],[0];[0 0; 0 0],[0; 0]};
        },
        {
            {[3],[0]},
            {zeros(3,0)},
        },

        {
            {[0],[3]},
            {zeros(0,3)},
        },
        {
            {[0 2],[0 3]},
            {
                zeros(0,0), zeros(0,3);
                zeros(2,0), zeros(2,3);
            },
        },
    };

    for i = 1:length(cases)
        out = convertToFull(blockmatrix.zero(cases{i}{1}));
        expected = cases{i}{2};
        testCase.verifyEqual(out,expected);
    end
end


function C = convertToFull(C)
    [N,M] = size(C);
    for i = 1:N
        for j = 1:M
            C{i,j} = full(C{i,j});
        end
    end
end