This page was created by the IDL library routine
mk_html_help2
.
Last modified: Thu Feb 6 18:16:35 2025.
FUNCTION: findpath.pro PURPOSE: Finds the path to a particular file in current IDL paths ARGUMENTS: FILENAME -> Name of the file to find - STRING PATH <- Path to file (without "/") - STRING RETURNS: Status of find 0 - Failure 1 - Success (exact match) 2 - Success (after adding ".pro") KEYWORDS: EXACT / Find exact match only (Don't try to add '.pro') VERBOSE / Print out search pathes CALLING SEQUENCE: found=findpath('filename',pathname) case found of 0 : ERROR 1 : fullpath=pathname+'/'+filename 2 : fullpath=pathname+'/'+filename+'.pro' endcase or if not findpath('filename',path,/exact) then ERROR NOTES: By default, FINDPATH searches for exact match. If not found looks for 'filename' with ".pro" appended (unless /EXACT keyword is set). CREATED BY: John P. Dombeck 7/03/2001 MODIFICATION HISTORY: 07/03/01- J. Dombeck Original writing 06/25/04- J. Dombeck Added VERBOSE keyword Changed close -> free_lun
(See general/missions/rbsp/efw/findpath.pro)
NAME: rbsp_ac_highpass_response (function) PURPOSE: Calculate the response of the one-pole 10 Hz high-pass analog filter applied to RBSP AC channel field signals. CATEGORIES: CALLING SEQUENCE: resp = rbsp_ac_highpass_response(f) ARGUMENTS: f: (Input, required) A frequency array for which the response of the filter is calcuated. The frequency should be in units of Hz. KEYWORDS: None. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-08-08: Created by Jianbao Tao, SSL, UC Berkeley. Version: $LastChangedBy: jianbao_tao $ $LastChangedDate: 2012-09-06 11:42:13 -0700 (Thu, 06 Sep 2012) $ $LastChangedRevision: 10895 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_ac_highpass_response.pro $
(See general/missions/rbsp/efw/rbsp_ac_highpass_response.pro)
NAME: rbsp_adc_response (function) PURPOSE: Calculate the responses of the RBSP DFB ADC chip. CATEGORIES: CALLING SEQUENCE: response = rbsp_adc_response(f, channel, delay = delay) ARGUMENTS: f: (Input, required) A floating array of frequencies at which the responses are calculated. channel: (Input, required) A string of channel names. Valid channels are: 'V1DC', 'V2DC', 'V3DC', 'V4DC', 'V5DC', 'V6DC', 'E12DC', 'E34DC', 'E56DC', 'E12AC', 'E34AC', 'E56AC', 'V1AC', 'V2AC', 'V3AC', 'V4AC', 'V5AC', 'V6AC', 'MAGU', 'MAGV', 'MAGW', 'MSCU', 'MSCV', 'MSCW' KEYWORDS: delay: (Output, optional) A variable name to hold the time delay of the given channel. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-08-10: Created by Jianbao Tao (JBT), SSL, UC Berkley. Version: $LastChangedBy: jianbao_tao $ $LastChangedDate: 2012-09-06 11:42:13 -0700 (Thu, 06 Sep 2012) $ $LastChangedRevision: 10895 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_adc_response.pro $
(See general/missions/rbsp/efw/rbsp_adc_response.pro)
NAME: rbsp_anti_aliasing_response (function) PURPOSE: Calculate the frequency responses of the anti-aliasing filters for RBSP field signals. CATEGORIES: CALLING SEQUENCE: response = rbsp_anti_aliasing_response(f) ARGUMENTS: f: (Input, required) A floating array of frequencies at which the responses are calculated. KEYWORDS: None. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-08-10: Created by Jianbao Tao (JBT), SSL, UC Berkley. Version: $LastChangedBy: jianbao_tao $ $LastChangedDate: 2012-09-06 11:42:13 -0700 (Thu, 06 Sep 2012) $ $LastChangedRevision: 10895 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_anti_aliasing_response.pro $
(See general/missions/rbsp/efw/rbsp_anti_aliasing_response.pro)
NAME: rbsp_corotation_efield PURPOSE: Determine the co-rotation electric field for RBSP. Saves as tplot variable INPUT: probe -> 'a' or 'b' date -> ex '2012-10-13' KEYWORDS: no_spice_load -> don't load SPICE kernels NOTES: 1) I've tested this with the hires mag data as well as lowres 4-sec data. The lowres data work just as well. 2) uses accurate 1-min cadence spinaxis pointing direction HISTORY: 2013-07-08: Adapted by Aaron Breneman from program by Scott Thaller, University of Minnesota 2014-12-12: added data_preloaded keyword. Designed for when I call this from rbsp_efw_vxb_subtract_crib (and other cribs) so that program doesn't reload a bunch of data that's already been loaded. VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2017-06-15 11:18:24 -0700 (Thu, 15 Jun 2017) $ $LastChangedRevision: 23480 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_corotation_efield.pro $
(See general/missions/rbsp/efw/rbsp_corotation_efield.pro)
NAME: rbsp_cotrans (procedure) PURPOSE: A wrapper of cotrans for RBSP, with a few mission-specific features added. CATEGORIES: CALLING SEQUENCE: rbsp_cotrans, from_tvar, to_tvar $ , gse2gsm = gse2gsm $ , gsm2gse = gsm2gse $ , dsc2gse = dsc2gse $ , dsc2mgse = dsc2mgse $ , dsc2gsm = dsc2gsm $ , gse2dsc = gse2dsc $ , gse2mgse = gse2mgse $ , gsm2dsc = gsm2dsc $ , dsc2fac = dsc2fac $ , mat_dsc = mat_dsc $ , tmag = tmag $ , vectype = vectype $ , verbose = verbose NOTES: 1. A tplot variable of magnetic field in DSC, specified with tmag keyword, is required to perfrom dsc2fac. The default value of tmag is something like 'rbspa_mag_dsc'. 2. A tplot variable of rotation matrix from DSC to GSE, specified with the mat_dsc keyword, is required to perform dsc2gse, gse2dsc, dsc2gsm, and gsm2dsc. The rotation matrix is usually generated by *rbsp_load_state*. The default value of mat_dsc is something like 'rbspa_mat_dsc'. ARGUMENTS: from_tvar: (In, required) A tplot variable to which the rotation is applied. to_tvar: (Out, required) A tplot name for storing the rotation results. KEYWORDS: The following keywords enable the transformations indicated by their names. /gse2gsm, /gsm2gse, /dsc2gse, /dsc2gsm, /gse2dsc, /gsm2dsc mat_dsc: (In, optional) A tplot name of the rotation matrix between DSC and GSE. It is usually loaded in rbsp_load_state. By default, this name is derived as strmid(from_tvar, 0, 6) + 'mat_dsc' vectype: (In, optional) The type of the vectors being transformed. Valid types are 'E', 'B', and 'V'. By default, vectype = ''. This string is used for labelling the to_tvar. verbose: (In, optional) A number to indicate the verbose level. See dprint. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-11-03: Created by Jianbao Tao (JBT), SSL, UC Berkley. 2012-11-05: JBT, SSL, UC Berkley. Initial release to TDAS. 2012-11-20: JBT, SSL, UC Berkley. 1. Added dsc-to-fac transformation. VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2019-12-19 12:45:43 -0800 (Thu, 19 Dec 2019) $ $LastChangedRevision: 28129 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_cotrans.pro $
(See general/missions/rbsp/efw/rbsp_cotrans.pro)
NAME: rbsp_despin (procedure) PURPOSE: Rotate data from a spinning frame to DSC. By default, the spinning frame is assumed to be the UVW frame. CATEGORIES: CALLING SEQUENCE: rbsp_despin, sc, tvar, angle_offset = angle_offset, pertvar = pertvar, $ newname = newname, uvw = uvw, xyz = xyz, offset_name = offset_name, $ no_axial_processing = no_axial_processing, $ no_offset_remove = no_offset_remove, $ tper = tper, tphase = tphase ARGUMENTS: sc: (In, required) Spacecraft name. Should be 'a' or 'b'. tvar: (In, required) Tplot variable to be despun, such as 'rbspa_mag_uvw'. KEYWORDS: angle_offset: (In, optional) Angle offset additional to spin phase. For UVW, angle_offset is 10 degree, which is the default. pertvar: (In, optional) Spin period tplot data. By default, pertvar = 'rbsp' + strlowcase(sc[0]) + '_spinper'. newname: (In, optional) New name for the despun data. By default, newname = tvar + '_dsc' /uvw: Shortcut for rotating UVW data. /xyz: Shortcut for rotating XYZ data. Equivalent to set angle_offset = 45. offset_name: A tplot name for saving offsets in spin-plane components. /no_axial_processing: If set, axial component is not processed. By default, the first spin-tone harmonic is removed in the axial component. /no_offset_remove: If set, offsets in spin-plane components are not removed. tper: (In, optional) Tplot name of spin period data. By default, tper = pertvar. If tper is set, pertvar = tper. tphase: (In, optional) Tplot name of spin phase data. By default, tphase = 'rbsp' + strlowcase(sc[0]) + '_spinphase' Note: tper and and tphase are mostly used for using eclipse-corrected spin data. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-11-03: Created by Jianbao Tao (JBT), SSL, UC Berkley. 2012-11-05: Initial release to TDAS. JBT, SSL/UCB. 2012-11-06: JBT, SSL/UCB. 1. Added tper and tphase to use eclipse-corrected spin data. 2. Added keyword *no_offset_remove*. VERSION: $LastChangedBy: nikos $ $LastChangedDate: 2016-10-06 16:51:43 -0700 (Thu, 06 Oct 2016) $ $LastChangedRevision: 22061 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_despin.pro $
(See general/missions/rbsp/efw/rbsp_despin.pro)
NAME: rbsp_dfb_response (function) PURPOSE: Calculate DFB responses at given frequencies. Two modes are suppored. If the sample rate keyword, SAMPLE_RATE, is specified, it will calculate the response of the low-pass output from DFB. If the the filter bank level keyword, FBK_LEVEL, is specified, it will calculate the response of the corresponding filter bank level. Warning: If both keywords are set, FBK_LEVEL is ignored. If neither is set, a NaN will be returned. Filter bank level look-up table: Frequency range in Hz | Level 8192 - 4096 | 1 4096 - 2048 | 2 2048 - 1024 | 3 1024 - 512 | 4 512 - 256 | 5 256 - 128 | 6 128 - 64 | 7 64 - 32 | 8 32 - 16 | 9 16 - 8 | 10 8 - 4 | 11 4 - 2 | 12 2 - 1 | 13 CATEGORIES: CALLING SEQUENCE: result = rbsp_dfb_response(f, sample_rate = sample_rate, $ fbk_level = fbk_level) ARGUMENTS: f: (Input, required) A floating array of frequencies at which the responses are calculated. KEYWORDS: sample_rate: (Input, optional) See PURPOSE. fbk_level: (Input, optional) See PURPOSE. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-08-08: Created by Jianbao Tao (JBT), SSL, UC Berkley. Version: $LastChangedBy: jianbao_tao $ $LastChangedDate: 2012-09-06 11:42:13 -0700 (Thu, 06 Sep 2012) $ $LastChangedRevision: 10895 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_dfb_response.pro $
(See general/missions/rbsp/efw/rbsp_dfb_response.pro)
NAME: rbsp_efw_boom_length (function) PURPOSE: Return the boom length for a give time. CATEGORIES: CALLING SEQUENCE: result = rbsp_efw_boom_length(sc, time) ARGUMENTS: sc: (In, required) Spacecraft name. Should be 'a' or 'b'. time: (In, required) A value of time. KEYWORDS: COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-10-08: Created by Jianbao Tao (JBT), SSL, UC Berkley. 2012-11-05: Initial release to TDAS. JBT, SSL/UCB. 2013-06-20: JBT. Accounted for AXB trimming. VERSION: $LastChangedBy: jianbao_tao $ $LastChangedDate: 2013-06-20 14:01:20 -0700 (Thu, 20 Jun 2013) $ $LastChangedRevision: 12561 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_boom_length.pro $
(See general/missions/rbsp/efw/rbsp_efw_boom_length.pro)
NAME: rbsp_efw_boom_response (function) PURPOSE: CATEGORIES: CALLING SEQUENCE: resp = rbsp_efw_boom_response(f, boom_type, rsheath = rsheath, $ H_before = H_before, H_after = H_after) ARGUMENTS: KEYWORDS: COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-08-12: Created by Jianbao Tao (JBT), SSL, UC Berkley. VERSION: $LastChangedBy: jianbao_tao $ $LastChangedDate: 2012-08-14 18:00:24 -0700 (Tue, 14 Aug 2012) $ $LastChangedRevision: 10823 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_boom_response.pro $
(See general/missions/rbsp/efw/rbsp_efw_boom_response.pro)
NAME: rbsp_efw_cal_fbk PURPOSE: Calibrate RBSP filterbank data NOTES: -This is meant to be called from rbsp_load_efw_fbk.pro -No check at this point to see if the channel changes over day. Now I'm using the channels at the start of day. -Boom lengths currently set to 100.02000 100.02000 10.000000 -add in boom shorting factor SEE ALSO: HISTORY: 2012-xx-xx: Created by Aaron W Breneman, University of Minnesota 2013-04-xx: added support for FBK 7 2013-04-18: Added freq-dependent gain correction. At this point the gain curves are "hard-wired" into the code. In the future they will be accessed from the Berkeley RBSP website. 2013-05-15: freq-dependent gain curves now obtained from rbsp_get_efw_gain_results.pro and are no longer "hard-wired" into this code. Also added the full freq-dependent correction as well as the mu-metal square can (nT/v) curves to correct the SCM data. 2013-09-20: Switched the channels for FBK7. Previously they were flipped. 2013-10-02: Re-switched the channels for FBK7. The L1 files have been corrected and all works as it should. VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2020-01-03 14:13:58 -0800 (Fri, 03 Jan 2020) $ $LastChangedRevision: 28162 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_cal_fbk.pro $
(See general/missions/rbsp/efw/rbsp_efw_cal_fbk.pro)
NAME: rbsp_efw_cal_spec PURPOSE: Calibrate RBSP spectral data NOTES: Intended to be called from rbsp_load_efw_spec.pro TO DO: -No accounting for possible midday source change -not using boom shorting factor There are 7 returned spec channels. The possibilities are Select 7 of: E12dc,E34dc,E56dc E12ac,E34ac,E56ac Edcpar,Edcprp Eacpar,Eacprp V1ac,V2ac,V3ac,V4ac,V5ac,V6ac SCMU,SCMV,SCMW SCMpar,SCMprp, (V1dc+V2dc+V3dc+V4dc)/4, Edcprp2, Eacprp2, SCMprp2 Calibration procedure subtract offset vals = (double(vals) - offset[j]) Compensate for 4 bit dynamic range compression vals /= 16. Divide the 0th bin by 4 (from weirdness doc) vals[*,0] /= 4. Compensate for using Hanning window vals /= 0.375^2 Apply ADC conversion vals *= adc_factor^2 Apply channel gain vals *= gain[j]^2 (V^2/Hz at this point) Apply boom length to change from V^2/Hz to mV/m^2/Hz vals *= conversion[j]^2 ;mV/m ^2 /Hz Apply freq dependent gain HISTORY: 2012-09-xx: Created by Aaron W Breneman, University of Minnesota 2013-04-xx: added automated channel selection 2013-04-23: added freq-dependent gain 2013-05-15: freq-dependent gain curves now obtained from rbsp_efw_get_gain_results.pro and are no longer "hard-wired" into this code. Also added the full freq-dependent correction as well as the mu-metal square can (nT/v) curves to correct the SCM data. VERSION: $LastChangedBy: $ $LastChangedDate: $ $LastChangedRevision: $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/ssl_general/trunk/missions/rbsp/efw/rbsp_efw_cal_fbk.pro $
(See general/missions/rbsp/efw/rbsp_efw_cal_spec.pro)
NAME: rbsp_efw_cal_waveform (procedure) PURPOSE: Calibrate EFW waveform data. CATEGORIES: CALLING SEQUENCE: rbsp_efw_cal_waveform, probe = probe, datatype = datatype, $ trange = trange, get_support_data = get_support_data, $ coord = coord, no_adc = no_adc, $ tper = tper, tphase = tphase ARGUMENTS: KEYWORDS: probe: (In, optional) RBSP spacecraft names, either 'a', or 'b', or ['a', 'b']. The default is ['a', 'b'] datatype: (In, optional) A string scalar of data types that acceptable to *rbsp_load_efw_waveform*. trange: (In, optional) Time range for performing the calibration. By default, trange = timerange() /get_support_data: If set, offsets in spin-plane components are stored in a tplot variable with format '*_uvw_offset'. coord: (In, optional) If set to 'uvw', despinning will not be performed. /no_adc: If set, ADC-to-physical units is ignored. tper: (In, optional) Tplot name of spin period data. By default, tper = pertvar. If tper is set, pertvar = tper. tphase: (In, optional) Tplot name of spin phase data. By default, tphase = 'rbsp' + strlowcase(sc[0]) + '_spinphase' Note: tper and and tphase are mostly used for using eclipse-corrected spin data. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-08-07: Created by Jianbao Tao (JBT), SSL, UC Berkley. 2012-11-06: JBT, SSL/UCB. 1. Added despinning capability. 2012-11-12: JBT, SSL/UCB. 1. Added esvy and vsvy cleaning. 2013-06-21: JBT, SSL/UCB. 1. Added instrument response deconvolution for eb1. VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2019-01-29 10:01:48 -0800 (Tue, 29 Jan 2019) $ $LastChangedRevision: 26513 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_cal_waveform.pro $
(See general/missions/rbsp/efw/rbsp_efw_cal_waveform.pro)
NAME: rbsp_efw_cal_xspec PURPOSE: Calibrate RBSP cross-spectral data NOTES: meant to be called from rbsp_load_efw_xspec.pro The default is that xspec0 is SCMw x E12AC and xspec1 is V1AC x V2AC xspec3 is not used at this time A note on the various channels. From the LASP DFB document Fig 4, the spectral FFT of each channel (ex SCMw and E12AC) is sent directly into the Xspec processor. The "top" channel in this figure shows the calculation of the real and imaginary parts. FFT(SCMw) and FFT(E12AC) --> Xspec calc (eg SCMw x E12AC) --> bin averaging --> xspec compression The power is calculated via the "bottom" channel FFT(SCMw) --> FFT(SCMw)*FFT(SCMw)* --> bin averaging --> spec compression These values are "src1" and "src2" src1 and src2 refer to the individual sources that comprise the xspec. These are power spectral densities Data calibration (ex, starting with src1, described above) subtract offset src1_2 = (double(src1.y) - offset_chn1) Compensate for dynamic range compression src1_2 /= 16 (/8 for the real and imaginary parts) Divide the 0th bin by 4 (from weirdness doc) src1_2[*,0] /= 4. Compensate for using Hanning window src1_2 /= 0.375^2 Apply ADC conversion src1_2 *= adc_factor^2 Apply channel gain src1_2 *= gain[0]^2 Resulting data in V^2/Hz The coherence values are calculated as in Eqn 3.91 in "Engineering Applications of Correlation and Spectral Analysis" by Bendat and Piersol (vol 1 apparently) Coherence(f) = |Gxy(f)|^2 / Gxx(f)*Gyy(f) where |Gxy(f)|^2 = (Real^2 + Imaginary^2) Gxx(f) = src1_2 Gyy(f) = src2_2 SEE ALSO: HISTORY: Sept 2012: Created by Aaron W Breneman, University of Minnesota VERSION: $LastChangedBy: $ $LastChangedDate: $ $LastChangedRevision: $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/ssl_general/trunk/missions/rbsp/efw/rbsp_efw_cal_fbk.pro $
(See general/missions/rbsp/efw/rbsp_efw_cal_xspec.pro)
NAME: rbsp_efw_clean_esvy (procedure) PURPOSE: Clean the axial component of EFW esvy data type. CATEGORIES: CALLING SEQUENCE: rbsp_efw_clean_esvy, tvar, newname = newname, $ notch = notch, phase_tolerance = phase_tol, $ ind_spike = ind_spike, threshold = thres, $ sc = sc, tper = tper, tphase = tphase ARGUMENTS: tvar: (In, required) Tplot name of esvy data. KEYWORDS: newname: (In, optional) Tplot name for cleaned data. Default is something like 'rbspa_esvy_clean'. notch: (In, optional) Number of data points to be notched. Default = 43. phase_tolerance: (In, optional) Spin phase tolerance for locating spikes in the axial component. Default = 5 (degree) ind_spike: (Out, optional) A named variable to return the found spikes to. threhold: (In, optional) Threshold for finding extrema when locating spikes. Default = 1. sc: (In, optional) Spacecraft name. Default = strmid(tvar, 4, 1) tper: (In, optional) Tplot name of spin period data. Default is something like 'rbspa_spinper'. tphase: (In, optional) Tplot name of spin phase data. Default is something like 'rbspa_spinphase'. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-10-12: Created by Jianbao Tao (JBT), SSL, UC Berkley. 2012-11-12: Initial release in TDAS. JBT, SSL/UCB. VERSION: $LastChangedBy: jianbao_tao $ $LastChangedDate: 2012-11-12 14:34:49 -0800 (Mon, 12 Nov 2012) $ $LastChangedRevision: 11226 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_clean_esvy.pro $
(See general/missions/rbsp/efw/rbsp_efw_clean_esvy.pro)
NAME: rbsp_efw_clean_vsvy (procedure) PURPOSE: Clean the axial components (V5 and V6) of EFW vsvy data type. CATEGORIES: CALLING SEQUENCE: rbsp_efw_clean_vsvy, tvar, newname = newname, $ notch = notch, phase_tolerance = phase_tol, $ ind_spike = ind_spike, threshold = thres, $ sc = sc, tper = tper, tphase = tphase ARGUMENTS: tvar: (In, required) Tplot name of esvy data. KEYWORDS: newname: (In, optional) Tplot name for cleaned data. Default is something like 'rbspa_esvy_clean'. notch: (In, optional) Number of data points to be notched. Default = 21. phase_tolerance: (In, optional) Spin phase tolerance for locating spikes in the axial component. Default = 5 (degree) ind_spike: (Out, optional) A named variable to return the found spikes to. threhold: (In, optional) Threshold for finding extrema when locating spikes. Default = 0.1. sc: (In, optional) Spacecraft name. Default = strmid(tvar, 4, 1) tper: (In, optional) Tplot name of spin period data. Default is something like 'rbspa_spinper'. tphase: (In, optional) Tplot name of spin phase data. Default is something like 'rbspa_spinphase'. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-11-11: Created by Jianbao Tao (JBT), SSL, UC Berkley. 2012-11-12: Initial release in TDAS. JBT, SSL/UCB. VERSION: $LastChangedBy: jianbao_tao $ $LastChangedDate: 2012-11-12 14:34:49 -0800 (Mon, 12 Nov 2012) $ $LastChangedRevision: 11226 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_clean_vsvy.pro $
(See general/missions/rbsp/efw/rbsp_efw_clean_vsvy.pro)
PRO rbsp_efw_config This procedure serves as the RBSP EFW configuration file. It sets global (system) variables and initializes devices This procedure will define the location of data files and the data server. This procedure is intended to be called from within the "RBSP_EFW_INIT" procedure. This should be the only RBSP EFW file that requires modification for use in different locations. There is no need to modify this file if: - Your computer is an SSL UNIX machine that mounts "/disks/data/" (i.e. ALL Linux and Solaris machines at SSL) - You use a portable computer that will be caching files on a local hard drive. Settings in this file will be overridden by settings in the environment. (see setup_themis or setup_themis_bash for examples of setting environment variables on UNIX-like systems. The environment can also be set on Windows systems.) KEYWORDS no_color_setup: do not set colors if already taken care of Author: Peter Schroeder Jul 2011 $LastChangedBy: peters $ $LastChangedDate: 2012-02-09 14:17:52 -0800 (Thu, 09 Feb 2012) $ $LastChangedRevision: 9704 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_config.pro $
(See general/missions/rbsp/efw/rbsp_efw_config.pro)
Function: rbsp_efw_config_filedir.pro Purpose: Get the applications user directory for RBSP EFW data analysis software $LastChangedBy: peters $ $LastChangedDate: 2011-12-28 10:26:47 -0800 (Wed, 28 Dec 2011) $ $LastChangedRevision: 9477 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_config_filedir.pro $
(See general/missions/rbsp/efw/rbsp_efw_config_filedir.pro)
NAME: rbsp_efw_create_esvy_uvw_from_vsvy.pro (see rbsp_efw_create_esvy_uvw_from_vsvy_testing.pro to compare to known good data) SYNTAX: PURPOSE: Create the UVW Ew waveform data from the single-ended measurements. Returns tplot variable rbspx_efw_esvy. This routine is similar to rbsp_load_efw_waveform.pro called with the 'esvy' keyword. That routine will just load Esvy straight from the L1 files. However, the output is based on V12 and V34, which is not useful if one of the antennas is bad. This routine allows you to construct Esvy UVW from any combination of antenna pairs. INPUT: date -> 'yyyy-mm-dd' probe -> 'a' or 'b' bad_probe -> (integer) probe to avoid (1,2,3, or 4) KEYWORDS: pairs -> can directly input antenna pairs to be used instead of just indicating the bad_antennas rerun -> don't reload spice kernels or other stuff method -> 1 = (default) Calculate Ew directly using linear combination of diagonal antenna pairs. Project the result onto the usual u or v axis. For ex, if V1 is bad we can calculate V12 from V23 and V24 method -> 2 = Calculate Ew using average of good boom pair. Ex, if V1 is bad then E12 = 2*(V3+V4)/2 - V2 method -> 3 = (NOT WORKING YET) mimic the bad antenna by time-shifting data from adjacent antenna by 1/4 spinperiod. For ex, if V4 is bad we can substitute V4 data with time-shifted V1 data. This method can be useful if two probe potentials are misbehaving. Ex. 2015-03-17 at 20:00. Only V2 and V4 are good. Comparison of method 1 and 2 method 1 -> disadvantage: shorter baseline for calculating Ew (length*cos(45) advantage: No time-shift involved. Higher resolution for final data product method 2 -> disadvantage: larger time-shift (1/4 sp as opposed to 1/8) advantage: longer antenna baselines. Always 100 m. OUTPUT: tplot variable rb_efw_esvy, which is the Efield in UVW coord. This can then be despun using rbsp_uvw_to_mgse.pro or spinfit with rbsp_spinfit. EXAMPLES: Call for two bad antennas. rbsp_efw_create_esvy_uvw_from_vsvy,'a',bad_antennas=[1,2],method=1 For this example V34 will be time-shifted by 1/4 spinperiod to mimic V12 Call for one bad antenna rbsp_efw_create_esvy_uvw_from_vsvy,'a',bad_antennas=1,method=1 explicitly define antenna pairs to be used (assume V4 is bad) rbsp_efw_create_esvy_uvw_from_vsvy,'a',pairs=['12','31'],method=1 In this case V1 will be time-shifted by 1/4 spinperiod to mimic V4. HISTORY: Written by Aaron W Breneman, June 2016 VERSION:
(See general/missions/rbsp/efw/rbsp_efw_create_esvy_uvw_from_vsvy.pro)
NAME: rbsp_efw_deconvol_inst_resp (function) PURPOSE: De-convolve instrument responses for RBSP EFW data, including search-coil data that are channeled into EFW. It will return a tplot data structure. CATEGORIES: CALLING SEQUENCE: result = rbsp_efw_deconvol_inst_resp(data, probe, datatype) ARGUMENTS: data: (Input, required) A tplot data structure, i.e., a structure with the form {x:time_array, y:[nt, 3]}. probe: (Input, required) RBSP probe name. It should be 'a' or 'b'. datatype: (Input, required) Data type name. Valid names are: 'eb2', 'mscb1', 'mscb2'. KEYWORDS: None. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-08-23: Created by Jianbao Tao (JBT), SSL, UC Berkley. 2013-06-21: JBT. 1. Added support to eb1. 2. Removed hard-wired sample rate. 2014-06-01: AWB Checks to be sure that block length is greater than kernel length Not doing this can cause blk_con to fail for short bursts. Version: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2014-09-17 14:33:45 -0700 (Wed, 17 Sep 2014) $ $LastChangedRevision: 15817 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_deconvol_inst_resp.pro $
(See general/missions/rbsp/efw/rbsp_efw_deconvol_inst_resp.pro)
NAME: RBSP_EFW_DSC_TO_MGSE SYNTAX: rbsp_dsc_to_mgse,'a',tplot_var,wgse PURPOSE: Rotates data from despun spacecraft coordinates (DSC) into the modified GSE (MGSE) coordinate system. DSC is defined: Z_DSC is the spin axis direction, W_SC X_DSC is the sun sensor triggering direction, perpendicular to the spin axis Y_DSC completes the RH system in the spin plane MGSE is defined: Y_MGSE=-W_SC(GSE) x Z_GSE Z_MGSE=W_SC(GSE) x Y_MGSE X_MGSE=Y_MGSE x Z_MGSE INPUT: probe - either 'a' or 'b' tvar - TPLOT variable containing 3-component DSC data (either string or integer). tvar_wgse - TPLOT variable containing the spin axis pointing direction in GSE coord. Get this from rbsp_load_spice_cdf_file.pro KEYWORDS: suffix = 'string', suffix appended to the tplot variable name. Default is 'mgse' uangle = degrees, angle between sun sensor and +U (EFW 1) boom /debug - save various quantities for debugging NOTES: 0) This routine does not check that the supplied data is in DSC system. HISTORY: 1. Created July 2020 - Aaron Breneman forked from Kris Kersten's rbsp_dsc_to_mgse.pro VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2020-09-11 13:41:36 -0700 (Fri, 11 Sep 2020) $ $LastChangedRevision: 29145 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_dsc_to_mgse.pro $
(See general/missions/rbsp/efw/rbsp_efw_dsc_to_mgse.pro)
NAME: rbsp_efw_get_cal_params (function) PURPOSE: Return RBSP EFW calibration parameters for converting L1 data to L2 data. CATEGORIES: CALLING SEQUENCE: cp = rbsp_efw_get_cal_params(time) ARGUMENTS: time: (Input, required) A floating time scalar for determining time-dependent calibration parameters. KEYWORDS: None. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-08-07: Created by Jianbao Tao (JBT), SSL, UC Berkley. VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2014-02-25 11:57:04 -0800 (Tue, 25 Feb 2014) $ $LastChangedRevision: 14428 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_get_cal_params.pro $
(See general/missions/rbsp/efw/rbsp_efw_get_cal_params.pro)
NAME: rbsp_efw_get_gain_results PURPOSE: return structure with freq-dependent calibration curves for the searchcoil and EDC channnels on EFW. Also includes notes on how to apply the calibration CATEGORIES: CALLING SEQUENCE: x = rbsp_efw_get_gain_results() ARGUMENTS: KEYWORDS: COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2013-05-15: Created by Aaron Breneman (UMN) VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2013-05-16 13:03:08 -0700 (Thu, 16 May 2013) $ $LastChangedRevision: 12351 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_get_gain_results.pro $
(See general/missions/rbsp/efw/rbsp_efw_get_gain_results.pro)
PROCEDURE: rbsp_efw_init PURPOSE: Initializes system variables for RBSP EFW. Can be called from idl_startup to set custom locations. The system variable !RBSP_EFW is defined here. The elements of this structure are explained below: !RBSP_EFW.LOCAL_DATA_DIR This is the root location for all RBSP EFW data files. The RBSP EFW software expects all data files to reside in specific subdirectories relative to this root directory.; !RBSP_EFW.REMOTE_DATA_DIR This is the URL of the server that can provide the data files. (default is: "http://themis.ssl.berkeley.edu/data/themis/") if the software does not find a needed file in LOCAL_DATA_DIR, then it will attempt to download the data from the URL and REMOTE_DATA_DIR is defined, the software will attempt to download the file from REMOTE_DATA_DIR, place it in LOCAL_DATA_DIR with the same relative pathname, and then continue processing. (NOT YET IMPLEMENTED) KEYWORDS: RESET: Reset !rbsp to values in environment (or values in keywords). LOCAL_DATA_DIR: use given value for local_data_dir, rather than environment. Only works on initial call or reset. REMOTE_DATA_DIR: Use given value for remote_data_dir, rather than env. Only works on inital call or reset. NO_COLOR_SETUP do not set colors if already taken care of Typical examples: Desktop UNIX/LINUX computer located at SSL LOCAL_DATA_DIR = '/disks/data/rbsp/' ; This master directory is read only. REMOTE_DATA_DIR = '' ; Should be empty string. (/disks/data/rbsp and server are the same) Desktop WINDOWS computer located at SSL LOCAL_DATA_DIR = '\\justice\data\rbsp\' ; Justice is a samba server (physically the same as /disk/data/rbsp) REMOTE_DATA_DIR = '' laptop WINDOWS computer located far from a data server, but with internet connection. LOCAL_DATA_DIR = 'C;\data\rbsp\' ; Local (portable) directory on laptop REMOTE_DATA_DIR = 'http://themis.ssl.berkeley.edu/data/themis/' ; URL used to download data to LOCAL_DATA_DIR MacOS computer located away from SSL without a nearby data server LOCAL_DATA_DIR = '/data/rbsp/' ; Local (portable) directory on laptop REMOTE_DATA_DIR = 'http://themis.ssl.berkeley.edu/data/themis/' ; URL used to download data to LOCAL_DATA_DIR Note: If automatic downloads are used. (i.e. REMOTE_DATA_DIR is not an empty string) the user must ensure that LOCAL_DATA_DIR is writeable. Note to WINDOWS users: the WINDOWS version of IDL accepts both the '\' and '/' character as the directory separation character. The converse is not true. HISTORY Written by Peter Schroeder July 2011 $LastChangedBy: peters $ $LastChangedDate: 2014-02-06 15:28:08 -0800 (Thu, 06 Feb 2014) $ $LastChangedRevision: 14187 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_init.pro $
(See general/missions/rbsp/efw/rbsp_efw_init.pro)
NAME: rbsp_efw_read_config PURPOSE: Reads the rbsp_efw_config file CALLING SEQUENCE: cstruct = rbsp_efw_read_config() INPUT: none, the filename is hardcoded, 'rbsp_efw_config.txt',and is s put in a folder given by the routine rbsp_efw_config_filedir, that uses the IDL routine app_user_dir to create/obtain it OUTPUT: cstruct = a structure with the changeable fields of the !rbsp_efw structure HISTORY: 01-jul-2011, peters $LastChangedBy: nikos $ $LastChangedDate: 2015-11-18 14:03:31 -0800 (Wed, 18 Nov 2015) $ $LastChangedRevision: 19411 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_efw_read_config.pro $
(See general/missions/rbsp/efw/rbsp_efw_read_config.pro)
Remove spikes around perigee due to mode switch.
(See general/missions/rbsp/efw/rbsp_emfisis_remove_perigee_spike.pro)
NAME: rbsp_get_efw_dfb_config (function) PURPOSE: Decode the EFW DFB Config byte CALLING SEQUENCE: result = rbsp_get_efw_dfb_config(config_byte) ARGUMENTS: config_byte: (Input, required) Integer or array of integers containing the DFB config byte KEYWORDS: COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2013-04-03: Created by Peter Schroeder (PCS), SSL, UC Berkley. Version: $LastChangedBy: peters $ $LastChangedDate: 2013-04-08 10:45:51 -0700 (Mon, 08 Apr 2013) $ $LastChangedRevision: 11983 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_get_efw_dfb_config.pro $
(See general/missions/rbsp/efw/rbsp_get_efw_dfb_config.pro)
Procedure: rbsp_gse2mgse Purpose: Transforms from GSE to MGSE (modified GSE coord..defined below) If W gse is the spin axis unit vector in GSE coordinates, then (1) Ymgse = -(Wgse x Zgse) So Ymgse is now in the spin plane and in the ecliptic plane and duskward. (nearly same as Ygse) (2) Zmgse = (Wgse x Ymgse) So Z mgse points in the spin plane nearly along the positive normal to the ecliptic (3) Xmgse= Ymgse x Zmgse This actually the spin axis of the spacecraft X mgse= W gse One of the properties of this coordinate system is that if the spin axis points towards the sun, then the MGSE system is exactly the same as the GSE system. This is a real advantage when thinking about the data and comparing to other instruments. Second, since on RBSP the spin axis has a large angle relative to the z GSE axis the cross product in equation 1 is well defined. None of the cross products involve nearly parallel vectors- nothing is ever close to degenerate. Input : tname = the tplot variable with data in GSE coord [n,3] wgse = the w-antenna direction in GSE coord. This can either be a [3] element array or an [n,3] element array. Here's how to get wgse: 1) rbsp_efw_position_velocity_crib.pro 2) rbsp_load_state,probe='a',datatype=['spinper','spinphase','mat_dsc','Lvec'] Whichever way you choose, you'll get the direction from: get_data,rbspx+'_spinaxis_direction_gse',data=wsc_GSE wgse = wsc_gse.y newname = name for output tplot variable. If not set then new name is old name + '_mgse' Example: rbsp_gse2mgse,'mag_gse',[1,0,0],/nochange Written by Aaron Breneman, Oct 31, 2012 2013-10-02 -> added a check to make sure the WGSE array is the correct size. Returns if it isn't. 2022-08-07 -> just use rbsp_mgse2gse with inverse.
(See general/missions/rbsp/efw/rbsp_gse2mgse.pro)
NAME: rbsp_interp_spin_phase (function) PURPOSE: Calculate spin phases at arbitrary times using linear interpolation. CATEGORIES: CALLING SEQUENCE: phase = rbsp_interp_spin_phase(sc, time_array, $ newname = newname $ , tper = tper $ , tphase = tphase $ , tumbra_sta = tumbra_sta $ , tumbra_end = tumbra_end $ , umbra_pad = umbra_pad) ARGUMENTS: sc: (In, required) Spacecraft name. Should be 'a' or 'b'. time_array: (In, required) A time array at which spin phases are returned. KEYWORDS: newname: (In, optional) A tplot name for storing the returned spin phases. If not provided, the spin phases are not stored into a tplot name. tper: (In, optional) Spin-period tplot name. By default, tper = 'rbsp' + strlowcase(sc[0]) + '_spinper' tphase: (In, optional) Spin-phase tplot name. By default, tphase = 'rbsp' + strlowcase(sc[0]) + '_spinphase' tumbra_sta: (In, optional) Umbra starting time tplot name. By default, tumbra_sta = 'rbsp' + strlowcase(sc[0]) + '_umbta_sta' tumbra_end: (In, optional) Umbra ending time tplot name. By default, tumbra_sta = 'rbsp' + strlowcase(sc[0]) + '_umbta_end' umbra_pad: (In, optional) Time padding to the umbra times. By default, umbra_pad = [-20d, 20d] * 60d This padding is to account for spin-period distrotion around umbra. APL has learned this problem, so this default padding will likely change in the future. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-10-24: Created by Jianbao Tao (JBT), SSL, UC Berkley. 2012-11-05: Initial release to TDAS. JBT, SSL/UCB. VERSION: $LastChangedBy: nikos $ $LastChangedDate: 2016-10-06 16:51:43 -0700 (Thu, 06 Oct 2016) $ $LastChangedRevision: 22061 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_interp_spin_phase.pro $
(See general/missions/rbsp/efw/rbsp_interp_spin_phase.pro)
NAME: RBSP_LOAD_EFW_BURST_TIMES SYNTAX: rbsp_load_efw_burst_times,probe='a b' PURPOSE: Loads EFW B1 and B2 availability KEYWORDS: probe = 'a', 'b', 'a b', or ['a','b'] trange = time range local_data_dir = local data directory, for overriding default location set in !rbsp_efw or root_data_dir() b1_times, b2_times -> set to named variables to return [x,2] arrays of the start and stop times of each burst in trange HISTORY: 11/2012 - Created - Kris Kersten, kris.kersten@gmail.com 22 Apr 2013 - changed remote_data_dir location 04 Sept 2013 - added support for EB1,2 and MSCB1,2 13 Jan 2014 - added b1_times, b2_times keywords (AWB) VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2020-01-13 10:26:26 -0800 (Mon, 13 Jan 2020) $ $LastChangedRevision: 28188 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_efw_burst_times.pro $
(See general/missions/rbsp/efw/rbsp_load_efw_burst_times.pro)
NAME: RBSP_LOAD_EFW_ESVY_MGSE SYNTAX: rbsp_load_efw_esvy_mgse,probe='a' rbsp_load_efw_esvy_mgse,probe='a',/no_spice_load PURPOSE: Loads EFW ESVY data and despins using SPICE via rbsp_uvw_to_mgse.pro The MGSE coordinate system is defined: Y_MGSE=-W_SC(GSE) x Z_GSE Z_MGSE=W_SC(GSE) x Y_MGSE X_MGSE=Y_MGSE x Z_MGSE where W_SC(GSE) is the spin axis direction in GSE. This is equivalent to the GSE coordinate system if the spin axis lies along the X_GSE direction. KEYWORDS: probe = 'a' or 'b' NOTE: single spacecraft only, does not accept ['a b'] NOTE: defaults to probe='a' /no_spice_load - skip loading/unloading of SPICE kernels NOTE: This assumes spice kernels have been manually loaded using: rbsp_load_spice_predict ; (optional) rbsp_load_spice_kernels ; (required) /debug - prints debugging info /qa - load the QA test file instead of standard L1 file bad_probe -> integer indicating a bad probe. NOTES: HISTORY: 1. Created Nov 2012 - Kris Kersten, kris.kersten@gmail.com VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2017-04-05 10:09:53 -0700 (Wed, 05 Apr 2017) $ $LastChangedRevision: 23110 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_efw_esvy_mgse.pro $
(See general/missions/rbsp/efw/rbsp_load_efw_esvy_mgse.pro)
Procedure: RBSP_LOAD_EFW_FBK_L2 Purpose: Loads RBSP EFW L2 filterbank 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' varformat=strin 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 kw to narrow the data products. Wildcards and glob-style patterns accepted (e.g., ef?, *_dot0). VARNAMES: names of variables to load from cdf: default is all. /DOWNLOADONLY: download file but don't read it. (NOT IMPLEMENTED YET) /ETU: If set, load data from the ETU. /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 tper: (In, optional) Tplot name of spin period data. By default, tper = pertvar. If tper is set, pertvar = tper. tphase: (In, optional) Tplot name of spin phase data. By default, tphase = 'rbsp' + strlowcase(sc[0]) + '_spinphase' Note: tper and and tphase are mostly used for using eclipse-corrected spin data. Example: rbsp_load_efw_filterbank_l2,probe=['a', 'b'] HISTORY: 1. Written by Aaron Breneman, August, 2015 $LastChangedBy: aaronbreneman $ $LastChangedDate: 2018-12-17 14:55:59 -0800 (Mon, 17 Dec 2018) $ $LastChangedRevision: 26349 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_efw_fbk_l2.pro $
(See general/missions/rbsp/efw/rbsp_load_efw_fbk_l2.pro)
Procedure: RBSP_LOAD_EFW_FIT Purpose: Loads RBSP EFW FIT 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' varformat=string 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 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. (NOT IMPLEMENTED YET) /INTEGRATION: If set, load data from integration. /QA: If set, load data from l1_qa testing directory. /MSIM: If set, load data from mission simulations. /ETU: If set, load data from the ETU. /DOWNLOADONLY: download file but don't read it. (NOT IMPLEMENTED YET) /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 type: set to 'calibrated' to automatically convert data into physical units Example: rbsp_load_efw_fit,/get_suppport_data,probe=['a', 'b'] Notes: 1. Written by Peter Schroeder, February 2012 $LastChangedBy: aaronbreneman $ $LastChangedDate: 2018-12-17 14:57:49 -0800 (Mon, 17 Dec 2018) $ $LastChangedRevision: 26350 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_efw_fit.pro $
(See general/missions/rbsp/efw/rbsp_load_efw_fit.pro)
Procedure: RBSP_LOAD_EFW_SPEC Purpose: Loads RBSP EFW SPEC 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' varformat=string 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 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. (NOT IMPLEMENTED YET) /DOWNLOADONLY: download file but don't read it. (NOT IMPLEMENTED YET) /QA: If set, load data from 11_qa testing directory. /INTEGRATION: If set, load data from integration. /MSIM: If set, load data from mission simulations. /ETU: If set, load data from the ETU. /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 type: set to 'calibrated' to automatically convert data into physical units Example: rbsp_load_efw_spec,/get_support_data,probe=['a', 'b'] Notes: 1. Written by Peter Schroeder, February 2012 $LastChangedBy: aaronbreneman $ $LastChangedDate: 2018-12-17 14:27:59 -0800 (Mon, 17 Dec 2018) $ $LastChangedRevision: 26344 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_efw_spec.pro $
(See general/missions/rbsp/efw/rbsp_load_efw_spec.pro)
Procedure: RBSP_LOAD_EFW_SPEC_L2 Purpose: Loads RBSP EFW L2 spectrogram data from EFW server 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' varformat=strin 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 kw to narrow the data products. Wildcards and glob-style patterns accepted (e.g., ef?, *_dot0). VARNAMES: names of variables to load from cdf: default is all. /DOWNLOADONLY: download file but don't read it. (NOT IMPLEMENTED YET) /ETU: If set, load data from the ETU. /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 tper: (In, optional) Tplot name of spin period data. By default, tper = pertvar. If tper is set, pertvar = tper. tphase: (In, optional) Tplot name of spin phase data. By default, tphase = 'rbsp' + strlowcase(sc[0]) + '_spinphase' Note: tper and and tphase are mostly used for using eclipse-corrected spin data. Example: rbsp_load_efw_spec_l2,probe=['a', 'b'] HISTORY: 1. Written by Aaron Breneman, August, 2015 $LastChangedBy: aaronbreneman $ $LastChangedDate: 2020-07-27 13:36:11 -0700 (Mon, 27 Jul 2020) $ $LastChangedRevision: 28942 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_efw_spec_l2.pro $
(See general/missions/rbsp/efw/rbsp_load_efw_spec_l2.pro)
Procedure: RBSP_LOAD_EFW_WAVEFORM Purpose: Loads RBSP EFW Waveform 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' varformat=strin 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 DATATYPE: Input, string. Default setting is to calibrate all raw quantites and also produce all _0 and _dot0 quantities. Use DATATYPE kw to narrow the data products. Wildcards and glob-style patterns accepted (e.g., ef?, *_dot0). 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. (NOT IMPLEMENTED YET) /DOWNLOADONLY: download file but don't read it. (NOT IMPLEMENTED YET) /QA: If set, load data from l1_qa testing directory. /INTEGRATION: If set, load data from integration. /MSIM: If set, load data from mission simulations. /ETU: If set, load data from the ETU. /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 type: set to 'calibrated' to automatically convert data into physical units coord: Set to 'uvw' to return data in UVW. Otherwise the output is in DSC coordinate system tper: (In, optional) Tplot name of spin period data. By default, tper = pertvar. If tper is set, pertvar = tper. tphase: (In, optional) Tplot name of spin phase data. By default, tphase = 'rbsp' + strlowcase(sc[0]) + '_spinphase' Note: tper and and tphase are mostly used for using eclipse-corrected spin data. Example: rbsp_load_efw_waveform,/get_suppport_data,probe=['a', 'b'] HISTORY: 1. Written by Peter Schroeder, February 2012 2012-11-06: JBT, SSL/UCB. 1. Added keywords *coord*, *tper*, and *tphase* that are passed into *rbsp_efw_cal_waveform*. $LastChangedBy: aaronbreneman $ $LastChangedDate: 2018-12-17 14:06:25 -0800 (Mon, 17 Dec 2018) $ $LastChangedRevision: 26341 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_efw_waveform.pro $
(See general/missions/rbsp/efw/rbsp_load_efw_waveform.pro)
Procedure: RBSP_LOAD_EFW_WAVEFORM_L2 Purpose: Loads RBSP EFW L2 Waveform 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' varformat=strin 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 DATATYPE: Input, string. Default setting is to calibrate all raw quantites and also produce all _0 and _dot0 quantities. Use DATATYPE kw to narrow the data products. Wildcards and glob-style patterns accepted (e.g., ef?, *_dot0). 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. (NOT IMPLEMENTED YET) /DOWNLOADONLY: download file but don't read it. (NOT IMPLEMENTED YET) /QA: If set, load data from l1_qa testing directory. /INTEGRATION: If set, load data from integration. /MSIM: If set, load data from mission simulations. /ETU: If set, load data from the ETU. /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 type: set to 'calibrated' to automatically convert data into physical units coord: Set to 'uvw' to return data in UVW. Otherwise the output is in DSC coordinate system tper: (In, optional) Tplot name of spin period data. By default, tper = pertvar. If tper is set, pertvar = tper. tphase: (In, optional) Tplot name of spin phase data. By default, tphase = 'rbsp' + strlowcase(sc[0]) + '_spinphase' Note: tper and and tphase are mostly used for using eclipse-corrected spin data. Example: rbsp_load_efw_waveform_l2,/get_suppport_data,probe=['a', 'b'] HISTORY: 1. Written by Peter Schroeder, February 2012 2012-11-06: JBT, SSL/UCB. 1. Added keywords *coord*, *tper*, and *tphase* that are passed into *rbsp_efw_cal_waveform*. $LastChangedBy: aaronbreneman $ $LastChangedDate: 2018-12-17 14:16:58 -0800 (Mon, 17 Dec 2018) $ $LastChangedRevision: 26342 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_efw_waveform_l2.pro $
(See general/missions/rbsp/efw/rbsp_load_efw_waveform_l2.pro)
Procedure: RBSP_LOAD_EFW_WAVEFORM_L3 Purpose: Loads RBSP EFW L3 Waveform 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' varformat=strin 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 kw to narrow the data products. Wildcards and glob-style patterns accepted (e.g., ef?, *_dot0). VARNAMES: names of variables to load from cdf: default is all. /DOWNLOADONLY: download file but don't read it. (NOT IMPLEMENTED YET) /ETU: If set, load data from the ETU. /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 tper: (In, optional) Tplot name of spin period data. By default, tper = pertvar. If tper is set, pertvar = tper. tphase: (In, optional) Tplot name of spin phase data. By default, tphase = 'rbsp' + strlowcase(sc[0]) + '_spinphase' Note: tper and and tphase are mostly used for using eclipse-corrected spin data. Example: rbsp_load_efw_waveform_l3,probe=['a', 'b'] HISTORY: 1. Written by Peter Schroeder, February 2012 2012-11-06: JBT, SSL/UCB. 1. Added keywords *coord*, *tper*, and *tphase* that are passed into *rbsp_efw_cal_waveform*. $LastChangedBy: aaronbreneman $ $LastChangedDate: 2018-12-17 14:19:27 -0800 (Mon, 17 Dec 2018) $ $LastChangedRevision: 26343 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_efw_waveform_l3.pro $
(See general/missions/rbsp/efw/rbsp_load_efw_waveform_l3.pro)
Procedure: RBSP_LOAD_EFW_XSPEC Purpose: Loads RBSP EFW XSPEC 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' varformat=string 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 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. (NOT IMPLEMENTED YET) /DOWNLOADONLY: download file but don't read it. (NOT IMPLEMENTED YET) /QA: If set, load data from l1_qa testing directory. /INTEGRATION: If set, load data from integration. /MSIM: If set, load data from mission simulations. /ETU: If set, load data from the ETU. /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 type: set to 'calibrated' to automatically convert data into physical units Example: rbsp_load_efw_xspec,/get_suppport_data,probe=['a', 'b'] Notes: 1. Written by Peter Schroeder, February 2012 $LastChangedBy: aaronbreneman $ $LastChangedDate: 2018-12-17 14:50:55 -0800 (Mon, 17 Dec 2018) $ $LastChangedRevision: 26347 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_efw_xspec.pro $
(See general/missions/rbsp/efw/rbsp_load_efw_xspec.pro)
NAME: RBSP_LOAD_EMFISIS_BURST_TIMES SYNTAX: rbsp_load_emfisis_burst_times,probe='a b' PURPOSE: Loads EMFISIS Burst data availability. Creates a tplot variable indicating available times. date = 'yyyy-mm-dd' probe = 'a' or 'b' VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2018-12-06 09:25:24 -0800 (Thu, 06 Dec 2018) $ $LastChangedRevision: 26261 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_emfisis_burst_times.pro $
(See general/missions/rbsp/efw/rbsp_load_emfisis_burst_times.pro)
NAME: rbsp_load_maneuver_file SYNTAX: x = rbsp_load_maneuver_file(probe,date) PURPOSE: Returns a structure with start and end times of maneuvers from the MOC data product "maneuver_sequence" files. INPUT: probe = 'a' or 'b' date = '2012-10-13' format http://themis.ssl.berkeley.edu/data/rbsp/MOC_data_products NOTES: uses the MAXARMTIME variable to determine the extent of the maneuver. This may be the maximum upper limit maneuver time and not the actual maneuver time. Unfortunately the final maneuver log files are Word documents. HISTORY: Written by Aaron W Breneman - University of Minnesota 2014-10-26 VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2019-12-19 11:19:56 -0800 (Thu, 19 Dec 2019) $ $LastChangedRevision: 28126 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_load_maneuver_file.pro $
(See general/missions/rbsp/efw/rbsp_load_maneuver_file.pro)
TYPE: function. NAME: rbsp_mgse2gse. PURPOSE: Convert vector in mGSE coord to GSE. (Also see rbsp_gse2mgse.pro) PARAMETERS: tname, in, type = string or int, required. tplot variable name or number, data must be in [n,3]. wgse, in/out, type = [3] or [n,3], optional. The w-antenna direction in GSE. By default, we load wgse automatically. It is saved for backward compatibility. If set, then keywords probe and no_spice_load has no effect. If omitted, then use spice to get wgse. KEYWORDS: newname = newname, in, string, optional. name of output tplot variable. If not set, newname = oldname+'_mgse'. inverse = inverse, in, boolean, optional. If set do gse->mgse, otherwise do mgse->gse. probe = probe, in, string, optional. probe can be 'a' or 'b'. Default is 'a'. Used only when wgse is not set. no_spice_load = no_spice_load, in, boolean, optional. Set when spice kernel is loaded already. Set to 0, to use spice kernel. RETURN: none. EXAMPLE: rbsp_mgse2gse, 'rbspa_pos_mgse', wgse, newname = 'rbspa_pos_gse' rbsp_mgse2gse, 'rbspa_pos_gse', wgse, newname = 'rbspa_pos_mgse', /inverse rbsp_mgse2gse, 'rbspa_pos_mgse', newname = 'rbspa_pos_gse', $ probe = 'a', /no_spice_load rbsp_mgse2gse, 'rbspa_pos_gse', newname = 'rbspa_pos_mgse', /inverse, $ probe = 'a', /no_spice_load DEPENDENCE: idl_icy module, see icy_test.pro in tdas. NOTES: * wgse and x_mgse are the same, x_mgse = {sint*cosp, sint*sinp, cost}. * v_gse = {vx_gse, vy_gse, vz_gse}, v_mgse = {vx_mgse, vy_mgse, vz_mgse}, gse->mgse, M1 = | sint*cosp, sint*sinp, cost | | -sinp , cosp , 0 | |-cost*cosp,-cost*sinp, sint | mgse->gse, M2 = transpose(M1), v_gse = M2*v_mgse. HISTORY: Sheng Tian, UMN 2013-09-18 (created) Sheng Tian, 2022-07-08, load wsc_gse from spice_var. VERSION: $LastChangedBy: jimm $ $LastChangedDate: 2024-07-10 12:50:20 -0700 (Wed, 10 Jul 2024) $ $LastChangedRevision: 32732 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_mgse2gse.pro $
(See general/missions/rbsp/efw/rbsp_mgse2gse.pro)
NAME: rbsp_msc_response (function) PURPOSE: Calculate the transmittance of the search-coil magnetometer. CATEGORIES: CALLING SEQUENCE: response = rbsp_msc_response(f, probe, component) ARGUMENTS: f: (Input, required) A floating array of frequencies at which the responses are calculated. probe: (Input, required) RBSP probe name. It should be 'a' or 'b'. component: (Input, required) Component name. Valid names are: 'Bu', 'Bv', 'Bw'. KEYWORDS: None. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2012-09-04: Created by Jianbao Tao (JBT), SSL, UC Berkley. Version: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2014-02-25 12:02:41 -0800 (Tue, 25 Feb 2014) $ $LastChangedRevision: 14431 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_msc_response.pro $
(See general/missions/rbsp/efw/rbsp_msc_response.pro)
PROCEDURE : rbsp_poynting_flux PURPOSE : calculates Poynting flux (ergs/s/cm^2). Separates into field-aligned and perp components Returns results as tplot variables. Includes values with and w/o spinaxis component REQUIRES: tplot library KEYWORDS: Bw -> tplot name of the [n,3] magnetic field waveform (nT) in MGSE Ew -> tplot name of the [n,3] electric field waveform (mV/m) in MGSE Tshort, Tlong -> short and long period of waveform to use. Bo -> (optional keyword) array of DC magnetic field directions in MGSE. Use, for example, if Bw is from AC-coupled data. If not included then Bw is downsampled and used as background field method1 -> uses smoothing instead of a bandpass_filter which results in a sharper freq rolloff than smoothing method. Both methods give very similar results for test chorus waves method2 (default -- seems to work much better for higher freqs) -> The waveform data are first downsampled to 1/Tshort to avoid the wasted computation of having to run program with data at unnecessarily high sample rate. The waveform is then run through bandpass_filter to the frequency range flow=1/Tlong...fhigh=1/Tshort NOTES: DO NOT INPUT DATA WITH SIGNIFICANT GAPS ******************************************************************** Tested on Van Allen Probes chorus from EFW's B1 data on 2014-08-27 at ~07:42 on probe A. A is at +20 mlat and the Pflux indicates propagation away from eq with magnitude values consistent with those in Li et al., 2013 and Santolik et al., 2010 ******************************************************************** Poynting flux coord system P1mgse = Bmgse x xhat_mgse (xhat_mgse is spin axis component) P2mgse = Bmgse x P1mgse P3mgse = Bmgse The output tplot variables are: These three output variables contain a mix of spin axis and spin plane components: pflux_perp1 -> Poynting flux in perp1 direction pflux_perp2 -> Poynting flux in perp2 direction pflux_para -> Poynting flux along Bo These partial Poynting flux calculations contain only spin plane Ew. pflux_nospinaxis_perp pflux_nospinaxis_para All of the above variables projected to the ionosphere CREATED: 11/28/2012 CREATED BY: Aaron W. Breneman LAST MODIFIED: MM/DD/YYYY v1.0.0 MODIFIED BY:
(See general/missions/rbsp/efw/rbsp_poynting_flux.pro)
NAME: rbsp_read_ect_mag_ephem SYNTAX: PURPOSE: Read in RBSP ECT's official magnetic field model predicted quantities INPUT: sc -> 'a' or 'b' date -> '2014-01-01' type -> defaults to OP77Q. Can also have "TS04D" (definitive) or "T89Q" for predicted. OUTPUT: tplot variables with prefix 'rbsp'+sc+'_ME_' Will also return perigeetimes as keyword KEYWORDS: HISTORY: Written by Aaron W Breneman, UMN VERSION: $LastChangedBy: $ $LastChangedDate: $ $LastChangedRevision: $ $URL: $
(See general/missions/rbsp/efw/rbsp_read_ect_mag_ephem.pro)
NAME: rbsp_spinfit (procedure) PURPOSE: Derive spin-fit E-field from instantaneous E-field measurements. The spin-fit model is as such: fit = A + B * cos(phi) + C * sin(phi) where B and C are E-fields in the DSC X and Y dimensions, and angle is the angle between the DSC X direction and the EFW spin plane boom used in the spin-fit derivation, as demonstrated below. DSC Y | / EFW spin plane boom | / | / | / | / | / | / |/)angle________ DSC X NOTES: 1. Similar to thm_spinfit.pro, this routine is a wrapper of spinfit.pro for RBSP. Unlike thm_spinfit, this routine only works on one tplot variable at a time. 2. Normally, this routine saves four tplot variables, such as 'rbspa_efw_esvy_spinfit_a' 'rbspa_efw_esvy_spinfit_b' 'rbspa_efw_esvy_spinfit_c' 'rbspa_efw_esvy_spinfit' where the first three are the three cooefficients from the fit and the last one is like a normal EFW data type in DSC. CATEGORIES: CALLING SEQUENCE: rbsp_spinfit ,var_name_in, $ sigma=sigma, npoints=npoints, spinaxis=spinaxis, median=median, $ plane_dim=plane_dim, axis_dim=axis_dim, $ min_points=min_points,alpha=alpha,beta=beta, $ phase_mask_starts=phase_mask_starts, $ phase_mask_ends=phase_mask_ends, $ sc = sc, force = force, tper = tper, tphase = tphase ARGUMENTS: var_name_in: IN, REQUIRED EFW tplot data used for the spin-fit derivation. Must be in UVW. KEYWORDS: sc: IN, OPTIONAL Spacecraft name. Must be 'a' or 'b'. /force: IN, OPTIONAL If set, force to do the derivation. Useful when the input tplot data do not have coord_sys information. tper: IN, OPTIONAL Spin-period tplot name. tphase: IN, OPTIONAL Spin-phase tplot name. See spinfit.pro and thm_spinfit.pro for usage of other keywords. Exception: AXIS_DIM defaults to 2 instead of 0 in this routine. COMMON BLOCKS: EXAMPLES: SEE ALSO: HISTORY: 2013-01-22: Created by Jianbao Tao (JBT), SSL, UC Berkley. VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2018-12-21 11:30:03 -0800 (Fri, 21 Dec 2018) $ $LastChangedRevision: 26393 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_spinfit.pro $
(See general/missions/rbsp/efw/rbsp_spinfit.pro)
NAME: rbsp_split_fbk PURPOSE: Split the filterbank data into separate tplot variables for each channel. Can also combine peak and average on a single panel KEYWORDS: probe = 'a' or 'b' NOTE: single spacecraft only, does not accept ['a b'] combine -> set to combine peak and average onto a single plot meansz -> number of data points over which to calculate the number of values the local mean is away from the local standard deviation. This is used to set y-scaling. If not done then the yscale of the FBK plots is often dominated by single large amplitude spikes, masking the majority of the data. Default is 100. ; meansz -> number of data points over which to calculate the mean. This is used ; to set y-scaling. If not done then the yscale of the FBK plots ; is often dominated by single large amplitude spikes, masking the majority ; of the data. Default is 20. ; ysc -> Scale factor for y-scaling. Default is 1. This should be set to ; values greater than 1 for meansz larger than the default. For ; example, ysc=3. works well for meansz=1000. CREATED: Aaron Breneman 11/07/2012 MODIFIED: changed y-scaling based on a running average rather than the max value for each FBK channel. This avoids having a ridiculous yscaling based on a few very large amplitude spiky events. VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2014-04-21 13:19:06 -0700 (Mon, 21 Apr 2014) $ $LastChangedRevision: 14901 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_split_fbk.pro $
(See general/missions/rbsp/efw/rbsp_split_fbk.pro)
NAME: RBSP_UVW_TO_DSC SYNTAX: rbsp_uvw_to_dsc,'a',tplot_var rbsp_uvw_to_dsc,'a',tplot_var,/no_spice_load PURPOSE: Rotates data from spinning spacecraft (UVW) coordinates into despun spacecraft (DSC) coordinates. DSC is defined: Z_DSC is the spin axis direction, W_SC X_DSC is the sun sensor triggering direction, perpendicular to the spin axis Y_DSC completes the RH system in the spin plane INPUT: probe - either 'a' or 'b' tvar - TPLOT variable containing 3-component UVW data (either string or integer). KEYWORDS: uangle = degrees, angle between SSH and U suffix = 'string', suffix appended to the tplot variable name. Default is 'mgse' /debug - save various quantities for debugging NOTES: 0) This routine does not check that the supplied data is in UVW system. HISTORY: 1. Created Nov 2012 - Kris Kersten, kris.kersten@gmail.com VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2020-09-21 18:16:09 -0700 (Mon, 21 Sep 2020) $ $LastChangedRevision: 29174 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_uvw_to_dsc.pro $
(See general/missions/rbsp/efw/rbsp_uvw_to_dsc.pro)
NAME: RBSP_UVW_TO_GSE SYNTAX: rbsp_uvw_to_gse,'a','rbspa_efw_esvy' rbsp_uvw_to_gse,'a','rbspa_efw_esvy',/no_spice_load PURPOSE: Transforms from spinning UVW (RBSP SCIENCE) frame to GSE. INPUT: probe - either 'a' or 'b' tvar - TPLOT variable containing 3-component UVW data (either string or integer tplot variable id) KEYWORDS: suffix=suffix - optional suffix for rotated tplot variable names /no_spice_load - skip loading/unloading of SPICE kernels NOTE: This assumes spice kernels have been manually loaded using: rbsp_load_spice_predict ; (optional) rbsp_load_spice_kernels ; (required) /remove_offset - remove slowly varying offsets in spin plane /debug - prints debugging info NOTES: HISTORY: 1. Created Jan 2013 - Kris Kersten, kris.kersten@gmail.com VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2019-08-14 14:21:17 -0700 (Wed, 14 Aug 2019) $ $LastChangedRevision: 27604 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_uvw_to_gse.pro $
(See general/missions/rbsp/efw/rbsp_uvw_to_gse.pro)
NAME: RBSP_UVW_TO_MGSE SYNTAX: rbsp_uvw_to_mgse,'a','rbspa_efw_esvy' rbsp_uvw_to_mgse,'a','rbspa_efw_esvy',/no_spice_load PURPOSE: Transforms from spinning UVW (RBSP SCIENCE) frame to MGSE. The MGSE coordinate system is defined: Y_MGSE=-W_SC(GSE) x Z_GSE Z_MGSE=W_SC(GSE) x Y_MGSE X_MGSE=Y_MGSE x Z_MGSE where W_SC(GSE) is the spin axis direction in GSE. This is equivalent to the GSE coordinate system if the spin axis lies along the X_GSE direction. INPUT: probe - either 'a' or 'b' tvar - TPLOT variable containing 3-component UVW data (either string or integer tplot variable id) OUTPUT: N/A Rotated timeseries is saved in a new tplot var with _mgse suffix.. KEYWORDS: suffix=suffix - suffix for rotated tplot var name (default is _mgse) /no_offset - skip offset removal in spin plane /force_offset - force offset removal for slowly sampled data /nointerp - use SPICE to calculate rotation matrix directly at each timestep instead of default quaternion interpolation rotation matrix nointerp=2 - use SPICE to calculate spin axis pointing at each timestep instead of interpolating from 5m cadence pointing (this may be useful during maneuvers) _extra --> useful keywords are: 'no_spice_load' 'no_rbsp_efw_init' /debug - prints debugging info NOTES: By default this routine uses SPICE to generate the spin axis pointing direction at a 5 minute cadence, and the despinning matrix at a 1s cadence. These quantities are interpolated (spin axis linearly, and despinning matrix via quaternion interpolation) to the sample times of the input time series. If the input time series is sampled at <= 1S/s, the routine will calculate the SPICE pointing and rotation directly at each time stamp rather than using the interpolation described above. The nointerp keyword is provided to bypass the interpolation and calculate the spin axis pointing direction and rotation matrix at the time stamps of the input time series. Calling the routine with /nointerp or nointerp=1 will cause the rotation matrix to be calculated directly. Calling with nointerp=2 will cause both the rotation matrix and the spin axis pointing direction to be calculated directly. This will be VERY time consuming for high time resolution data, but may be useful for debugging or during spacecraft maneuvers. SPIN PLANE OFFSETS: By default, offsets in the spin plane quantities are removed. This is only valid for quantities sampled faster than the spin period (~12s). The offset removal is automatically skipped for quantities sampled at or below 1S/s. This can be overridden by using the /force_offset keyword. HISTORY: 1. Created Nov 2012 - Kris Kersten, kris.kersten@gmail.com VERSION: $LastChangedBy: aaronbreneman $ $LastChangedDate: 2020-09-21 18:15:56 -0700 (Mon, 21 Sep 2020) $ $LastChangedRevision: 29173 $ $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/missions/rbsp/efw/rbsp_uvw_to_mgse.pro $
(See general/missions/rbsp/efw/rbsp_uvw_to_mgse.pro)
***************************************************************************************** FUNCTION : vector_bandpass.pro PURPOSE : This program does a bandpass filter on the input data using IDL's built-in FFT.PRO routine. The data is first padded with zeroes to ensure the number of elements remains an integer power of 2. The user defines the input vector array of data, the sample rate, and frequency range(s) before running the program, then tells the program whether a low-pass (i.e. only return low frequency signals), high-pass, or middle frequency bandpass filter. The program eliminates the postitive AND negative frequency bins in frequency space to ensure symmetry before performing the inverse FFT on the data. CALLED BY: NA CALLS: power_of_2.pro REQUIRES: NA INPUT: DAT : [N,3]-Array of magnetic or electric field data SR : Scalar defining the sample rate (mHz, Hz, kHz, etc. doesn't matter as long as everything is consistent) LF : Scalar defining the low frequency cutoff (Default = 0) [Note: MUST be same units as SR] HF : Scalar defining the high frequency cutoff (Default = Nyquist) [Note: MUST have same units as SR AND LF] EXAMPLES: htr_mfi2tplot,DATE=date get_data,'WIND_B3_HTR(GSE,nT)',DATA=mag magf = mag.Y tt = mag.X ; -Unix time (s since 01/01/1970) nt = N_ELEMENTS(tx) evl = MAX(tt,/NAN) - MIN(tt,/NAN) ; -Event length (s) nsps = ((nt - 1L)/evl) ; -Approx Sample Rate (Hz) lfmf1 = vector_bandpass(magf,nsps,15d-2,15d-1,/LOWF) KEYWORDS: LOWF : If set, program returns low-pass filtered data with freqs below LF MIDF : If set, program returns bandpass filtered data with freqs between LF and HF **[Default]** HIGHF : If set, program returns high-pass filtered data with freqs above HF CHANGED: 1) Fixed Low Freq. bandpass to get rid of artificial zero frequency bin created by FFT calc. [01/14/2009 v1.0.1] 2) Fixed case where NaN's are in data [01/18/2009 v1.0.2] 3) Changed program my_power_of_2.pro to power_of_2.pro and renamed [08/10/2009 v2.0.0] CREATED: 12/30/2009 CREATED BY: Lynn B. Wilson III LAST MODIFIED: 08/10/2009 v2.0.0 MODIFIED BY: Lynn B. Wilson III *****************************************************************************************
(See general/missions/rbsp/efw/rbsp_vector_bandpass.pro)
Type: function. Purpose: Interpolate given data of at abscissa x to new x. Parameters: data, in, [*], req. For scalar array, dimension is [n0]. For m dimension vector array, dimension is [m, n0] or [n0, m]. oldabs, in, [n0], req. Old abscissa. newabs, in, [n1], req. New abscissa. Keywords: _extra = extra, in, struct, opt. Keywords for interpol, see idl help. /LSQuadratic, /NaN, /Quatradic, /Spline. Return: [*]. If data is array of [n0], then return [n1]; if data is array of [m, n0], then return, [m, n1]. if data is array of [n0, m], then return, [n1, m]. Notes: Do not work if given data has more than 2 dimensions. Do NOT set /NaN automatically for interpol(). History: 2011-07-20, Sheng Tian, create. 2011-08-16, Sheng Tian, add throw exterpolate. 2012-09-17, Sheng Tian, auto deal with dims.
(See general/missions/rbsp/efw/sinterpol.pro)