These are a list of routines that are usful for EIS analysis. If you find others useful let us know and they can be added to the SSW tree. 

%%information
routines marked with %%(color:red;)red-color%% are in common use.
%%

__%%(color:red;)eis_auto_fit.pro%%__    :   {{{
;   This routine takes the output from EIS_GETWINDATA and performs a fit
;   over the intensity array, returning values for the intensity, line width
;   and centroid.
;
;   The quality of the spectrum is checked to ensure that a good fit can be
;   obtained (for bad data, the routine can hang while it tries to find a
;   solution).
}}}


__%%(color:red;)eis_data~__getwindata.pro%%__  : {{{
;       Returns EIS data from a detector window.
; EXAMPLE:
;       Create an object:
;           IDL> eisfile = 'eis_l1_20070202_104212.fits'
;           IDL> eisfile = 'eis_er_20070202_104212.fits'
;           IDL> obj = obj_new('eis_data',eisfile)
;           IDL> obj_er = obj_new('eis_data',errfile)
;       And extract data from window 0.
;           IDL> data = obj -> getwindata(0, data_er=obj_er)
}}}

__eis_data~__getwinheader.pro__: {{{
;       Returns the FITS header for a spectral window
; Example:
;       IDL> data = obj_new('eis_data')
;       IDL> eisfile = '$HINODE/eis/mission/2007/02/02/eis_l0_20070202_104212.fits.gz'
;       IDL> header=data->getwinheader(eisfile,0)
}}}

__eis_debias.pro__: {{{
;       Removes the CCD bias from an EIS data window.
}}}

__eis_despike.pro__: {{{
;       EIS_DESPIKE is part of the SOLAR-B EIS analysis software . It is used
;       for de-spiking, i.e. to remove cosmic ray spikes from the pixel
;       data.
}}}

__eis_exposure_times.pro__ : {{{
;     This routine extracts the start times of each exposure in an EIS data
;     object. The times are given in seconds relative to the first exposure.
}}}

__eis_find_window.pro__: {{{
;     Given the a header structure for an EIS data-set, this routine checks
;     if the specified wavelength, WVL, is found in the data-set's wavelength
;     windows. If yes, then the index of the wavelength window is returned.
}}}

__eis_get_hdr_struc.pro__: {{{
;    This routine extracts selected information from an EIS data header
;    into a structure. The particular fields taken from the header are
;    defined in the file $SSW/hinode/eis/idl/atest/pyoung/headcat_tags.txt.
}}}

__eis_get_iwin.pro__: {{{
;          PURPOSE : To find the data window given the line id or the
;                    wavelength.
;          EXAMPLE : IDL> iwin = eis_get_iwin('eis_l0_20061214_192012',195)
;                    IDL> print,iwin
;                         4
}}}

__%%(color:red;)eis_get_wininfo.pro%%__ : {{{
;          PURPOSE : To return information on the windows contained in
;                    an eis fits file.
;          EXAMPLE : IDL> file = 'eis_l0_20061214_192012'
;                    IDL> wininfo = eis_get_winfo(file,/list,nwin=nwin)
;                    iwin             line_id   wvl_min   wvl_max
;                       0        FE X 184.540    184.29    184.80
;                       1     FE VIII 185.210    184.96    185.47
;                       2       FE XI 188.230    187.97    188.48
;                       3     CA XVII 192.820    192.56    193.07
;                       4      FE XII 195.120    194.85    195.37
;                       5     FE XIII 202.040    201.78    202.30
;                       6       HE II 256.320    256.06    256.58
;                       7      FE XIV 274.200    273.96    274.47
;                       8       FE XV 284.160    283.92    284.43
;                    IDL> print,nwin
;                         9
}}}

__%%(color:red;)eis_getdata.pro%%__: {{{
;       EIS_GETDATA is a script to extract data (one, sevceral or all
;       line windows) from a (FITS or CCSDS) data file.
;       example 1: Get line window 0 and hdr from CCSDS file1= 'file1.dat':
;                  IDL> eis_getdata, file1, wd, hdr=hdr, /ccsds
;                  If e.g 32 pixel wide line window *wavelength,
;                  512 slit pos. and 100 raster pos, the dimension of
;                  wd will now be: wd = uint[32, 512, 100]
;       example 2: Get line windows 2 and 3 from fitsfile file2='file2.fits':
;                  IDL> eis_getdata, file2, wd, iwin=[2,3]
;                  If same dimensions as above, wd will now be:
;                   wd = uintarr[32, 512, 100, 2], i.e.
;                   wd[nlam, nslit, nraster, nwin]
;       example 3: Get all 25 line windows and hdr from FITS file 'file2.fits'
;                  IDL>eis_getdata, file2, hdr=hdr, /all
;                  wd is now uintarr[32, 512, 100, 25]
}}}

__eis_getlambda.pro__ : {{{
;       get the wavelength range of the CCDs
}}}

__%%(color:red;)eis_getmoments.pro%%__: {{{
;       EIS_GETMOMENTS is a script to calculate moments from one,
;       several or all spectral line windows from a (fits or CCSDS) data file.
}}}

__%%(color:red;)eis_getwindata.pro%%__: {{{
;       Returns EIS data from one spectral window.
; CALLING SEQUENCE:
;       d = eis_getwindata(file, [iwin ,keywords])
}}}

__%%(color:red;)eis_orbit_correction.pro%%__: {{{
;    Calculates the wavelength vector for each exposure in the EIS data-set,
;    corrected for the orbital variation.
}}}

__eis_orbit_spline_quick.pro__: {{{
;    Represents the orbital variation of EIS line centroids by a spline
;    function with nodes spaced at 5 minute intervals. Returns the value
;    of the centroid at the input times.
}}}

__%%(color:red;)eis_prep.pro%%__: {{{
;    carries out standard EIS calibration
}}}

__eis_raster_browser.pro__: {{{
;     This routine is used to browse 3D EIS data-cubes. It is based on
;     software available in the SOHO/CDS software.
}}}

__eis_spike_viewer.pro__: {{{
;     This tool is for browsing EIS data arrays that have been cleaned of
;     cosmic ray hits.
; EXAMPLE
;     IDL> data=obj_new('eis_data',filename)
;     IDL> wd=data->getvar(iwin)
;     IDL> eis_debias,wd
;     IDL> eis_despike,wd,wd_clean,swtch=spikes
;     IDL> EIS_SPIKE_VIEWER,wd,wd_clean,spikes
}}}

__fig_tsmean.pro__: {{{
;            plots temporal mean of spectrum
}}}

__line_centroid.pro__: {{{
;     Finds the centroid of an emission or absorption line by minmizing the
;     function SUM( (wavel_i-ref) * flux_i ), for the centroid wavelength,
;     ref. Note that the accuracy of the derived wavelength is improved by
;     having the input wavelength vector (str.wavel) on a fine scale.
; USE
;
;     IDL> line_centroid, wvl, flx, [1030,1035]
}}}

__eis_getfilename.pro__: {{{
;       A simple routine for turning a file name into an absolute file
;       name.  The routine looks in three places for the file: the present
;       directory, the mission archive and the quick look directory. If
;       nothing is passed a widget comes up, but this isn't very useful.
; EXAMPLE:
;       IDL> file=eis_getfilename('eis_l0_20061202_140632')
;       IDL> print,file
;       .../eis/mission/2006/12/02/eis_l0_20061202_140632.fits.gz
}}}

__eis_help.pro__: {{{
;       Instatiates the hw_help object and calls the display_all method to give a
;       first introduction to the object help documentation for the eis/hw software.
}}}

__photons_to_energy.pro__: {{{
;       Convert intensity from photons [ph m-2 s-1 sr-1] to energy in SI units
;       [W m-2 sr-1]
}}}

__eis_get_compression_factor__: {{{
; PURPOSE: Returns the reciprocal of the latest EIS compression factor
}}}


__%%(color:red;)eis_colors.pro%%__: {{{
;       set eis colortable for velocity & width maps display
}}}


___eis_raster_fov.pro__: {{{
;          PURPOSE : to calculate information about the field of view
;                    for an EIS raster
;          EXAMPLE : IDL> d = eis_getwindata('eis_l0_20071221_001727')
;                    IDL> eis_raster_fov,d,scale,origin,fovx,fovy
;                    IDL> print,scale
;                          1.00000      1.00000
;                    IDL> print,origin
;                         -32.9291     -79.1299
;                    IDL> print,fovx,fovy
;                          128.000      184.000
}}}


__%%(color:red;)eis_element2mass.pro%%__: {{{
; Returns the mass (in grams or kilograms) of an element.
; EXAMPLE:
;
; IDL> Fe_mass = element2mass('Fe')
; IDL> print,Fe_mass
;   9.27339e-23
}}}


__%%(color:red;)eis_slit_tilt.pro%%__: {{{
;          PURPOSE : Calculates the slit tilt as a function position
;                    along the CCD.
;          EXAMPLE : dw  = eis_slit_tilt(256,512,/short,locations=y)
;                    wvl = wvl - dw
;                    plot,y,dw
;                    ALTERNATIVE USAGE:
;                    d  = eis_getwindata(file,wave)
;                    dw = eis_slit_tilt(d,locations=y)
}}}


__%%(color:red;)eis_wave_corr.pro%%__: {{{
;          PURPOSE : PRELIMINARY EIS wavelength corrections for
;                    orbital variations and slit tilt using moments.
;          EXAMPLE : IDL> eis_wave_corr,file,wvl_corr,dw_tilt,dw_t,/show
;                    IDL> d.wvl = d.wvl - wvl_corr[i,j]
}}}


__eis_width2velocity.pro__: {{{
;          Compute thermal and nonthermal velocities.
;          EXAMPLE:
;
; Some example thermal widths:
;
; v_t = eis_width2velocity('C','II',1335,/thermal,ti_max=t,therm_fwhm=fwhm)
;
;   ion      wave A   temp K fwhm A
;  C   II   1335.00  2.2e+04  0.041
;  C   IV   1548.00  1.1e+05  0.105
;  N    V   1238.00  1.8e+05  0.101
;  O    I   1355.00  1.0e+04  0.024
;  O   IV   1401.00  1.7e+05  0.102
;  Si  II   1304.00  1.4e+04  0.021
;  Si III   1206.00  3.0e+04  0.028
;  Si  IV   1393.00  6.3e+04  0.047
;  S    I   1472.00  1.0e+04  0.019
;
; Compare with Feldman, Doschek, and Patterson, ApJ, 209:270-281, 1976
;
; An example nonthermal velocity:
;
; v_nt = eis_width2velocity('S','I',1900.29,0.04,ti_max=t)
; v_nt = 3.0 km/sec
; t    = 10,000 K
;
; Compare with Mariska, Feldman, and Doschek, ApJ, 226:698-705, 1978
}}}


__eis_add_wd_to_spec.pro__: {{{
;     This routine takes an EIS spectrum structure and fills in the
;     intensity, error and quality tags using the input EIS_GETWINDATA
;     structure and a pixel mask.
}}}


__eis_adjust_mask.pro__: {{{
;     Because of the grating tilt and CCD offset in the EIS
;     instrument, the same pixel position in an EIS image formed from
;     one wavelength will not directly correspond to the same pixel
;     position in an image from a different wavelength. For this
;     reason a pixel mask generated with EIS_PIXEL_MASK needs to be
;     adjusted when being used for another wavelength.
;
;     This routine performs the adjustment using information from the
;     routine EIS_CCD_OFFSET.
}}}


__%%(color:red;)eis_ccd_offset.pro%%__: {{{
;     Evaluates the spatial offset of the specified wavelength relative
;     to He II 256. 
; EXAMPLES
;     IDL> offset=eis_ccd_offset(195.12)
;     IDL> l=findgen(120)+170
;     IDL> plot,l,eis_ccd_offset(l)
}}}


__eis_cubic_spline.pro__: {{{
;     Creates an optimised cubic spline fit to the orbital variation of EIS
;     emission line centroids. The spline is used by eis_orbit_spline to
;     perform the orbital variation correction to the output of eis_auto_fit.
}}}


__eis_fit_viewer.pro__: {{{
;     Widget-based routine for studying the Gaussian fits produced by
;     EIS_AUTO_FIT.PRO.
}}}


__eis_flag_night.pro__: {{{
;     Takes the fit structure from eis_auto_fit and estimates which
;     data-columns fall into orbital night. Any columns identified are set
;     to missing data in the fitdata data arrays, and the new structure is
;     returned.
}}}


__eis_get_hdr_struc.pro__: {{{
;    This routine extracts selected information from an EIS data header
;    into a structure. The particular fields taken from the header are
;    defined in the file $SSW/hinode/eis/idl/atest/pyoung/headcat_tags.txt.
}}}


__eis_make_image.pro__: {{{
;     Given a level-1 FITS file name and a wavelength, this routine
;     creates an image at the specified wavelength by summing 7 pixels
;     across the line profile.
}}}


__%%(color:red;)eis_orbit_spline.pro%%__: {{{
;    Takes the centroid tag from the output of the EIS_AUTO_FIT
;    routine and computes a fit to the orbital variation. The velocity array
;    is averaged in the Y-direction (see the keyword YRANGE=), and a cubic
;    spline is fit to the averaged function (see the routine
;    EIS_CUBIC_SPLINE). The spline fit is then subtracted from the centroid
;    array to give the corrected centroid array. The velocity array is also
;    corrected by converting the centroid to km/s.
}}}


__eis_pixel_mask.pro__: {{{
;       This is a mouse-based routine that requires for input an image
;       array. The image is displayed and a `menu' will appear in the
;       IDL window. The options are:
;
;       LEFT:   Go into `polygon' mode
;       MIDDLE: Go into `painting' mode
;       RIGHT:  Exit
; EXAMPLES:
;       EIS_PIXEL_MASK, IMAGE, MASK, WVL, SLIT
;       EIS_PIXEL_MASK, IMAGE, MASK, WVL, SLIT, COL=255, MAXIMAGE=0.5
}}}


__eis_mask_spectrum.pro__: {{{
;     Using a pixel mask created with EIS_PIXEL_MASK, this routine
;     averages the EIS spectra over the specified spatial pixels to
;     create an averaged spectrum. The error bars on the intensities
;     are correctly calculated.
;   EXAMPLE:
;     IDL> eis_mask_spectrum, l1name, mask, swspec=swspec, lwspec=lwspec'
}}}


__%%(color:red;)eis_tilt_correction.pro%%__: {{{
;    Corrects the eis_auto_fit fit structure for the tilt of the EIS slit.
;    Both the 1" and 2" slits are accounted for.
}}}


__eis_winwvl_hdr.pro__: {{{
;     For the specifed wavelength window in an EIS data object, this routine
;     returns the wavelength vector for the window.
}}}


__errors.pro__: {{{
;     Given two line intensities/fluxes and their 1-sigma errors,
;     calculates the ratio and the 1-sigma error on the ratio.
}}}


__%%(color:red;)fe12_density.pro%%__: {{{
;     Takes the Fe XII 195 and 186 fit structures produced by eis_auto_fit,
;     and creates a density structure containing a density map. The densities
;     are derived used the CHIANTI atomic database.
}}}


__spec_gauss_eis.pro__: {{{
;    This routine is a 'wrapper' for calling the general purpose
;    line fitting routine SPEC_GAUSS_WIDGET. For creating the input
;    spectrum in the correct format, try using the routine
;    EIS_MASK_SPECTRUM.
}}}


__%%(color:red;)eis_find_lineraster.pro%%__: {{{
;       Searches if a specific wavelength is within the wavelength
;       range of observation of the rasters in the EIS database.
; Example:
;       Look for 195.33:
;       IDL> acronyms=eis_find_lineraster(195.33,summary=summary,rasters=rasters,lines=lines)
}}}



!!Quicklook tools

__%%(color:red;)xfiles.pro%%__:{{{
;       XFILES is used to select data files from data bases. It reads
;       data from many data sources. The user can also specify own
;       data sources, in which case data-read procedures must be
;       provided. XFILES defines the data objects, header objects and
;       auxiliary objects and sends them to XDISPLAY. The XDISPLAY
;       window is opened when the user selects a data file in XFILES.
}}}

__xmap.pro__: calling by xfiles.pro only {{{
;       XMAP is used to display 2-D (or higher) data. It is a
;       widget based program with several options and functions that
;       allows data to be displayed in a nukmber of modes.
}}}

__xcontrol.pro__: calling by xfiles.pro only {{{
;       XCONTROL is the main QL control window. After selecting a file (CCSDS or
;       FITS) this windows opens with information about the data, and control
;       buttons etc. for the various display methods and data processing
;       options available for a particular set of data.
}}}

__xdetector.pro__: calling by xfiles.pro only {{{
;       XDETECTOR is used to display 2-D (or higher) data. It is a
;       widget based program with several options and functions that
;       allows data to be displayed in a nukmber of modes.
}}}

__xraster.pro__: calling by xfiles.pro only {{{
;       XRASTER is used to display 3-D spectroscopic data in the form
;       of a raster (i.e. intensity[lambda, slit pos, raster pos.].
;       One line is displayed as I[lambda, slit pos] with one display window
;       for each raster (using !p.multi). If more than one line, these
;       are added as extra rows of display windows.
}}}

__xwhisker.pro__: calling by xfiles.pro only {{{
;       xwhisker is used to display 2-D spectroscopic data as whisker plots
;       (images). I.e. Intensity[wavelength, y].
;       Typically y will be solar_x (for a raster) or
;       for sit-and-stare observations it will be time.
}}}

__xmoment.pro__: calling by xfiles.pro only {{{
;       XMOMENT plots mean line profile, and has interactive mouse
;       functions to mark where the line is (start/stop pixels) and
;       where the continuum is. This information is used by the
;       eis_moment__moment program to calulate moments of the line
;       profile.
}}}

__ximovie.pro__: calling by xfiles.pro only {{{
;       XIMOVIE provides a widget interface to run and control
;       images displayed as a movie. The images must be written
;       as an assoc file.
}}}



!!Other useful routines

__%%(color:red;)eis_cat.pro%%__: {{{
; Purpose     : widget interface to EIS AS-RUN catalog
; Syntax      : IDL> eis_cat
}}}


__eis_search_rasters.pro__: {{{
;          PURPOSE : To search the EIS raster database
;          EXAMPLE : eis_search_rasters
}}}