]> Creatis software - CreaPhase.git/blobdiff - octave_packages/nan-2.5.5/range.m
Add a useful package (from Source forge) for octave
[CreaPhase.git] / octave_packages / nan-2.5.5 / range.m
diff --git a/octave_packages/nan-2.5.5/range.m b/octave_packages/nan-2.5.5/range.m
new file mode 100644 (file)
index 0000000..5a271a6
--- /dev/null
@@ -0,0 +1,66 @@
+function Q=range(Y,DIM)
+% RANGE calculates the range of Y 
+%  Missing values (encoded as NaN) are ignored. 
+%
+%  Q = range(Y)
+%  Q = range(Y,DIM)
+%     returns the range along dimension DIM of sample array Y.
+%
+%  Q = range(HIS)
+%     returns the RANGE from the histogram HIS.
+%     HIS must be a HISTOGRAM struct as defined in HISTO2 or HISTO3.
+%
+% see also: IQR, MAD, HISTO2, HISTO3, PERCENTILE, QUANTILE
+
+
+%      $Id$
+%      Copyright (C) 2009,2010,2011 by Alois Schloegl <alois.schloegl@gmail.com>
+%       This function is part of the NaN-toolbox
+%       http://pub.ist.ac.at/~schloegl/matlab/NaN/
+
+
+%    it under the terms of the GNU General Public License as published by
+%    the Free Software Foundation; either version 3 of the License, or
+%    (at your option) any later version.
+%
+%    This program 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 this program; If not, see <http://www.gnu.org/licenses/>.
+
+if nargin<2,
+        DIM = [];
+end;
+if isempty(DIM),
+        DIM = find(size(Y)>1,1);
+        if isempty(DIM), DIM = 1; end;
+end;
+
+
+if nargin<1,
+       help range
+
+else
+        SW = isstruct(Y);
+        if SW, SW = isfield(Y,'datatype'); end;
+        if SW, SW = strcmp(Y.datatype,'HISTOGRAM'); end;
+        if SW,
+               Q = repmat(NaN,1,size(Y.H,2)); 
+               for k=1:size(Y.H,2);
+                       t = Y.X(find(Y.H(:,k)>0),min(size(Y.X,2),k));
+                       Q(1,k) = max(t)-min(t);
+               end;
+        elseif isnumeric(Y) && nargin==1,
+               Q = max(Y) - min(Y); 
+        elseif isnumeric(Y) && nargin==2,
+               Q = max(Y,[],DIM) - min(Y,[],DIM); 
+       else 
+               help range
+       end; 
+end;
+
+
+