; $Id: errplot.pro,v 1.4 1997/01/15 03:11:50 ali Exp $ ; ; Copyright (c) 1983-1997, Research Systems, Inc. All rights reserved. ; Unauthorized reproduction prohibited. ; Pro Errplot, X, Low, High, Width = width ;+ ; NAME: ; ERRPLOT ; ; PURPOSE: ; Plot error bars over a previously drawn plot. ; ; CATEGORY: ; J6 - plotting, graphics, one dimensional. ; ; CALLING SEQUENCE: ; ERRPLOT, Low, High ;X axis = point number. ; ; ERRPLOT, X, Low, High ;To explicitly specify abscissae. ; ; INPUTS: ; Low: A vector of lower estimates, equal to data - error. ; High: A vector of upper estimates, equal to data + error. ; ; OPTIONAL INPUT PARAMETERS: ; X: A vector containing the abscissae. ; ; KEYWORD Parameters: ; WIDTH: The width of the error bars. The default is 1% of plot width. ; ; OUTPUTS: ; None. ; ; COMMON BLOCKS: ; None. ; ; SIDE EFFECTS: ; An overplot is produced. ; ; RESTRICTIONS: ; Logarithmic restriction removed. ; ; PROCEDURE: ; Error bars are drawn for each element. ; ; EXAMPLES: ; To plot symmetrical error bars where Y = data values and ; ERR = symmetrical error estimates, enter: ; ; PLOT, Y ;Plot data ; ERRPLOT, Y-ERR, Y+ERR ;Overplot error bars. ; ; If error estimates are non-symetrical, enter: ; ; PLOT,Y ; ERRPLOT, Upper, Lower ;Where Upper & Lower are bounds. ; ; To plot versus a vector of abscissae: ; ; PLOT, X, Y ;Plot data (X versus Y). ; ERRPLOT, X, Y-ERR, Y+ERR ;Overplot error estimates. ; ; MODIFICATION HISTORY: ; DMS, RSI, June, 1983. ; ; Joe Zawodney, LASP, Univ of Colo., March, 1986. Removed logarithmic ; restriction. ; ; DMS, March, 1989. Modified for Unix IDL. ;- on_error,2 ;Return to caller if an error occurs if n_params(0) eq 3 then begin ;X specified? up = high down = low xx = x endif else begin ;Only 2 params up = x down = low xx=findgen(n_elements(up)) ;make our own x endelse if n_elements(width) eq 0 then width = .01 ;Default width ; n = n_elements(up) < n_elements(down) < n_elements(xx) ;# of pnts xxmin = min(!x.crange) ;X range xxmax = max(!x.crange) yymax = max(!y.crange) ;Y range yymin = min(!y.crange) if !x.type eq 0 then begin ;Test for x linear ;Linear in x wid = (xxmax - xxmin) * (width/2.) ;bars = .01 of plot wide. endif else begin ;Logarithmic X xxmax = 10.^xxmax xxmin = 10.^xxmin wid = (xxmax/xxmin)* (width/10.) ;bars = .01 of plot wide endelse print,!x.type, wid ; for i=0,n-1 do begin ;do each point. xxx = xx[i] ;x value if (xxx ge xxmin) and (xxx le xxmax) then begin if !x.type eq 0 then begin x0 = xxx-wid & x1 = xxx+wid endif else begin x0 = xxx * (1.0-wid) & x1 = xxx*(1.0+wid) endelse plots,[x0,x1,xxx,xxx,x0,x1],$ [down[i],down[i],down[i],up[i],up[i],up[i]] endif endfor return end