add_noise
adds synthetic noise to annotations in extended selection tables
Arguments
- X
Object of class 'extended_selection_table' (created by the function
selection_table
from the warbleR package), generated 'by element', with the reference to the test sounds (typically the output ofalign_test_files
). Must contain the following columns: 1) "sound.files": name of the .wav files, 2) "selec": unique selection identifier (within a sound file), 3) "start": start time and 4) "end": end time of selections, 5) "bottom.freq": low frequency for bandpass, 6) "top.freq": high frequency for bandpass and 7) "sound.id": ID of sounds (needed to calculate signal to noise ratio internally usingsignal_to_noise_ratio
).- mar
numeric vector of length 1. Specifies the margins adjacent to the start point of the annotation over which to measure ambient noise.
- target.snr
numeric vector of length 1. Specifies the desired signal-to-noise ratio. Must be lower that the current signal-to-noise ratio. Annotations showing a signal-to-noise ratio higher than 'target.snr' will remain unchanged. Must be supplied.
- precision
numeric vector of length 1. Specifies the precision of the adjusted signal-to-noise ratio (in dB).
- cores
Numeric vector of length 1. Controls whether parallel computing is applied by specifying the number of cores to be used. Default is 1 (i.e. no parallel computing). Can be set globally for the current R session via the "mc.cores" option (see
options
).- pb
Logical argument to control if progress bar is shown. Default is
TRUE
. Can be set globally for the current R session via the "pb" option (seeoptions
).- max.iterations
Numeric vector of length 1. Specifies the maximum number of iterations that the internal signal-to-noise adjusting routine will run before stopping. Note that in most cases the default maximum number of iterations (1000) is not reached.
- kind
Character vector of length 1 indicating the kind of noise, “white”, “pink”, “power”, "brown", or “red”. Noise is synthesized with a modified version of the function
noise
. Default is "pink" which is similar to background noise in natural environments.- alpha
Numeric vector of length 1. The power for the power law noise (defaults are 1 for pink and 1.5 for red noise). Only used when
kind = "power"
.- ...
Additional arguments to be passed internally to
signal_to_noise_ratio
.
Value
Object 'X' in which the wave objects have been modified to match the target signal-to-noise ratio. It also includes an additional column, 'adjusted.snr', with the new signal-to-noise ratio values.
Details
The function adds synthetic noise to sounds referenced in an extended selection table (class created by the function selection_table
from the warbleR package) to decrease the signal-to-noise ratio. This can be useful, for instance, for evaluating the effect of background noise on signal structure. Note that the implementation is slow.
References
Araya-Salas M., E. Grabarczyk, M. Quiroz-Oliva, A. Garcia-Rodriguez, A. Rico-Guevara. (2023), baRulho: an R package to quantify degradation in animal acoustic signals .bioRxiv 2023.11.22.568305. Timmer. J and M. König (1995): On generating power law noise. Astron. Astrophys. 300, 707-710.
See also
Other miscellaneous:
attenuation()
,
noise_profile()
Author
Marcelo Araya-Salas (marcelo.araya@ucr.ac.cr)
Examples
if (FALSE) { # \dontrun{
# load example data
data("test_sounds_est")
# make it a 'by element' extended selection table
X <- warbleR::by_element_est(X = test_sounds_est)
# add noise to the first five rows
X_noise <- add_noise(X = X[1:5, ], mar = 0.2, target.snr = 3)
} # }