summaryrefslogtreecommitdiff
path: root/modules/optimization/macros/vec2list.sci
blob: b55923cbfa0d49ff003a509d03887625559190fb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
// Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
// Copyright (C) INRIA
//
// This file must be used under the terms of the CeCILL.
// This source file is licensed as described in the file COPYING, which
// you should have received as part of this distribution.  The terms
// are also available at
// http://www.cecill.info/licences/Licence_CeCILL_V2.1-en.txt
//
function li=vec2list(bigVector,varsizes,ind)
    //bigVector: big vector
    //varsizes: k x 2 matrix, varsizes(i,:)=size of ith matrix
    //li: list of k matrices, li(i)=matrix of size varsizes(i,:);

    [LHS, RHS] = argn(0)
    if RHS < 2 then
        error(sprintf(gettext("%s: Wrong number of input argument(s): %d or %d expected.\n"), "vec2list", 2, 3));
    end

    if bigVector==[] then
        n=0;for dimi=varsizes',n=n+prod(dimi);end
        bigVector=zeros(n,1);
    end
    li=list();point=1;i=0;
    for dimi=varsizes'
        newpoint=point+prod(dimi)-1;i=i+1;
        li(i)=matrix(bigVector(point:newpoint),dimi(1),dimi(2));
        point=newpoint+1;
    end
    if RHS==3 then li=recons(li,ind); end
endfunction