This page was created by the IDL library routine
mk_html_help2
.
Last modified: Sun Feb 16 18:16:23 2025.
NAME: thm_autoload_support PURPOSE: given a THEMIS tplot variable name, check to see if spin period and phase exist, for coordinate transformations, If they do not, load the state data for the appropriate time period CALLING SEQUENCE: thm_autoload_support, vname=vname, spinmodel=spinmodel, spinaxis=spinaxis, slp=slp, probe_in=probe, trange=[tmin, tmax], history_out=hist_string INPUT: OUTPUT: KEYWORDS: vname = tplot variable name probe_in: Specifies the probe name to load support data for (required for /spinmodel and /spinaxis) spinmodel: if set to 1, ensure spinmodel data is loaded and covers the requested time interval spinaxis: if set to 1, ensure state (spinras, spindec) data is loaded and covers the requested time interval slp: if set, ensure sun & moon data are loaded and cover the requested time interval trange: Specify a time range for which support data should be loaded (required if vname is not supplied) history_out = a history string, if data needs loading HISTORY: 2013-12-19: Adapted from thm_ui_check4spin by jwl NOTES: $LastChangedBy: jwl $ $LastChangedDate: 2021-06-29 16:13:26 -0700 (Tue, 29 Jun 2021) $ $LastChangedRevision: 30093 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/projects/themis/state/thm_autoload_support.pro $
(See projects/themis/state/thm_autoload_support.pro)
function: thm_interpolate_state Purpose: interpolates the low res STATE file all variables are structures as produced by get_data keywords: Examples: tha_spinper_highres=thm_interpolate_state(thx_xxx_in=thx_xxx_in,thx_spinper=thx_spinper) --> linear interpolation tha_spinphase_highres=thm_interpolate_state(thx_xxx_in=thx_xxx_in,thx_spinper=thx_spinper,thx_spinphase=thx_spinphase) --> phase constructed according to the nearest neighbor spin phase, spin period tha_spinras_highres=thm_interpolate_state(thx_xxx_in=thx_xxx_in,thx_spinras=thx_spinras) --> linear interpolation tha_spindec_highres=thm_interpolate_state(thx_xxx_in=thx_xxx_in,thx_spindec=thx_spindec) --> linear interpolation tha_spinalpha_highres=thm_interpolate_state(thx_xxx_in=thx_xxx_in,thx_spinalpha=thx_spinalpha) --> linear interpolation tha_spinbeta_highres=thm_interpolate_state(thx_xxx_in=thx_xxx_in,thx_spinbeta=thx_spinbeta) --> linear interpolation tha_pos_highres=thm_interpolate_state(thx_xxx_in=thx_xxx_in,thx_pos=thx_pos) --> spline interpolation tha_vel_highres=thm_interpolate_state(thx_xxx_in=thx_xxx_in,thx_vel=thx_vel) --> spline interpolation Notes: under construction!! Written by Hannes Schwarzl $LastChangedBy: pcruce $ $LastChangedDate: 2013-06-13 17:51:42 -0700 (Thu, 13 Jun 2013) $ $LastChangedRevision: 12531 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/projects/themis/state/thm_interpolate_state.pro $
(See projects/themis/state/thm_interpolate_state.pro)
Procedure: THM_LOAD_SLP, thm_load_slp, datatype = datatype, trange = trange, $ verbose = verbose, $ varname_out = varname_out, $ downloadonly = downloadonly, $ no_download=no_download, relpathnames_all=relpathnames_all,$ files=files,$ valid_names = valid_names,$ suffix=suffix Purpose: Loads Solar and Lunar Ephemeris data from a CDF. 1. Data is generated using the JPL SPICE/ICY library. Extensive documentation can be found on the SPICE/ICY website: http://naif.jpl.nasa.gov/pub/naif/toolkit_docs/IDL/req/index.html 2. All quantities are in GEI coordinates. GEI Epoch is True of Date(this is the THEMIS standard). 3. All data have abberational corrections for light time and stellar abberation. Thus the data represent the state of the Moon and the Sun as they would be observed on earth at a particular time. A more detailed discussion of this topic can be found in the SPICE/ICY 'SPK' required reading document. The SPICE/ICY abberation used is called 'LT+S'. 4. GEI True of Date are not built into SPICE/ICY. A custom kernel is used when generating these data that accounts for earth precession using the IAU_1976 precessional model and accounts for earth nutation using the IAU_1980 nutational model which are built into SPICE/ICY. The quantities returned and their descriptions follow. 1. slp_sun_pos: Sun position X,Y,Z in km. 2. slp_sun_vel: Sun velocity X,Y,Z in km/sec. 3. slp_sun_att_x: IAU_SUN coordinate system X-axis(X,Y,Z). (unitless/normalized) A. This axis lies in the Solar equatorial plane and the plane containing the Solar prime meridian B. This axis points towards a fixed point on the solar surface and rotates with the sun. C. This axis rotates with sidereal rotation period of the sun.~24.47 days. D. This quantity created by rotation the basis vector [1,0,0] from IAU_SUN into GEI coordinate orientation. E. While this quantity is oriented relative to the GEI coordinate system, it is not technically earth centered. Only the rotational component of the transformation is performed, not the translation into earth-center. F. slp_sun_att_z and slp_sun_att_x are orthognal axes, thus slp_sun_att_y = slp_sun_att_z x slp_sun_att_x, and this set of axes can be used to transform between GEI and IAU_SUN coordinates 4. slp_sun_att_z: IAU_SUN coordinate system Z-axis(X,Y,Z). (unitless/normalized) A. This axis points in the direction of the mean rotational axis of the sun. B. This quantity created by rotation the basis vector [0,0,1] from IAU_SUN into GEI coordinate orientation. C. While this quantity is oriented relative to the GEI coordinate system, it is not technically earth centered. Only the rotational component of the transformation is performed, not the translation into earth-center. D. slp_sun_att_z and slp_sun_att_x are orthognal axes, thus slp_sun_att_y = slp_sun_att_z x slp_sun_att_x, and this set of axes can be used to transform between GEI and IAU_SUN coordinates 5. slp_sun_ltime: The time, in seconds, it takes for light to travel from the sun to the earth at the time of observation.. To translate data from light corrected to uncorrected data subtract these corrections from the data times. 6. slp_lun_pos: Lunar position X,Y,Z in km. 7. slp_lun_pos: Lunar velocity X,Y,Z in km/s. 8. slp_lun_att_x: IAU_MOON coordinate system X-axis (X,Y,Z) A. This axis lies in the Lunar equatorial plane and the plane containing the Lunar prime meridian B. This axis points towards a fixed point on the moon's surface and rotates with the moon. C. This quantity created by rotation the basis vector [0,0,1] from IAU_MOON into GEI coordinate orientation.. D. While this quantity is oriented relative to the GEI coordinate system, it is not technically earth centered. Only the rotational component of the transformation is performed, not the translation into earth-center. E. slp_lun_att_z and slp_lun_att_x are orthognal axes, thus slp_lun_att_y = slp_lun_att_z x slp_lun_att_x, and this set of axes can be used to transform between GEI and IAU_SUN coordinates 9. slp_lun_att_z: IAU_MOON coordinate system Z-axis(X,Y,Z). (unitless/normalized) A. This axis points in the direction of the mean rotational axis of the moon. B. This quantity created by rotation the basis vector [0,0,1] from IAU_MOON into GEI coordinates. C. While This quantity is in GEI coordinates, it is not technically earth centered. Only the rotational component of the transformation is performed, not the translation into earth-center. D. slp_lun_att_z and slp_;un_att_x are orthognal axes, thus slp_lun_att_y = slp_lun_att_z x slp_lun_att_x, and this set of axes can be used to transform between GEI and IAU_MOON coordinates. 10. slp_lun_ltime: The time, in seconds, it takes for light to travel from the moon to the earth at the time of observation. To translate data from light corrected to uncorrected data subtract these corrections from the data times. keywords: datatype = The type of data to be loaded. Allowed values are: 'sun_pos','sun_vel','sun_att_x','sun_att_z','sun_ltime', 'lun_pos','lun_vel','lun_att_x','lun_att_z','lun_ltime' TRANGE= (Optional) Time range of interest (2 element array), if this is not set, the default is to prompt the user. Note that if the input time range is not a full day, a full day's data is loaded level = ignored, only one level for this datatype: L1 /VERBOSE : set to output some useful info varname_out= a string array containing the tplot variable names for the loaded data /downloadonly, if set, then only download the data, do not load it into variables. /no_download: use only files which are online locally. relpathnames_all: named variable in which to return all files that are required for specified timespan, probe, datatype, and level. If present, no files will be downloaded, and no data will be loaded. files named varible for output of pathnames of local files. /valid_names, if set, then this will return the valid site, datatype and/or level options in named variables, for example, thm_load_gmag, site = xxx, /valid_names will return the array of valid sites in the variable xxx suffix= suffix to add to output data quantity (not added to support data) Examples: timespan,'2007-03-23' thm_load_slp thm_load_slp,datatype='sun_pos',trange=['2007-01-22/00:00:00','2007-01-24/00:00:00'] $LastChangedBy: egrimes $ $LastChangedDate: 2018-12-21 11:50:27 -0800 (Fri, 21 Dec 2018) $ $LastChangedRevision: 26397 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/projects/themis/state/thm_load_slp.pro $
(See projects/themis/state/thm_load_slp.pro)
Procedure: thm_load_ssc Purpose: Load THEMIS current/past orbit data, and predicted data, from CDAWeb/SSCWeb (Satellite Situation Center). Keywords: trange: Standard time range of interest. probes: Probe names. This can be an array of strings, e.g., ['a', 'b'] predicted: If set, it loads predicted data. varformat: Only load these variable names. If not set, load all. downloadonly: Only download files, do not load them into tplot. prefix: Give this prefix to tplot variable names suffix: Give this suffix to tplot variable names no_time_clip: Do not time clip tplot variables (not recommended because some files contain a year of data) ssc_server: (optional) URL of CDAWeb server. Returns: tplotnames: List of variables loaded into tplot Examples: thm_load_ssc, trange = ['2026-01-01', '2026-01-10'], probes=['a','b','c'], /predicted thm_load_ssc, trange = ['2016-01-01', '2016-01-10'], probes='e' $LastChangedBy: nikos $ $LastChangedDate: 2024-09-27 15:53:46 -0700 (Fri, 27 Sep 2024) $ $LastChangedRevision: 32864 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/projects/themis/state/thm_load_ssc.pro $
(See projects/themis/state/thm_load_ssc.pro)
Procedure: THM_LOAD_STATE Purpose: Loads THEMIS STATE (orbit and attitude) data ;keywords: probe = Probe name. The default is 'all', i.e., load all available probes. This can be an array of strings, e.g., ['a', 'b'] or a single string delimited by spaces, e.g., 'a b' datatype = The type of data to be loaded, can be an array of strings or single string separate by spaces. The default is 'pos vel' TRANGE= (Optional) Time range of interest (2 element array), if this is not set, the default is to prompt the user. Note that if the input time range is not a full day, a full day's data is loaded version = the version of the state file, one of 'v00', 'v01', 'v02', 'v03'. defaults to 'v01' level = the level of the data, the default is 'l1', or level-1 data. A string (e.g., 'l2') or an integer can be used. 'all' can be passed in also, to get all levels. suffix= suffix to add to tplot variable names. Note: this will get added support_data variables as well as regular data variables. CDF_DATA: named variable in which to return cdf data structure: only works for a single spacecraft and datafile name. VARNAMES: names of variables to load from cdf: default is all. /GET_SUPPORT_DATA: load support_data variables as well as data variables into tplot variables. /DOWNLOADONLY: download file but don't read it. /no_download: use only files which are online locally. /NO_UPDATE: prevent contact to server if local file already exists. relpathnames_all: named variable in which to return all files that are required for specified timespan, probe, datatype, and level. If present, no files will be downloaded, and no data will be loaded. /valid_names, if set, then this routine will return the valid probe, datatype level, and version options in named variables supplied as arguments to the corresponding keywords. files named varible for output of pathnames of local files. /VERBOSE set to output some useful info coord: Can specify the coordinate system you would like data returned in. no_spin: if set, do not call thm_load_spin to load spinmodel data. Example: thm_load_state Notes: Modifications: If /GET_SUPPORT_DATA and ~/NO_SPIN, then call THM_LOAD_SPIN, W.M.Feuerstein, 4/10/2008. Delete th?_spin* TPLOT variables after calling THM_LOAD_SPIN (as long as ~/KEEP_SPIN_DATA), add KEEP_SPIN_DATA kw, include a couple of (normally commented) lines to chck consistency of spinmodel, WMF, 4/10/08. coordinate systems of returned variables: *_pos : gei *_vel : gei *_ras : gei *_dec : gei *_alpha : spg *_beta : spg *_spinper : none(listed in dlimits as unknown) *_spinphase : none(listed in dlimits as unknown) *_roi : none(listed in dlimits as unknown) *_man : none(listed in dlimits as unknown) If you modify the d_names constant make sure to make the corresponding changes to the c_names constant $LastChangedBy: jwl $ $LastChangedDate: 2023-04-03 12:28:04 -0700 (Mon, 03 Apr 2023) $ $LastChangedRevision: 31701 $ $URL $
(See projects/themis/state/thm_load_state.pro)
Procedure: THM_LOAD_STATE2 Purpose: Loads THEMIS STATE (orbit and attitude) data ;keywords: probe = Probe name. The default is 'all', i.e., load all available probes. This can be an array of strings, e.g., ['a', 'b'] or a single string delimited by spaces, e.g., 'a b' datatype = The type of data to be loaded, can be an array of strings or single string separate by spaces. The default is 'all' TRANGE= (Optional) Time range of interest (2 element array), if this is not set, the default is to prompt the user. Note that if the input time range is not a full day, a full day's data is loaded version = the version of the state file, one of 'v01', 'v02', 'v03', 'v04'. defaults to 'v01' level = the level of the data, the default is 'l1', or level-1 data. A string (e.g., 'l2') or an integer can be used. 'all' can be passed in also, to get all levels. CDF_DATA: named variable in which to return cdf data structure: only works for a single spacecraft and datafile name. VARNAMES: names of variables to load from cdf: default is all. /GET_SUPPORT_DATA: load support_data variables as well as data variables into tplot variables. /DOWNLOADONLY: download file but don't read it. /valid_names, if set, then this routine will return the valid probe, datatype and/or level options in named variables supplied as arguments to the corresponding keywords. files named varible for output of pathnames of local files. /VERBOSE set to output some useful info Example: thm_load_state Notes: $LastChangedBy: egrimes $ $LastChangedDate: 2018-12-21 11:50:27 -0800 (Fri, 21 Dec 2018) $ $LastChangedRevision: 26397 $ $URL $
(See projects/themis/state/thm_load_state2.pro)
Procedure: THM_LOAD_STATE2 Purpose: Loads THEMIS STATE (orbit and attitude) data ;keywords: probe = Probe name. The default is 'all', i.e., load all available probes. This can be an array of strings, e.g., ['a', 'b'] or a single string delimited by spaces, e.g., 'a b' datatype = The type of data to be loaded, can be an array of strings or single string separate by spaces. The default is 'all' TRANGE= (Optional) Time range of interest (2 element array), if this is not set, the default is to prompt the user. Note that if the input time range is not a full day, a full day's data is loaded version = the version of the state file, one of 'v01', 'v02', 'v03', 'v04'. defaults to 'v01' level = the level of the data, the default is 'l1', or level-1 data. A string (e.g., 'l2') or an integer can be used. 'all' can be passed in also, to get all levels. CDF_DATA: named variable in which to return cdf data structure: only works for a single spacecraft and datafile name. VARNAMES: names of variables to load from cdf: default is all. /GET_SUPPORT_DATA: load support_data variables as well as data variables into tplot variables. /DOWNLOADONLY: download file but don't read it. /valid_names, if set, then this routine will return the valid probe, datatype and/or level options in named variables supplied as arguments to the corresponding keywords. files named varible for output of pathnames of local files. /VERBOSE set to output some useful info Example: thm_load_state Notes: $LastChangedBy: egrimes $ $LastChangedDate: 2018-12-21 11:50:27 -0800 (Fri, 21 Dec 2018) $ $LastChangedRevision: 26397 $ $URL $
(See projects/themis/state/thm_load_state3.pro)
NAME: thm_load_state_relpath PURPOSE: Alternate relpathname routine for L1 state data, allows for different relpath from SPDF directory with v0? in the final relpathname CALLING SEQUENCE: relpathnames = thm_load_state_relpath(sname = sname, filetype = filetype, level = level, $ version = version, $ trange = trange, $ addmaster = addmaster) INPUT: sname = probe, one of ['a','b','c','d','e'] filetype = 'state' -> this keyword is only defined here due to the interface to thm_load_xxx level = 'l1' -> this keyword is only defined here due to the interface to thm_load_xxx version = '0','1','2','3' or '?' The default is to not have a version number, and this keyword is not used trange = the timerange relpathnames_local = the fullpath of the file as it will be saved locally, this is an output keyword OUTPUT: relpathnames = the full path of the files relative to the local and remote data directories. HISTORY: April 1, 2010, jmm, jimm@ssl.berkeley.edu $LastChangedBy: pcruce $ $LastChangedDate: 2014-02-20 12:48:24 -0800 (Thu, 20 Feb 2014) $ $LastChangedRevision: 14398 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/projects/themis/state/thm_load_state_relpath.pro $
(See projects/themis/state/thm_load_state_relpath.pro)
NAME: thm_spin_phase Purpose: Use sunpulse data produced by thm_sunpulse to get spinphase at abitrary times Input Parameters: time_dat: double precision array: times of data points at which interpolates are desired. Output Parameters: spinpha_int: interpolated spin phase Keywords: Probe: a single probe name. e.g. 'a' suffix: suffix on tplot variable (thx_state_sunpulse[_suffix]) Optional Input Parameters (If not present, then state data will be loaded from standard state tplot variables, using probe keyword) sunpulse: double precision array: times of sunpulses sunp_spinper: spin period at each sunpulse time K. Bromund, SPSystems/NASA/GSFC, May 2007 $LastChangedBy: aaflores $ $LastChangedDate: 2012-02-13 14:41:42 -0800 (Mon, 13 Feb 2012) $ $LastChangedRevision: 9728 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/projects/themis/state/thm_spin_phase.pro $
(See projects/themis/state/thm_spin_phase.pro)
NAME: thm_sunpulse Purpose: Interpolate spin phase to have same time resolution as time_dat Keyword: probe: string indicating probe. Array of strings, or a string like 'a b'. Not used if positional parameters are present. suffix: suffix to add to default tplot name in which to store sunpulse data: thx_state_sunpulse (x = probe letter designation) This suffix is expected on the names of the state data inputs. Optional Inputs/Output parameters: (if not present, then standard state tplot variable names will be used for i/o) Input Parameters: time_state: double precision array: times of data from state file spinpha: spin phase from state file spinper: spin period from state file Output Parameters: sunpulse: sunpulse times (times of zero spin phase) sunp_spinper: spin period at time of each sunpulse. Keywords: sunpulse_name: string. If present, store sunpulse/spinperiod in tplot variable with this name. Has no effect if probe keyword is provided. Notes: Written by K. Bromund, SPSystems/NASA/GSFC, May 2007 $LastChangedBy: aaflores $ $LastChangedDate: 2015-04-30 15:28:49 -0700 (Thu, 30 Apr 2015) $ $LastChangedRevision: 17458 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/projects/themis/state/thm_sunpulse.pro $
(See projects/themis/state/thm_sunpulse.pro)