Title: | Environmental Seismology Toolbox |
---|---|
Description: | Environmental seismology is a scientific field that studies the seismic signals, emitted by Earth surface processes. This package provides all relevant functions to read/write seismic data files, prepare, analyse and visualise seismic data, and generate reports of the processing history. |
Authors: | Michael Dietze [cre, aut, trl], Christoph Burow [ctb], Sophie Lagarde [ctb, trl], Clement Hibert [ctb, aut] |
Maintainer: | Michael Dietze <[email protected]> |
License: | GPL-3 |
Version: | 0.8.0 |
Built: | 2024-11-24 14:41:48 UTC |
Source: | https://github.com/coffeemuggler/eseis |
Environmental seismoloy studies the seismic signals, emitted by Earth surface processes. This package eseis provides all relevant functions to read/write seismic data files, prepare, analyse and visualise seismic data, and generate reports of the processing history.
Maintainer: Michael Dietze [email protected] [translator]
Authors:
Clement Hibert [contributor]
Other contributors:
Christoph Burow [contributor]
Sophie Lagarde [contributor, translator]
The function checks seismic files organised by aux_organisecubefiles
or aux_organisecentaurfiles
for completeness. The tests include
agreement of file name and seismic file meta data.
aux_checkfiles( dir, station, component = "BHZ", method = "thorough", period = "weekly", format = "sac", duration_set = 3600, plot = TRUE )
aux_checkfiles( dir, station, component = "BHZ", method = "thorough", period = "weekly", format = "sac", duration_set = 3600, plot = TRUE )
dir |
|
station |
|
component |
|
method |
|
period |
|
format |
|
duration_set |
|
plot |
|
Data frame
containing check results and meta data.
Michael Dietze
## Not run: ## set seismic data directory dir_data <- paste0(system.file("extdata", package="eseis"), "/") ## check data archive for record completeness chk <- aux_checkfiles(dir = dir_data, station = "RUEG1", component = "BHZ", plot = TRUE) ## End(Not run)
## Not run: ## set seismic data directory dir_data <- paste0(system.file("extdata", package="eseis"), "/") ## check data archive for record completeness chk <- aux_checkfiles(dir = dir_data, station = "RUEG1", component = "BHZ", plot = TRUE) ## End(Not run)
The function compares the sampling intervals of a list of eseis
objects and identifies the highest common sampling interval (dt) as well
as the aggregation factors for each eseis
object needed to reach
this common sampling interval.
aux_commondt(data, dt)
aux_commondt(data, dt)
data |
|
dt |
|
list
object with elements dt
(highest common
sampling interval) and agg
(aggregation factors for each
of the input data sets to reach the common sampling interval)
Michael Dietze
## Not run: ## TO BE WRITTEN ## End(Not run)
## Not run: ## TO BE WRITTEN ## End(Not run)
This is a simple wrapper for the Gipptools program cubeinfo
,
providing a short summary of the cube file meta data, in a coherent
data frame structure.
aux_cubeinfo(file, gipptools)
aux_cubeinfo(file, gipptools)
file |
|
gipptools |
|
data frame
with cube meta data
Michael Dietze
## Not run: ## get cube info x = aux_cubeinfo(file = "data/cube/example.ATB", gipptools = "/software/gipptools-2019.332/") ## End(Not run)
## Not run: ## get cube info x = aux_cubeinfo(file = "data/cube/example.ATB", gipptools = "/software/gipptools-2019.332/") ## End(Not run)
The function converts an eseis object to an ObsPy stream object. The functionality is mainly useful when running ObsPy through R using the package 'reticulate'. Currently, only single traces (i.e., single eseis objects) can be converted. Thus, to convert multiple traces, these need to be converted individually and added to the first trace using ObsPy functionalities.
aux_eseisobspy(data)
aux_eseisobspy(data)
data |
|
ObsPy
stream object as defined by the architecture of
package 'reticulate'.
Michael Dietze
## Not run: ## load ObsPy library with package 'reticulate' ## (requires ObsPy to be installed on the computer) obspy <- reticulate::import("obspy") ## load example data set data(rockfall) ## convert example eseis object to ObsPy stream object x <- aux_eseisobspy(data = rockfall_eseis) ## filter data set using ObsPy x_filter <- obspy$traces[[1]]$filter(type = "bandpass", freqmin = 0.5, freqmax = 1.0) ## plot filtered trace using ObsPy plotting routine x$traces[[1]]$plot() ## End(Not run)
## Not run: ## load ObsPy library with package 'reticulate' ## (requires ObsPy to be installed on the computer) obspy <- reticulate::import("obspy") ## load example data set data(rockfall) ## convert example eseis object to ObsPy stream object x <- aux_eseisobspy(data = rockfall_eseis) ## filter data set using ObsPy x_filter <- obspy$traces[[1]]$filter(type = "bandpass", freqmin = 0.5, freqmax = 1.0) ## plot filtered trace using ObsPy plotting routine x$traces[[1]]$plot() ## End(Not run)
This function is a wrapper for the library 'dataselect' from IRIS. It reads a corrupt mseed file and saves it in fixed state. Therefore, the function requires dataselect being installed (see details).
aux_fixmseed(file, input_dir, output_dir, software)
aux_fixmseed(file, input_dir, output_dir, software)
file |
|
input_dir |
|
output_dir |
|
software |
|
The library 'dataselect' can be downloaded at https://github.com/iris-edu/dataselect and requires compilation (see README file in dataselect directory). The function goes back to an email discussion with Gillian Sharer (IRIS team), many thanks for pointing me at this option to process corrupt mseed files.
a set of mseed files written to disk.
Michael Dietze
## Not run: aux_fixmseed(file = list.files(path = "~/data/mseed", pattern = "miniseed"), input_dir = "~/data/mseed", software = "~/software/dataselect-3.17") ## End(Not run)
## Not run: aux_fixmseed(file = list.files(path = "~/data/mseed", pattern = "miniseed"), input_dir = "~/data/mseed", software = "~/software/dataselect-3.17") ## End(Not run)
The function loads seismic data from a data directory structure (see
aux_organisecubefiles()
) based on the event start time, duration,
component and station ID.
aux_getevent( start, duration, station, component = "BHZ", format, dir, simplify = TRUE, eseis = TRUE, try = FALSE, verbose = FALSE )
aux_getevent( start, duration, station, component = "BHZ", format, dir, simplify = TRUE, eseis = TRUE, try = FALSE, verbose = FALSE )
start |
|
duration |
|
station |
|
component |
|
format |
|
dir |
|
simplify |
|
eseis |
|
try |
|
verbose |
|
The data to be read needs to be adequately structured. The data directory
must contain SAC files organised by year (e.g.2022) then by Julian Day
in full three digits (e.g. 001) and then by a dedicated SAC file name,
containing the station ID, two-digit year, three-digit Julian Day, start
time hour, minute and second, three channel ID and the file extension SAC.
All these items need to be separated by stops (e.g.
sac/2022/001/LAU01.22.001.08.00.00. BHZ.SAC). This data structure will be
most conveniently created by the functions aux_organisecubefiles()
or aux_organisecentaurfiles()
, or by manually written R code.
The function assumes complete data sets, i.e., not a single hourly data set must be missing. The time vector is loaded only once, from the first station and its first component. Thus, it is assumed that all loaded seismic signals are of the same sampling frequency and length.
A list
object containing either a set of eseis
objects or a data set with the time vector ($time
)
and a list of seismic stations ($station_ID
) with their seismic
signals as data frame ($signal
). If simplify = TRUE
(the
default option) and only one seismic station is provided, the output
object containseither just one eseis object or the vectors for
$time
and $signal
.
Michael Dietze
## set seismic data directory dir_data <- paste0(system.file("extdata", package="eseis"), "/") ## load the z component data from a station data <- aux_getevent(start = as.POSIXct(x = "2017-04-09 01:20:00", tz = "UTC"), duration = 120, station = "RUEG1", component = "BHZ", dir = dir_data) ## plot signal plot_signal(data = data) ## load data from two stations data <- aux_getevent(start = as.POSIXct(x = "2017-04-09 01:20:00", tz = "UTC"), duration = 120, station = c("RUEG1", "RUEG2"), component = "BHZ", dir = dir_data) ## plot both signals par(mfcol = c(2, 1)) lapply(X = data, FUN = plot_signal)
## set seismic data directory dir_data <- paste0(system.file("extdata", package="eseis"), "/") ## load the z component data from a station data <- aux_getevent(start = as.POSIXct(x = "2017-04-09 01:20:00", tz = "UTC"), duration = 120, station = "RUEG1", component = "BHZ", dir = dir_data) ## plot signal plot_signal(data = data) ## load data from two stations data <- aux_getevent(start = as.POSIXct(x = "2017-04-09 01:20:00", tz = "UTC"), duration = 120, station = c("RUEG1", "RUEG2"), component = "BHZ", dir = dir_data) ## plot both signals par(mfcol = c(2, 1)) lapply(X = data, FUN = plot_signal)
The function accesses the specified FDSN internet data base(s) and downloads seismic data based on the network and station IDs and time constraints.
aux_getFDSNdata( start, duration, channel = "BHZ", network, station, url, link_only = FALSE, eseis = TRUE )
aux_getFDSNdata( start, duration, channel = "BHZ", network, station, url, link_only = FALSE, eseis = TRUE )
start |
|
duration |
|
channel |
|
network |
|
station |
|
url |
|
link_only |
|
eseis |
|
A convenient way to get all the required input data is using the
function aux_getFDSNstation
before. It will return all the
information in a structured way.
It is possible to use the function to process more than one data set. In
this case, the arguments network
, station
and url
must match pairwise. The arguments start
, duration
and
channel
will be treated as constants if not also provided as
vectors.
List
object with imported seismic data for each provided
set of input arguments.
Michael Dietze
aux_get_FDSNstation, read_mseed
## Not run: ## get stations < 0.6 degrees away from Piz Chengalo collapse x <- aux_getFDSNstation(centre = c(46.3, 9.6), radius = 0.6, access = TRUE) ## sort statiions by distance x <- x[order(x$distance),] ## download available data d <- aux_getFDSNdata(start = as.POSIXct(x = "2017-08-23 07:30:00", tz = "UTC"), duration = 180, network = x$network_ID, station = x$station_code, url = x$network_url) ## remove stations without available data x <- x[!unlist(lapply(d, is.null)),] d <- d[!unlist(lapply(d, is.null))] ## generate plots of the three nearest stations par(mfcol = c(3, 1)) for(i in 1:3) { plot_signal(data = d[[i]], main = paste(x$ID[i], " | ", round(x$distance[i], 2), "distance (DD)")) } ## End(Not run)
## Not run: ## get stations < 0.6 degrees away from Piz Chengalo collapse x <- aux_getFDSNstation(centre = c(46.3, 9.6), radius = 0.6, access = TRUE) ## sort statiions by distance x <- x[order(x$distance),] ## download available data d <- aux_getFDSNdata(start = as.POSIXct(x = "2017-08-23 07:30:00", tz = "UTC"), duration = 180, network = x$network_ID, station = x$station_code, url = x$network_url) ## remove stations without available data x <- x[!unlist(lapply(d, is.null)),] d <- d[!unlist(lapply(d, is.null))] ## generate plots of the three nearest stations par(mfcol = c(3, 1)) for(i in 1:3) { plot_signal(data = d[[i]], main = paste(x$ID[i], " | ", round(x$distance[i], 2), "distance (DD)")) } ## End(Not run)
This function queries as series of data bases for seismic stations that
match a set of criteria for seismic data. The criteria include signal time
stamp and location, and component. The returned data can be used to
download data using the function aux_FDSNdata
.
aux_getFDSNstation(centre, radius, start, access, url)
aux_getFDSNstation(centre, radius, start, access, url)
centre |
|
radius |
|
start |
|
access |
|
url |
|
The function requires a working internet connection to perform the query. It uses the following FDSN data bases by default:
orfeus
"http://www.orfeus-eu.org"
geofon
"http://geofon.gfz-potsdam.de/"
bgr
"http://eida.bgr.de"
sss
"http://eida.ethz.ch"
Other FDSN data base addresses can be provided in the same way as the
addresses in the above list. They need to be provided as character
vector. For a list of addresses see
"http://www.fdsn.org/webservices/datacenters/"
and
"http://docs.obspy.org/packages/obspy.clients.fdsn.html#module-obspy.clients.fdsn"
.
Data frame
with query results. The data frame contains
information for all seismic stations fulfilling the defined criteria.
Michael Dietze
aux_get_FDSNdata, aux_getIRISstation
## Not run: x <- aux_getFDSNstation(start = as.POSIXct(x = "2010-01-01 22:22:22", tz = "UTC"), centre = c(45, 10), radius = 1) ## optionally plot station locations on a map (requires RgoogleMaps) center <- c(mean(x$station_latitude), mean(x$station_longitude)) zoom <- min(RgoogleMaps::MaxZoom(range(x$station_latitude), range(x$station_longitude))) Map <- RgoogleMaps::GetMap(center = center, zoom = zoom, maptype = "terrain") RgoogleMaps::PlotOnStaticMap(MyMap = Map, lat = x$station_latitude, lon = x$station_longitude, pch = 15, col = 4) ## End(Not run)
## Not run: x <- aux_getFDSNstation(start = as.POSIXct(x = "2010-01-01 22:22:22", tz = "UTC"), centre = c(45, 10), radius = 1) ## optionally plot station locations on a map (requires RgoogleMaps) center <- c(mean(x$station_latitude), mean(x$station_longitude)) zoom <- min(RgoogleMaps::MaxZoom(range(x$station_latitude), range(x$station_longitude))) Map <- RgoogleMaps::GetMap(center = center, zoom = zoom, maptype = "terrain") RgoogleMaps::PlotOnStaticMap(MyMap = Map, lat = x$station_latitude, lon = x$station_longitude, pch = 15, col = 4) ## End(Not run)
This function reads auxiliary information stored in Omnirecs/Digos Datacube files and extracts the temperature data that is stored along with each GPS tag. Optionally, the data is interpolated to equal intervals.
aux_gettemperature(input_dir, logger_ID, interval, cpu, gipptools)
aux_gettemperature(input_dir, logger_ID, interval, cpu, gipptools)
input_dir |
|
logger_ID |
|
interval |
|
cpu |
|
gipptools |
|
This feature is ony available for Omnirecs/Digos Datacube that were produced since 2015, i.e., whose GPS output files also record the temperature inside the logger. Generating an ACSII GPS tag file using the gipptools software requires a few minutes time per daily file.
A list
of data frames
with time and temperature
values for each cube data logger.
Michael Dietze
## uncomment to use # t <- aux_gettemperature(input_dir = "input", # logger_ID = c("ANN", "ABT"), # interval = 15, # gipptools = "~/software/gipptools-2015.225/")
## uncomment to use # t <- aux_gettemperature(input_dir = "input", # logger_ID = c("ANN", "ABT"), # interval = 15, # gipptools = "~/software/gipptools-2015.225/")
This function either downloads an online station XML file and (optionally) saves it and/or reads an already existing local station XML file.
aux_getxml( xml, start, duration, network, station, component, url, level = "response" )
aux_getxml( xml, start, duration, network, station, component, url, level = "response" )
xml |
|
start |
|
duration |
|
network |
|
station |
|
component |
|
url |
|
level |
|
Currently, the function uses Obspy python code. Hence, both python and the package 'obspy' need to be installed in order to use the function.
Obspy
object with station meta info inventory.
Michael Dietze
## Not run: x <- aux_getxml(start = "2010-10-10", duration = 60, network = "GE", station = "BRNL", component = "BHZ", url = "http://service.iris.edu") ## End(Not run)
## Not run: x <- aux_getxml(start = "2010-10-10", duration = 60, network = "GE", station = "BRNL", component = "BHZ", url = "http://service.iris.edu") ## End(Not run)
This function cuts a three component seismic data set into time windows
that may or may not overlap and calculates the spectral ratio for each of
these windows. It returns a matrix with the ratios for each time slice.
Thus, it is a wrapper for the function signal_hvratio
. For
further information about the technique and function arguments see the
description of signal_hvratio
.
aux_hvanalysis( data, time, window, overlap = 0, dt, method = "periodogram", kernel, order = "xyz", plot = FALSE, ... )
aux_hvanalysis( data, time, window, overlap = 0, dt, method = "periodogram", kernel, order = "xyz", plot = FALSE, ... )
data |
|
time |
|
window |
|
overlap |
|
dt |
|
method |
|
kernel |
|
order |
|
plot |
|
... |
Additional arguments passed to the plot function. |
A matrix
with the h-v-frequency ratios for each time slice.
Michael Dietze
## load example data set data(earthquake) ## ATTENTION, THIS EXAMPLE DATA SET IS FAR FROM IDEAL FOR THIS PURPOSE ## detrend data s <- signal_detrend(data = s) ## calculate the HV ratios straightforward HV <- aux_hvanalysis(data = s, dt = 1 / 200, kernel = 100) ## calculate the HV ratios with plot output, userdefined palette plot_col <- colorRampPalette(colors = c("grey", "darkblue", "blue", "orange")) HV <- aux_hvanalysis(data = s, dt = 1 / 200, kernel = 100, plot = TRUE, col = plot_col(100)) ## calculate the HV ratios with optimised method settings HV <- aux_hvanalysis(data = s, time = t, dt = 1 / 200, window = 10, overlap = 0.9, method = "autoregressive", plot = TRUE, col = plot_col(100), xlab = "Time (UTC)", ylab = "f (Hz)") ## calculate and plot stack (mean and sd) of all spectral ratios HV_mean <- apply(X = HV, MARGIN = 1, FUN = mean) HV_sd <- apply(X = HV, MARGIN = 1, FUN = sd) HV_f <- as.numeric(rownames(HV)) plot(x = HV_f, y = HV_mean, type = "l", ylim = c(0, 50)) lines(x = HV_f, y = HV_mean + HV_sd, col = 2) lines(x = HV_f, y = HV_mean - HV_sd, col = 2)
## load example data set data(earthquake) ## ATTENTION, THIS EXAMPLE DATA SET IS FAR FROM IDEAL FOR THIS PURPOSE ## detrend data s <- signal_detrend(data = s) ## calculate the HV ratios straightforward HV <- aux_hvanalysis(data = s, dt = 1 / 200, kernel = 100) ## calculate the HV ratios with plot output, userdefined palette plot_col <- colorRampPalette(colors = c("grey", "darkblue", "blue", "orange")) HV <- aux_hvanalysis(data = s, dt = 1 / 200, kernel = 100, plot = TRUE, col = plot_col(100)) ## calculate the HV ratios with optimised method settings HV <- aux_hvanalysis(data = s, time = t, dt = 1 / 200, window = 10, overlap = 0.9, method = "autoregressive", plot = TRUE, col = plot_col(100), xlab = "Time (UTC)", ylab = "f (Hz)") ## calculate and plot stack (mean and sd) of all spectral ratios HV_mean <- apply(X = HV, MARGIN = 1, FUN = mean) HV_sd <- apply(X = HV, MARGIN = 1, FUN = sd) HV_f <- as.numeric(rownames(HV)) plot(x = HV_f, y = HV_mean, type = "l", ylim = c(0, 50)) lines(x = HV_f, y = HV_mean + HV_sd, col = 2) lines(x = HV_f, y = HV_mean - HV_sd, col = 2)
The function generates an empty eseis object, starting with processing step 0. The object contains no data and the history only contains the system information.
aux_initiateeseis()
aux_initiateeseis()
The S3 object class eseis
contains the data vector ($signal
),
a meta information list ($meta
) with all essential seismic meta data -
such as sampling interval, station ID, component, start time of the stream
or file name of the input file - a list with header data of the seismic
source file ($header
), and a history list ($history
), which
records all data manipulation steps of an (eseis
) object. The element
($meta
) will be used by functions of the package to look for
essential information to perform data manipulations (e.g., the sampling
interval). Thus, working with (eseis
) objects is convenient and less
prone to user related errors/bugs, given that the meta information is
correct and does not change during the processing chain; package functions
will update the meta information whenever necessary (e.g.,
signal_aggregate
). The element $header
will only be
present if a seismic source file has been imported.
The history element is the key feature for transparent and reproducable
research using this R package. An eseis
object records a history of
every function it has been subject to, including the time stamp, the
function call, all used function arguments and their associated values,
and the overall processing duration in seconds. The history is updated
whenever an eseis
object is manipulated with one of the functions
of this package (with a few exceptions, mainly from the aux_... category).
S3
list object of class eseis
.
Michael Dietze
## initiate eseis object aux_initiateeseis()
## initiate eseis object aux_initiateeseis()
The function converts an ObsPy stream object to an eseis object. The functionality is mainly useful when running ObsPy through R using the package 'reticulate'.
aux_obspyeseis(data, simplify = TRUE)
aux_obspyeseis(data, simplify = TRUE)
data |
|
simplify |
|
Initiation of the reticulate-based python toolbox support can be cumbersome. The following suggestions from Guthub (https://github.com/rstudio/reticulate/issues/578) helped in a case study:
library(reticulate)
use_condaenv("r-reticulate")
py_install("obspy", pip = TRUE)
eseis
object.
Michael Dietze
## Not run: ## load ObsPy library with package 'reticulate' ## (requires ObsPy to be installed on the computer) obspy <- reticulate::import("obspy") ## set seismic data directory dir_data <- paste0(system.file("extdata", package="eseis"), "/") ## read miniseed file to stream object via ObsPy x <- obspy$read(pathname_or_url = "dir_data/2017/99/RUEG1.17.99.00.00.00.BHZ.SAC") ## convert ObsPy stream object to eseis object y <- aux_obspyeseis(data = x) ## plot eseis object plot_signal(y) ## End(Not run)
## Not run: ## load ObsPy library with package 'reticulate' ## (requires ObsPy to be installed on the computer) obspy <- reticulate::import("obspy") ## set seismic data directory dir_data <- paste0(system.file("extdata", package="eseis"), "/") ## read miniseed file to stream object via ObsPy x <- obspy$read(pathname_or_url = "dir_data/2017/99/RUEG1.17.99.00.00.00.BHZ.SAC") ## convert ObsPy stream object to eseis object y <- aux_obspyeseis(data = x) ## plot eseis object plot_signal(y) ## End(Not run)
This function optionally converts mseed files to sac files and organises these in a coherent directory structure, by year, Julian day, (station, hour and channel). It depends on the cubetools or gipptools software package (see details). The function is at an experimental stage and only used for data processing at the GFZ Geomorphology section, currently.
aux_organisecentaurfiles( stationfile, input_dir, output_dir, format = "sac", channel_name = "bh", cpu, gipptools, file_key = "miniseed", network )
aux_organisecentaurfiles( stationfile, input_dir, output_dir, format = "sac", channel_name = "bh", cpu, gipptools, file_key = "miniseed", network )
stationfile |
|
input_dir |
|
output_dir |
|
format |
|
channel_name |
|
cpu |
|
gipptools |
|
file_key |
|
network |
|
The function assumes that the Nanometrics Centaur data logger directory
contains only hourly mseed files. These hourly files are organised in a
coherent directory structure which is organised by year and Julian day.
In each Julian day directory the hourly files are placed and named according
to the following scheme:
STATIONID.YEAR.JULIANDAY.HOUR.MINUTE.SECOND.CHANNEL.
The function requires that the software cubetools
(http://www.omnirecs.de/documents.html
) or gipptools
(http://www.gfz-potsdam.de/en/section/geophysical-deep-sounding/infrastructure/geophysical-instrument-pool-potsdam-gipp/software/gipptools/
)
are installed.
Specifying an input directory
(input_dir
) is mandatory. This input directory must only contain the
subdirectories with mseed data for each Centaur logger. The subdirectory
must be named after the four digit Centaur ID and contain only mseed files,
regardless if further subdirectories are used (e.g., for calendar days).
In the case a six-channel Centaur is used to record signals from two
sensors, in the station info file (cf. aux_stationinfofile()
)
the logger ID field must contain the four digit logger ID and the
channel qualifiers, e.g., "AH" (first three channels) or "BH" (last three channels),
separated by an underscore.
A set of hourly seismic files written to disk.
Michael Dietze
## Not run: ## basic example with minimum effort aux_organisecentaurfiles(stationfile = "output/stationinfo.txt", input_dir = "input", gipptools = "software/gipptools-2015.225/") ## End(Not run)
## Not run: ## basic example with minimum effort aux_organisecentaurfiles(stationfile = "output/stationinfo.txt", input_dir = "input", gipptools = "software/gipptools-2015.225/") ## End(Not run)
The function converts Omnirecs/Digos Datacube files to mseed or sac files and organises these in a coherent directory structure (see details) for available structures. The conversion depends on the gipptools software package (see details) provided externally.
aux_organisecubefiles( station, input, output, gipptools, format = "sac", pattern = "eseis", component = "BH", mode = "dir-wise", fringe = "constant", cpu, verbose = TRUE )
aux_organisecubefiles( station, input, output, gipptools, format = "sac", pattern = "eseis", component = "BH", mode = "dir-wise", fringe = "constant", cpu, verbose = TRUE )
station |
|
input |
|
output |
|
gipptools |
|
format |
|
pattern |
|
component |
|
mode |
|
fringe |
|
cpu |
|
verbose |
|
The function converts seismic data from the binary cube file format to
mseed (cf. read_mseed
) or sac (cf. read_sac
) and organises
the resulting files into a consistent structure, expected by 'eseis' for
convenient data handling (cf. read_data
).
Currently, there are two data structure schemes supported, "eseis"
and "seiscomp"
. In the "eseis"
case, the daily cube files are
cut to hourly files and organised in directories structured by four digit
year and three digit Julian day numbers. In each Julian day directory, the
hourly files are placed and named after the following scheme:
STATION.YEAR.JULIANDAY.HOUR.MINUTE.SECOND.COMPONENT.
The "seiscomp"
case will yield daily files, which are organised by
four digit year, seismic network, seismic station, and seismic component,
each building a separate directory. In the deepest subdirectory, files are
named by: NETWORK.STATION.LOCATION.COMPONENT.TYPE.YEAR.JULIANDAY.
The component naming scheme defines the codes for the sensor's band
code (first letter) and instrument code (second letter). The third letter,
defining the spatial component, will be added automatically. For definitions
of channel codes see https://migg-ntu.github.io/SeisTomo_Tutorials/seismology/seismic-data/seismic-time-series-data.html
.
The function requires that the software gipptools
(http://www.gfz-potsdam.de/en/section/geophysical-deep-sounding/infrastructure/geophysical-instrument-pool-potsdam-gipp/software/gipptools/
)
is installed. Note that the gipptools are provided at regular update
intervals, including an up to date GPS leap second table, essential to
convert recently recorded files.
The Cube files will be imported in place but a series of temporary files
will be created in a temporary directory in the specified output directory.
Hence, if the routine stops due to a processing issue, one needs to delete
the temporary data manually. The path to the temporary directory will be
provided as screen output when the argument verbose = TRUE
.
The Cube files can be converted in two modes: "file-wise"
and
"dir-wise"
. In "file-wise"
mode, each Cube file will be
converted individually. This option has the advantage that if one file in
a month-long sequence of records is corrupt, the conversion will not stop,
but only discard the part from the corrupted section until the file end.
The disadvantage is however, that the data before the first and after
the last GPS tags will not be converted unless the option
fringe = "constant"
(by default this is the case) is used.
In "dir-wise"
mode, the fringe sample issue reduces to the margins of
the total sequence of daily files but the corrupt file issue will become a
more severe danger to the success when converting a large number of files.
Specifying an input directory (input
) is mandatory. That
directory should only contain the directories with the cube files to
process. Files downloaded from a Cube are usually contained in one or more
further directories, which should be moved into a single one before
running this function.
Each set of cube files from a given logger should be located in a separate
directory per logger and these directories should have the same name as
the logger IDs (logger_ID
). An appropriate structure for files from
two loggers, A1A and A1B, would be something like:
input
A1A
file1.A1A
file2.A1A
A1B
file1.A1B
file2.A1B
The component definition can follow the typical keywords and key letters
defined in seismology: https://migg-ntu.github.io/SeisTomo_Tutorials/seismology/seismic-data/seismic-time-series-data.html
,
hence the first letter indicating the instrument's band type and the second
letter indicating the instrument code or instrument type.
Band code | Explanation band type |
E | Extremely short period |
S | Short period |
H | High broad band |
B | Broad band |
M | Mid band |
L | Long band |
V | Very long band |
Instrument code | Explanation |
H | High gain seismometer |
L | Low gain seismometer |
G | Gravimeter |
M | Mass position seismometer |
N | Accelerometer |
P | Geophone |
A set of converted and organised seismic files written to disk.
Michael Dietze
## Not run: ## basic example with minimum effort aux_organisecubefiles(stationfile = data.frame(logger = c("A1A", "A1B"), station = c("ST1", "ST2")), input = "input", gipptools = "software/gipptools-2023.352") ## End(Not run)
## Not run: ## basic example with minimum effort aux_organisecubefiles(stationfile = data.frame(logger = c("A1A", "A1B"), station = c("ST1", "ST2")), input = "input", gipptools = "software/gipptools-2023.352") ## End(Not run)
The function allows detection of discrete seismic events using the STA-LTA picker approach and including several stations of a seismic network. It will pick events at all input stations and identify events picked by more than a user defined minimum number of stations, within a given time window. It further allows rejecting events that are too short or too long, or occur to short after a previous event. The function can be used to process long data archives organised in a consistent file structure.
aux_picknetwork( start, stop, res, buffer, station, component, dir, f, envelope = TRUE, sta, lta, on, off, freeze, dur_min, dur_max, n_common, t_common, t_pause, verbose = FALSE, ... )
aux_picknetwork( start, stop, res, buffer, station, component, dir, f, envelope = TRUE, sta, lta, on, off, freeze, dur_min, dur_max, n_common, t_common, t_pause, verbose = FALSE, ... )
start |
|
stop |
|
res |
|
buffer |
|
station |
|
component |
|
dir |
|
f |
|
envelope |
|
sta |
|
lta |
|
on |
|
off |
|
freeze |
|
dur_min |
|
dur_max |
|
n_common |
|
t_common |
|
t_pause |
|
verbose |
|
... |
Further arguments passed to the function, i.e. keywords for the signal deconvolution part. See details for further information. |
The data will be imported time slice by time slice. Optionally, a signal deconvolution can be done. The data will be filtered to isolate the frequency range of interest, and tapered to account for edge effects. The taper size is automatically set be the two-sided buffer (see below). Optionally, a signal envelope can be calculated as part of the preprocessing work. For all successfully imported and preprocessed signal time snippets, events will be detected by the STL-LTA approach. Events from all input signals will be checked for a minium and maximum allowed event duration, set as thresholds by the user. All remaining events are checked for the number of stations of the network that did consistently detect an event. That means an event must be found in each signal within a user defined time window, a window that corresponds to the maximum travel time of a seismic signal through the network. The minimum number of stations that detect the event can be set by the user. In addition, events can be rejected if they occur during a user defined ban time after the onset of a previous event, which assumes that no subsequent events are allowed during the implementation of long duration events happening.
The time period to process is defined by start
, end
and the
length of time snippets res
(s). In addition, a left sided and
right sided buffer can and should be added buffer = c(60, 60)
(s),
to account for artefacts during signal preprocessing and events that
occur across the time snippets. The start
and end
time should
be provided in POSIXct
format. If it is provided as text string, the
function will try to convert to POSIXct assuming the time zone is UTC.
There must be at least two seismic stations. The seismic components
component
must be a vector of the same length as station
and
contain the corresponding information for each station.
Deconvolution of the input signals can be done, although usually this is
not essential for just picking events if the filter frequencies are in the
flat response range of the sensors. If wanted, one needs to provide the
additional vectors (all of the same length as station
) sensor
,
logger
and optionally gain
(otherwise assumed to be 1
).
See signal_deconvolve()
for further information on the deconvolution
routine and the supported keywords for sensors and loggers.
STA-LTA picking is usually done on signal envelopes enevelope = TRUE
.
However, for array seismology or other specific cases it might be useful to
work with the waveforms directly, instead of with their envelopes.
The STA-LTA routine requires information on the length of the STA window,
the LTA window, the on-threshold to define the start of an event, the
off-threshold to define the end of an event, and the option to freeze the
STA-LTA ratio at the onset of and event. See the documentation of the
function pick_stalta()
for further information.
Events that last shorter than dur_min
or longer than dur_max
are rejected. This criterion is applied before the test of how many stations
have commonly detected an event. Hence, the minimum and maximum duration
criteria need to be fulfilled by an event for all seismic stations, or at
least as many as defined as minimum number of stations n_common
.
A valid event should be detected by more than one station. At least two
stations (n_common = 2
) should detect it to confirm it is not just a
local effect like rain drop impacts or animal activity. At least three
stations (n_common = 3
) are needed to locate an event. Detection at
more stations increases the validity of an event as proper signal. However,
the likelihood of stations not operating correctly or that some stations
may be too far to detect a smaller event limits the number of stations that
are be set as (n_common
).
An event that happens just outside a seismic network will generate seismic
waves that travel through the network and will require a given time for
that. The time is set by the longest inter-station distance and the apparent
seismic wave velocity. For example, an event who's signal propagated with
1000 m/s through a network with a maximum aperture of 1000 m will need up to
1 s. Hence, the parameter t_common
should be set to 1
, in
this case. This parameter is good to reject events that show a longer travel
time, e.g. because they are pressure waves that travel through the
atmosphere, like helicopter signals or lightning strikes.
data frame
, detected events (start time, duration in
seconds)
Michael Dietze
picks <- aux_picknetwork(start = "2017-04-09 01:00:00 UTC", stop = "2017-04-09 02:00:00 UTC", res = 1800, buffer = c(90, 90), station = c("RUEG1","RUEG2"), component = rep("BHZ", 2), dir = paste0(path.package("eseis"), "/extdata/"), f = c(0.1, 0.2), envelope = TRUE, sta = 0.5, lta = 300, on = 3, off = 1, freeze = TRUE, dur_min = 2, dur_max = 90, n_common = 2, t_common = 5, t_pause = 30, verbose = TRUE) print(picks)
picks <- aux_picknetwork(start = "2017-04-09 01:00:00 UTC", stop = "2017-04-09 02:00:00 UTC", res = 1800, buffer = c(90, 90), station = c("RUEG1","RUEG2"), component = rep("BHZ", 2), dir = paste0(path.package("eseis"), "/extdata/"), f = c(0.1, 0.2), envelope = TRUE, sta = 0.5, lta = 300, on = 3, off = 1, freeze = TRUE, dur_min = 2, dur_max = 90, n_common = 2, t_common = 5, t_pause = 30, verbose = TRUE) print(picks)
The function allows detection of discrete seismic events using the STA-LTA
picker approach and including several stations of a seismic network. It
will pick events at all input stations and identify events picked by more
than a user defined minimum number of stations, within a given time window.
It further allows rejecting events that are too short or too long, or occur
to short after a previous event. The function can be used to process long
data archives organised in a consistent file structure. This is the parallel
computation version of the routine. For the single CPU version, allowing to
show verbose progress information, use aux_picknetwork()
.
aux_picknetworkparallel( start, stop, res, buffer, station, component, dir, f, envelope = TRUE, sta, lta, on, off, freeze, dur_min, dur_max, n_common, t_common, t_pause, cpu, ... )
aux_picknetworkparallel( start, stop, res, buffer, station, component, dir, f, envelope = TRUE, sta, lta, on, off, freeze, dur_min, dur_max, n_common, t_common, t_pause, cpu, ... )
start |
|
stop |
|
res |
|
buffer |
|
station |
|
component |
|
dir |
|
f |
|
envelope |
|
sta |
|
lta |
|
on |
|
off |
|
freeze |
|
dur_min |
|
dur_max |
|
n_common |
|
t_common |
|
t_pause |
|
cpu |
|
... |
Further arguments passed to the function, i.e. keywords for the signal deconvolution part. See details for further information. |
The data will be imported time slice by time slice. Optionally, a signal deconvolution can be done. The data will be filtered to isolate the frequency range of interest, and tapered to account for edge effects. The taper size is automatically set be the two-sided buffer (see below). Optionally, a signal envelope can be calculated as part of the preprocessing work. For all successfully imported and preprocessed signal time snippets, events will be detected by the STL-LTA approach. Events from all input signals will be checked for a minium and maximum allowed event duration, set as thresholds by the user. All remaining events are checked for the number of stations of the network that did consistently detect an event. That means an event must be found in each signal within a user defined time window, a window that corresponds to the maximum travel time of a seismic signal through the network. The minimum number of stations that detect the event can be set by the user. In addition, events can be rejected if they occur during a user defined ban time after the onset of a previous event, which assumes that no subsequent events are allowed during the implementation of long duration events happening.
The time period to process is defined by start
, end
and the
length of time snippets res
(s). In addition, a left sided and
right sided buffer can and should be added buffer = c(60, 60)
(s),
to account for artefacts during signal preprocessing and events that
occur across the time snippets. The start
and end
time should
be provided in POSIXct
format. If it is provided as text string, the
function will try to convert to POSIXct assuming the time zone is UTC.
There must be at least two seismic stations. The seismic components
component
must be a vector of the same length as station
and
contain the corresponding information for each station.
Deconvolution of the input signals can be done, although usually this is
not essential for just picking events if the filter frequencies are in the
flat response range of the sensors. If wanted, one needs to provide the
additional vectors (all of the same length as station
) sensor
,
logger
and optionally gain
(otherwise assumed to be 1
).
See signal_deconvolve()
for further information on the deconvolution
routine and the supported keywords for sensors and loggers.
STA-LTA picking is usually done on signal envelopes enevelope = TRUE
.
However, for array seismology or other specific cases it might be useful to
work with the waveforms directly, instead of with their envelopes.
The STA-LTA routine requires information on the length of the STA window,
the LTA window, the on-threshold to define the start of an event, the
off-threshold to define the end of an event, and the option to freeze the
STA-LTA ratio at the onset of and event. See the documentation of the
function pick_stalta()
for further information.
Events that last shorter than dur_min
or longer than dur_max
are rejected. This criterion is applied before the test of how many stations
have commonly detected an event. Hence, the minimum and maximum duration
criteria need to be fulfilled by an event for all seismic stations, or at
least as many as defined as minimum number of stations n_common
.
A valid event should be detected by more than one station. At least two
stations (n_common = 2
) should detect it to confirm it is not just a
local effect like rain drop impacts or animal activity. At least three
stations (n_common = 3
) are needed to locate an event. Detection at
more stations increases the validity of an event as proper signal. However,
the likelihood of stations not operating correctly or that some stations
may be too far to detect a smaller event limits the number of stations that
are be set as (n_common
).
An event that happens just outside a seismic network will generate seismic
waves that travel through the network and will require a given time for
that. The time is set by the longest inter-station distance and the apparent
seismic wave velocity. For example, an event who's signal propagated with
1000 m/s through a network with a maximum aperture of 1000 m will need up to
1 s. Hence, the parameter t_common
should be set to 1
, in
this case. This parameter is good to reject events that show a longer travel
time, e.g. because they are pressure waves that travel through the
atmosphere, like helicopter signals or lightning strikes.
data frame
, detected events (start time, duration in
seconds)
Michael Dietze
picks <- aux_picknetwork(start = "2017-04-09 01:00:00 UTC", stop = "2017-04-09 02:00:00 UTC", res = 1800, buffer = c(90, 90), station = c("RUEG1","RUEG2"), component = rep("BHZ", 2), dir = paste0(path.package("eseis"), "/extdata/"), f = c(0.1, 0.2), envelope = TRUE, sta = 0.5, lta = 300, on = 3, off = 1, freeze = TRUE, dur_min = 2, dur_max = 90, n_common = 2, t_common = 5, t_pause = 30) print(picks)
picks <- aux_picknetwork(start = "2017-04-09 01:00:00 UTC", stop = "2017-04-09 02:00:00 UTC", res = 1800, buffer = c(90, 90), station = c("RUEG1","RUEG2"), component = rep("BHZ", 2), dir = paste0(path.package("eseis"), "/extdata/"), f = c(0.1, 0.2), envelope = TRUE, sta = 0.5, lta = 300, on = 3, off = 1, freeze = TRUE, dur_min = 2, dur_max = 90, n_common = 2, t_common = 5, t_pause = 30) print(picks)
The function generates a long time PSD with aggregated time and frequency resolution.
aux_psdsummary( start, stop, ID, component = "BHZ", dir, window, sensor, logger, gain = 1, hours_skip, res = 1000, n = 100, cpu, verbose = FALSE )
aux_psdsummary( start, stop, ID, component = "BHZ", dir, window, sensor, logger, gain = 1, hours_skip, res = 1000, n = 100, cpu, verbose = FALSE )
start |
|
stop |
|
ID |
|
component |
|
dir |
|
window |
|
sensor |
|
logger |
|
gain |
|
hours_skip |
|
res |
|
n |
|
cpu |
|
verbose |
|
The function will calculate PSDs using the Welch method (see
signal_spectrogram
), with no overlap of the main time windows. The
sub-windows will be automatically set to 10
the overlap of sub-windows to 0.5.
eseis
object, a spectrogram
Michael Dietze
## Not run: p <- aux_psdsummary(start = "2017-04-15 19:00:00 UTC", stop = "2017-04-15 22:00:00 UTC", ID = "RUEG1", component = "BHE", dir = "~/data/sac/", sensor = "TC120s", logger = "Cube3ext", window = 600, res = 1000, verbose = TRUE) plot(p) ## End(Not run)
## Not run: p <- aux_psdsummary(start = "2017-04-15 19:00:00 UTC", stop = "2017-04-15 22:00:00 UTC", ID = "RUEG1", component = "BHE", dir = "~/data/sac/", sensor = "TC120s", logger = "Cube3ext", window = 600, res = 1000, verbose = TRUE) plot(p) ## End(Not run)
The function converts a seismic signal to sound and saves it as a wav file.
aux_sonifysignal( data, file, aggregate = 1, amplification = 10^6, speed = 1, dt )
aux_sonifysignal( data, file, aggregate = 1, amplification = 10^6, speed = 1, dt )
data |
|
file |
|
aggregate |
|
amplification |
|
speed |
|
dt |
|
Sound file in wav format, written to disk.
Michael Dietze
## Not run: ## load example data data(rockfall) ## deconvolve and taper signal s <- signal_deconvolve(data = rockfall_eseis) s <- signal_taper(data = s, p = 0.05) ## sonify as is (barely sensible, due to too low frequency) aux_sonifysignal(data = s, file = "~/Downloads/r1.wav") ## sonify at 20-fold speed aux_sonifysignal(data = s, file = "~/Downloads/r1.wav", speed = 20) ## End(Not run)
## Not run: ## load example data data(rockfall) ## deconvolve and taper signal s <- signal_deconvolve(data = rockfall_eseis) s <- signal_taper(data = s, p = 0.05) ## sonify as is (barely sensible, due to too low frequency) aux_sonifysignal(data = s, file = "~/Downloads/r1.wav") ## sonify at 20-fold speed aux_sonifysignal(data = s, file = "~/Downloads/r1.wav", speed = 20) ## End(Not run)
The function changes the meta data and file names of seismic data sets (organised in an eseis-compatible data structure). Data cubes in combination with splitter break-out boxes allow to record vertical component signals from three single-channel geophones, each connected by an individual cable. The logger interprets the data as E, N and Z components, regardless of the actual sensor and component connected to the respective cable. Hence, it is possible to record data from three independent (vertical) sensors with a single Data cube. However, the channels will be named according to the internal scheme (E, N, Z). To correct for that effect, the function will look up the right combination of station ID and component, and change meta data and name of each file in the input directory accordingly, before saving the updated file in the output directory.
aux_splitcubechannels( input, output, ID_in, component_in, ID_out, component_out, gipptools )
aux_splitcubechannels( input, output, ID_in, component_in, ID_out, component_out, gipptools )
input |
|
output |
|
ID_in |
|
component_in |
|
ID_out |
|
component_out |
|
gipptools |
|
A set of converted and organised seismic files written to disk.
Michael Dietze
## Not run: ## the example will convert the E, N and Z components of station RUEG1 ## to the station IDs RUEGA, RUEGB, RUEGC, all with BHZ as component aux_splitcubechannels(input = paste0(system.file("extdata", package="eseis"), "/"), output = tempdir(), ID_in = c("RUEG1", "RUEG1", "RUEG1"), component_in = c("BHE", "BHN", "BHZ"), ID_out = c("RUEGA", "RUEGB", "RUEGC"), component_out = c("BHZ", "BHZ", "BHZ")) ## End(Not run)
## Not run: ## the example will convert the E, N and Z components of station RUEG1 ## to the station IDs RUEGA, RUEGB, RUEGC, all with BHZ as component aux_splitcubechannels(input = paste0(system.file("extdata", package="eseis"), "/"), output = tempdir(), ID_in = c("RUEG1", "RUEG1", "RUEG1"), component_in = c("BHE", "BHN", "BHZ"), ID_out = c("RUEGA", "RUEGB", "RUEGC"), component_out = c("BHZ", "BHZ", "BHZ")) ## End(Not run)
This function reads GPS tags from Omnirecs/Digos Datacube files and creates a station info file from additional input data. It depends on the cubetools or gipptools software package (see details).
aux_stationinfofile( name, input_dir, output_dir, station_ID, station_name, station_z, station_d, sensor_type, logger_type, sensor_ID, logger_ID, unit = "dd", n, quantile = 0.95, random = TRUE, cpu, gipptools, write_file = TRUE, write_raw = FALSE, write_data = FALSE )
aux_stationinfofile( name, input_dir, output_dir, station_ID, station_name, station_z, station_d, sensor_type, logger_type, sensor_ID, logger_ID, unit = "dd", n, quantile = 0.95, random = TRUE, cpu, gipptools, write_file = TRUE, write_raw = FALSE, write_data = FALSE )
name |
|
input_dir |
|
output_dir |
|
station_ID |
|
station_name |
|
station_z |
|
station_d |
|
sensor_type |
|
logger_type |
|
sensor_ID |
|
logger_ID |
|
unit |
|
n |
|
quantile |
|
random |
|
cpu |
|
gipptools |
|
write_file |
|
write_raw |
|
write_data |
|
A station info file is an ASCII file that contains all relevant information
about the individual stations of a seismic network. The variables contain a
station ID (containing not more than 5 characters), station name, latitude,
longitude, elevation, deployment depth, sensor type, logger type, sensor
ID and logger ID.
The function requires that the software cubetools
(http://www.omnirecs.de/documents.html
) or gipptools
(http://www.gfz-potsdam.de/en/section/geophysical-deep-sounding/infrastructure/geophysical-instrument-pool-potsdam-gipp/software/gipptools/
)
are installed. Note that GPS tag extraction may take several minutes per
cube file. Hence, depending on the number of files and utilised CPUs the
processing may take a while.
Specifying an input directory
(input_dir
) is mandatory. This input directory must only contain the
subdirectories with the cube files to process, each set of cube files must
be located in a separate subdirectory and these subdiretories must
have the same name as specified by the logger IDs (logger_ID
). An
appropriate structure would be something like:
input
A1A
file1.A1A
file2.A1A
A1B
file1.A1B
file2.A1B
A set of files written to disk and a data frame with seismic station information.
Michael Dietze
## Not run: ## basic example with minimum effort aux_stationinfofile(name = "stationinfo.txt", input_dir = "input", logger_ID = c("864", "876", "AB1"), gipptools = "software/gipptools-2015.225") ## example with more adjustments aux_stationinfofile(name = "stationinfo.txt", input_dir = "input", logger_ID = c("864", "876", "AB1"), station_name = c("KTZ01", "KTZ02", "KTZ03"), station_z = c(30, 28, 29), station_d = rep(0.5, 3), sensor_type = rep("TC120s", 3), logger_type = rep("Cube3ext", 3), unit = "utm", n = 1, cpu = 0.9, gipptools = "software/gipptools-2015.225", write_raw = TRUE, write_data = TRUE) ## End(Not run)
## Not run: ## basic example with minimum effort aux_stationinfofile(name = "stationinfo.txt", input_dir = "input", logger_ID = c("864", "876", "AB1"), gipptools = "software/gipptools-2015.225") ## example with more adjustments aux_stationinfofile(name = "stationinfo.txt", input_dir = "input", logger_ID = c("864", "876", "AB1"), station_name = c("KTZ01", "KTZ02", "KTZ03"), station_z = c(30, 28, 29), station_d = rep(0.5, 3), sensor_type = rep("TC120s", 3), logger_type = rep("Cube3ext", 3), unit = "utm", n = 1, cpu = 0.9, gipptools = "software/gipptools-2015.225", write_raw = TRUE, write_data = TRUE) ## End(Not run)
The dataset comprises the seismic signal (all three components) of a small earthquake. The data have been recorded at 200 Hz sampling frequency with an Omnirecs Cube ext 3 data logger.
The dataset comprises the time vector associated with the data set
earthquake
.
s t
s t
The format is: List of 3 $ BHE: num [1:8001] -3.95e-07 ... $ BHN: num [1:8001] -2.02e-07 ... $ BHZ: num [1:8001] -1.65e-07 ...
The format is: POSIXct[1:98400], format: "2015-04-06 13:16:54" ...
## load example data set data(earthquake) ## plot signal vector plot(x = t, y = s$BHZ, type = "l") ## load example data set data(earthquake) ## show range of time vector range(t)
## load example data set data(earthquake) ## plot signal vector plot(x = t, y = s$BHZ, type = "l") ## load example data set data(earthquake) ## show range of time vector range(t)
The fluvial model inversion (FMI) routine uses a predefined look-up table with reference spectra to identify those spectra that fit the empirical data set best, and returns the corresponding target variables and fit errors.
fmi_inversion(reference, data, n_cores = 1)
fmi_inversion(reference, data, n_cores = 1)
reference |
|
data |
|
n_cores |
|
Note that the frequencies of the empiric and modelled data sets must match.
List
object containing the inversion results.
Michael Dietze
## NOTE THAT THE EXAMPLE IS OF BAD QUALITY BECAUSE ONLY 10 REFERENCE ## PARAMETER SETS AND SPECTRA ARE CALCULATED, DUE TO COMPUATATION TIME ## CONSTRAINTS. SET THE VALUE TO 1000 FOR MORE MEANINGFUL RESULTS. ## create 100 example reference parameter sets ref_pars <- fmi_parameters(n = 10, h_w = c(0.02, 1.20), q_s = c(0.001, 8.000) / 2650, d_s = 0.01, s_s = 1.35, r_s = 2650, w_w = 6, a_w = 0.0075, f_min = 5, f_max = 80, r_0 = 6, f_0 = 1, q_0 = 10, v_0 = 350, p_0 = 0.55, e_0 = 0.09, n_0_a = 0.6, n_0_b = 0.8, res = 100) ## create corresponding reference spectra ref_spectra <- fmi_spectra(parameters = ref_pars) ## define water level and bedload flux time series h <- c(0.01, 1.00, 0.84, 0.60, 0.43, 0.32, 0.24, 0.18, 0.14, 0.11) q <- c(0.05, 5.00, 4.18, 3.01, 2.16, 1.58, 1.18, 0.89, 0.69, 0.54) / 2650 hq <- as.list(as.data.frame(rbind(h, q))) ## calculate synthetic spectrogram psd <- do.call(cbind, lapply(hq, function(hq) { psd_turbulence <- eseis::model_turbulence(h_w = hq[1], d_s = 0.01, s_s = 1.35, r_s = 2650, w_w = 6, a_w = 0.0075, f = c(10, 70), r_0 = 5.5, f_0 = 1, q_0 = 18, v_0 = 450, p_0 = 0.34, e_0 = 0.0, n_0 = c(0.5, 0.8), res = 100, eseis = FALSE)$power psd_bedload <- eseis::model_bedload(h_w = hq[1], q_s = hq[2], d_s = 0.01, s_s = 1.35, r_s = 2650, w_w = 6, a_w = 0.0075, f = c(10, 70), r_0 = 5.5, f_0 = 1, q_0 = 18, v_0 = 450, x_0 = 0.34, e_0 = 0.0, n_0 = 0.5, res = 100, eseis = FALSE)$power ## combine spectra psd_sum <- psd_turbulence + psd_bedload ## return output return(10 * log10(psd_sum)) })) graphics::image(t(psd)) ## invert empiric data set X <- fmi_inversion(reference = ref_spectra, data = psd) ## plot model results plot(X$parameters$q_s * 2650, type = "l") plot(X$parameters$h_w, type = "l")
## NOTE THAT THE EXAMPLE IS OF BAD QUALITY BECAUSE ONLY 10 REFERENCE ## PARAMETER SETS AND SPECTRA ARE CALCULATED, DUE TO COMPUATATION TIME ## CONSTRAINTS. SET THE VALUE TO 1000 FOR MORE MEANINGFUL RESULTS. ## create 100 example reference parameter sets ref_pars <- fmi_parameters(n = 10, h_w = c(0.02, 1.20), q_s = c(0.001, 8.000) / 2650, d_s = 0.01, s_s = 1.35, r_s = 2650, w_w = 6, a_w = 0.0075, f_min = 5, f_max = 80, r_0 = 6, f_0 = 1, q_0 = 10, v_0 = 350, p_0 = 0.55, e_0 = 0.09, n_0_a = 0.6, n_0_b = 0.8, res = 100) ## create corresponding reference spectra ref_spectra <- fmi_spectra(parameters = ref_pars) ## define water level and bedload flux time series h <- c(0.01, 1.00, 0.84, 0.60, 0.43, 0.32, 0.24, 0.18, 0.14, 0.11) q <- c(0.05, 5.00, 4.18, 3.01, 2.16, 1.58, 1.18, 0.89, 0.69, 0.54) / 2650 hq <- as.list(as.data.frame(rbind(h, q))) ## calculate synthetic spectrogram psd <- do.call(cbind, lapply(hq, function(hq) { psd_turbulence <- eseis::model_turbulence(h_w = hq[1], d_s = 0.01, s_s = 1.35, r_s = 2650, w_w = 6, a_w = 0.0075, f = c(10, 70), r_0 = 5.5, f_0 = 1, q_0 = 18, v_0 = 450, p_0 = 0.34, e_0 = 0.0, n_0 = c(0.5, 0.8), res = 100, eseis = FALSE)$power psd_bedload <- eseis::model_bedload(h_w = hq[1], q_s = hq[2], d_s = 0.01, s_s = 1.35, r_s = 2650, w_w = 6, a_w = 0.0075, f = c(10, 70), r_0 = 5.5, f_0 = 1, q_0 = 18, v_0 = 450, x_0 = 0.34, e_0 = 0.0, n_0 = 0.5, res = 100, eseis = FALSE)$power ## combine spectra psd_sum <- psd_turbulence + psd_bedload ## return output return(10 * log10(psd_sum)) })) graphics::image(t(psd)) ## invert empiric data set X <- fmi_inversion(reference = ref_spectra, data = psd) ## plot model results plot(X$parameters$q_s * 2650, type = "l") plot(X$parameters$h_w, type = "l")
In order to run the fluvial model inversion (FMI) routine, a set of randomised target parameter combinations needs to be created. This function does this job.
fmi_parameters( n, d_s, s_s, r_s, q_s, h_w, w_w, a_w, f_min, f_max, r_0, f_0, q_0, v_0, p_0, e_0, n_0_a, n_0_b, res )
fmi_parameters( n, d_s, s_s, r_s, q_s, h_w, w_w, a_w, f_min, f_max, r_0, f_0, q_0, v_0, p_0, e_0, n_0_a, n_0_b, res )
n |
|
d_s |
|
s_s |
|
r_s |
|
q_s |
|
h_w |
|
w_w |
|
a_w |
|
f_min |
|
f_max |
|
r_0 |
|
f_0 |
|
q_0 |
|
v_0 |
|
p_0 |
|
e_0 |
|
n_0_a |
|
n_0_b |
|
res |
|
All parameters must be provided as single values, except for those parameters that shall be randomised, which must be provided as a vector of length two. This vector defines the range within which uniformly distributed random values will be generated and assigned.
List
object with model reference parameters.
Michael Dietze
## create two parameter sets where h_w (water level) and q_s (sediment ## flux) are randomly varied. ref_pars <- fmi_parameters(n = 2, h_w = c(0.02, 2.00), q_s = c(0.001, 50.000) / 2650, d_s = 0.01, s_s = 1.35, r_s = 2650, w_w = 6, a_w = 0.0075, f_min = 5, f_max = 80, r_0 = 6, f_0 = 1, q_0 = 10, v_0 = 350, p_0 = 0.55, e_0 = 0.09, n_0_a = 0.6, n_0_b = 0.8, res = 100)
## create two parameter sets where h_w (water level) and q_s (sediment ## flux) are randomly varied. ref_pars <- fmi_parameters(n = 2, h_w = c(0.02, 2.00), q_s = c(0.001, 50.000) / 2650, d_s = 0.01, s_s = 1.35, r_s = 2650, w_w = 6, a_w = 0.0075, f_min = 5, f_max = 80, r_0 = 6, f_0 = 1, q_0 = 10, v_0 = 350, p_0 = 0.55, e_0 = 0.09, n_0_a = 0.6, n_0_b = 0.8, res = 100)
In order to run the fluvial model inversion (FMI) routine, a look-up table with reference spectra needs to be created (based on predefined model parameters). This function does this job.
fmi_spectra(parameters, n_cores = 1)
fmi_spectra(parameters, n_cores = 1)
parameters |
|
n_cores |
|
List
object containing the calculated reference spectra
and the corresponding input parameters. Note that the spectra are given
in dB for a seamless comparison with the empirical PSD data, while the
original output of the models are in linear scale.
Michael Dietze
## create 2 example reference parameter sets ref_pars <- fmi_parameters(n = 2, h_w = c(0.02, 2.00), q_s = c(0.001, 50.000) / 2650, d_s = 0.01, s_s = 1.35, r_s = 2650, w_w = 6, a_w = 0.0075, f_min = 5, f_max = 80, r_0 = 6, f_0 = 1, q_0 = 10, v_0 = 350, p_0 = 0.55, e_0 = 0.09, n_0_a = 0.6, n_0_b = 0.8, res = 100) ## create corresponding reference spectra ref_spectra <- fmi_spectra(parameters = ref_pars)
## create 2 example reference parameter sets ref_pars <- fmi_parameters(n = 2, h_w = c(0.02, 2.00), q_s = c(0.001, 50.000) / 2650, d_s = 0.01, s_s = 1.35, r_s = 2650, w_w = 6, a_w = 0.0075, f_min = 5, f_max = 80, r_0 = 6, f_0 = 1, q_0 = 10, v_0 = 350, p_0 = 0.55, e_0 = 0.09, n_0_a = 0.6, n_0_b = 0.8, res = 100) ## create corresponding reference spectra ref_spectra <- fmi_spectra(parameters = ref_pars)
This function starts a browser-based graphic user interface to explore the parameter space of seismic models that predict the spectra of turbulent water flow and bedload flux. Empirical spectra can be added if they are present in the current environment as eseis objects. Note that those spectra should be made from deconvolved input data in order to have the same units as the model spectra (dB). ATTENTION, due to an unresolved issue, there must be at least one eseis object present in the working environment.
gui_models(...)
gui_models(...)
... |
further arguments to pass to |
Michael Dietze
runApp
## Not run: # Start the GUI gui_models() ## End(Not run)
## Not run: # Start the GUI gui_models() ## End(Not run)
The function returns the list of supported data loggers to extract signal deconvolution parameters.
list_logger()
list_logger()
The value AD is the analogue-digital conversion factor.
List
object, supported loggers with their parameters.
Michael Dietze
## show documented loggers list_logger() ## show names of loggers in list names(list_logger())
## show documented loggers list_logger() ## show names of loggers in list names(list_logger())
The function returns a data frame with all header values of a sac file. It may be used for advanced modifications by the user.
list_sacparameters()
list_sacparameters()
List
object, parameters supported by a sac file.
Michael Dietze
## show sac parameters list_sacparameters()
## show sac parameters list_sacparameters()
The function returns the list of supported sensors to extract signal deconvolution parameters.
list_sensor()
list_sensor()
Poles and zeros must be given in rad/s. Characteristics of further
sensors can be added manually. See examples of signal_deconvolve
for further information. The value s is the generator constant
(sensitivity) given in Vs/m. The value k is the normalisation factor of
the sensor.
List
object, supported sensors with their parameters.
Michael Dietze
## show sensors list_sensor()
## show sensors list_sensor()
The function fits one of several models of signal amplitude attenuation and returns a set of model parameters, including the source amplitude (a_0).
model_amplitude( data, model = "SurfSpreadAtten", distance, source, d_map, coupling, v, q, f, k, a_0 )
model_amplitude( data, model = "SurfSpreadAtten", distance, source, d_map, coupling, v, q, f, k, a_0 )
data |
|
model |
|
distance |
|
source |
|
d_map |
|
coupling |
|
v |
|
q |
|
f |
|
k |
|
a_0 |
|
Depending on the choice of the model to fit, several parameters can
(or should) be provided, e.g. f
,q
, v
, k
,
and most importantly, a_0
.
If more signals than free parameters are available, the missing
parameters may be estimated during the fit, but without any checks
of quality and meaningfulness. The parameter a_0
will be
defined as 100 times the maximum input amplitude, by default. The
parameters f
will be set to 10 Hz, q
to 50, v
to 1000 m/s and k
to 0.5.
ISSUES: account for non-fixed parameters, especially k
The following amplitude-distance models are available:
"SurfSpreadAtten"
, Surface waves including geometric
spreading and unelastic attenuation
"BodySpreadAtten"
, Body waves including geometric
spreading and unelastic attenuation
"SurfBodySpreadAtten"
, Surface and body waves including
geometric spreading and unelastic attenuation
"SurfSpread"
, Surface waves including geometric
spreading, only
"BodySpread"
, Body waves including geometric
spreading, only
"SurfBodySpread"
, Surface and body waves including
geometric spreading, only
**SurfSpreadAtten** The model is based on Eq. 17 from Burtin et al. (2016):
where a_0 is the source amplitude, a_d the amplitude as recorded by a sensor at distance d, f is the center frequency of the signal, q the ground quality factor and v the seismic wave velocity.
**BodySpreadAtten** The model is based on Eq. 16 from Burtin et al. (2016):
where a_0 is the source amplitude, a_d the amplitude as recorded by a sensor at distance d, f is the center frequency of the signal, q the ground quality factor and v the seismic wave velocity.
**SurfBodySpreadAtten** The model based on Eqs. 16 and 17 from Burtin et al. (2016):
where a_0 is the source amplitude, a_d the amplitude as recorded by a sensor at distance d, f is the center frequency of the signal, q the ground quality factor, v the seismic wave velocity, and n and m two factors determining the relative contributions of the two wave types, thus summing to 1.
**BodySpread** The model is simply accounting for geometric spreading
where a_0 is the source amplitude, a_d the amplitude as recorded by a sensor at distance d.
**SurfSpread** The model is simply accounting for geometric spreading
where a_0 is the source amplitude, a_d the amplitude as recorded by a sensor at distance d.
**SurfBodySpread** The model is simply accounting for geometric spreading
where a_0 is the source amplitude, a_d the amplitude as recorded by a sensor at distance d, and n and m two factors determining the relative contributions of the two wave types, thus summing to 1.
**References** - Burtin, A., Hovius, N., and Turowski, J. M.: Seismic monitoring of torrential and fluvial processes, Earth Surf. Dynam., 4, 285–307, https://doi.org/10.5194/esurf-4-285-2016, 2016.
List
with model results, including a_0
(source
amplitude), residuals
(model residuals), coefficients
model coefficients.
Michael Dietze
## Not run: ## create synthetic DEM dem <- terra::rast(nrows = 20, ncols = 20, xmin = 0, xmax = 10000, ymin= 0, ymax = 10000, vals = rep(0, 400)) ## define station coordinates sta <- data.frame(x = c(1000, 9000, 5000, 9000), y = c(1000, 1000, 9000, 9000), ID = c("A", "B", "C", "D")) ## create synthetic signal (source in towards lower left corner of the DEM) s <- rbind(dnorm(x = 1:1000, mean = 500, sd = 50) * 50, dnorm(x = 1:1000, mean = 500, sd = 50) * 2, dnorm(x = 1:1000, mean = 500, sd = 50) * 1, dnorm(x = 1:1000, mean = 500, sd = 50) * 0.5) ## calculate spatial distance maps and inter-station distances D <- eseis::spatial_distance(stations = sta[,1:2], dem = dem) model_amplitude(data = s, source = c(500, 600), d_map = D$maps, v = 500, q = 50, f = 10) model_amplitude(data = s, distance = c(254, 8254, 9280, 11667), model = "SurfBodySpreadAtten", v = 500, q = 50, f = 10, k = 0.5) ## End(Not run)
## Not run: ## create synthetic DEM dem <- terra::rast(nrows = 20, ncols = 20, xmin = 0, xmax = 10000, ymin= 0, ymax = 10000, vals = rep(0, 400)) ## define station coordinates sta <- data.frame(x = c(1000, 9000, 5000, 9000), y = c(1000, 1000, 9000, 9000), ID = c("A", "B", "C", "D")) ## create synthetic signal (source in towards lower left corner of the DEM) s <- rbind(dnorm(x = 1:1000, mean = 500, sd = 50) * 50, dnorm(x = 1:1000, mean = 500, sd = 50) * 2, dnorm(x = 1:1000, mean = 500, sd = 50) * 1, dnorm(x = 1:1000, mean = 500, sd = 50) * 0.5) ## calculate spatial distance maps and inter-station distances D <- eseis::spatial_distance(stations = sta[,1:2], dem = dem) model_amplitude(data = s, source = c(500, 600), d_map = D$maps, v = 500, q = 50, f = 10) model_amplitude(data = s, distance = c(254, 8254, 9280, 11667), model = "SurfBodySpreadAtten", v = 500, q = 50, f = 10, k = 0.5) ## End(Not run)
The function calculates a seismic spectrum as predicted by the model of Tsai et al. (2012) for river bedload transport. The code was written to R by Sophie Lagarde and integrated to the R package 'eseis' by Michael Dietze.
model_bedload( gsd, d_s, s_s, r_s, q_s, h_w, w_w, a_w, f = c(1, 100), r_0, f_0, q_0, e_0, v_0, x_0, n_0, n_c, res = 100, adjust = TRUE, eseis = FALSE, ... )
model_bedload( gsd, d_s, s_s, r_s, q_s, h_w, w_w, a_w, f = c(1, 100), r_0, f_0, q_0, e_0, v_0, x_0, n_0, n_c, res = 100, adjust = TRUE, eseis = FALSE, ... )
gsd |
|
d_s |
|
s_s |
|
r_s |
|
q_s |
|
h_w |
|
w_w |
|
a_w |
|
f |
|
r_0 |
|
f_0 |
|
q_0 |
|
e_0 |
|
v_0 |
|
x_0 |
|
n_0 |
|
n_c |
|
res |
|
adjust |
|
eseis |
|
... |
Further arguments passed to the function. |
The model uses a set of predefined constants. These can also be changed
by the user, using the ...
argument:
g = 9.81
, gravitational acceleration (m/s^2)
r_w = 1000
, fluid specific density (kg/m^3)
k_s = 3 * d_50
, roughness length (m)
log_lim = c(0.0001, 100), limits of grain-size distribution
function template (m)
log_length = 10000, length of grain-size distribution
function template
nu = 10^(-6)
, specific density of the fluid (kg/m^3)
power_d = 3
, grain-size power exponent
gamma = 0.9
, gamma parameter, after Parker (1990)
s_c = 0.8
, drag coefficient parameter
s_p = 3.5
, drag coefficient parameter
c_1 = 2 / 3
, inter-impact time scaling, after
Sklar & Dietrich (2004)
When no user defined grain-size distribution function is provided,the
function calculates the raised cosine distribution function as defined
in Tsai et al. (2012) using the default range and resolution as specified
by log_lim
and log_length
(see additional arguments list
above). These default values are appropriate for mean sediment sizes
between 0.001 and 10 m and log standard deivations between 0.05 and 1.
When more extreme distributions are to be used, it is necessary to either
adjust the arguments log_lim
and log_length
or use a
user defined distribution function.
The adjustment option (implemented with package version 0.6.0) is only
relevant for wide grain-size distributions, i.e., s_s
> 0.2. In
such cases, the unadjusted version tends to underestimate seismic power.
eseis
object containing the modelled spectrum.
Sophie Lagarde, Michael Dietze
Tsai, V. C., B. Minchew, M. P. Lamb, and J.-P. Ampuero (2012), A physical model for seismic noise generation from sediment transport in rivers, Geophys. Res. Lett., 39, L02404, doi:10.1029/2011GL050255.
## calculate spectrum (i.e., fig. 1b in Tsai et al., 2012) p_bedload <- model_bedload(d_s = 0.7, s_s = 0.1, r_s = 2650, q_s = 0.001, h_w = 4, w_w = 50, a_w = 0.005, f = c(0.1, 20), r_0 = 600, f_0 = 1, q_0 = 20, e_0 = 0, v_0 = 1295, x_0 = 0.374, n_0 = 1, res = 100, eseis = TRUE) ## plot spectrum plot_spectrum(data = p_bedload, ylim = c(-170, -110)) ## define empiric grain-size distribution gsd_empiric <- data.frame(d = c(0.70, 0.82, 0.94, 1.06, 1.18, 1.30), p = c(0.02, 0.25, 0.45, 0.23, 0.04, 0.00)) ## calculate spectrum p_bedload <- model_bedload(gsd = gsd_empiric, r_s = 2650, q_s = 0.001, h_w = 4, w_w = 50, a_w = 0.005, f = c(0.1, 20), r_0 = 600, f_0 = 1, q_0 = 20, e_0 = 0, v_0 = 1295, x_0 = 0.374, n_0 = 1, res = 100, eseis = TRUE) ## plot spectrum plot_spectrum(data = p_bedload, ylim = c(-170, -110)) ## define mean and sigma for parametric distribution function d_50 <- 1 sigma <- 0.1 ## define raised cosine distribution function following Tsai et al. (2012) d_1 <- 10^seq(log10(d_50 - 5 * sigma), log10(d_50 + 5 * sigma), length.out = 20) sigma_star <- sigma / sqrt(1 / 3 - 2 / pi^2) p_1 <- (1 / (2 * sigma_star) * (1 + cos(pi * (log(d_1) - log(d_50)) / sigma_star))) / d_1 p_1[log(d_1) - log(d_50) > sigma_star] <- 0 p_1[log(d_1) - log(d_50) < -sigma_star] <- 0 p_1 <- p_1 / sum(p_1) gsd_raised_cos <- data.frame(d = d_1, p = p_1)
## calculate spectrum (i.e., fig. 1b in Tsai et al., 2012) p_bedload <- model_bedload(d_s = 0.7, s_s = 0.1, r_s = 2650, q_s = 0.001, h_w = 4, w_w = 50, a_w = 0.005, f = c(0.1, 20), r_0 = 600, f_0 = 1, q_0 = 20, e_0 = 0, v_0 = 1295, x_0 = 0.374, n_0 = 1, res = 100, eseis = TRUE) ## plot spectrum plot_spectrum(data = p_bedload, ylim = c(-170, -110)) ## define empiric grain-size distribution gsd_empiric <- data.frame(d = c(0.70, 0.82, 0.94, 1.06, 1.18, 1.30), p = c(0.02, 0.25, 0.45, 0.23, 0.04, 0.00)) ## calculate spectrum p_bedload <- model_bedload(gsd = gsd_empiric, r_s = 2650, q_s = 0.001, h_w = 4, w_w = 50, a_w = 0.005, f = c(0.1, 20), r_0 = 600, f_0 = 1, q_0 = 20, e_0 = 0, v_0 = 1295, x_0 = 0.374, n_0 = 1, res = 100, eseis = TRUE) ## plot spectrum plot_spectrum(data = p_bedload, ylim = c(-170, -110)) ## define mean and sigma for parametric distribution function d_50 <- 1 sigma <- 0.1 ## define raised cosine distribution function following Tsai et al. (2012) d_1 <- 10^seq(log10(d_50 - 5 * sigma), log10(d_50 + 5 * sigma), length.out = 20) sigma_star <- sigma / sqrt(1 / 3 - 2 / pi^2) p_1 <- (1 / (2 * sigma_star) * (1 + cos(pi * (log(d_1) - log(d_50)) / sigma_star))) / d_1 p_1[log(d_1) - log(d_50) > sigma_star] <- 0 p_1[log(d_1) - log(d_50) < -sigma_star] <- 0 p_1 <- p_1 / sum(p_1) gsd_raised_cos <- data.frame(d = d_1, p = p_1)
The function calculates the seismic spectrum as predicted by the model of Gimbert et al. (2014) for hydraulic turbulence. The code was written to R by Sophie Lagarde and integrated to the R package 'eseis' by Michael Dietze.
model_turbulence( d_s, s_s, r_s = 2650, h_w, w_w, a_w, f = c(1, 100), r_0, f_0, q_0, v_0, p_0, n_0, res = 1000, eseis = FALSE, ... )
model_turbulence( d_s, s_s, r_s = 2650, h_w, w_w, a_w, f = c(1, 100), r_0, f_0, q_0, v_0, p_0, n_0, res = 1000, eseis = FALSE, ... )
d_s |
|
s_s |
|
r_s |
|
h_w |
|
w_w |
|
a_w |
|
f |
|
r_0 |
|
f_0 |
|
q_0 |
|
v_0 |
|
p_0 |
|
n_0 |
|
res |
|
eseis |
|
... |
Further arguments passed to the function. |
The model uses a set of predefined constants. These can also be changed
by the user, using the ...
argument:
c = 0.5
, instantaneous fluid-grain friction coefficient
(dimensionless)
g = 9.81
, gravitational acceleration (m/s^2)
k = 0.5
, Kolmogrov constant (dimensionless)
k_s = 3 * d_s
, roughness length (m)
h = k_s / 2
, reference height of the measurement (m)
e_0 = 0
, exponent of Q increase with frequency
(dimensionless)
r_w = 1000
, specific density of the fluid (kg/m^3)
c_w = 0.5
, instantaneous fluid-grain friction coefficient
(dimensionless)
eseis
object containing the modelled spectrum.
Sophie Lagarde, Michael Dietze
## model the turbulence-related power spectrum P <- model_turbulence(d_s = 0.03, # 3 cm mean grain-size s_s = 1.35, # 1.35 log standard deviation r_s = 2650, # 2.65 g/cm^3 sediment density h_w = 0.8, # 80 cm water level w_w = 40, # 40 m river width a_w = 0.0075, # 0.0075 rad river inclination f = c(1, 200), # 1-200 Hz frequency range r_0 = 10, # 10 m distance to the river f_0 = 1, # 1 Hz Null frequency q_0 = 10, # 10 quality factor at f = 1 Hz v_0 = 2175, # 2175 m/s phase velocity p_0 = 0.48, # 0.48 power law variation coefficient n_0 = c(0.6, 0.8), # Greens function estimates res = 1000) # 1000 values build the output resolution ## plot the power spectrum plot_spectrum(data = P)
## model the turbulence-related power spectrum P <- model_turbulence(d_s = 0.03, # 3 cm mean grain-size s_s = 1.35, # 1.35 log standard deviation r_s = 2650, # 2.65 g/cm^3 sediment density h_w = 0.8, # 80 cm water level w_w = 40, # 40 m river width a_w = 0.0075, # 0.0075 rad river inclination f = c(1, 200), # 1-200 Hz frequency range r_0 = 10, # 10 m distance to the river f_0 = 1, # 1 Hz Null frequency q_0 = 10, # 10 quality factor at f = 1 Hz v_0 = 2175, # 2175 m/s phase velocity p_0 = 0.48, # 0.48 power law variation coefficient n_0 = c(0.6, 0.8), # Greens function estimates res = 1000) # 1000 values build the output resolution ## plot the power spectrum plot_spectrum(data = P)
The function creates a cross correlation time series of two input data
sets. The input data is cut into overlapping snippets and, optionally,
further smaller sub snippets for averaging the results per time snippet.
The data can be made subject to a series of optional preprocessing steps,
i.e. be aggregated, deconvolved, filtered, cut by standard deviation, and
sign-cut. the cross correlation function is calculated and returned for a
defined lag time window. The output of the function is supposed to be
used as input for the function ncc_process()
.
ncc_correlate( start, stop, ID, component, dir, window, overlap = 0, window_sub, lag, dt, deconvolve = FALSE, f, pick = FALSE, whiten = FALSE, sd, sign = FALSE, cpu, buffer = 0.05, eseis = TRUE, ... )
ncc_correlate( start, stop, ID, component, dir, window, overlap = 0, window_sub, lag, dt, deconvolve = FALSE, f, pick = FALSE, whiten = FALSE, sd, sign = FALSE, cpu, buffer = 0.05, eseis = TRUE, ... )
start |
|
stop |
|
ID |
|
component |
|
dir |
|
window |
|
overlap |
|
window_sub |
|
lag |
|
dt |
|
deconvolve |
|
f |
|
pick |
|
whiten |
|
sd |
|
sign |
|
cpu |
|
buffer |
|
eseis |
|
... |
Further arguments passed to the functions
|
The sampling interval (dt
must be defined). It is wise to set it
to more than twice the filter's higher corner frequency (f[2]
).
Aggregation is recommended to improve computational efficiency, but is
mandatory if data sets of different sampling intervals are to be analysed.
In that case, it must be possible to aggregate the data sets to the
provided aggregation sampling interval (dt
), otherwise an error
will arise. As an example, if the two data sets have sampling intervals of
1/200
and 1/500
, the highest possible aggregated sampling
interval is 1/100
. See aux_commondt()
for further
information.
The function supports parallel processing. However, keep in mind that calculating the cross correlation functions for large data sets and large windows will draw serious amounts of memory. For example, a 24 h window of two seismic signals recorded at 200 Hz will easily use 15 GB of RAM. Combining this with parallel processing will multiply that memory size. Therefore, it is better think before going for too high ambitions, and check how the computer system statistics evolve with increasing windows and parallel operations.
Deconvolution is recommended if different station hardware and setup is used for the stations to analyse (i.e., different sensors, loggers or gain factors).
To account for biases due to brief events in the signals, the data sets
can be truncated (cut) in their amplitude. This cutting can either be
done based on the data sets' standard deviations (or a multiplicator of
those standard deviations, see signal_cut()
for further details),
using the argument sd = 1
, for one standard deviation.
Alternatively, the data can also be cut by their sign (i.e., positive and
negative values will be converted to 1
and -1
, respectively).
List
with spectrogram matrix, time and frequency vectors.
Michael Dietze
## Not run: ## calculate correlogram cc <- ncc_correlate(start = "2017-04-09 00:30:00", stop = "2017-04-09 01:30:00", ID = c("RUEG1", "RUEG2"), dt = 1/10, component = c("Z", "Z"), dir = paste0(system.file("extdata", package = "eseis"), "/"), window = 600, overlap = 0, lag = 20, deconvolve = TRUE, sensor = "TC120s", logger = "Cube3extBOB", gain = 1, f = c(0.05, 0.1), sd = 1) ## plot output plot_correlogram(cc) ## End(Not run)
## Not run: ## calculate correlogram cc <- ncc_correlate(start = "2017-04-09 00:30:00", stop = "2017-04-09 01:30:00", ID = c("RUEG1", "RUEG2"), dt = 1/10, component = c("Z", "Z"), dir = paste0(system.file("extdata", package = "eseis"), "/"), window = 600, overlap = 0, lag = 20, deconvolve = TRUE, sensor = "TC120s", logger = "Cube3extBOB", gain = 1, f = c(0.05, 0.1), sd = 1) ## plot output plot_correlogram(cc) ## End(Not run)
The function estimates the relative seismic wave velocity changes over
time based on matching iteratively stretched master correlations to
previously calculated correlograms (cf. ncc_correlate
).
ncc_stretch( data, lag, master = "mean", normalise = TRUE, sides = "both", range = 0.01, steps = 100, method = "r", reject = 0, ... )
ncc_stretch( data, lag, master = "mean", normalise = TRUE, sides = "both", range = 0.01, steps = 100, method = "r", reject = 0, ... )
data |
|
lag |
|
master |
|
normalise |
|
sides |
|
range |
|
steps |
|
method |
|
reject |
|
... |
Further arguments passed to the function. |
A data.frame
, object with the time and relative wave
velocity change estimate.
Michael Dietze
## Not run: cc <- ncc_preprocess(start = "2017-04-09 00:30:00", stop = "2017-04-09 01:30:00", ID = c("RUEG1", "RUEG2"), component = c("Z", "Z"), dir = paste0(system.file("extdata", package = "eseis"), "/"), window = 600, overlap = 0, lag = 20, deconvolve = TRUE, sensor = "TC120s", logger = "Cube3extBOB", gain = 1, f = c(0.05, 0.1), sd = 1) ## estimate dv/v dv <- ncc_stretch(data = cc, range = 0.05) ## plot result plot(dv$time, dv$dvv, type = "l") ## End(Not run)
## Not run: cc <- ncc_preprocess(start = "2017-04-09 00:30:00", stop = "2017-04-09 01:30:00", ID = c("RUEG1", "RUEG2"), component = c("Z", "Z"), dir = paste0(system.file("extdata", package = "eseis"), "/"), window = 600, overlap = 0, lag = 20, deconvolve = TRUE, sensor = "TC120s", logger = "Cube3extBOB", gain = 1, f = c(0.05, 0.1), sd = 1) ## estimate dv/v dv <- ncc_stretch(data = cc, range = 0.05) ## plot result plot(dv$time, dv$dvv, type = "l") ## End(Not run)
The function picks (identifies) events from continuous data by comparing the data patterns against a template signal using Pearson's correlation coefficient, defining an event when that coefficient is above a threshold value.
pick_correlation(data, on, template, dur_min, time, dt)
pick_correlation(data, on, template, dur_min, time, dt)
data |
|
on |
|
template |
|
dur_min |
|
time |
|
dt |
|
data.frame
, picked events.
Michael Dietze
## create synthetic event signal p <- sin(seq(0, 10 * pi, by = 0.35)) * 0.2 * (1 + sin(seq(0, pi, length.out = 90)))^5 ## show event signal plot(p, type = "l") ## create synthetic noise signal x <- runif(n = 1000, min = -1, max = 1) t <- seq(from = Sys.time(), length.out = length(x), by = 1/200) ii <- floor(runif(n = 3, min = 100, max = 900)) ## add events to noise for(k in 1:length(ii)) { nn <- ii[k]:(ii[k] + 89) x[nn] <- x[nn] + p } ## show resulting time series plot(x = t, y = x, type = "l") ## pick events based on template picks <- eseis::pick_correlation(data = x, on = 0.8, template = p, time = t, dt = 1/200) ## show result print(picks)
## create synthetic event signal p <- sin(seq(0, 10 * pi, by = 0.35)) * 0.2 * (1 + sin(seq(0, pi, length.out = 90)))^5 ## show event signal plot(p, type = "l") ## create synthetic noise signal x <- runif(n = 1000, min = -1, max = 1) t <- seq(from = Sys.time(), length.out = length(x), by = 1/200) ii <- floor(runif(n = 3, min = 100, max = 900)) ## add events to noise for(k in 1:length(ii)) { nn <- ii[k]:(ii[k] + 89) x[nn] <- x[nn] + p } ## show resulting time series plot(x = t, y = x, type = "l") ## pick events based on template picks <- eseis::pick_correlation(data = x, on = 0.8, template = p, time = t, dt = 1/200) ## show result print(picks)
The function picks (identifies) events from continuous data using the kurtosis of the signal, and when it reaches beyond a defined threshold value. The end of an event is determined by the signal-to-noise ratio (SNR)
pick_kurtosis( data, on, off = 1, dur_min = 0, dur_max, window_kurt, window_amp, time, dt )
pick_kurtosis( data, on, off = 1, dur_min = 0, dur_max, window_kurt, window_amp, time, dt )
data |
|
on |
|
off |
|
dur_min |
|
dur_max |
|
window_kurt |
|
window_amp |
|
time |
|
dt |
|
Further reading:
Baillard, C., Crawford, W.C., Ballu, V., Hibert, C., Mangeney, A., 2014. An automatic kurtosis-based p- and s-phase picker designed for local seismic networks. Bull. Seismol. Soc. Am. 104 (1), 394–409.
Hibert, C., Mangeney, A., Grandjean, G., Baillard, C., Rivet, D., Shapiro, N.M., Satriano, C., Maggi, A., Boissier, P., Ferrazzini, V., Crawford, W., 2014. Automated identification, location, and volume estimation of rockfalls at Piton de la Fournaise Volcano. J. Geophys. Res. Earth Surf. 119 (5), 1082–1105. http://dx.doi.org/10.1002/2013JF002970.
data.frame
, picked events.
Michael Dietze
## load example data set data(rockfall) ## preprocess signal (aggregate to increase speed, filter, envelope) s <- signal_aggregate(data = rockfall_eseis, n = 4) s <- signal_filter(data = s, f = c(5, 20), lazy = TRUE) e <- signal_envelope(data = s) ## pick events based on signal kurtosis p <- eseis::pick_kurtosis(data = e, window_kurt = 200, on = 15, off = 5, dur_min = 10, dur_max = 90, window_amp = 300) p$picks
## load example data set data(rockfall) ## preprocess signal (aggregate to increase speed, filter, envelope) s <- signal_aggregate(data = rockfall_eseis, n = 4) s <- signal_filter(data = s, f = c(5, 20), lazy = TRUE) e <- signal_envelope(data = s) ## pick events based on signal kurtosis p <- eseis::pick_kurtosis(data = e, window_kurt = 200, on = 15, off = 5, dur_min = 10, dur_max = 90, window_amp = 300) p$picks
The function calculates the ratio of the short-term-average and long-term-average of the input signal.
pick_stalta(data, time, dt, sta, lta, freeze = FALSE, on, off)
pick_stalta(data, time, dt, sta, lta, freeze = FALSE, on, off)
data |
|
time |
|
dt |
|
sta |
|
lta |
|
freeze |
|
on |
|
off |
|
data frame
, detected events (ID, start time, duration in
seconds, STA-LTA vaue).
Michael Dietze
## load example data data(rockfall) ## filter signal rockfall_f <- signal_filter(data = rockfall_eseis, f = c(1, 90), p = 0.05) ## calculate signal envelope rockfall_e <- signal_envelope(data = rockfall_f) ## pick earthquake and rockfall event p <- pick_stalta(data = rockfall_e, sta = 100, lta = 18000, freeze = TRUE, on = 5, off = 3) p$picks
## load example data data(rockfall) ## filter signal rockfall_f <- signal_filter(data = rockfall_eseis, f = c(1, 90), p = 0.05) ## calculate signal envelope rockfall_e <- signal_envelope(data = rockfall_f) ## pick earthquake and rockfall event p <- pick_stalta(data = rockfall_e, sta = 100, lta = 18000, freeze = TRUE, on = 5, off = 3) p$picks
The function visualises the time evolution of three seismic components
of the same signal against each other as line graphs. There are three
different visualisation types available: 2D
(a panel of three
2D plots), 3D
(a perspective threedimensional plot) and
scene
(an interactive threedimensional plot, mainly for
exploratory purpose).
plot_components(data, type = "2D", order = "xyz", ...)
plot_components(data, type = "2D", order = "xyz", ...)
data |
|
type |
|
order |
|
... |
Further arguments passed to the plot function. |
The plot type type = "3D"
requires the package plot3D
being installed. The plot type type = "scene"
requires the
package rgl
being installed.
A plot
Michael Dietze
## load example data set data(earthquake) ## filter seismic signals s <- eseis::signal_filter(data = s, dt = 1/200, f = c(0.05, 0.1)) ## integrate signals to get displacement s_d <- eseis::signal_integrate(data = s, dt = 1/200) ## plot components in 2D plot_components(data = s_d, type = "2D") ## plot components with time colour-coded plot_components(data = s_d, type = "2D", col = rainbow(n = length(s$BHE))) ## plot components with used defined coulour ramp col_user <- colorRampPalette(colors = c("grey20", "darkblue", "blue", "green", "red", "orange")) plot_components(data = s_d, type = "2D", col = col_user(n = length(s$BHE))) ## plot components as 3D plot, uncomment to use #plot_components(data = s_d, # type = "3D", # col = rainbow(n = length(s$BHE)))
## load example data set data(earthquake) ## filter seismic signals s <- eseis::signal_filter(data = s, dt = 1/200, f = c(0.05, 0.1)) ## integrate signals to get displacement s_d <- eseis::signal_integrate(data = s, dt = 1/200) ## plot components in 2D plot_components(data = s_d, type = "2D") ## plot components with time colour-coded plot_components(data = s_d, type = "2D", col = rainbow(n = length(s$BHE))) ## plot components with used defined coulour ramp col_user <- colorRampPalette(colors = c("grey20", "darkblue", "blue", "green", "red", "orange")) plot_components(data = s_d, type = "2D", col = col_user(n = length(s$BHE))) ## plot components as 3D plot, uncomment to use #plot_components(data = s_d, # type = "3D", # col = rainbow(n = length(s$BHE)))
The function uses the output of ncc_correlate()
to show an
image plot of a noise cross correlation analysis.
plot_correlogram(data, agg = c(1, 1), legend = TRUE, keep_par = FALSE, ...)
plot_correlogram(data, agg = c(1, 1), legend = TRUE, keep_par = FALSE, ...)
data |
|
agg |
|
legend |
|
keep_par |
|
... |
Additional arguments passed to the plot function. |
Graphic output of a correlogram.
Michael Dietze
## Not run: ## calculate correlogram cc <- ncc_correlate(start = "2017-04-09 00:30:00", stop = "2017-04-09 01:30:00", ID = c("RUEG1", "RUEG2"), component = c("Z", "Z"), dir = paste0(system.file("extdata", package = "eseis"), "/"), window = 600, overlap = 0, lag = 20, f = c(0.05, 0.1), sd = 1) ## explicit plot function call with adjusted resolution plot_correlogram(data = cc, agg = c(2, 5)) ## define plot colour scale cls <- colorRampPalette(colors = c("brown", "white", "green")) ## simple function call with user-defined colour scale plot(cc, col = cls(100)) ## End(Not run)
## Not run: ## calculate correlogram cc <- ncc_correlate(start = "2017-04-09 00:30:00", stop = "2017-04-09 01:30:00", ID = c("RUEG1", "RUEG2"), component = c("Z", "Z"), dir = paste0(system.file("extdata", package = "eseis"), "/"), window = 600, overlap = 0, lag = 20, f = c(0.05, 0.1), sd = 1) ## explicit plot function call with adjusted resolution plot_correlogram(data = cc, agg = c(2, 5)) ## define plot colour scale cls <- colorRampPalette(colors = c("brown", "white", "green")) ## simple function call with user-defined colour scale plot(cc, col = cls(100)) ## End(Not run)
The function creates from an input waveform a multi panel plot, including a seismogram, spectrum and spectrogram, and additional frequency statistics information.
plot_event(data, ratio = c(0.3, 0.3), ...)
plot_event(data, ratio = c(0.3, 0.3), ...)
data |
|
ratio |
|
... |
Additional arguments passed to the plot function. See details for further information |
Note that plot generation time can get long when other than short
events are passed to the function. The axes limits can only be changed
for the spectrum and spectrogram plots, ylim
affects the frequency
range, zlim
affects the spectral power range.
The function uses the native plot function plot_signal()
,
plot_spectrum()
and plot_spectrogram()
along with
signal_stats()
to build a four panel plot.
Graphic output of an event waveform.
Michael Dietze
## Not run: ## load and deconvolve example event data(rockfall) rockfall_eseis <- signal_deconvolve(rockfall_eseis) ## plot event straight away plot_event(data = rockfall_eseis) ## plot event with adjusted parameters plot_event(data = rockfall_eseis, ratio = c(0.4, 0.3), method = "periodogram", n = 100, window = 6, overlap = 0.8, window_sub = 4, overlap_sub = 0.8, format ="%M:%S", col = "jet", ylim = c(5, 80), zlim = c(-170, -100)) ## End(Not run)
## Not run: ## load and deconvolve example event data(rockfall) rockfall_eseis <- signal_deconvolve(rockfall_eseis) ## plot event straight away plot_event(data = rockfall_eseis) ## plot event with adjusted parameters plot_event(data = rockfall_eseis, ratio = c(0.4, 0.3), method = "periodogram", n = 100, window = 6, overlap = 0.8, window_sub = 4, overlap_sub = 0.8, format ="%M:%S", col = "jet", ylim = c(5, 80), zlim = c(-170, -100)) ## End(Not run)
The function uses the output of signal_spectrogram()
to plot a
probabilistic power spectral density estimate.
plot_ppsd(data, res = c(500, 500), n, ...)
plot_ppsd(data, res = c(500, 500), n, ...)
data |
|
res |
|
n |
|
... |
Additional arguments passed to the plot function. |
Graphic output of a spectrogram.
Michael Dietze
## load example data set data(rockfall) ## deconvolve data set r <- signal_deconvolve(data = rockfall_eseis) ## calculate PSD p <- signal_spectrogram(data = r) ## plot PPSD plot_ppsd(data = p$PSD) ## plot PPSD with lower resolution, more smoothing and other colour ppsd_color <- colorRampPalette(c("white", "black", "red")) plot_ppsd(data = p$PSD, res = c(200, 200), n = c(15, 20), col = ppsd_color(200))
## load example data set data(rockfall) ## deconvolve data set r <- signal_deconvolve(data = rockfall_eseis) ## calculate PSD p <- signal_spectrogram(data = r) ## plot PPSD plot_ppsd(data = p$PSD) ## plot PPSD with lower resolution, more smoothing and other colour ppsd_color <- colorRampPalette(c("white", "black", "red")) plot_ppsd(data = p$PSD, res = c(200, 200), n = c(15, 20), col = ppsd_color(200))
This function plots a line graph of a seismic signal. To avoid long plot preparation times the signal is reduced to a given number of points.
plot_signal(data, time, n = 10000, ...)
plot_signal(data, time, n = 10000, ...)
data |
|
time |
|
n |
|
... |
Further arguments passed to the plot function. |
The format
argument is based on hints provided by Sebastian
Kreutzer and Christoph Burow. It allows plotting time axis units in
user defined formats. The time format must be provided as character string
using the POSIX standard (see documentation of strptime
for a list
of available keywords), e.g., "
"
A line plot of a seismic wave form.
Michael Dietze
## load example data set data(rockfall) ## plot data set straightforward plot_signal(data = rockfall_eseis) ## plot data set with lower resolution plot_signal(data = rockfall_eseis, n = 100) ## plot data set but not as an eseis object plot_signal(data = rockfall_z, time = rockfall_t) ## load earthquake data set data(earthquake) ## plot all three components (after changing plot options) pars <- par(no.readonly = TRUE) par(mfcol = c(3, 1)) plt <- lapply(s, plot_signal, t = t) par(pars)
## load example data set data(rockfall) ## plot data set straightforward plot_signal(data = rockfall_eseis) ## plot data set with lower resolution plot_signal(data = rockfall_eseis, n = 100) ## plot data set but not as an eseis object plot_signal(data = rockfall_z, time = rockfall_t) ## load earthquake data set data(earthquake) ## plot all three components (after changing plot options) pars <- par(no.readonly = TRUE) par(mfcol = c(3, 1)) plt <- lapply(s, plot_signal, t = t) par(pars)
This function plots spectrograms of seismic signals. It uses the output
of signal_spectrogram
.
plot_spectrogram(data, legend = TRUE, keep_par = FALSE, agg = c(1, 1), ...)
plot_spectrogram(data, legend = TRUE, keep_par = FALSE, agg = c(1, 1), ...)
data |
|
legend |
|
keep_par |
|
agg |
|
... |
Additional arguments passed to the plot function. |
As of version 0.7.2, the value range (zlim
) is no longer set to the
full data range but to the range between quantiles 0.01 and 0.99. For the
full value range to be plotted, use zlim = range(data$PSD$S)
.
As of version 0.7.2, the default plot colour has changed from the "jet"
colour palette to the "Inferno" palette. This due to perception issues with
the "jet" palette. If one wants to decisively use the "jet" colours, this
can be done by adding the keyword col = "jet"
. To use other
colour schemes, such as sequential HCL schemes from the
colorspace package, specify them as additional argument, e.g.
col = colorspace::sequential_hcl(200, palette = "Plasma")
,
col = colorspace::sequential_hcl(200, palette = "Inferno")
,
col = colorspace::sequential_hcl(200, palette = "Viridis")
.
Graphic output of a spectrogram.
Michael Dietze
## load example data set data(rockfall) ## deconvolve signal rockfall <- signal_deconvolve(data = rockfall_eseis) ## calculate spectrogram PSD <- signal_spectrogram(data = rockfall) ## plot spectrogram plot_spectrogram(data = PSD) ## plot spectrogram with legend and labels in rainbow colours plot_spectrogram(data = PSD, xlab = "Time (min)", ylab = "f (Hz)", main = "Power spectral density estimate", legend = TRUE, zlim = c(-220, -70), col = rainbow(100)) ## plot spectrogram with frequencies in log scale plot_spectrogram(data = PSD, log = "y") ## plot spectrogram with formatted time axis (minutes and seconds) plot_spectrogram(data = PSD, format = "%M:%S")
## load example data set data(rockfall) ## deconvolve signal rockfall <- signal_deconvolve(data = rockfall_eseis) ## calculate spectrogram PSD <- signal_spectrogram(data = rockfall) ## plot spectrogram plot_spectrogram(data = PSD) ## plot spectrogram with legend and labels in rainbow colours plot_spectrogram(data = PSD, xlab = "Time (min)", ylab = "f (Hz)", main = "Power spectral density estimate", legend = TRUE, zlim = c(-220, -70), col = rainbow(100)) ## plot spectrogram with frequencies in log scale plot_spectrogram(data = PSD, log = "y") ## plot spectrogram with formatted time axis (minutes and seconds) plot_spectrogram(data = PSD, format = "%M:%S")
This function plots a line graph of the spectrum of a seismic signal.
plot_spectrum(data, unit = "dB", n = 10000, ...)
plot_spectrum(data, unit = "dB", n = 10000, ...)
data |
|
unit |
|
n |
|
... |
Further arguments passed to the plot function. |
A line plot.
Michael Dietze
## load example data set data(rockfall) ## calculate spectrum spectrum_rockfall <- signal_spectrum(data = rockfall_eseis) ## plot data set with lower resolution plot_spectrum(data = spectrum_rockfall)
## load example data set data(rockfall) ## calculate spectrum spectrum_rockfall <- signal_spectrum(data = rockfall_eseis) ## plot data set with lower resolution plot_spectrum(data = spectrum_rockfall)
The function loads seismic data from a data directory structure (see
aux_organisecubefiles
) based on the event start time, duration,
component and station ID. The data to be read needs to be adequately
structured. The data directory must contain mseed or SAC files. These
files will either be identified automatically or can be defined
explicitly by the parameter format
.
read_data( start, duration, station, component = "BHZ", format, dir, pattern = "eseis", simplify = TRUE, interpolate = FALSE, eseis = TRUE, try = TRUE, ... )
read_data( start, duration, station, component = "BHZ", format, dir, pattern = "eseis", simplify = TRUE, interpolate = FALSE, eseis = TRUE, try = TRUE, ... )
start |
|
duration |
|
station |
|
component |
|
format |
|
dir |
|
pattern |
|
simplify |
|
interpolate |
|
eseis |
|
try |
|
... |
Further arguments to describe data structure, only needed for
pattern type |
Data organisation must follow a consistent scheme. The default scheme,
eseis
(Dietze, 2018 ESurf) requires
hourly files organised in a directory for each Julian Day, and in each
calendar year. The file name must be entirely composed of
station ID, 2-digit year, Julian Day, hour, minute, second and
channel name. Each item must be separated by a full stop,
e.g. "2013/203/IGB01.13.203.16.00.00.BHZ"
for a
file from 2013, Julian Day 203, from station IGB01, covering one hour from
"16:00:00 UTC"
, and containing the BHZ component. Each Julian Day directory
can contain files from different components and stations. The respective
pattern string to describe that file organisation is
"%Y/%j/%STA.%y.%j.%H.%M.%S.%CMP"
. The percent sign indicates
a wild card, where %Y
is the 4-digit year, %j
the 3-digit Julian
Julian Day, %STA
the station ID, %y
the 2-digit year,
%H
the 2-digit hour, %M
the 2-digit minute, %S
the
2-digit second and %CMP
the component ID. The files can have a
further file extension which does not need to be explicitly defined in the
pattern string. The slashes in the above pattern string define
subdirectories.
An alternative organisation scheme is the one used by SeisComP, indicated
by the keyword "seiscomp"
or the pattern string
"%Y/%NET/%STA/%CMP/%NET.%STA.%LOC.%CMP.%TYP.%Y.%j"
.
The wild card "NET"
means the network ID, "LOC"
the location
abbreviation and "TYP"
the data type. The other wild cards are as
defined above. Hence, the SeisComP scheme consists of directories of the
calendar year, the network to which the data belongs, the station it has
been recorded by, and the component it belongs to. The files in that
latter directory must be daily files.
A list
object containing either a set of eseis
objects or a data set with the time vector ($time
)
and a list of seismic stations ($station_ID
) with their seismic
signals as data frame ($signal
). If simplify = TRUE
(the
default option) and only one seismic station is provided, the output
object containseither just one eseis object or the vectors for
$time
and $signal
.
Michael Dietze
## set seismic data directory dir_data <- paste0(system.file("extdata", package="eseis"), "/") ## load the z component data from a station data <- read_data(start = as.POSIXct(x = "2017-04-09 01:20:00", tz = "UTC"), duration = 120, station = "RUEG1", component = "BHZ", dir = dir_data) ## plot signal plot_signal(data = data) ## load data from two stations data <- read_data(start = as.POSIXct(x = "2017-04-09 01:20:00", tz = "UTC"), duration = 120, station = c("RUEG1", "RUEG2"), component = "BHZ", dir = dir_data) ## plot both signals par(mfcol = c(2, 1)) lapply(X = data, FUN = plot_signal)
## set seismic data directory dir_data <- paste0(system.file("extdata", package="eseis"), "/") ## load the z component data from a station data <- read_data(start = as.POSIXct(x = "2017-04-09 01:20:00", tz = "UTC"), duration = 120, station = "RUEG1", component = "BHZ", dir = dir_data) ## plot signal plot_signal(data = data) ## load data from two stations data <- read_data(start = as.POSIXct(x = "2017-04-09 01:20:00", tz = "UTC"), duration = 120, station = c("RUEG1", "RUEG2"), component = "BHZ", dir = dir_data) ## plot both signals par(mfcol = c(2, 1)) lapply(X = data, FUN = plot_signal)
The function implements download and import of seismic data from FDSN data providers via the fdsnws-dataselect service (see https://www.fdsn.org/webservices/). It is basically a wrapper for the query approach.
read_fdsn( start, duration, station, network, component = "BHZ", url, eseis = TRUE, ... )
read_fdsn( start, duration, station, network, component = "BHZ", url, eseis = TRUE, ... )
start |
|
duration |
|
station |
|
network |
|
component |
|
url |
|
eseis |
|
... |
Additional query arguments sent to the FDSN data provider. See details for available argument names and conventions. |
The FDSN (International Federation of Digital Seismograph Networks)
provides access to a large number of seismic stations worldwide. The data
are organised by network, station, component and further arguments. In
order to use the eseis function read_fdsn
, one must know at least
the former three criteria for the data of interest. A list of networks is
available here: https://www.fdsn.org/networks/. The function expects
the 2-digit network code, the 3- or 4-digit station code, a single seismic
component ID, and the URL to the data archive. Additional query arguments
can be added (and must be added to point at a single seismic trace to
download and import). A complete list of query arguments is available
here: https://www.fdsn.org/webservices/fdsnws-dataselect-1.1.pdf.
For each network listed there, one can find the URL that gives access to the data (if existing) under "Data Access". Note that the function only requires the first URL part, e.g., https://geofon.gfz-potsdam.de.
An eseis
object or a list
with the time
($time
) and $signal
vectors as well as meta information.
Michael Dietze
## Not run: ## read and plot 10 min of data from Ecuador, specifying the component s <- read_fdsn(start = "2020-05-16 22:42:00", duration = 360, station = "IMBA", network = "EC", component = "HHZ") plot(s) ## read and plot 10 min of data from Germany, specifying the URL s <- read_fdsn(start = "2017-03-21 04:38:00", duration = 360, station = "RGN", network = "GE", url = "http://geofon.gfz-potsdam.de") plot(s) ## End(Not run)
## Not run: ## read and plot 10 min of data from Ecuador, specifying the component s <- read_fdsn(start = "2020-05-16 22:42:00", duration = 360, station = "IMBA", network = "EC", component = "HHZ") plot(s) ## read and plot 10 min of data from Germany, specifying the URL s <- read_fdsn(start = "2017-03-21 04:38:00", duration = 360, station = "RGN", network = "GE", url = "http://geofon.gfz-potsdam.de") plot(s) ## End(Not run)
This function reads mseed files. If append = TRUE
, all
files will be appended to the first one in the order as they are provided.
In the append-case the function returns a either a list with the elements
signal
, time
, meta
and header
or a list of the
class eseis
(see documentation of
aux_initiateeseis()
). If append = FALSE
and more than one file
is provided, the function returns a list of the length of the input files,
each containing the above elements.
read_mseed( file, append = TRUE, signal = TRUE, time = TRUE, meta = TRUE, header = TRUE, eseis = TRUE, type = "waveform" )
read_mseed( file, append = TRUE, signal = TRUE, time = TRUE, meta = TRUE, header = TRUE, eseis = TRUE, type = "waveform" )
file |
|
append |
|
signal |
|
time |
|
meta |
|
header |
|
eseis |
|
type |
|
The mseed data format is read based on C code that was part of the now
CRAN-archived package IRISSeismic
v. 1.6.6
(https://cran.r-project.org/src/contrib/Archive/IRISSeismic/). The C code
and wrapper are a simplified version of the material from IRISSeismic
written by Jonathan Callahan. A future version of read_mseed
may
use a further simplified version, restricting the header information to
the pure information, required by eseis to build its meta information.
List
object, optionally of class eseis
Michael Dietze
## Not run: ## read mseed file with default options x <- read_mseed(file = "input.miniseed") ## read mseed file, only signal trace, not as eseis object x <- read_mseed(file = "input.miniseed", time = FALSE, meta = FALSE, header = FALSE, eseis = FALSE) ## read more than one mseed files and append traces x <- read_mseed(file = c("input_1.miniseed", "input_2.miniseed")) ## End(Not run)
## Not run: ## read mseed file with default options x <- read_mseed(file = "input.miniseed") ## read mseed file, only signal trace, not as eseis object x <- read_mseed(file = "input.miniseed", time = FALSE, meta = FALSE, header = FALSE, eseis = FALSE) ## read more than one mseed files and append traces x <- read_mseed(file = c("input_1.miniseed", "input_2.miniseed")) ## End(Not run)
This function reads sac files.
read_sac( file, append = TRUE, signal = TRUE, time = TRUE, meta = TRUE, header = TRUE, eseis = TRUE, get_instrumentdata = FALSE, endianness = "little", biglong = FALSE, type = "waveform" )
read_sac( file, append = TRUE, signal = TRUE, time = TRUE, meta = TRUE, header = TRUE, eseis = TRUE, get_instrumentdata = FALSE, endianness = "little", biglong = FALSE, type = "waveform" )
file |
|
append |
|
signal |
|
time |
|
meta |
|
header |
|
eseis |
|
get_instrumentdata |
|
endianness |
|
biglong |
|
type |
|
The function reads one or more sac-files. If append = TRUE
, all
files will be appended to the first one in the order as they are provided.
In the append-case the function returns a either a list with the elements
signal
, time
, meta
and header
or a list of the
class eseis
(see documentation of
aux_initiateeseis
). If append = FALSE
and more than one file
is provided, the function returns a list of the length of the input files,
each containing the above elements.
The sac data format is
implemented as descibed on the IRIS website
(https://ds.iris.edu/files/sac-manual/manual/file_format.html).
List
object, optionally of class eseis
.
Michael Dietze
## Not run: ## read one file file1 <- "~/Data/sac/EXMP01.14.213.01.00.00.BHE.SAC" sac1 <- read_sac(file = file1) ## read two (or more files) without meta and header parts file2 <- c("~/Data/sac/EXMP01.14.213.01.00.00.BHE.SAC", "~/Data/sac/EXMP01.14.213.02.00.00.BHE.SAC") sac2 <- read_sac(file = file2, meta = FALSE, header = FALSE, eseis = FALSE) ## End(Not run)
## Not run: ## read one file file1 <- "~/Data/sac/EXMP01.14.213.01.00.00.BHE.SAC" sac1 <- read_sac(file = file1) ## read two (or more files) without meta and header parts file2 <- c("~/Data/sac/EXMP01.14.213.01.00.00.BHE.SAC", "~/Data/sac/EXMP01.14.213.02.00.00.BHE.SAC") sac2 <- read_sac(file = file2, meta = FALSE, header = FALSE, eseis = FALSE) ## End(Not run)
The dataset comprises the seismic signal (vertical component) of a rockfall event, preceded by an earthquake. The data have been recorded at 200 Hz sampling frequency with an Omnirecs Cube ext 3 data logger.
The dataset comprises the time vector corresponding the to seismic signal of the rockfall event from the example data set "rockfall".
The dataset comprises the seismic signal (vertical component) of a rockfall event, preceeded by an earthquake. The data have been recorded at 200 Hz sampling frequency with an Omnirecs Cube ext 3 data logger.
rockfall_z rockfall_t rockfall_eseis
rockfall_z rockfall_t rockfall_eseis
The format is: num [1:98400] 65158 65176 65206 65194 65155 ...
The format is: POSIXct[1:98400], format: "2015-04-06 13:16:54" ...
List of 4 $ signal : num [1:98399] 65211 65192 65158 65176 65206 ... $ meta :List of 12 ..$ station : chr "789 " ..$ network : chr "XX " ..$ component: chr "p0 " ..$ n : int 98399
## load example data set data(rockfall) ## plot signal vector using base functionality plot(x = rockfall_t, y = rockfall_z, type = "l") ## plot signal vector using the package plot function plot_signal(data = rockfall_z, time = rockfall_t) ## load example data set data(rockfall) ## load example data set data(rockfall)
## load example data set data(rockfall) ## plot signal vector using base functionality plot(x = rockfall_t, y = rockfall_z, type = "l") ## plot signal vector using the package plot function plot_signal(data = rockfall_z, time = rockfall_t) ## load example data set data(rockfall) ## load example data set data(rockfall)
The signal vector data
is aggregated by an integer factor n
.
If an eseis
object is provided, the meta data is updated. The
function is a wrapper for the funcion decimate
of the package
signal
.
signal_aggregate(data, n = 2, type = "iir")
signal_aggregate(data, n = 2, type = "iir")
data |
|
n |
|
type |
|
Aggregated data set.
Michael Dietze
## load example data set data(rockfall) ## aggregate signal by factor 4 (i.e., dt goes from 1/200 to 1/50) rockfall_agg <- signal_aggregate(data = rockfall_z, n = 4) ## create example data set s <- 1:10 ## aggregate x by factor 2 s_agg_2 <- signal_aggregate(data = s, n = 2) ## aggregate x by factor 3 s_agg_3 <- signal_aggregate(data = s, n = 3) ## plot results plot(x = s, y = rep(x = 1, times = length(s)), ylim = c(1, 3)) points(x = s_agg_2, y = rep(x = 2, times = length(s_agg_2)), col = 2) points(x = s_agg_3, y = rep(x = 3, times = length(s_agg_3)), col = 3) abline(v = s_agg_2, col = 2) abline(v = s_agg_3, col = 3) ## create signal matrix X <- rbind(1:100, 1001:1100, 10001:10100) ## aggregate signal matrix by factor 4 X_agg <- signal_aggregate(data = X, n = 4)
## load example data set data(rockfall) ## aggregate signal by factor 4 (i.e., dt goes from 1/200 to 1/50) rockfall_agg <- signal_aggregate(data = rockfall_z, n = 4) ## create example data set s <- 1:10 ## aggregate x by factor 2 s_agg_2 <- signal_aggregate(data = s, n = 2) ## aggregate x by factor 3 s_agg_3 <- signal_aggregate(data = s, n = 3) ## plot results plot(x = s, y = rep(x = 1, times = length(s)), ylim = c(1, 3)) points(x = s_agg_2, y = rep(x = 2, times = length(s_agg_2)), col = 2) points(x = s_agg_3, y = rep(x = 3, times = length(s_agg_3)), col = 3) abline(v = s_agg_2, col = 2) abline(v = s_agg_3, col = 3) ## create signal matrix X <- rbind(1:100, 1001:1100, 10001:10100) ## aggregate signal matrix by factor 4 X_agg <- signal_aggregate(data = X, n = 4)
The function clips a seismic signal based on the corresponding time vector.
signal_clip(data, limits, time)
signal_clip(data, limits, time)
data |
|
limits |
|
time |
|
Numeric
data set clipped to provided time interval.
Michael Dietze
## load example data data(rockfall) ## define limits (second 10 to 20 of the signal) limits <- c(rockfall_t[1] + 10, rockfall_t[1] + 20) ## clip signal rockfall_clip <- signal_clip(data = rockfall_z, time = rockfall_t, limits = limits) ## clip signal using the eseis object rockfall_clip <- signal_clip(data = rockfall_eseis, limits = limits)
## load example data data(rockfall) ## define limits (second 10 to 20 of the signal) limits <- c(rockfall_t[1] + 10, rockfall_t[1] + 20) ## clip signal rockfall_clip <- signal_clip(data = rockfall_z, time = rockfall_t, limits = limits) ## clip signal using the eseis object rockfall_clip <- signal_clip(data = rockfall_eseis, limits = limits)
This function calculates the running cross-correlation of two or more seismic signas and returns that characteristic function.
signal_correlation(data, window = 200)
signal_correlation(data, window = 200)
data |
|
window |
|
Numeric
running cross-correlation of the input signals.
Michael Dietze
## calculate cross-correlation s_cc <- signal_correlation(data = list(a = runif(1000), b = runif(1000), c = runif(1000)), window = 200)
## calculate cross-correlation s_cc <- signal_correlation(data = list(a = runif(1000), b = runif(1000), c = runif(1000)), window = 200)
This function cuts the amplitude of signal parts that exceede a user defined threshold set by k times the standard deviation of the signal.
signal_cut(data, k = 1)
signal_cut(data, k = 1)
data |
|
k |
|
Numeric
vector or list of vectors, cut signal.
Michael Dietze
## load example data data(rockfall) ## cut signal rockfall_cut <- signal_cut(data = rockfall_eseis)
## load example data data(rockfall) ## cut signal rockfall_cut <- signal_cut(data = rockfall_eseis)
The function removes the instrument response from a signal vector.
signal_deconvolve( data, xml, sensor = "TC120s", logger = "Cube3BOB", gain = 1, use_metadata = FALSE, dt, url, xml_use, p = 10^-6, waterlevel = 10^-6, na.replace = FALSE, verbose = FALSE )
signal_deconvolve( data, xml, sensor = "TC120s", logger = "Cube3BOB", gain = 1, use_metadata = FALSE, dt, url, xml_use, p = 10^-6, waterlevel = 10^-6, na.replace = FALSE, verbose = FALSE )
data |
|
xml |
station XML file to use, either an |
sensor |
|
logger |
|
gain |
|
use_metadata |
|
dt |
|
url |
|
xml_use |
|
p |
|
waterlevel |
|
na.replace |
|
verbose |
|
The function requires a set of input parameters, apart from the signal
vector. These parameters are contained in and read from the function
list_sensor()
and list_logger()
. Poles and zeros are used
to build the transfer function. The value s is the generator constant in
Vs/m. The value k is the normalisation factor. AD is the analogue-digital
conversion factor n Volts per count. If the signal was recorded with a gain
value other than 1, the resulting signal needs to be corrected for this,
as well. As of v. 0.8.0, the function also supports deconvolution using
the station XML scheme. However, that feature is implemented through the
python toolbox Obspy, which needs to be installed separately.
Numeric
vector or list of vectors, deconvolved signal.
Michael Dietze
## load example data set data(rockfall) ## deconvolve signal with minimum effort rockfall_decon <- signal_deconvolve(data = rockfall_eseis) ## plot time series plot_signal(data = rockfall_decon, main = "Rockfall, deconvolved signal", ylab = "m/s") ## add new logger manually logger_new <- list_logger()[[1]] ## add logger data logger_new$ID <- "logger_new" logger_new$name <- "logger_new" logger_new$AD <- 2.4414e-07 ## deconvolve signal with new logger rockfall_decon <- signal_deconvolve(data = rockfall_eseis, sensor = "TC120s", logger = logger_new) ## Change the setup of a logger, here: Centaur AD is changed due to ## other than default Vpp value, according to AD = V / (2^24). ## extract default Centaur logger Centaur_10V <- list_logger()[[2]] ## replace AD value Centaur_10V$AD <- 20/(2^24) ## Not run: ## working with station XML files: ## download and import example data set s <- read_fdsn(start = "2023-06-10", duration = 600, station = "DAVA", network = "OE", component = "BHZ") ## download and save station XML file xml <- aux_getxml(xml = "OE.DAVA.XML", start = "2023-06-10", duration = 600, network = "OE", station = "DAVA", component = "BHZ", url = "http://service.iris.edu") ## deconvolve data set with downloaded XML file s_d <- signal_deconvolve(data = s, xml = "OE.DAVA.XML") ## alternatively, deconvolve data set by online XML file (no saving) s_d <- signal_deconvolve(data = s, xml = TRUE, url = "http://service.iris.edu") ## End(Not run)
## load example data set data(rockfall) ## deconvolve signal with minimum effort rockfall_decon <- signal_deconvolve(data = rockfall_eseis) ## plot time series plot_signal(data = rockfall_decon, main = "Rockfall, deconvolved signal", ylab = "m/s") ## add new logger manually logger_new <- list_logger()[[1]] ## add logger data logger_new$ID <- "logger_new" logger_new$name <- "logger_new" logger_new$AD <- 2.4414e-07 ## deconvolve signal with new logger rockfall_decon <- signal_deconvolve(data = rockfall_eseis, sensor = "TC120s", logger = logger_new) ## Change the setup of a logger, here: Centaur AD is changed due to ## other than default Vpp value, according to AD = V / (2^24). ## extract default Centaur logger Centaur_10V <- list_logger()[[2]] ## replace AD value Centaur_10V$AD <- 20/(2^24) ## Not run: ## working with station XML files: ## download and import example data set s <- read_fdsn(start = "2023-06-10", duration = 600, station = "DAVA", network = "OE", component = "BHZ") ## download and save station XML file xml <- aux_getxml(xml = "OE.DAVA.XML", start = "2023-06-10", duration = 600, network = "OE", station = "DAVA", component = "BHZ", url = "http://service.iris.edu") ## deconvolve data set with downloaded XML file s_d <- signal_deconvolve(data = s, xml = "OE.DAVA.XML") ## alternatively, deconvolve data set by online XML file (no saving) s_d <- signal_deconvolve(data = s, xml = TRUE, url = "http://service.iris.edu") ## End(Not run)
The function removes the mean from a signal vector.
signal_demean(data)
signal_demean(data)
data |
|
Numeric
vector or list of vectors, data set with mean
subtracted.
Michael Dietze
## load example data set data(rockfall) ## remove mean from data set rockfall_demean <- signal_demean(data = rockfall_eseis) ## compare data ranges range(rockfall_eseis$signal) range(rockfall_demean$signal) ## show mean of initial signal mean(rockfall_eseis$signal)
## load example data set data(rockfall) ## remove mean from data set rockfall_demean <- signal_demean(data = rockfall_eseis) ## compare data ranges range(rockfall_eseis$signal) range(rockfall_demean$signal) ## show mean of initial signal mean(rockfall_eseis$signal)
The function removes a trend from a signal vector.
signal_detrend(data, method = "linear")
signal_detrend(data, method = "linear")
data |
|
method |
|
The method "simple"
subtracts a linear trend built from
the first and last sample of the data set. The method "linear"
uses the linear function as implemented in pracma::detrend.
Numeric
vector or list of vectors, detrended data set.
Michael Dietze
## load example data set data(rockfall) ## remove linear trend from data set rockfall_detrend <- signal_detrend(data = rockfall_eseis) ## compare data ranges range(rockfall_eseis$signal) range(rockfall_detrend$signal)
## load example data set data(rockfall) ## remove linear trend from data set rockfall_detrend <- signal_detrend(data = rockfall_eseis) ## compare data ranges range(rockfall_eseis$signal) range(rockfall_detrend$signal)
The function integrates a signal vector to, for example convert values from displacement to velocity.
signal_differentiate(data)
signal_differentiate(data)
data |
|
Derivative of the input data set.
Michael Dietze
## load example data set data(rockfall) ## detrend and demean data set s <- signal_demean(signal_detrend(data = rockfall_eseis)) ## differentiate s_d = signal_differentiate(data = s) ## plot result plot(s_d)
## load example data set data(rockfall) ## detrend and demean data set s <- signal_demean(signal_detrend(data = rockfall_eseis)) ## differentiate s_d = signal_differentiate(data = s) ## plot result plot(s_d)
The function calculates envelopes of the input signals as cosine-tapered envelope of the Hilbert-transformed signal. The signal should be detrended and/or the mean should be removed before processing.
signal_envelope(data, p = 0)
signal_envelope(data, p = 0)
data |
|
p |
|
Numeric
vector or list of vectors, signal envelope.
Michael Dietze
## load example data set data(rockfall) ## detrend data set rockfall_detrend <- signal_detrend(data = rockfall_eseis) ## calculate envelope rockfall_envelope <- signal_envelope(data = rockfall_detrend) ## plot envelope plot_signal(data = rockfall_envelope)
## load example data set data(rockfall) ## detrend data set rockfall_detrend <- signal_detrend(data = rockfall_eseis) ## calculate envelope rockfall_envelope <- signal_envelope(data = rockfall_detrend) ## plot envelope plot_signal(data = rockfall_envelope)
This function performs linear interpolation of NA values or pads them with zeros.
signal_fill(data, method = "linear")
signal_fill(data, method = "linear")
data |
|
method |
|
Note that the procedure will contaminate the signal by artefacts as increasingly larger data gaps are filled with interpolated or zero values.
eseis
object, numeric vector or list of objects,
gap-filled data set(s).
Michael Dietze
## create synthetic data set and add NA-gaps data(rockfall) x <- rockfall_z[25000:26000] x_gap <- x x_gap[100:102] <- NA x_gap[500:530] <- NA ## fill gaps y <- signal_fill(data = x_gap) ## plot filled data set plot(y, type = "l") ## filter both data sets x <- signal_filter(data = x, f = c(1, 3), dt = 1/200, lazy = TRUE) y <- signal_filter(data = y, f = c(1, 3), dt = 1/200, lazy = TRUE) ## plot both data sets plot(y, type = "l", col = "grey", lwd = 3) lines(x, col = "red")
## create synthetic data set and add NA-gaps data(rockfall) x <- rockfall_z[25000:26000] x_gap <- x x_gap[100:102] <- NA x_gap[500:530] <- NA ## fill gaps y <- signal_fill(data = x_gap) ## plot filled data set plot(y, type = "l") ## filter both data sets x <- signal_filter(data = x, f = c(1, 3), dt = 1/200, lazy = TRUE) y <- signal_filter(data = y, f = c(1, 3), dt = 1/200, lazy = TRUE) ## plot both data sets plot(y, type = "l", col = "grey", lwd = 3) lines(x, col = "red")
The function filters the input signal vector in the time or frequency domain.
signal_filter( data, f, fft = FALSE, dt, type, shape = "butter", order = 2, p, zero = FALSE, lazy = FALSE )
signal_filter( data, f, fft = FALSE, dt, type, shape = "butter", order = 2, p, zero = FALSE, lazy = FALSE )
data |
|
f |
|
fft |
|
dt |
|
type |
|
shape |
|
order |
|
p |
|
zero |
|
lazy |
|
Numeric
vector or list of vectors, filtered signal vector.
Michael Dietze
## load example data set data(rockfall) ## filter data set by bandpass filter between 1 and 90 Hz rockfall_bp <- signal_filter(data = rockfall_eseis, f = c(1, 90)) ## taper signal to account for edge effects rockfall_bp <- signal_taper(data = rockfall_bp, n = 2000) ## plot filtered signal plot_signal(data = rockfall_bp) ## compare time domain versus frequency domain filtering rockfall_td <- signal_filter(data = rockfall_eseis, f = c(10, 40), fft = FALSE) rockfall_td_sp <- signal_spectrum(data = rockfall_td) rockfall_fd <- signal_filter(data = rockfall_eseis, f = c(10, 40), fft = TRUE) rockfall_fd_sp <- signal_spectrum(data = rockfall_fd) plot_spectrum(data = rockfall_td_sp) plot_spectrum(data = rockfall_fd_sp)
## load example data set data(rockfall) ## filter data set by bandpass filter between 1 and 90 Hz rockfall_bp <- signal_filter(data = rockfall_eseis, f = c(1, 90)) ## taper signal to account for edge effects rockfall_bp <- signal_taper(data = rockfall_bp, n = 2000) ## plot filtered signal plot_signal(data = rockfall_bp) ## compare time domain versus frequency domain filtering rockfall_td <- signal_filter(data = rockfall_eseis, f = c(10, 40), fft = FALSE) rockfall_td_sp <- signal_spectrum(data = rockfall_td) rockfall_fd <- signal_filter(data = rockfall_eseis, f = c(10, 40), fft = TRUE) rockfall_fd_sp <- signal_spectrum(data = rockfall_fd) plot_spectrum(data = rockfall_td_sp) plot_spectrum(data = rockfall_fd_sp)
The function calculates the Hilbert transform of the input signal vector.
signal_hilbert(data)
signal_hilbert(data)
data |
|
Numeric
vector or list of vectors, Hilbert transform.
Michael Dietze
## load example data data(rockfall) ## calculate hilbert transform rockfall_h <- signal_hilbert(data = rockfall_eseis)
## load example data data(rockfall) ## calculate hilbert transform rockfall_h <- signal_hilbert(data = rockfall_eseis)
This function uses three components of a seismic signal, evaluates their spectra and builds the ratio of horizontal to vertical power. For details see http://www.geopsy.org/documentation/geopsy/hv.html.
signal_hvratio( data, dt, log = FALSE, method = "periodogram", kernel, order = "xyz" )
signal_hvratio( data, dt, log = FALSE, method = "periodogram", kernel, order = "xyz" )
data |
|
dt |
|
log |
|
method |
|
kernel |
|
order |
|
The spectra should be smoothed. This can either be done directly
during their calculation or before the calculation of the ratio. For
the former case set method = "autoregressive"
. For the latter
case provide a value for "kernel"
, which is the smoothing
window size. Smoothing is performed with the logarithms of the spectral
power data, using caTools::runmean()
with the
endrule = "NA"
. After smoothing the data is re-linearised.
A data frame
with the h-v-frequency ratio.
Michael Dietze
## load example data set data(earthquake) ## ATTENTION, THIS EXAMPLE DATA SET IS FAR FROM IDEAL FOR THIS PURPOSE ## detrend data s <- signal_detrend(data = s) ## calculate h-v-ratio, will be very rugged hv <- signal_hvratio(data = s, dt = 1 / 200) plot(hv$ratio, type = "l") ## calculate h-v-ratio using the autogressive spectrum method hv <- signal_hvratio(data = s, dt = 1 / 200, method = "autoregressive") plot(hv, type = "l") ## calculate h-v-ratio with a smoothing window equivalent to dt hv <- signal_hvratio(data = s, dt = 1 / 200, kernel = 200) plot(hv, type = "l")
## load example data set data(earthquake) ## ATTENTION, THIS EXAMPLE DATA SET IS FAR FROM IDEAL FOR THIS PURPOSE ## detrend data s <- signal_detrend(data = s) ## calculate h-v-ratio, will be very rugged hv <- signal_hvratio(data = s, dt = 1 / 200) plot(hv$ratio, type = "l") ## calculate h-v-ratio using the autogressive spectrum method hv <- signal_hvratio(data = s, dt = 1 / 200, method = "autoregressive") plot(hv, type = "l") ## calculate h-v-ratio with a smoothing window equivalent to dt hv <- signal_hvratio(data = s, dt = 1 / 200, kernel = 200) plot(hv, type = "l")
The function integrates a signal vector to convert values from velocity to displacement. Two methods are available
signal_integrate(data, dt, method = "fft", waterlevel = 10^-6)
signal_integrate(data, dt, method = "fft", waterlevel = 10^-6)
data |
|
dt |
|
method |
|
waterlevel |
|
Numeric
vector or list of vectors, integrated signal.
Michael Dietze
## load example data set data(rockfall) ## deconvolve signal rockfall_decon <- signal_deconvolve(data = rockfall_eseis) ## integrate signal rockfall_int <- signal_integrate(data = rockfall_decon) ## Note that usually the signal should be filtered prior to integration.
## load example data set data(rockfall) ## deconvolve signal rockfall_decon <- signal_deconvolve(data = rockfall_eseis) ## integrate signal rockfall_int <- signal_integrate(data = rockfall_decon) ## Note that usually the signal should be filtered prior to integration.
The signal vector data
is interpolated by an integer factor
n
. If an eseis
object is provided, the meta data is updated.
The function is a wrapper for the function interp
of the package
signal
. Note that interpolation does not create new meaningful
information but rather artefacts above the initial frequency range.
signal_interpolate(data, n, l = 4, ...)
signal_interpolate(data, n, l = 4, ...)
data |
|
n |
|
l |
|
... |
further arguments passed to |
The function calls the function signal::interp
and wraps the output
into the eseis object structure. The ...-argument may contain the passed
argument Wc
(FIR filter cutoff frequency). Note that by convention
the argument n
of eseis::signal_interpolate
does not equal the
argument n
of signal::interp
. Rather this is the argument
l
that is passed as n
.
Interpolated data set.
Michael Dietze
## load example data set data(rockfall) ## detrend data set s <- signal_detrend(data = rockfall_eseis) ## interpolate by factor 2 s_int = signal_interpolate(data = s, n = 2) ## calculate and plot spectrogram p_int = signal_spectrogram(data = s_int) plot(p_int)
## load example data set data(rockfall) ## detrend data set s <- signal_detrend(data = rockfall_eseis) ## interpolate by factor 2 s_int = signal_interpolate(data = s, n = 2) ## calculate and plot spectrogram p_int = signal_spectrogram(data = s_int) plot(p_int)
This function calculates the running kurtosis of a seismic signal and returns that characteristic function.
signal_kurtosis(data, window = 200)
signal_kurtosis(data, window = 200)
data |
|
window |
|
Numeric
running kurtosis of the input signal.
Michael Dietze
## load example data data(rockfall) ## calculate kurtosis rockfall_kurtosis <- signal_kurtosis(data = rockfall_eseis, window = 200)
## load example data data(rockfall) ## calculate kurtosis rockfall_kurtosis <- signal_kurtosis(data = rockfall_eseis, window = 200)
This function merges two or more single signals into one common. Only
eseis
objects are supported. Gaps will be filled with NA
values unless the argument fill = TRUE
. The resulting data length
will correspond to the combined length of the input data. The sampling
frequency must be the same for all input data sets. The meta data of the
first stream will be used for the output data.
signal_merge(..., fill = FALSE)
signal_merge(..., fill = FALSE)
... |
|
fill |
|
eseis
object with merged input data sets
Michael Dietze
## load rockfall data set data("rockfall") s_1 <- rockfall_eseis ## duplicate data set and shift start time (incl. gap) s_2 <- s_1 s_2$meta$starttime <- s_2$meta$starttime + 500 ## merge data sets s_merged <- signal_merge(s_1, s_2) ## plot merged data set plot(s_merged) ## merge and fill gap s_merged_filled <- signal_merge(s_1, s_2, fill = TRUE) ## plot merged data set plot(s_merged_filled)
## load rockfall data set data("rockfall") s_1 <- rockfall_eseis ## duplicate data set and shift start time (incl. gap) s_2 <- s_1 s_2$meta$starttime <- s_2$meta$starttime + 500 ## merge data sets s_merged <- signal_merge(s_1, s_2) ## plot merged data set plot(s_merged) ## merge and fill gap s_merged_filled <- signal_merge(s_1, s_2, fill = TRUE) ## plot merged data set plot(s_merged_filled)
The function calculates from a data set of three seismic components of the same signal the following particle motion paramters using a moving window approach: horizontal-vertical eigenvalue ratio, azimuth and inclination.
signal_motion(data, time, dt, window, step, order = "xyz")
signal_motion(data, time, dt, window, step, order = "xyz")
data |
|
time |
|
dt |
|
window |
|
step |
|
order |
|
The function code is loosely based on the function GAZI() from the package RSEIS with removal of unnecessary content and updated or rewritten loop functionality. In its current form, it also uses additional workflows from obspy.signal.polarisation, specifically following the Flinn (1965) approach. It windows the input signals, calculates the covariance matrix and performs a singular values decomposition to use the eigen values and vectors to determine the ratios corresponding to the output values rectilinearity, angularity, azimuth and incidence.
Note that the names of the output objects as well as the calculation routine have changed from the earlier version (V. 0.6.0), to increase computational efficiency and fix a bug in the windowing implementation.
A List object with rectilinearity (rectilinearity
),
angularity (polarity
), azimuth (azimuth
) and incidence
(incidence
), as well as the corresponding time vector for
these values.
Michael Dietze
## load example data set data(earthquake) ## filter seismic signals s <- eseis::signal_filter(data = s, dt = 1/200, f = c(1, 3)) ## convert list of signal vectors to column-wise matrix s <- do.call(cbind, s) ## calculate particle motion parameters pm <- signal_motion(data = s, dt = 1 / 200, window = 500, step = 250) ## plot function output par_original <- par(no.readonly = TRUE) par(mfcol = c(2, 2)) plot(pm$time, pm$rect, type = "b") plot(pm$time, pm$plan, type = "b") plot(pm$time, pm$azimuth, type = "b") plot(pm$time, pm$incidence, type = "b") par(par_original)
## load example data set data(earthquake) ## filter seismic signals s <- eseis::signal_filter(data = s, dt = 1/200, f = c(1, 3)) ## convert list of signal vectors to column-wise matrix s <- do.call(cbind, s) ## calculate particle motion parameters pm <- signal_motion(data = s, dt = 1 / 200, window = 500, step = 250) ## plot function output par_original <- par(no.readonly = TRUE) par(mfcol = c(2, 2)) plot(pm$time, pm$rect, type = "b") plot(pm$time, pm$plan, type = "b") plot(pm$time, pm$azimuth, type = "b") plot(pm$time, pm$incidence, type = "b") par(par_original)
The function adds zeros to the input vector to reach a length, corresponding to the next higher power of two.
signal_pad(data)
signal_pad(data)
data |
|
Numeric
vector or list of vectors, signal vector with
added zeros.
Michael Dietze
## load example data set data(rockfall) ## pad with zeros rockfall_pad <- signal_pad(data = rockfall_eseis) ## compare lengths rockfall_eseis$meta$n rockfall_pad$meta$n
## load example data set data(rockfall) ## pad with zeros rockfall_pad <- signal_pad(data = rockfall_eseis) ## compare lengths rockfall_eseis$meta$n rockfall_pad$meta$n
The function rotates the horizontal components of the input data according to the specified angle.
signal_rotate(data, angle)
signal_rotate(data, angle)
data |
|
angle |
|
Numeric
matrix, the 3-dimensional rotation matrix.
Michael Dietze
## create synthetic data set data <- rbind(x = sin(seq(0, pi, length.out = 10)), y = sin(seq(0, pi, length.out = 10)), z = rep(0, 10)) ## rotate the data set x_rot <- signal_rotate(data = data, angle = 15) ## plot the rotated data set plot(x_rot[1,], col = 1, ylim = c(-2, 2)) points(x_rot[2,], col = 2) points(x_rot[3,], col = 3)
## create synthetic data set data <- rbind(x = sin(seq(0, pi, length.out = 10)), y = sin(seq(0, pi, length.out = 10)), z = rep(0, 10)) ## rotate the data set x_rot <- signal_rotate(data = data, angle = 15) ## plot the rotated data set plot(x_rot[1,], col = 1, ylim = c(-2, 2)) points(x_rot[2,], col = 2) points(x_rot[3,], col = 3)
This function assigns 1 for positive values and -1 for negative input values of a signal.
signal_sign(data)
signal_sign(data)
data |
|
Numeric
vector or list of vectors, sign-cut signal.
Michael Dietze
## load example data data(rockfall) ## sign-cut signal rockfall_sign <- signal_sign(data = rockfall_eseis)
## load example data data(rockfall) ## sign-cut signal rockfall_sign <- signal_sign(data = rockfall_eseis)
The function calculates the signal-to-noise ratio of an input signal vector as the ratio between mean and max.
signal_snr(data, detrend = FALSE)
signal_snr(data, detrend = FALSE)
data |
|
detrend |
|
Numeric
value, signal-to-noise ratio.
Michael Dietze
## load example data set data(rockfall) ## calculate snr with detrend option off and on snr <- signal_snr(data = rockfall_eseis) print(snr$snr) snr <- signal_snr(data = rockfall_eseis, detrend = TRUE) print(snr$snr)
## load example data set data(rockfall) ## calculate snr with detrend option off and on snr <- signal_snr(data = rockfall_eseis) print(snr$snr) snr <- signal_snr(data = rockfall_eseis, detrend = TRUE) print(snr$snr)
This function creates spectrograms from seismic signals. It supports the standard spectrogram approach and the Welch method.
signal_spectrogram( data, time, dt, Welch = FALSE, window, overlap = 0.5, window_sub, overlap_sub = 0.5, method = "periodogram", cpu = NULL, plot = FALSE, ... )
signal_spectrogram( data, time, dt, Welch = FALSE, window, overlap = 0.5, window_sub, overlap_sub = 0.5, method = "periodogram", cpu = NULL, plot = FALSE, ... )
data |
|
time |
|
dt |
|
Welch |
|
window |
|
overlap |
|
window_sub |
|
overlap_sub |
|
method |
|
cpu |
|
plot |
|
... |
Additional arguments passed to the function. |
Data containing NA
values is replaced by zeros and set to NA in the
output data set.
List
with spectrogram matrix, time and frequency vectors.
Michael Dietze
## load example data set data("earthquake") ## calculate and plot PSD straight away P <- signal_spectrogram(data = s$BHZ, time = t, dt = 1 / 200, plot = TRUE) ## calculate and plot PSD with defined window sizes and the Welch method P <- signal_spectrogram(data = s$BHZ, time = t, dt = 1 / 200, window = 5, overlap = 0.9, window_sub = 3, overlap_sub = 0.9, Welch = TRUE, plot = TRUE)
## load example data set data("earthquake") ## calculate and plot PSD straight away P <- signal_spectrogram(data = s$BHZ, time = t, dt = 1 / 200, plot = TRUE) ## calculate and plot PSD with defined window sizes and the Welch method P <- signal_spectrogram(data = s$BHZ, time = t, dt = 1 / 200, window = 5, overlap = 0.9, window_sub = 3, overlap_sub = 0.9, Welch = TRUE, plot = TRUE)
The power spectral density estimate of the time series is calculated using different approaches.
signal_spectrum(data, dt, method = "periodogram", n, res, log = FALSE, ...)
signal_spectrum(data, dt, method = "periodogram", n, res, log = FALSE, ...)
data |
|
dt |
|
method |
|
n |
|
res |
|
log |
|
... |
Additional arguments passed to the function. |
If the res
option is used, the frequency and power vectors will be
interpolated using a spline interpolator, using equally spaced frequency
values. If desired, the additional option log = TRUE
can be used
to interpolate with log spaced frequency values.
Data frame
with frequency and power vector
Michael Dietze
## load example data set data(rockfall) ## calculate spectrum with standard setup s <- signal_spectrum(data = rockfall_eseis) ## plot spectrum plot_spectrum(data = s)
## load example data set data(rockfall) ## calculate spectrum with standard setup s <- signal_spectrum(data = rockfall_eseis) ## plot spectrum plot_spectrum(data = s)
This function calculates the short-time-average to long time average (STA-LTA) ratio of a seismic signal and returns that ratio time series.
signal_stalta(data, sta, lta, lazy = FALSE)
signal_stalta(data, sta, lta, lazy = FALSE)
data |
|
sta |
|
lta |
|
lazy |
|
Numeric
vector or list of vectors, STA-LTA ratio signal.
Michael Dietze
## load example data data(rockfall) ## calculate STA-LTA ratio rockfall_stalta <- signal_stalta(data = rockfall_eseis, sta = 0.5 * 200, lta = 10 * 200, lazy = TRUE)
## load example data data(rockfall) ## calculate STA-LTA ratio rockfall_stalta <- signal_stalta(data = rockfall_eseis, sta = 0.5 * 200, lta = 10 * 200, lazy = TRUE)
This function calculates a set of statistics for the seismic signal submitted.
signal_stats(data, stats, range_f, res_psd = 1, dt, cut = TRUE)
signal_stats(data, stats, range_f, res_psd = 1, dt, cut = TRUE)
data |
|
stats |
|
range_f |
|
res_psd |
|
dt |
|
cut |
|
Available statistics keywords are:
1. '"t_duration"' (Duration of the signal)
1. '"t_rise"' (Signal rise time, time from start to maximum amplitude)
1. '"t_fall"' (Signal fall time, tme from maximum amplitude to end)
1. '"t_risefall"' (Ratio of rise to fall time)
1. '"a_skewness"' (Skewness of the signal amplitude, see seewave::specprop
)
1. '"a_kurtosis"' (Kurtosis of the signal amplitude, see seewave::specprop
)
1. '"a1_kurtosis"' (Kurtosis of the filtered (0.1-1 Hz) signal amplitude, see seewave::specprop
)
1. '"a2_kurtosis"' (Kurtosis of the filtered (1-3 Hz) signal amplitude, see seewave::specprop
)
1. '"a3_kurtosis"' (Kurtosis of the filtered (3-10 Hz) signal amplitude, see seewave::specprop
)
1. '"a4_kurtosis"' (Kurtosis of the filtered (10-20 Hz) signal amplitude, see seewave::specprop
)
1. '"a5_kurtosis"' (Kurtosis of the filtered (20-50 Hz) signal amplitude, see seewave::specprop
)
1. '"e_maxmean"' (Ratio of maximum and mean envelope value, see Hibert et al. (2017))
1. '"e_maxmedian"' (Ratio of maximum and median envelope value, see Hibert et al. (2017))
1. '"e_skewness"' (Skewness of the signal envelope, see seewave::specprop
)
1. '"e_kurtosis"' (Kurtosis of the signal envelope, see seewave::specprop
)
1. '"e1_logsum"' (Logarithm of the filtered (0.1-1 Hz) envelope sum, see Hibert et al. (2017))
1. '"e2_logsum"' (Logarithm of the filtered (1-3 Hz) envelope sum, see Hibert et al. (2017))
1. '"e3_logsum"' (Logarithm of the filtered (3-10 Hz) envelope sum, see Hibert et al. (2017))
1. '"e4_logsum"' (Logarithm of the filtered (10-20 Hz) envelope sum, see Hibert et al. (2017))
1. '"e5_logsum"' (Logarithm of the filtered (20-50 Hz) envelope sum, see Hibert et al. (2017))
1. '"e_rmsdecphaseline"' (RMS of envelope from linear decrease, see Hibert et al. (2017))
1. '"c_peaks"' (Number of peaks (excursions above 75
1. '"c_energy1"' (Sum of the first third of the signal cross correlation function, see Hibert et al. (2017))
1. '"c_energy2"' (Sum of the last two thirds of the signal cross correlation function, see Hibert et al. (2017))
1. '"c_energy3"' (Ratio of c_energy1 and c_energy2, see Hibert et al. (2017))
1. '"s_peaks"' (Number of peaks (excursions above 75
1. '"s_peakpower"' (Mean power of spectral peaks, see Hibert et al. (2017))
1. '"s_mean"' (Mean spectral power, see Hibert et al. (2017))
1. '"s_median"' (Median spectral power, see Hibert et al. (2017))
1. '"s_max"' (Maximum spectral power, see Hibert et al. (2017))
1. '"s_var"' (Variance of the spectral power, see Hibert et al. (2017))
1. '"s_sd"' (Standard deviation of the spectral power, see seewave::specprop
)
1. '"s_sem"' (Standard error of the mean of the spectral power, see seewave::specprop
)
1. '"s_flatness"' (Spectral flatness, see seewave::specprop
)
1. '"s_entropy"' (Spectral entropy, see seewave::specprop
)
1. '"s_precision"' (Spectral precision, see seewave::specprop
)
1. '"s1_energy"' (Energy of the filtered (0.1-1 Hz) spectrum, see Hibert et al. (2017))
1. '"s2_energy"' (Energy of the filtered (1-3 Hz) spectrum, see Hibert et al. (2017))
1. '"s3_energy"' (Energy of the filtered (3-10 Hz) spectrum, see Hibert et al. (2017))
1. '"s4_energy"' (Energy of the filtered (10-20 Hz) spectrum, see Hibert et al. (2017))
1. '"s5_energy"' (Energy of the filtered (20-30 Hz) spectrum, see Hibert et al. (2017))
1. '"s_gamma1"' (Gamma 1, spectral centroid, see Hibert et al. (2017))
1. '"s_gamma2"' (Gamma 2, spectral gyration radius, see Hibert et al. (2017))
1. '"s_gamma3"' (Gamma 3, spectral centroid width, see Hibert et al. (2017))
1. '"f_modal"' (Modal frequency, see seewave::specprop
)
1. '"f_mean"' (Mean frequency (aka central frequency), see seewave::specprop
)
1. '"f_median"' (Median frequency, see seewave::specprop
)
1. '"f_q05"' (Quantile 0.05 of the spectrum, see seewave::specprop
)
1. '"f_q25"' (Quantile 0.25 of the spectrum, see seewave::specprop
)
1. '"f_q75"' (Quantile 0.75 of the spectrum, see seewave::specprop
)
1. '"f_q95"' (Quantile 0.95 of the spectrum, see seewave::specprop
)
1. '"f_iqr"' (Inter quartile range of the spectrum, see seewave::specprop
)
1. '"f_centroid"' (Spectral centroid, see seewave::specprop
)
1. '"p_kurtosismax"' (Kurtosis of the maximum spectral power over time, see Hibert et al. (2017))
1. '"p_kurtosismedian"' (Kurtosis of the median spectral power over time, see Hibert et al. (2017))
1. '"p_maxmean"' (Mean of the ratio of max to mean spectral power over time, see Hibert et al. (2017))
1. '"p_maxmedian"' (Mean of the ratio of max to median spectral power over time, see Hibert et al. (2017))
1. '"p_peaksmean"' (Number of peaks in normalised mean spectral power over time, see Hibert et al. (2017))
1. '"p_peaksmedian"' (Number of peaks in normalised median spectral power over time, see Hibert et al. (2017))
1. '"p_peaksmax"' (Number of peaks in normalised max spectral power over time, see Hibert et al. (2017))
1. '"p_peaksmaxmean"' (Ratio of number of peaks in normalised max and mean spectral power over time, see Hibert et al. (2017))
1. '"p_peaksmaxmedian"' (Ratio of number of peaks in normalised max and median spectral power over time, see Hibert et al. (2017))
1. '"p_peaksfcentral"' (Number of peaks in spectral power at central frequency over time, see Hibert et al. (2017))
1. '"p_diffmaxmean"' (Mean difference between max and mean power, see Hibert et al. (2017))
1. '"p_diffmaxmedian"' (Mean difference between max and median power, see Hibert et al. (2017))
1. '"p_diffquantile21"' (Mean difference between power quantiles 2 and 1, see Hibert et al. (2017))
1. '"p_diffquantile32"' (Mean difference between power quantiles 3 and 2, see Hibert et al. (2017))
1. '"p_diffquantile31"' (Mean difference between power quantiles 3 and 1, see Hibert et al. (2017))
References: - Hibert C, Provost F, Malet J-P, Maggi A, Stumpf A, Ferrazzini V. 2017. Automatic identification of rockfalls and volcano-tectonic earthquakes at the Piton de la Fournaise volcano using a Random Forest algorithm. Journal of Volcanology and Geothermal Research 340, 130-142.
data frame
with calculated statsitics
Michael Dietze
## load example data data(rockfall) ## clip data to event of interest eq <- signal_clip(data = rockfall_eseis, limits = as.POSIXct(c("2015-04-06 13:18:50", "2015-04-06 13:20:10"), tz = "UTC")) ## calculate full statistics eq_stats <- signal_stats(data = eq) ## show names of statistics names(eq_stats) ## calculate and show selected statistics, with truncated frequency range eq_stats_sub <- signal_stats(data = eq, stats = c("t_rise", "c_peaks", "f_centroid"), range_f = c(1, 90)) print(eq_stats_sub)
## load example data data(rockfall) ## clip data to event of interest eq <- signal_clip(data = rockfall_eseis, limits = as.POSIXct(c("2015-04-06 13:18:50", "2015-04-06 13:20:10"), tz = "UTC")) ## calculate full statistics eq_stats <- signal_stats(data = eq) ## show names of statistics names(eq_stats) ## calculate and show selected statistics, with truncated frequency range eq_stats_sub <- signal_stats(data = eq, stats = c("t_rise", "c_peaks", "f_centroid"), range_f = c(1, 90)) print(eq_stats_sub)
The function calculates the vector sum of the input signals.
signal_sum(...)
signal_sum(...)
... |
|
Numeric
vector, signal vector sum.
Michael Dietze
## create random vectors x <- runif(n = 1000, min = -1, max = 1) y <- runif(n = 1000, min = -1, max = 1) z <- runif(n = 1000, min = -1, max = 1) ## calculate vector sums xyz <- signal_sum(x, y, z)
## create random vectors x <- runif(n = 1000, min = -1, max = 1) y <- runif(n = 1000, min = -1, max = 1) z <- runif(n = 1000, min = -1, max = 1) ## calculate vector sums xyz <- signal_sum(x, y, z)
The function tapers a signal vector with a cosine bell taper, either of a given proportion or a discrete number of samples.
signal_taper(data, p = 0, n)
signal_taper(data, p = 0, n)
data |
|
p |
|
n |
|
Data frame
, tapered signal vector.
Michael Dietze
## load example data set data(rockfall) ## remove mean from data set rockfall <- signal_demean(data = rockfall_eseis) ## create artefact at the beginning rockfall_eseis$signal[1:100] <- runif(n = 100, min = -5000, max = 5000) ## taper signal rockfall_taper <- signal_taper(data = rockfall, n = 1000) ## plot both data sets plot_signal(data = rockfall_eseis) plot_signal(rockfall_taper)
## load example data set data(rockfall) ## remove mean from data set rockfall <- signal_demean(data = rockfall_eseis) ## create artefact at the beginning rockfall_eseis$signal[1:100] <- runif(n = 100, min = -5000, max = 5000) ## taper signal rockfall_taper <- signal_taper(data = rockfall, n = 1000) ## plot both data sets plot_signal(data = rockfall_eseis) plot_signal(rockfall_taper)
The function normalises the input signal within a given frequency window. If a time series is provided, it is converted to the spectral domain, whitening is performed, and it is transformed back to the time domain.
signal_whiten(data, f, dt)
signal_whiten(data, f, dt)
data |
|
f |
|
dt |
|
Numeric
vector or eseis object, whitened signal vector.
Michael Dietze
## load example data set data("rockfall") ## whiten data set between 10 and 30 Hz rockfall_2 <- signal_whiten(data = rockfall_eseis, f = c(10, 30)) ## plot whitened data set plot(rockfall_2)
## load example data set data("rockfall") ## whiten data set between 10 and 30 Hz rockfall_2 <- signal_whiten(data = rockfall_eseis, f = c(10, 30)) ## plot whitened data set plot(rockfall_2)
The function fits a model of signal amplitude attenuation for all grid cells of the distance data sets and returns the residual sum as measure of the most likely source location of an event.
spatial_amplitude( data, coupling, d_map, aoi, v, q, f, a_0, normalise = TRUE, output = "variance", cpu )
spatial_amplitude( data, coupling, d_map, aoi, v, q, f, a_0, normalise = TRUE, output = "variance", cpu )
data |
|
coupling |
|
d_map |
|
aoi |
|
v |
|
q |
|
f |
|
a_0 |
|
normalise |
|
output |
|
cpu |
|
A raster object with the location output metrics for each grid cell.
Michael Dietze
## Not run: ## create synthetic DEM dem <- terra::rast(xmin = 0, xmax = 10000, ymin= 0, ymax = 10000, res = c(500, 500), vals = rep(0, 400)) ## define station coordinates sta <- data.frame(x = c(1000, 9000, 5000), y = c(1000, 1000, 9000), ID = c("A", "B", "C")) ## create synthetic signal (source in towards lower left corner of the DEM) s <- rbind(dnorm(x = 1:1000, mean = 500, sd = 50) * 100, dnorm(x = 1:1000, mean = 500, sd = 50) * 2, dnorm(x = 1:1000, mean = 500, sd = 50) * 1) ## plot DEM and stations terra::plot(dem) text(x = sta$x, y = sta$y, labels = sta$ID) ## calculate spatial distance maps and inter-station distances D <- eseis::spatial_distance(stations = sta[,1:2], dem = dem) ## locate signal e <- eseis::spatial_amplitude(data = s, d_map = D$maps, v = 500, q = 50, f = 10) ## get most likely location coordinates (example contains two equal points) e_max <- spatial_pmax(data = e) ## plot output terra::plot(e) points(e_max[1], e_max[2], pch = 20) points(sta[,1:2]) ## End(Not run)
## Not run: ## create synthetic DEM dem <- terra::rast(xmin = 0, xmax = 10000, ymin= 0, ymax = 10000, res = c(500, 500), vals = rep(0, 400)) ## define station coordinates sta <- data.frame(x = c(1000, 9000, 5000), y = c(1000, 1000, 9000), ID = c("A", "B", "C")) ## create synthetic signal (source in towards lower left corner of the DEM) s <- rbind(dnorm(x = 1:1000, mean = 500, sd = 50) * 100, dnorm(x = 1:1000, mean = 500, sd = 50) * 2, dnorm(x = 1:1000, mean = 500, sd = 50) * 1) ## plot DEM and stations terra::plot(dem) text(x = sta$x, y = sta$y, labels = sta$ID) ## calculate spatial distance maps and inter-station distances D <- eseis::spatial_distance(stations = sta[,1:2], dem = dem) ## locate signal e <- eseis::spatial_amplitude(data = s, d_map = D$maps, v = 500, q = 50, f = 10) ## get most likely location coordinates (example contains two equal points) e_max <- spatial_pmax(data = e) ## plot output terra::plot(e) points(e_max[1], e_max[2], pch = 20) points(sta[,1:2]) ## End(Not run)
The function replaces raster values based on different thresholds.
spatial_clip(data, quantile, replace = NA, normalise = TRUE)
spatial_clip(data, quantile, replace = NA, normalise = TRUE)
data |
|
quantile |
|
replace |
|
normalise |
|
SpatRaster
object, data set with clipped values.
Michael Dietze
## load example data set data(volcano) ## convert matrix to raster object volcano <- terra::rast(volcano) ## clip values to those > quantile 0.5 volcano_clip <- spatial_clip(data = volcano, quantile = 0.5) ## plot clipped data set terra::plot(volcano_clip)
## load example data set data(volcano) ## convert matrix to raster object volcano <- terra::rast(volcano) ## clip values to those > quantile 0.5 volcano_clip <- spatial_clip(data = volcano, quantile = 0.5) ## plot clipped data set terra::plot(volcano_clip)
Coordinates are converted between reference systems.
spatial_convert(data, from, to)
spatial_convert(data, from, to)
data |
|
from |
|
to |
|
Numeric
data frame with converted coordinates.
Michael Dietze
## create lat lon coordinates xy <- c(13, 55) ## define output coordinate systems proj_in <- "+proj=longlat +datum=WGS84" proj_out <- "+proj=utm +zone=32 +datum=WGS84" ## convert coordinate pair spatial_convert(data = xy, from = proj_in, to = proj_out) ## define set of coordinates xy <- data.frame(x = c(10, 11), y = c(54, 55)) ## convert set of coordinates spatial_convert(data = xy, from = proj_in, to = proj_out)
## create lat lon coordinates xy <- c(13, 55) ## define output coordinate systems proj_in <- "+proj=longlat +datum=WGS84" proj_out <- "+proj=utm +zone=32 +datum=WGS84" ## convert coordinate pair spatial_convert(data = xy, from = proj_in, to = proj_out) ## define set of coordinates xy <- data.frame(x = c(10, 11), y = c(54, 55)) ## convert set of coordinates spatial_convert(data = xy, from = proj_in, to = proj_out)
The function crops the spatial extent of raster objects or other spatial objects based on bounding box coordinates.
spatial_crop(data, bbox)
spatial_crop(data, bbox)
data |
|
bbox |
|
spatial object, cropped to bounding box
Michael Dietze
## create example data set x <- terra::rast(nrows = 100, ncols = 100, xmin = 0, xmax = 10, ymin = 0, ymax = 10) terra::values(x) <- 1:10000 ## create crop extent vector bbox <- c(3, 7, 3, 7) ## crop spatial object y <- spatial_crop(data = x, bbox = bbox) ## plot both objects terra::plot(x) terra::plot(y, add = TRUE)
## create example data set x <- terra::rast(nrows = 100, ncols = 100, xmin = 0, xmax = 10, ymin = 0, ymax = 10) terra::values(x) <- 1:10000 ## create crop extent vector bbox <- c(3, 7, 3, 7) ## crop spatial object y <- spatial_crop(data = x, bbox = bbox) ## plot both objects terra::plot(x) terra::plot(y, add = TRUE)
The function calculates topography-corrected distances either between seismic stations or from seismic stations to pixels of an input raster.
spatial_distance( stations, dem, topography = TRUE, maps = TRUE, matrix = TRUE, aoi, verbose = FALSE )
spatial_distance( stations, dem, topography = TRUE, maps = TRUE, matrix = TRUE, aoi, verbose = FALSE )
stations |
|
dem |
|
topography |
|
maps |
|
matrix |
|
aoi |
|
verbose |
|
Topography correction is necessary because seismic waves can only travel on the direct path as long as they are within solid matter. When the direct path is through air, the wave can only travel along the surface of the landscape. The function accounts for this effect and returns the corrected travel distance data set.
List
object with distance maps (list of
SpatRaster
objects from terra
package) and station distance
matrix (data.frame
).
Michael Dietze
## Not run: data("volcano") dem <- terra::rast(volcano) dem <- dem * 10 terra::ext(dem) <- terra::ext(dem) * 10 terra::ext(dem) <-terra::ext(dem) + c(510, 510, 510, 510) ## define example stations stations <- cbind(c(200, 700), c(220, 700)) ## plot example data terra::plot(dem) points(stations[,1], stations[,2]) ## calculate distance matrices and stations distances D <- spatial_distance(stations = stations, dem = dem) D_map_1 <- terra::rast(crs = D$maps[[1]]$crs, ext = D$maps[[1]]$ext, res = D$maps[[1]]$res, val = D$maps[[1]]$val) ## plot distance map terra::plot(D_map_1) ## show station distance matrix print(D$matrix) ## calculate with AOI and in verbose mode D <- spatial_distance(stations = stations, dem = dem, verbose = TRUE, aoi = c(0, 200, 0, 200)) ## plot distance map for station 2 terra::plot(D$maps[[1]]) ## End(Not run)
## Not run: data("volcano") dem <- terra::rast(volcano) dem <- dem * 10 terra::ext(dem) <- terra::ext(dem) * 10 terra::ext(dem) <-terra::ext(dem) + c(510, 510, 510, 510) ## define example stations stations <- cbind(c(200, 700), c(220, 700)) ## plot example data terra::plot(dem) points(stations[,1], stations[,2]) ## calculate distance matrices and stations distances D <- spatial_distance(stations = stations, dem = dem) D_map_1 <- terra::rast(crs = D$maps[[1]]$crs, ext = D$maps[[1]]$ext, res = D$maps[[1]]$res, val = D$maps[[1]]$val) ## plot distance map terra::plot(D_map_1) ## show station distance matrix print(D$matrix) ## calculate with AOI and in verbose mode D <- spatial_distance(stations = stations, dem = dem, verbose = TRUE, aoi = c(0, 200, 0, 200)) ## plot distance map for station 2 terra::plot(D$maps[[1]]) ## End(Not run)
The function performs signal migration in space in order to determine the location of a seismic signal.
spatial_migrate( data, d_stations, d_map, snr, v, dt, normalise = TRUE, verbose = FALSE )
spatial_migrate( data, d_stations, d_map, snr, v, dt, normalise = TRUE, verbose = FALSE )
data |
|
d_stations |
|
d_map |
|
snr |
|
v |
|
dt |
|
normalise |
|
verbose |
|
With the switch from the package raster to the package terra, the resulting distance maps can no longer be saved in lists as distance maps. Thus, the function re-defines the distance SpatRaster objects by a list of data on crs, extent, resolution and raster values. As a consequence, plotting the data requires turning them into a SpatRaster object, first (see examples).
A SpatialGridDataFrame-object with Gaussian probability density function values for each grid cell.
Michael Dietze
## Not run: ## create synthetic DEM dem <- terra::rast(nrows = 20, ncols = 20, xmin = 0, xmax = 10000, ymin= 0, ymax = 10000, vals = rep(0, 400)) ## define station coordinates sta <- data.frame(x = c(1000, 9000, 5000), y = c(1000, 1000, 9000), ID = c("A", "B", "C")) ## create synthetic signal (source in the center of the DEM) s <- rbind(dnorm(x = 1:1000, mean = 500, sd = 50), dnorm(x = 1:1000, mean = 500, sd = 50), dnorm(x = 1:1000, mean = 500, sd = 50)) ## plot DEM and stations terra::plot(dem) text(x = sta$x, y = sta$y, labels = sta$ID) ## calculate spatial distance maps and inter-station distances D <- spatial_distance(stations = sta[,1:2], dem = dem) ## restore SpatRaster object for plotting purpose D_map_1 <- terra::rast(crs = D$maps[[1]]$crs, ext = D$maps[[1]]$ext, res = D$maps[[1]]$res, val = D$maps[[1]]$val) ## plot distance map terra::plot(D_map_1) ## locate signal e <- spatial_migrate(data = s, d_stations = D$matrix, d_map = D$maps, v = 1000, dt = 1/100) ## get most likely location coordinates e_max <- spatial_pmax(data = e) ## plot location estimate, most likely location estimate and stations terra::plot(e) points(e_max[1], e_max[2], pch = 20) points(sta[,1:2]) ## End(Not run)
## Not run: ## create synthetic DEM dem <- terra::rast(nrows = 20, ncols = 20, xmin = 0, xmax = 10000, ymin= 0, ymax = 10000, vals = rep(0, 400)) ## define station coordinates sta <- data.frame(x = c(1000, 9000, 5000), y = c(1000, 1000, 9000), ID = c("A", "B", "C")) ## create synthetic signal (source in the center of the DEM) s <- rbind(dnorm(x = 1:1000, mean = 500, sd = 50), dnorm(x = 1:1000, mean = 500, sd = 50), dnorm(x = 1:1000, mean = 500, sd = 50)) ## plot DEM and stations terra::plot(dem) text(x = sta$x, y = sta$y, labels = sta$ID) ## calculate spatial distance maps and inter-station distances D <- spatial_distance(stations = sta[,1:2], dem = dem) ## restore SpatRaster object for plotting purpose D_map_1 <- terra::rast(crs = D$maps[[1]]$crs, ext = D$maps[[1]]$ext, res = D$maps[[1]]$res, val = D$maps[[1]]$val) ## plot distance map terra::plot(D_map_1) ## locate signal e <- spatial_migrate(data = s, d_stations = D$matrix, d_map = D$maps, v = 1000, dt = 1/100) ## get most likely location coordinates e_max <- spatial_pmax(data = e) ## plot location estimate, most likely location estimate and stations terra::plot(e) points(e_max[1], e_max[2], pch = 20) points(sta[,1:2]) ## End(Not run)
The function performs event location in space by finding the grid cell with minimum average travel time difference using the parabola approach. For further information see also Hibert et al. (2014) DOI: 10.1002/2013JF002970.
spatial_parabola(data, d_map, v, dt, plot, ...)
spatial_parabola(data, d_map, v, dt, plot, ...)
data |
|
d_map |
|
v |
|
dt |
|
plot |
|
... |
Additional arguments passed to the plot function. |
A terra raster with average travel time offsets for each grid cell, implying the most likely source location coinciding with the smallest offset value.
Michael Dietze, Clement Hibert (ITES Strasbourg)
## Not run: ## create synthetic DEM dem <- terra::rast(nrows = 20, ncols = 20, xmin = 0, xmax = 10000, ymin= 0, ymax = 10000, vals = rep(0, 400)) ## define station coordinates sta <- data.frame(x = c(1000, 9000, 5000), y = c(1000, 1000, 9000), ID = c("A", "B", "C")) ## create synthetic signal (source in the center of the DEM) s <- rbind(dnorm(x = 1:1000, mean = 400, sd = 50), dnorm(x = 1:1000, mean = 400, sd = 50), dnorm(x = 1:1000, mean = 800, sd = 50)) ## plot DEM and stations terra::plot(dem) text(x = sta$x, y = sta$y, labels = sta$ID) ## calculate spatial distance maps and inter-station distances D <- spatial_distance(stations = sta[,1:2], dem = dem) ## restore SpatRaster object for plotting purpose D_map_1 <- terra::rast(crs = D$maps[[1]]$crs, ext = D$maps[[1]]$ext, res = D$maps[[1]]$res, val = D$maps[[1]]$val) ## plot distance map terra::plot(D_map_1) ## locate signal e <- spatial_parabola(data = s, d_map = D$maps, v = 1000, dt = 1/100, plot = "parabola", zlim = c(0, 2)) ## End(Not run)
## Not run: ## create synthetic DEM dem <- terra::rast(nrows = 20, ncols = 20, xmin = 0, xmax = 10000, ymin= 0, ymax = 10000, vals = rep(0, 400)) ## define station coordinates sta <- data.frame(x = c(1000, 9000, 5000), y = c(1000, 1000, 9000), ID = c("A", "B", "C")) ## create synthetic signal (source in the center of the DEM) s <- rbind(dnorm(x = 1:1000, mean = 400, sd = 50), dnorm(x = 1:1000, mean = 400, sd = 50), dnorm(x = 1:1000, mean = 800, sd = 50)) ## plot DEM and stations terra::plot(dem) text(x = sta$x, y = sta$y, labels = sta$ID) ## calculate spatial distance maps and inter-station distances D <- spatial_distance(stations = sta[,1:2], dem = dem) ## restore SpatRaster object for plotting purpose D_map_1 <- terra::rast(crs = D$maps[[1]]$crs, ext = D$maps[[1]]$ext, res = D$maps[[1]]$res, val = D$maps[[1]]$val) ## plot distance map terra::plot(D_map_1) ## locate signal e <- spatial_parabola(data = s, d_map = D$maps, v = 1000, dt = 1/100, plot = "parabola", zlim = c(0, 2)) ## End(Not run)
The function identifies the location of a seismic source with the heighest likelihood (P_max).
spatial_pmax(data)
spatial_pmax(data)
data |
|
data.frame
, coordinates (x and y) of the most likely s
ource location(s).
Michael Dietze
## create example source location likelihood raster x <- terra::rast(nrows = 100, ncols = 100, xmin = 0, xmax = 10, ymin = 0, ymax = 10) terra::values(x) <- runif(n = 100) ## identify location of highest likelihood p_max <- spatial_pmax(data = x) ## show result print(p_max)
## create example source location likelihood raster x <- terra::rast(nrows = 100, ncols = 100, xmin = 0, xmax = 10, ymin = 0, ymax = 10) terra::values(x) <- runif(n = 100) ## identify location of highest likelihood p_max <- spatial_pmax(data = x) ## show result print(p_max)
This function allows tracking a spatially mobile seismic source and thereby estimating the source amplitude and the model's variance reduction as a measure of quality or robustness of the time-resolved estimates.
spatial_track( data, coupling, window, overlap = 0, d_map, aoi, v, q, f, k, qt = 1, dt, model = "SurfSpreadAtten", cpu, verbose = FALSE, plot = FALSE )
spatial_track( data, coupling, window, overlap = 0, d_map, aoi, v, q, f, k, qt = 1, dt, model = "SurfSpreadAtten", cpu, verbose = FALSE, plot = FALSE )
data |
|
coupling |
|
window |
|
overlap |
|
d_map |
|
aoi |
|
v |
|
q |
|
f |
|
k |
|
qt |
|
dt |
|
model |
|
cpu |
|
verbose |
|
plot |
|
The method is based on ideas published by Burtin et al. (2016),
Walter et al. 82017) and Perez-Guillen et al. (2019) and implemented
in the R package eseis by Dietze (2018). It is related to the function
spatial_amplitude
, which can be used to locate spatially
stable seismic sources by the same technique, and it resuires
prepared input data as delivered by the function
spatial_distance
.
The input data (data
) should ideally be a list of eseis
objects (alternatively a matrix with seismic signal traces) containing
the envelopes of the seismic event to track (i.e., describe by its
location and amplitude as a function of propagation time). The temporal
resolution of the track is defined by the arguments window
and
overlap
(as a fraction between 0 and 1). The approach is based on
fitting known amplitude-distance functions (for an overview of available
functions see model_amplitude
) to the envelope time snippets
for each pixel of a grid, which provides the distance from a pixel to
each seismic station, i.e., the distance map set d_map
. To avoid
fitting each of the pixels of the distance map, one can provide an area
of interest, AOI (aoi
), which has the same extent and resolution
as the distance map set and pixel values are either TRUE
or
FALSE
. Depending on which amplitude-distance function is chosen,
further arguments need to be provided (ground quality factor q
,
center frequency of the signal f
). The apparent seismic wave
velocity v
is required regardless, either as fit model parameter
or to correct the amplitude time snippets for the travel time delay from
the source to the respective pixel of the distance map set. The output
of the function can be provided with uncertainty estimates on all output
values. The uncertainty is based on the size of accepted location
estimates per time step, as defined by the variance reduction quantile
threshold qt
(i.e., all locations above this quantile will be
assumed to be valid location estimates, whose parameters will be used
to estimate the uncertainty). Note that usually, qt
should be
set to around 0.99, a value that depends on the number of pixels in
the distance map set and that affects the location uncertainty, which
in many cases is about 10
Note however, that this value is purely arbitrary and should be based
on field-based control data. It is possible to run the function in a
multi-CPU mode, to speed up computational time, using the argument
cpu
. Also, the function can generate generic plot output of
the results, a panel of three plots: source trajectory, source
amplitude and variance reduction.
Note that depending on the resolution of the distance map set, number of included seismic stations, and number of time windows, the function can take significant processing time. 50 time steps for 5 stations and 5000 pixels per distance map requires about 10 minutes time on a normal grade computer using a single CPU.
A List
object with summarising statistics of the fits.
Burtin, A., Hovius, N., and Turowski, J. M.: Seismic monitoring of torrential and fluvial processes, Earth Surf. Dynam., 4, 285–307, https://doi.org/10.5194/esurf-4-285-2016, 2016.
Dietze, M.: The R package 'eseis' – a software toolbox for environmental seismology, Earth Surf. Dynam., 6, 669–686, https://doi.org/10.5194/esurf-6-669-2018, 2018.
Perez-Guillen, C., Tsunematsu, K., Nishimura, K., and Issler, D.: Seismic location and tracking of snow avalanches and slush flows on Mt. Fuji, Japan, Earth Surf. Dynam., 7, 989–1007, https://doi.org/10.5194/esurf-7-989-2019, 2019.
Walter, F., Burtin, A., McArdell, B. W., Hovius, N., Weder, B., and Turowski, J. M.: Testing seismic amplitude source location for fast debris-flow detection at Illgraben, Switzerland, Nat. Hazards Earth Syst. Sci., 17, 939–955, https://doi.org/10.5194/nhess-17-939-2017, 2017.
## Not run: x <- spatial_track(data = data, window = 5, overlap = 0.5, d_map = D$maps, aoi = aoi, v = 800, q = 40, f = 12, qt = 0.99) ## End(Not run)
## Not run: x <- spatial_track(data = data, window = 5, overlap = 0.5, d_map = D$maps, aoi = aoi, v = 800, q = 40, f = 12, qt = 0.99) ## End(Not run)
The time series x
is aggregated by an integer factor n
.
time_aggregate(data, n = 2)
time_aggregate(data, n = 2)
data |
|
n |
|
POSIXct
vector, aggregated data.
Michael Dietze
## load example data set data(rockfall) ## aggregate time series rockfall_t_agg <- time_aggregate(data = rockfall_t, n = 2) ## compare results range(rockfall_t) diff(rockfall_t) range(rockfall_t_agg) diff(rockfall_t_agg)
## load example data set data(rockfall) ## aggregate time series rockfall_t_agg <- time_aggregate(data = rockfall_t, n = 2) ## compare results range(rockfall_t) diff(rockfall_t) range(rockfall_t_agg) diff(rockfall_t_agg)
The function clips a time vector based on provided limits.
time_clip(time, limits)
time_clip(time, limits)
time |
|
limits |
|
POSIXct
vector, clipped time vector.
Michael Dietze
## load example data data(rockfall) ## define limits to clip to limits <- c(min(rockfall_t) + 10, max(rockfall_t) - 10) ## clip data set rockfall_t_clip <- time_clip(time = rockfall_t, limits = limits) ## compare time ranges range(rockfall_t) range(rockfall_t_clip)
## load example data data(rockfall) ## define limits to clip to limits <- c(min(rockfall_t) + 10, max(rockfall_t) - 10) ## clip data set rockfall_t_clip <- time_clip(time = rockfall_t, limits = limits) ## compare time ranges range(rockfall_t) range(rockfall_t_clip)
The function converts a Julian Day value to a date, to POSIXct
if a
year is provided, otherwise to POSIXlt
.
time_convert(input, output, timezone = "UTC", year)
time_convert(input, output, timezone = "UTC", year)
input |
|
output |
|
timezone |
|
year |
|
Numeric
vector,
Michael Dietze
## convert Julian Day 18 to POSIXct time_convert(input = 18, output = "POSIXct") ## convert Julian Day 18 to yyyy-mm-dd time_convert(input = 18, output = "yyyy-mm-dd") ## convert yyyy-mm-dd to Julian Day time_convert(input = "2016-01-18", output = "JD") ## convert a vector of Julian Days to yyyy-mm-dd time_convert(input = 18:21, output = "yyyy-mm-dd")
## convert Julian Day 18 to POSIXct time_convert(input = 18, output = "POSIXct") ## convert Julian Day 18 to yyyy-mm-dd time_convert(input = 18, output = "yyyy-mm-dd") ## convert yyyy-mm-dd to Julian Day time_convert(input = "2016-01-18", output = "JD") ## convert a vector of Julian Days to yyyy-mm-dd time_convert(input = 18:21, output = "yyyy-mm-dd")
This function converts a POSIXct-like date into the corresponding Julian Day number and returns it as string format.
time_jd(time)
time_jd(time)
time |
|
There is also a more powerful function to convert between different time
formats, see time_convert
for details.
Character
value, Julian Day corresponding to the input
date.
Michael Dietze
time_jd(time = "2020-05-01")
time_jd(time = "2020-05-01")
This function converts seismic traces to mseed files and writes them to disk. It makes use of the Python library 'ObsPy'. Thus, this software must be installed, to make use of this function.
write_mseed(data, file, time, component, station, location, network, dt)
write_mseed(data, file, time, component, station, location, network, dt)
data |
|
file |
|
time |
|
component |
|
station |
|
location |
|
network |
|
dt |
|
The ObsPy Python library can be installed following the information
provided here: "https://github.com/obspy/obspy/wiki"
.
Since the ObsPy functionality through R is not able to interpret path
definitions using the tilde symbol, e.g. "~/Downloads"
, this
Linux type definition must be avoided.
A binary file written to disk.
Michael Dietze
## Not run: ## load example data data("rockfall") ## write as mseed file write_mseed(data = rockfall_eseis, file = "rockfall.mseed") ## End(Not run)
## Not run: ## load example data data("rockfall") ## write as mseed file write_mseed(data = rockfall_eseis, file = "rockfall.mseed") ## End(Not run)
This function creates a HTML report for a given eseis object, listing its complete processing history. The report serves both as a convenient way of browsing through objects and as a proper approach to documenting and saving scientific data and workflows.
write_report(object, file, title = "eseis report", browser = FALSE, css)
write_report(object, file, title = "eseis report", browser = FALSE, css)
object |
|
file |
|
title |
|
browser |
|
css |
|
The function heavily lends ideas from the function report_RLum()
written by Christoph Burow, which is contained in the package
Luminescence
. This function here is a truncated, tailored version
with minimised availabilities.
HTML and .Rds file.
Michael Dietze
## Not run: ## load example data set data(rockfall) ## make report for rockfall object write_report(object = rockfall_eseis, browser = TRUE) ## End(Not run)
## Not run: ## load example data set data(rockfall) ## make report for rockfall object write_report(object = rockfall_eseis, browser = TRUE) ## End(Not run)
This function converts seismic traces to sac files and writes them to disk.
write_sac( data, file, time, component, unit, station, location, network, dt, autoname = FALSE, parameters, biglong = FALSE )
write_sac( data, file, time, component, unit, station, location, network, dt, autoname = FALSE, parameters, biglong = FALSE )
data |
|
file |
|
time |
|
component |
|
unit |
|
station |
|
location |
|
network |
|
dt |
|
autoname |
|
parameters |
|
biglong |
|
For description of the sac file format see https://ds.iris.edu/files/sac-manual/manual/file_format.html. Currently the following parameters are not supported when writing the sac file: LAT, LON, ELEVATION, NETWORK.
A binary file written to disk.
Michael Dietze
## Not run: ## load example data data("rockfall") ## write as sac file write_sac(data = rockfall_eseis) ## End(Not run)
## Not run: ## load example data data("rockfall") ## write as sac file write_sac(data = rockfall_eseis) ## End(Not run)