Releases: xtyangpsp/SeisGo
Bug fixes and new functionalities
Here is a summary of major changes in this release. Please refer to changes.txt
in the package directory for detailed notes of changes. The main functionality change/update is the under-the-hood redesign of the cross-correlation workflow. It should be compatible with older scripts doing xcorr. The new/updated do_correlation() added more options.
Updates in v0.9.0:
SCRIPTS:
- Added the scripts for the whole workflow of extracting EGFs.
- Removed some old scripts that are incompatible with the new usage and functions.
SCRIPTS/2_XCORR_MPI.py:
- Added a switch named correct_orientation for channel orientation correction/conversion.
- Added pad_thre to define the maximum threshold of size gaps between channels when doing orientation correction.
- Added a switch named do_rotation for horizontal channel rotation
- Added a switch named channel_pairs for specifying which channel pairs are saved.
SIMULATION MODEL:
- Added build_vmodel() to create a layered model with linearly increasing velocity.
TYPES:
- Added checking for corrdata.data.ndim when initilizing CorrData to make sure substack True for ndim 2 (or >1).
OBSMASTER:
- Moved correct_orientations() out to utils, but kept the block of calling this function to be compatible with old usage.
UTILS:
- Moved correct_orientations() here.
- Fixed a bug where the number of traces in slicing_trace() is 1 trace less than the true number.
NOISE:
- Added trace_info() to extract trace and orientation info.
- Added the function to correct horizontal orientations and convert 1/2 channels to N/E channels.
- Optimized the workflow for cross-correlation with the option to do rotation before xcorr.
3a. Added the function to do channel rotation specified channel pairs
3b. do_correlation(): added an option to specify which channel pairs are saved.
3c. Added assemble_raw() to assemble raw data from h5 files
3d. Updated assemble_fft() to prepare data for FFT with rotation and specified xcorr pairs. - Added get_locator() to read inventory and location id of stations
- Added rotation() to perform horizontal channel rotation
Bug fixes for taper error
This release mostly fixed errors when using the latest scipy (1.13.0 as of the test), which caused incompatibility with the ObsPy taper function with "hann" window. The nested ObsPy taper
function uses hann window from scipy.signal
. This release also updated the notebooks/seisgo_download_xcorr_demo.ipynb
notebook with the latest seisgo usages. Minor fixes in noise
module replacing numpy.int
with int'. Same for
numpy.float`.
Added citation for pip project description
No other updates beyond adding citation.
Improvements and bug fixes
This release contains bug fixes and minor improvements. Please update to the latest version. See changes.txt
for detailed changes in this release.
Updates in v0.8.1
TYPES:
- Types.CorrData.subset: clarified documentary of overwrite option. Default False.
- Added a new class for plotting shaded relief based on cartopy.
NOISE:
- In shaping_corrdata(), modified to loop through all pairs and all components, if not specified by the user.
UTILS:
- qml2list:add option to only extract location and dates.
- slicing_trace(): fixed a bug when all trace std was computed using the amplitudes instead of the absolute amplitudes.
- slicing_trace(): changed to compute trace_stdS after demean and detrend.
added demean and detrend of whole trace at the beginning. - import tukey from scipy.signal.windows to be compatible with different scipy version.
DOWNLOADERS:
- get_events(): added depth range and search with radius in circles.
PLOTTINGS:
- plot_stations: added options to specific colors and renamed it to gmt_scatters() to be more general.
Old function was kept but will throw an error.
OBSMASTER:
- import tukey from scipy.signal.windows to be compatible with different scipy version.
New features, improvements, and bug fixes
There have been several new features and improvements implemented since the last release (v0.7.5). The majority of these are on smoothing or improving existing functionalities. New options are all compatible with old usage.
Here is the list of changes since v0.7.5 (also documented in the changes.txt file):
Updates in v0.8.0
MONITORING:
- get_dvv():drop negative error data
TYPES:
- RawData: minor bug fix for attribute names.
- Added CorrDataEnsemble() placeholder, to store a gather of CorrData from the same virtual source.
- Fixed a bug when merging corrdata pairs with different channel types (when ignore_channel_type is True).
- Fixed typos in CorrData.filter(), where highpass() was typed as lhighpass.
- CorrData.merge(): fixed bugs when errors in joining two data matrices, the time attribute will still be merged, leading
to inconsistent sizes. - DvvData: drop negative error data and added option to specify maximum error in plot().
NOISE:
- merge_pairs(): fixed minor bugs. Removed try{} block in stack, split, egf, and saving steps. The try block would hide errors
that might be important to address.
DOWNLOADERS:
- download(): use "PRESSURE" as output for pressure channel.
UTILS:
- Change np.float to np.float32.
- save2asdf(): fixed sta_in when it is a list.
======= - save2asdf: Fixed a bug when saving multiple traces with a list of station inventory.
DOWNLOADERS:
- download(): changed pressure channel rmresp output to "PRESSURE", instead of hardcoding it to "VEL".
STACKING:
- stack: discard NaN traces before passing the data to each method.
- robust: fixed a bug when outlier traces have huge amplitudes, which would cause the dot product
and L2 norms too large to be handeled by the system. The final stack will be scaled back.
=================================================================
Updates in v0.7.7
TYPES: - CorrData.merge(): added option to ignore channel types. This is needed when stations update
their channels types, e.g., EH? to BH?. This new option would allow station pairs with different
channel types to merge. Default is False.
NOISE:
- merge_pairs(): added option of ignore_channel_type.
SETUP:
- Change numpy requirement to be <1.26.0.
=================================================================
Updates in v0.7.6
UTILS: - Added smooth functions for 1d, 2d, and 3d grids.
- Added matrix_in_polygon to extract 2d or 3d values with,in a polygon.
- Added boundary_points() to get the boundary of a series of points.
New features and improvements
This release added new features, fixed bugs, and improved some functionalities. See changes.txt for details. Here is a list of key changes in this version.
Updates in v0.7.5
NOISE:
- correlate(): discarded lines removing peak at zero lag (demean of the spectrum).
MONITORING:
- get_dvv: improved plot saving. Fixed a bug where stack_method was not specified for substacking.
- ts_dvv: trimed data to only compare the original data window, excluding the padded zeros.
- xc_dvv: newly added method using moving window cross-correlations. needs improvements and more tests.
DISPERSION:
- get_dispersion_image: use adaptive window size for different periods, increasing with periods.
This is options. Options to specify minimum number of trace and minimum number of wavelength.
- added option to specify energy type, "power_sum" or "envelope".
- added plotting options.
- fixed bugs when only processing one side.
- renamed get_dispersion_waveforms() to narrowband_waveforms to avoid using the word "dispersion".
DOWNLOADERS:
- read_data(): minor bug fixes.
- get_data() and get_sta_list(): added flexibility of specifying the source, which could be a Client object.
- download(): added verbose to calling getdata().
STACKING:
- Added handling of small data size, i.e., 1 trace, which will return the data without stacking.
- Added option of using DOST for tfpws, based on the implementation by Jared Bryan. It was added as a new function:tfpws_dost.
UTILS:
- Added two functions to get image gradient and convert xyz to matrix, without interpolation.
- extract_waveform: read all data if not specifying stations.
PLOTTING:
- Added facecolor to set the background of plots to white.
- Added plot_dispersion_image() to plot dispersion image.
SIMULATION:
- New module for seismic wave simulations.
New feature and improvements
v0.7.4 contains new features and improvements with bug fixes. See changes.txt for details (as summarized here).
Updates in v0.7.4
UTILS:
- Added spectral whitening function: whiten(), for time series data.
MONITORING:
- Added whitening option in get_dvv().
TYPES:
- FFTData, fixed a minor bug when getting Nfft for single trace data.
- CorrData shaping: trim_end option to accommodate the need by FWANT.
PLOTTING:
- plot_psd() bug fixed
STACKING:
- Fixed a bug in robust stacking when the trace amplitudes are anomalously small.
DOWNLOADERS:
- ms2asdf(): added option to specify response file.
DISPERSION:
- get_dispersion_waveforms: Use period to get the evenly-spaced period vector.
- get_dispersion_image: new function to extract dispersion image in velocity-period domain/space.
Bug fixes and new features
Bug fixes and new features, as listed in the changes.txt file (summarized here).
Updates in v0.7.3
NOISE:
- Added mpi option and fixed error in handling wrong file, in extract_corrdata()
- Fixed error handling in get_stationpairs().
- Added split_sides() to split corrfile sides and save separately.
- Added shaping_corrdata() to wrap shaping function, convolving with wavelet.
- Added split option in merge_pairs().
TYPES:
- Added CorrData.shaping() to shape the data with wavelet.
- Added CorrData.save() to wrap saving functions.
- In CorrData.to_asdf(), save stack_method.
- Fixed a bug in CorrData.to_egf() where the zero lag was not handled correctly. The negative side was wrong.
UTILS:
- Added gaussian() and ricker() as the shaping wavelets.
- Added box_smooth().
DOWNLOADERS:
- In read_data(), changed default to False for getstainv.
HELPERS:
- Added wavelet_labels().
MONITORING:
- Added vpcluster_evaluate_kmean() to find the optimal number of clusters.
DISPERSION:
- Improved frequency steps in disp_waveform_bp().
STACKING:
- Synced with stackmaster functions.
CLUSTERING:
- Automatically determine the optimal number of clusters.
Added two new stacking methods
See changes.txt for details.
Minor improvements and bug fixes
This release is mainly about minor improvements (though useful and important) and bug fixes. See changes.txt in the code folder for details.