X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=octave_packages%2Fdataframe-0.9.1%2F%40dataframe%2Frepmat.m;fp=octave_packages%2Fdataframe-0.9.1%2F%40dataframe%2Frepmat.m;h=6a48799af24df696df84f58cfc43da561d32be9e;hb=c880e8788dfc484bf23ce13fa2787f2c6bca4863;hp=0000000000000000000000000000000000000000;hpb=1705066eceaaea976f010f669ce8e972f3734b05;p=CreaPhase.git diff --git a/octave_packages/dataframe-0.9.1/@dataframe/repmat.m b/octave_packages/dataframe-0.9.1/@dataframe/repmat.m new file mode 100644 index 0000000..6a48799 --- /dev/null +++ b/octave_packages/dataframe-0.9.1/@dataframe/repmat.m @@ -0,0 +1,65 @@ +function resu = repmat(df, varargin) + + %% Copyright (C) 2009-2012 Pascal Dupuis + %% + %% This file is part of Octave. + %% + %% Octave is free software; you can redistribute it and/or + %% modify it under the terms of the GNU General Public + %% License as published by the Free Software Foundation; + %% either version 2, or (at your option) any later version. + %% + %% Octave is distributed in the hope that it will be useful, + %% but WITHOUT ANY WARRANTY; without even the implied + %% warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR + %% PURPOSE. See the GNU General Public License for more + %% details. + %% + %% You should have received a copy of the GNU General Public + %% License along with Octave; see the file COPYING. If not, + %% write to the Free Software Foundation, 51 Franklin Street - + %% Fifth Floor, Boston, MA 02110-1301, USA. + + %# + %# $Id: repmat.m 9585 2012-02-05 15:32:46Z cdemills $ + %# + + resu = df; idx = horzcat(varargin{:}); + %# for the second dim, use either 1 either the 3rd one + dummy = idx; + if (length(dummy) > 2), + dummy(2) = []; + else + dummy(2) = 1; + endif + %# operate on first dim + if (idx(1) > 1), + resu = df_mapper(@repmat, df, [idx(1) 1]); + if (!isempty(df._name{1})), + resu._name{1} = feval(@repmat, df._name{1}, [idx(1) 1]); + resu._over{1} = feval(@repmat, df._over{1}, [idx(1) 1]); + endif + resu._cnt(1) = resu._cnt(1) * idx(1); + endif + + if (dummy(2) > 1), + for indi = 1:resu._cnt(2), + resu._rep{indi} = feval(@repmat, resu._rep{indi}, [1 dummy(2)]); + endfor + endif + + %# operate on ridx + resu._ridx = feval(@repmat, resu._ridx, idx); + + %# operate on second dim + if (length(idx) > 1 && idx(2) > 1), + resu._data = feval(@repmat, resu._data, [1 idx(2)]); + resu._name{2} = feval(@repmat, df._name{2}, [idx(2) 1]); + resu._over{2} = feval(@repmat, df._over{2}, [1 idx(2)]); + resu._type = feval(@repmat, df._type, [1 idx(2)]); + resu._cnt(2) = resu._cnt(2) * idx(2); + endif + + resu = df_thirddim(resu); + +endfunction