X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?p=CreaPhase.git;a=blobdiff_plain;f=octave_packages%2Fdataframe-0.9.1%2F%40dataframe%2Fbsxfun.m;fp=octave_packages%2Fdataframe-0.9.1%2F%40dataframe%2Fbsxfun.m;h=740018b1431619fb77ee3df10f0618632860051f;hp=0000000000000000000000000000000000000000;hb=f5f7a74bd8a4900f0b797da6783be80e11a68d86;hpb=1705066eceaaea976f010f669ce8e972f3734b05 diff --git a/octave_packages/dataframe-0.9.1/@dataframe/bsxfun.m b/octave_packages/dataframe-0.9.1/@dataframe/bsxfun.m new file mode 100644 index 0000000..740018b --- /dev/null +++ b/octave_packages/dataframe-0.9.1/@dataframe/bsxfun.m @@ -0,0 +1,51 @@ +function resu = bsxfun(func, A, B) + + %# function resu = bsxfun(func, A, B) + %# Implements a wrapper around internal bsxfun + + %% 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: bsxfun.m 9585 2012-02-05 15:32:46Z cdemills $ + %# + + + try + + [A, B, resu] = df_basecomp(A, B, true, @bsxfun); + + for indi = 1:max(A._cnt(2), B._cnt(2)), + indA = min(indi, A._cnt(2)); + indB = min(indi, B._cnt(2)); + Au = A._data{indA}(:, A._rep{indA}); + Bu = B._data{indB}(:, B._rep{indB}); + resu._data{indi} = bsxfun(func, Au, Bu); + resu._rep{indi} = 1:size(resu._data{indi}, 2); + endfor + + resu = df_thirddim(resu); + + catch + disp(lasterr()); + error('bsxfun: non-compatible dimensions') + end_try_catch + +endfunction