Oxycline Index from Matrix Echograms
This package is built to take echogram data from Echopen software outputs and calculate oxycline depth limits using image-filtering algoriths.
oXim uses imagine algorithms, which includes median-filter and 2D-convolution implemented on Rcpp (C++) because the applicaion of this filters to echograms is very intensive and time expensive due to the size of echograms. oXim allows to change some parameters for filtering routines using an easily format (a table, data.frame object).
An echogram can be described as a visual representation of an acoustic variable, usually refered to the backscattering energy received after the emision of sound pulse to the water. Actualy, there are many softwares oriented to explore and analyze echogram data from echosounders as Echoview. One of them is Echopen, which was developed by IRD people under a Matlab environment and include libraries and routines for reading, integrate and cleaning databases from multibeam echosounders. oXim requires Echopen outputs as inputs for work.
For installing oXim, as follows:
install.packages("oXim")For reading data, it is necesary to specify Echopen outputs files (.m extension).
# Set directories where the Echopen's outputs are located
fileMode <- list(fish38_file   = system.file("extdata", "fish38.mat", package = "oXim"),
                 fluid120_file = system.file("extdata", "fluid120.mat", package = "oXim"),
                 blue38_file   = system.file("extdata", "blue38.mat", package = "oXim"))
# Read echograms (echoData object)
echoData <- readEchograms(fileMode = fileMode)Once the files have been read, output object will be of class echoData what means there are methods oriented to show main information (print), make a summary of data inside echograms (summary) and visualize the echograms as an image (plot). Then, methods for echoData objects are shown:
# Print method
print(echoData)## 
## Number of echograms:  1 
## 
## For echogram 1:
##  Range lon:  From 74.167° W to 74.113° W 
##  Range lat:  From 17.218° S to 17.187° S 
##  Range time: From 2011-09-12 00:54:29 to 2011-09-12 01:18:37# Print method
summary(echoData)## 
## Number of echograms:  1 
## 
## For echogram 1:
##      sA  lon lat time    
##  Min.    -122.8  -74.17  -17.22  2011-09-12 00:54:29 
##  1st Qu. -91.49  -74.15  -17.21  2011-09-12 00:59:50 
##  Median  -85.38  -74.14  -17.2   2011-09-12 01:06:06 
##  Mean    -84.41  -74.14  -17.2   2011-09-12 01:06:09 
##  3rd Qu. -76.53  -74.13  -17.19  2011-09-12 01:12:21 
##  Max.    -53.07  -74.11  -17.19  2011-09-12 01:18:37 # Plot method
plot(echoData)For oxycline depth calculation, getOxyrange function provides an easy-to-use way for applying median-filter and 2D convolution-based filters. This filters are explained below:
noiselessFilter: Median filter can be defined as a technique which returns the median value of the neighborhood of each cell of a matrix. Let \(X\) a matrix with dimensions \(n \times m\). Median filter will going to build a minimatrix (neighborhood) of \(p \times q\) dimensions (size defined by user) using each cell as center of this neighborhood. Then median filter will replace values of cells with the median of their own neighborhoods. getOxyrange implements a sub-function (.noiselessFilter) which allows to use not only percentile-50 value to make the replacing (medain filter) but also others values so by tolerance parameter. Thereby, tolerance = 0 will use first value (minimum) to make the replacing, tolerance = 1 will use the maximum, tolerance = 0.5 the median and so on. radius parameter will be use to indicate size of neighborhood (it will be an square neighborhood \(radius \times radius\)). Finally, with times parameter, user may indicate how many times the filter will be applied.
definerFilter: This function can be defined as a wrapper of noiselessFilter with tolerance = 1.
Both noiselessFilter and definerFilter do not use all values of neighborhood but only those located within diagonals of it. That because better results were found weighting up cells of diagonals.
For calculate oxycline depth limits from echoData objects, getOxyrange should be applied as follows:
# Calculate oxycline limits (oxyclineData object)
oxyLimits <- getOxyrange(fluidMatrix = echoData)## Message: 
## No filter-setting object or file detected. OXim will use default filter configuration.Likewise with readEchograms function, getOxyrange will return an object of class oxyclineData with their associated methods (print, summary and plot).
print(oxyLimits)## 
## For echogram 1:
##  Range lon:  From 74.167° W to 74.113° W 
##  Range lat:  From 17.218° S to 17.187° S 
##  Range time: From 2011-09-12 00:54:29 to 2011-09-12 01:18:37 
##  Range oxycline depth:   From 13.1 m to 96.7 msummary(oxyLimits)## 
## Number of database:  1 
## 
## For database 1:
##      lon lat limits  time    
##  Min.    -74.17  -17.22  -96.65  2011-09-12 00:54:29 
##  1st Qu. -74.15  -17.21  -73.77  2011-09-12 00:59:50 
##  Median  -74.14  -17.2   -71.47  2011-09-12 01:06:06 
##  Mean    -74.14  -17.2   -69.68  2011-09-12 01:06:09 
##  3rd Qu. -74.13  -17.19  -69.05  2011-09-12 01:12:21 
##  Max.    -74.11  -17.19  -13.06  2011-09-12 01:18:37 plot(oxyLimits)## [inverse distance weighted interpolation]