;+
;PROCEDURE: 
;	mvn_swe_sciplot
;PURPOSE:
;	Creates a science-oriented summary plot for SWEA and MAG and optionally other 
;   instruments.
;
;   Warning: This routine can consume a large amount of memory:
;
;     SWEA + MAG : 0.6 GB/day
;     SEP        : 0.2 GB/day
;     SWIA       : 0.2 GB/day
;     STATIC     : 3.5 GB/day
;     LPW        : 0.001 GB/day
;     EUV        : 0.004 GB/day
;     -------------------------
;      total     : 4.5 GB/day
;
;   You'll also need memory for performing calculations on large arrays, so you
;   can create a plot with all data types spanning ~1 day per 8 GB of memory.
;
;AUTHOR: 
;	David L. Mitchell
;CALLING SEQUENCE: 
;	mvn_swe_sciplot
;INPUTS:
;   None:      Uses data currently loaded into the SWEA common block.
;
;KEYWORDS:
;   SUN:       Create a panel for the Sun direction in spacecraft coordinates.
;
;   RAM:       Create a panel for the RAM direction in spacecraft coordinates.
;
;   NADIR:     Create a panel for the Nadir direction in spacecraft coordinates.
;
;   DATUM:     Reference surface for calculating altitude.  Can be one of
;              "sphere", "ellipsoid", "areoid", or "surface".  Passed to 
;              maven_orbit_tplot.  Default = 'ellipsoid'.
;              See mvn_altitude.pro for details.
;
;   SEP:       Include two panels for SEP data: one for ions, one for electrons.
;
;   SWIA:      Include panels for SWIA ion density and bulk velocity (coarse
;              survey ground moments).
;
;   STATIC:    Include two panels for STATIC data: one mass spectrum, one energy
;              spectrum.
;
;   IV_LEVEL:  IV level for STATIC, from 0 to 4.  Values greater than zero fill
;              in background estimates from up to four different sources.
;              Currently in development.  Default = 0.
;
;   APID:      Additional STATIC APID's to load.  (Hint: D0, D1 might be useful.)
;
;   LPW:       Include panel for electron density from LPW data.
;
;              Note: if two or more of O2+, O+, and electron densities are present
;              they are combined into a single panel.
;
;   EUV:       Include a panel for EUV data.
;
;   SC_POT:    Include a panel for spacecraft potential.
;
;   EPH:       Named variable to hold ephemeris data.
;
;   LOADONLY:  Create tplot variables, but don't plot.
;
;   PANS:      Array of tplot variables created.
;
;   PADSMO:    Smooth the resampled PAD data in time with this smoothing interval,
;              in seconds.
;
;   SHAPE:     Include a panel for the electron shape parameter.
;
;   MAGFULL:   If set, then try to load full resolution (32 Hz) MAG data.
;              Default is to load 1-sec data.
;
;OUTPUTS:
;
; $LastChangedBy: dmitchell $
; $LastChangedDate: 2024-03-14 08:00:09 -0700 (Thu, 14 Mar 2024) $
; $LastChangedRevision: 32494 $
; $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/tags/spedas_6_1/projects/maven/swea/mvn_swe_sciplot.pro $
;
;-

pro mvn_swe_sciplot, sun=sun, ram=ram, sep=sep, swia=swia, static=static, lpw=lpw, euv=euv, $
                     sc_pot=sc_pot, eph=eph, min_pad_eflux=min_pad_eflux, loadonly=loadonly, $
                     pans=pans, padsmo=padsmo, apid=apid, shape=shape, nadir=nadir, datum=dtm, $
                     magfull=magfull, iv_level=iv_level

  compile_opt idl2

  @mvn_swe_com
  @maven_orbit_common

  if not keyword_set(APID) then apid = 0
  
  if (size(min_pad_eflux,/type) eq 0) then min_pad_eflux = 6.e4
  if (size(iv_level,/type) eq 0) then iv_level = 0

; Make sure the datum is valid

  dlist = ['sphere','ellipsoid','areoid','surface']
  if (size(dtm,/type) ne 7) then dtm = dlist[1]
  i = strmatch(dlist, dtm+'*', /fold)
  case (total(i)) of
     0   : begin
             print, "Datum not recognized: ", dtm
             result = 0
             return
           end
     1   : datum = (dlist[where(i eq 1)])[0]
    else : begin
             print, "Datum is ambiguous: ", dlist[where(i eq 1)]
             result = 0
             return
           end
  endcase

  mvn_swe_stat, /silent, npkt=npkt
  if (npkt[4] eq 0) then begin
    print,"No SWEA data loaded."
    return
  endif

  str_element, a4, 'time', etime, success=ok
  if (not ok) then str_element, mvn_swe_engy, 'time', etime, success=ok
  if (not ok) then begin
    print,"This should be impossible: mvn_swe_stat says that data are loaded,"
    print,"but I can't find the L0 or L2 SPEC data."
    return
  endif

; Make sure ephemeris covers loaded data

  tplot_options, get=topt
  if (max(topt.trange) lt 1D) then timespan, (minmax(etime) + [0D,34D])

  if (find_handle('alt2',v=-1) gt 0) then begin
    get_data,'alt',data=alt
    tsp = minmax(alt.x)
    indx = where((etime lt tsp[0]) or (etime gt tsp[1]), count)
    if (count gt 0) then maven_orbit_tplot, /loadonly, /shadow, datum=datum
  endif else maven_orbit_tplot, /loadonly, /shadow, datum=datum

  mvn_swe_sumplot,/loadonly

; Try to load resampled PAD data - mask noisy data

  mvn_swe_pad_restore
  pad_pan = 'mvn_swe_pad_resample'
  get_data, pad_pan, data=pad, index=i, alim=dl
  if (i gt 0) then begin
    nf = rebin(dl.nfactor, n_elements(pad.x), n_elements(pad.y[0,*]))
    indx = where(average(pad.y*nf,2,/nan) lt min_pad_eflux, count)
    if (count gt 0L) then begin
      pad.y[indx,*] = !values.f_nan
      store_data, pad_pan, data=pad, dl=dl
    endif
    if (size(padsmo,/type) ne 0) then begin
      dx = median(pad.x - shift(pad.x,1))
      dt = double(padsmo[0])
      if (dt gt 1.5D*dx) then begin
        tsmooth_in_time, pad_pan, padsmo
        pad_pan += '_smoothed'
      endif
    endif
    zlim,pad_pan,0,2,0
    options,pad_pan,'zticks',2
    options,pad_pan,'x_no_interp',1
    options,pad_pan,'y_no_interp',1
    options,pad_pan,'datagap',129D
  endif else pad_pan = 'swe_a2_280'

; Spacecraft orientation

  alt_pan = 'alt2'
  mvn_attitude_bar
  att_pan = 'mvn_att_bar'

  if keyword_set(sun) then begin
    mvn_sundir, frame='swe', /polar
    sun_pan = 'Sun_SWEA_The'
    i = find_handle(sun_pan, verbose=-2)
    if (i eq 0) then sun_pan = ''
  endif else sun_pan = ''

  if keyword_set(ram) then begin
    mvn_ramdir
    ram_pan = 'V_sc_MAVEN_SPACECRAFT'
    i = find_handle(ram_pan, verbose=-2)
    if (i eq 0) then ram_pan = ''
  endif else ram_pan = ''

  if keyword_set(nadir) then begin
    mvn_nadir
    ndr_pan = 'Nadir_MAVEN_SPACECRAFT'
    i = find_handle(ndr_pan, verbose=-2)
    if (i eq 0) then ndr_pan = ''
  endif else ndr_pan = ''

; MAG data

  mvn_swe_addmag
  if keyword_set(magfull) then begin
    mvn_mag_load, 'L2_FULL'
    mvn_mag_geom, var='mvn_B_full'
    mvn_mag_tplot, 'mvn_B_full_maven_mso'
  endif else begin
    mvn_mag_geom
    mvn_mag_tplot, /model
  endelse
  
  mag_pan = ['mvn_mag_bamp','mvn_mag_bang']

; Shape Parameter

  shape_pan = ''
  if keyword_set(shape) then begin
     mvn_swe_shape_restore,/tplot
     i = find_handle('Shape_PAD', verbose=-2)
    if (i eq 0) then begin
      mvn_swe_shape_par_pad_l2, spec=45, /pot, tsmo=16
      i = find_handle('Shape_PAD', verbose=-2)
    endif
    if (i gt 0) then begin
      shape_pan = 'Shape_PAD'
      options, shape_pan, 'ytitle', 'Elec Shape'
    endif
  endif

; SEP electron and ion data - sum all look directions for both units

  sep_pan = ''
  if keyword_set(sep) then mvn_swe_addsep, pans=sep_pan

; SWIA survey data

  swi_pan = ''
  if keyword_set(swia) then mvn_swe_addswi, pans=swi_pan

; STATIC data

  sta_pan = ''
  if keyword_set(static) then mvn_swe_addsta, pans=sta_pan, apid=apid, iv=iv_level

; LPW data

  lpw_pan = ''
  if keyword_set(lpw) then mvn_swe_addlpw, pans=lpw_pan

; EUV data

  euv_pan = ''
  if keyword_set(euv) then mvn_swe_addeuv, pans=euv_pan

; Energy panel

  engy_pan = (find_handle('swe_a4_mask') gt 0) ? 'swe_a4_mask' : 'swe_a4'

; Spacecraft Potential

  pot_pan = ''
  if keyword_set(sc_pot) then begin
    mvn_scpot
    engy_pan = (find_handle('swe_a4_mask') gt 0) ? 'swe_a4_mask' : 'swe_a4_pot'
    options,engy_pan,'ytitle','SWEA elec!ceV'
    pot_pan = 'scpot_comp'
  endif

; Ephemeris information from SPICE

  mk = spice_test('*', verbose=-1)
  indx = where(mk ne '', count)
  if (count eq 0) then mvn_swe_spice_init,/force
  eph = state

  mvn_mars_localtime, result=mlt  
  str_element, eph, 'lst', mlt.lst, /add
  str_element, eph, 'slon', mlt.slon, /add
  str_element, eph, 'slat', mlt.slat, /add

; Burst bar, if available

  i = find_handle('swe_a3_bar', verbose=-1)
  if (i gt 0) then bst_pan = 'swe_a3_bar' else bst_pan = ''

; Quality flag, if available

  i = find_handle('swe_quality', verbose=-1)
  if (i gt 0) then q_pan = 'swe_quality' else q_pan = ''

; Assemble the panels and plot

  pans = [ram_pan, ndr_pan, sun_pan, alt_pan, att_pan, $
          euv_pan, swi_pan, sta_pan, mag_pan, sep_pan, $
          lpw_pan, pad_pan, pot_pan, bst_pan, shape_pan, $
          q_pan, engy_pan]

  indx = where(pans ne '', npans)
  if (npans gt 0) then begin
    pans = pans[indx]
    if (not keyword_set(loadonly)) then tplot, pans
  endif else pans = ''

  return

end