view scripts/plot/errorbar.m @ 3901:bd0dc53a5093

[project @ 2002-04-17 16:01:22 by jwe]
author jwe
date Wed, 17 Apr 2002 16:01:22 +0000
parents 65c6da68ddb3
children e0b7a493e5a8
line wrap: on
line source

## Copyright (C) 2000, Teemu Ikonen
##
## 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, 59 Temple Place - Suite 330, Boston, MA
## 02111-1307, USA.

## -*- texinfo -*-
## @deftypefn {Function File} {} errorbar (@var{args})
## This function produces two-dimensional plots with errorbars. Many
## different combinations of arguments are possible.  The simplest form is
##
## @example
## errorbar (@var{y}, @var{ey})
## @end example
##
## @noindent
## where the first argument is taken as the set of @var{y} coordinates
## and the second argument @var{ey} is taken as the errors of the
## @var{y} values. @var{x} coordinates are taken to be the indices
## of the elements, starting with 1.
##
## If more than two arguments are given, they are interpreted as
##
## @example
## errorbar (@var{x}, @var{y}, ..., @var{fmt} ...)
## @end example
##
## @noindent
## where after @var{x} and @var{y} there can be up to four error
## parameters such as @var{ey}, @var{ex}, @var{ly}, @var{uy} etc.,
## depending on the plot type. Any number of argument sets may appear,
## as long as they are separated with a format string @var{fmt}.
##
## If @var{y} is a matrix, @var{x} and error parameters must also be matrices
## having same dimensions. The columns of @var{y} are plotted versus the
## corresponding columns of @var{x} and errorbars are drawn from
## the corresponding columns of error parameters.
##
## If @var{fmt} is missing, yerrorbars ("~") plot style
## is assumed.
## If the @var{fmt} argument is supplied, it is interpreted as in
## normal plots (See __pltopt__). In addition the following
## plot styles are supported by errorbar:
##
## @table @samp
## @item ~
## Set yerrorbars plot style (default).
##
## @item >
## Set xerrorbars plot style.
##
## @item ~>
## Set xyerrorbars plot style.
##
## @item #
## Set boxes plot style.
##
## @item #~
## Set boxerrorbars plot style.
##
## @item #~>
## Set boxxyerrorbars plot style.
##
## @end table
##
## Examples:
##
## @example
## errorbar(@var{x}, @var{y}, @var{ex}, ">")
## @end example
##
## xerrorbar plot of @var{y} versus @var{x} with @var{x} errorbars drawn from
## @var{x}-@var{ex} to @var{x}+@var{ex}.
##
## @example
## errorbar(@var{x}, @var{y1}, @var{ey}, "~", @var{x}, @var{y2}, @var{ly}, @var{uy})
## @end example
##
## Two yerrorbar plots with @var{y1} and @var{y2} versus @var{x}.
## Errorbars for @var{y1} are drawn from @var{y1}-@var{ey} to
## @var{y1}+@var{ey}, errorbars for @var{y2} from @var{y2}-@var{ly} to
## @var{y2}+@var{uy}.
##
## @example
## errorbar(@var{x}, @var{y}, @var{lx}, @var{ux}, @var{ly}, @var{uy}, "~>")
## @end example
##
## xyerrorbar plot of @var{y} versus @var{x} where @var{x} errorbars
## are drawn from @var{x}-@var{lx} to @var{x}+@var{ux} and @var{y} errorbars
## from @var{y}-@var{ly} to @var{y}+@var{uy}.
##
## @end deftypefn
## @seealso{semilogx, semilogy, loglog, polar, mesh, contour, __pltopt__,
## bar, stairs, gplot, gsplot, replot, xlabel, ylabel, and title}

## Created: 18.7.2000
## Author: Teemu Ikonen <tpikonen@pcu.helsinki.fi>
## Keywords: errorbar, plotting

function errorbar (...)

  if (nargin < 2)
    usage ("errorbar (...)");
  endif

  save_hold = ishold;
  unwind_protect
    if (! ishold)
      clg ()
    endif
    hold ("on");
    while (nargin)
      a = va_arg ();
      nargin--;
      if (is_vector (a))
	a = a(:);
      elseif (is_matrix (a));
	;
      else
	usage ("errorbar (...)");
      endif
      sz = size (a);
      ndata = 1;
      arg1 = a;
      fmt = " ";
      while (nargin)
	nargin--;
	a = va_arg ();
	if (isstr (a))
	  fmt = a;
	  cmd = "__errplot__ (arg1";
	  for i = 2:ndata,
	    cmd = [cmd, sprintf(", arg%d",i)];
	  endfor
	  cmd = [cmd, ", fmt);"];
	  eval (cmd);
	  break;
	elseif (is_vector (a))
	  a = a(:);
	elseif (is_matrix (a))
	  ;
	else
	  error ("wrong argument types");
	endif
	if (size (a) != sz)
	  error ("argument sizes do not match");
	endif
	ndata++;
	eval (sprintf ("arg%d = a;", ndata));
	if (ndata > 6)
	  error ("too many arguments to a plot");
	endif
      endwhile
    endwhile

    if (! isstr (a))
      fmt = " ";
      cmd = "__errplot__(arg1";
      for i = 2:ndata,
	cmd = [cmd, sprintf(", arg%d",i)];
      endfor
      cmd = [cmd, ", fmt);"];
      eval (cmd);
    endif
  unwind_protect_cleanup
    if (! save_hold)
      hold ("off");
    endif
  end_unwind_protect

endfunction