Checking for non-preferred file/folder path names (may take a long time depending on the number of files/folders) ...
This resource contains some files/folders that have non-preferred characters in their name. Show non-conforming files/folders.
This resource contains content types with files that need to be updated to match with metadata changes. Show content type files that need updating.
Authors: |
|
|
---|---|---|
Owners: |
|
This resource does not have an owner who is an active HydroShare user. Contact CUAHSI (help@cuahsi.org) for information on this resource. |
Type: | Resource | |
Storage: | The size of this resource is 1.7 GB | |
Created: | Jun 03, 2021 at 7:36 p.m. | |
Last updated: | Mar 07, 2022 at 11:52 p.m. (Metadata update) | |
Published date: | Mar 07, 2022 at 11:46 p.m. | |
DOI: | 10.4211/hs.a6ea89ae20354e39b3c9f1228997e27a | |
Citation: | See how to cite this resource |
Sharing Status: | Published |
---|---|
Views: | 1432 |
Downloads: | 84 |
+1 Votes: | Be the first one to this. |
Comments: | No comments (yet) |
Abstract
This resource contains the supporting data and code files for the analyses presented in "Toward automating post processing of aquatic sensor data," an article published in the journal Environmental Modelling and Software. This paper describes pyhydroqc, a Python package developed to identify and correct anomalous values in time series data collected by in situ aquatic sensors. For more information on pyhydroqc, see the code repository (https://github.com/AmberSJones/pyhydroqc) and the documentation (https://ambersjones.github.io/pyhydroqc/) The package may be installed from the Python Package Index (more info: https://packaging.python.org/tutorials/installing-packages/)
Included in this resource are input data, Python scripts to run the package on the input data (anomaly detection and correction), results from running the algorithm, and Python scripts for generating the figures in the manuscript. The organization and structure of the files are described in detail in the readme file. The input data were collected as part of the Logan River Observatory (LRO). The data in this resource represent a subset of data available for the LRO and were compiled by querying the LRO’s operational database. All available data for the LRO can be sourced at http://lrodata.usu.edu/tsa/ or on HydroShare: https://www.hydroshare.org/search/?q=logan%20river%20observatory.
There are two sets of scripts in this resource: 1.) Scripts that reproduce plots for the paper using saved results, and 2.) Code used to generate the complete results for the series in the case study. While all figures can be reproduced, there are challenges to running the code for the complete results (it is computationally intensive, different results will be generated due to the stochastic nature of the models, and the code was developed with an early version of the package), which is why the saved results are included in this resource. For a simple example of running pyhydroqc functions for anomaly detection and correction on a subset of data, see this resource: https://www.hydroshare.org/resource/92f393cbd06b47c398bdd2bbb86887ac/.
Subject Keywords
Coverage
Spatial
Temporal
Start Date: | |
---|---|
End Date: |
Content
readme.md
Supporting data and tools for "Toward automating post processing of aquatic sensor data"
The files contained here are inputs, outputs, and processing scripts that support the analysis and visualization in the paper "Toward automating post processing of aquatic sensor data". The following files and directories are included and described in greater detail:
- LRO_data: Raw sensor observations that were used as inputs. Also include technician labels and corrections.
- DetectionResults: Results of anomaly detection are in the directory.
- CorrectionResults: Results of anomaly correction.
- ConfusionMatrixPlots.py, DetectionPlots.py, CorrectionPlots.py: Scripts to generate plots in the manuscript
- detect_script.py, correct_script.py: Scripts used to perform anomaly detection or correction that generated the output.
To reproduce figures shown in the paper, refer to the scripts ConfusionMatrixPlots.py, DetectionPlots.py, and CorrectionPlots.py.
The code provided in this resource was developed using Python 3.70. The following Python packages are required for running the scripts: pandas 1.1.5, matplotlib 3.4.2, pyhydroqc 0.0.4, numpy 1.19.5.
File Organization and Description
LRO_data
This directory contains csv files with time series for each monitoring location. Each file corresponds to a single year of data. The files are named according to monitoring site (FranklinBasin, TonyGrove, WaterLab, MainStreet, Mendon, BlackSmithFork) and year. The files were sourced by querying the Logan River Observatory relational database, and equaivalent data could be obtained from the LRO website or on HydroShare. Additional information on sites, variables, and methods can be found on the LRO website or HydroShare. Each file has the same structure indexed with a datetime column (mountain standard time) with three columns corresponding to each variable. Variable abbreviations and units are:
- temp: water temperature, degrees C
- cond: specific conductance, μS/cm
- ph: pH, standard units
- do: dissolved oxygen, mg/L
- turb: turbidity, NTU
- stage: stage height, cm
For each variable, there are 3 columns:
- Raw data value measured by the sensor (column header is the variable abbreviation).
- Technician quality controlled (corrected) value (column header is the variable abbreviation appended with '_cor').
- Technician labels/qualifiers (column header is the variable abbreviation appended with '_qual').
The directory also contains files with lists of dates for sensor calibrations at the MainStret site (MainStreet_cond_calib_dates.csv, MainStreet_ph_calib_dates.csv, MainStreet_do_calib_dates.csv). The dates were determined from technicians records and field notes. There is a separate file for each calibrated sensor (specific conductance (cond), pH (ph), dissolved oxygen (do)). Each file contains the following columns:
- start: Start date for the period of drift. This is the first point to be corrected by linear dirft correction.
- end: End date for the period of drift corresponding to a calibration event.
- gap: When correction was performed by technicians, the data were shifted by this value.
DetectionResults
This directory contains the results of anomaly detection using the pyhydroqc functions and workflow. Results are organized by monitoring site with a zipped directory for each site (FranklinBasin, TonyGrove, WaterLab, MainStreet, Mendon, BlackSmithFork). Each zipped directory contains separate files organized by model, variable, and result type. File names include abbreviations for model, variable, and result type.
Models: designated by the following abbreviations in the file name.
- ARIMA: autoregressive integrated moving average
- LSTM_univar: long short term memory univariate vanilla
- LSTM_univar_bidir: long short term memory univariate bidirectional
- LSTM_multivar: long short term memory multivariate
- LSTM_Multivar_bidir: long short term memory multivariate bidirectional
Variables: designated by the variable abbreviation appended to the file name.
- temp: water temperature, degrees C
- ph: pH, standard units
- cond: specific conductance, μS/cm
- do: dissolved oxygen, mg/L
Result types: There are several files containing results. Each result type corresponds to a combination of model and variable with the following abbreviations in the file name.
-
df or df_anomalies: a table of inputs and outputs to the pyhydroqc workflow containing the following columns:
- datetime: date time index
- raw: sensor measured value
- cor: technician corrected value
- labeled_anomaly: boolean indicating technician labeled anomaly
- anomaly: boolean indicating anomaly detected by rules based detection
- observed: sensor measured values after passing through rules based detection and correction
- obs_scaled: observed values scaled by the scikitlearn standard scaler
- raw_scaled: raw values scaled by the scikitlearn standard scaler
- labeled_event: numbering of technician labeled anomalies grouped into events
- detected_anomaly: boolearn indicating anomaly detected by model based detection
- all_anomalies: boolean combining rules based and model based detection
- detected_event: numbering of combined rules based and model based detection grouped into events
- grp: numbering of anomalies and non-anomalous groups
- conf_mtx: identification of each point as true negative (tn), true positive (tp), false negative (fn), false positive (fp)
-
threshold: a table of dynamic threshold values for each point containing the following columns:
- datetime: date time index
- low: the lower bound of the threshold
- high: the upper bound of the threshold
-
detections: a table with model predictions, residuals, and anomalies detected by the pyhydroqc workflow containing the following columns:
- datetime: date time index
- observed: sensor measured values after passing through rules based detection and correction
- prediction: values predicted by the model
- residual: difference between the observed and prediction
- anomaly: boolean indicating anomaly detected by model based deteection
-
aggregate: a table compiling anomaly detections from all models and comparing to technician labels containing the following columns:
- datetime: date time index
- ARIMA: boolean indiating anomaly detected by the ARIMA model workflow
- LSTM_van_uni: boolean indicating anomaly detected by LSTM vanilla univariate model workflow
- LSTM_bidir_uni: boolean indicating anomaly detected by LSTM bidirectional univariate model workflow
- LSTM_van_multi: boolean indicating anomaly detected by LSTM vanilla multivariate model workflow
- LSTM_bidir_multi: boolean indicating anomaly detected by LSTM bidirectional multivariate model workflow
- detected_event: boolean indicating anomaly detected by any of the models (the previous 5 columns) grouped into events
- labeled_anomaly: boolean indicating technician labeled anomaly
- labeled_event: numbering of technician labeled anomalies grouped into events
- grp: numbering of anomalies and non-anomalous groups
- conf_mtx: identification of each point as true negative (tn), true positive (tp), false negative (fn), false positive (fp)
-
metrics: pickled python object that contains the metrics determined by the pyhydroqc 'metrics' function (true positives, false positives, true negatives, false negatives, positive predictive value, negative predictive value, accuracy, recall, F1, F2)
CorrectionResults
This directory contains the results of anomaly correction using the pyhydroqc functions and workflow. Results are organized into files corresponding to each monitoring site (FranklinBasin, TonyGrove, WaterLab, MainStreet, Mendon, BlackSmithFork) and variable (temp: water temperature (degrees C), ph: pH (standard units), cond: specific conductance (μS/cm), do: dissolved oxygen (mg/L)). Each file contatins the following columns:
- datetime: date time index
- ARIMA: boolean indiating anomaly detected by the ARIMA model workflow
- detected_event: boolean indicating anomaly detected by any of the models grouped into events
- observed: sensor measured values after passing through rules based detection and correction
- det_cor: correction estimate determined by the pyhydroqc correction workflow
- corrected: boolean indicating whether the correction was performed
- forecasts: for corrected points, the foreward looking estimates used in the correction algorithm
- backcasts: for corrected points, the backward looking estimates used in the correction algorithm
ConfusionMatrixPlots.py
This script contains commands to generate Figures 6 and 7 in the manuscript. The script contains the data, which were generated from a run of the pyhydroqc workflow for all sites and all variables. These figures illustrate the confusion matrix for each series by showing the portion of true positives, false negatives, and false positives for both the rules based and model based anomaly detection. Figure 6 shows these for all model types and Figure 7 shows an aggregate for each series.
DetectionPlots.py
This script contains commands to generate Figures 3, 4, 5, C1, C2, C3, C4 focuesed on anomaly detection. Many of the plots use consistent symbology and show observed data, model predictions, technician labeled anomalies, and algorithm detected anomalies for specific date ranges identified in data series of interest. Some of the figures are generated from importing raw data and running pyhydroqc commands while others are generated by importing pyhydroqc results. The necessary files are found in the folders 'LROData' and 'Plotting/SelectedResults'.
CorrectionPlots.py
This script contains commands to generate Figures 8 and C5 focused on anomaly correction. These plots use consistent symbology and show observed data, model corrected data, and technician corrected data (where appropriate) along with the forecasts and backcasts used to generate the model corrections for specific date ranges identified in data series of interest. The figures are generated by importing PyHdydroQC results. The necessary files are found in the folder 'Plotting/SelectedResults'.
SelectedResults
This directory contains files with detection and correction results used for plotting in the scripts DetectionPlots.py and CorrectionPlots.py. The files are a subset of the detection and correction results for data series selected for illustration in the figures. The structure of each file is as described under DetectionResults and CorrectionResults sections of this file.
detect_script.py
This is the script used to generate the results in the DetectionResults directory. It runs the pyhydroqc anomaly detection workflow for all LRO monitoring sites and variables. It runs the workflows for all model types, calculates metrics, aggregates the results, and saves the results as csv files and as pickled object. This script used raw data with the necessary files found in the folder 'LROData'. Note that this script was created with a previous version of pyhydroqc and continuing compatibility has not been verified. This script is time and resource demanding as is mostly provided as a reference.
correct_script.py
This is the script used to generate the results in the CorrectionResults directory. It runs the pyhydroqc ARIMA anomaly detection workflow all LRO monitoring sites and variables and then performs anomaly correction on identified anomalies. It saves the corrections as csv files. This script used raw data with the necessary files found in the folder 'LROData'. This script is time and resource demanding as is mostly provided as a reference.
Related Resources
The content of this resource references | Jones, A. S. (2021). pyhydroqc Sensor Data QC: Single Site Example, HydroShare, https://doi.org/10.4211/hs.92f393cbd06b47c398bdd2bbb86887ac |
This resource is described by | Jones, A.S., Jones, T.L., Horsburgh, J.S. (2022). Toward automated post processing of aquatic sensor data, Environmental Modelling and Software, https://doi.org/10.1016/j.envsoft.2022.105364 |
Credits
Funding Agencies
This resource was created using funding from the following sources:
Agency Name | Award Title | Award Number |
---|---|---|
National Science Foundation | Collaborative Research: Elements: Advancing Data Science and Analytics for Water (DSAW) | 1931297 |
How to Cite
This resource is shared under the Creative Commons Attribution CC BY.
http://creativecommons.org/licenses/by/4.0/
Comments
There are currently no comments
New Comment