function thm_sst_psif,time,index=index,probe=probe,times=times,$
badbins2mask=badbins2mask, $
err_msg=err_msg, msg_suppress=msg_suppress, $
_extra=ex
data_cache,'th'+probe+'_sst_raw_data',data,/get
if not keyword_set(data) then begin
err_msg = 'No data loaded for probe '+probe
dprint,dlevel=1, err_msg
return,0
endif
if keyword_set(times) then return, *data.sif_064_time
dptr = data.sif_064_data
dim = size(/dimension,*dptr)
dist = thm_sst_dist3d_16x64(/ion,probe=probe)
dist.project_name = 'THEMIS '+strupcase(probe)
dist.spacecraft = strlowcase(probe)
dist.data_name = 'SST Ion Full distribution'
dist.apid = '45a'x
dist.magf = !values.f_nan
if n_elements(index) eq 0 then begin
if n_elements(time) eq 0 then begin
ctime,time
endif
index=round( interp(dindgen(dim[0]),*data.sif_064_time,time) ,/l64)
if index lt 0 || index ge dim[0] then begin
dprint,dlevel=0,'No valid data for the requested time'
return,0
endif
endif
dprint,dlevel=5,index
dist.index = index
if index lt 0 or index ge n_elements(*data.sif_064_time) then return,dist
dist.time = (*data.sif_064_time)[index]-1.5
dist.end_time = dist.time+3.0
dist.data= thm_part_decomp16((*data.sif_064_data)[index,*,*])
dist.cnfg= (*data.sif_064_cnfg)[index]
dist.nspins= (*data.sif_064_nspins)[index]
dist.eclipse_dphi = (*data.sif_064_edphi)[index]
dist.atten = (*data.sif_064_atten)[index-1>0]
dist.units_name = 'Counts'
dist.valid=1
dist.mass = 1836.*0.511e6/(2.9979e5)^2
dist.bins[12:15,*] = 0
if keyword_set(badbins2mask) then begin
if array_equal(badbins2mask,1) then begin
bad_ang = [0,16,32,48]
badbins2mask = intarr(64)+1
badbins2mask[bad_ang] = 0
endif
endif
dist = thm_sst_remove_sunpulse(badbins2mask=badbins2mask,dist,err_msg=err_msg,msg_suppress=msg_suppress,_extra=ex)
return,dist
end