-
Notifications
You must be signed in to change notification settings - Fork 8
Tutorial
**This page need major revision since it is automatically converted from an old tutorial for plugin version 1.0. **
This page is setup as a tutorial and you may follow the instructions from the beginning to the end of this page. In fact, if you are new to Midvatten plugin for QGIS, then you are strongly recommended to read and follow the steps in this tutorial.
The sample data used for this plugin may be downloaded from the Midvatten plugin home page or from here
-
Start QGIS and select Settings-Options-Map Tools and activate “Open identify results in a dock window”:
-
Then restart QGIS with a new project.
-
Create a new and empty database of predefined design:When prompted, select CRS 4326 (WGS84)
-
Get yourself a background map layer, I highly recommend any of the layers you can get by using OpenLayers plugin:.
-
Verify that the database is selected in Midvatten Settings (you may also click the Midvatten settings button in the Midvatten toolbar, or use function key F6):
-
Load default layers from the database, select Midvatten-Load default db-layers to qgis (or use function key F7):
Afterwards you will see that all default layers from the database is loaded into a layer group called Midvatten_OBS_DB:
The database design is shown below and as you can see, many but not all tables from the database are loaded by default:
On the other hand, the database also contains some spatial views that are loaded as default layers, we will get back to those later:
- obs_p_w_qual_field - all obs_points with data in table w_qual_field
- obs_p_w_qual_lab - all obs_points with data in table w_qual_lab
- obs_p_w_strat - all obs_points with data in table stratigraphy
- obs_p_w_lvl - all obs_points with data in table w_levels
- w_lvls_last_geom - all the latest measurements in table w_levels
-
Import some observation points to the database: When prompted, set charset encoding UTF-8 (please note that setting charset encoding is needed for every import in the following tutorialand it is of high importance to do this correctly oterhwise import might fail), select the file obs_points_4326.csv and go on with the import. Afterwards you may open the attribute table to see what data has been imported.
-
THIS IS NOT NEEDED IN THE UPCOMING RELEASEActivate layer obs_points and create geometries for the observation points by selecting Midvatten-Edit data in database – Update map position from coordinates: Select “All” when prompted to perform the update for all objects in the layer
-
Right-click layer obs_points and select “zoom to layer” to see positions for the imported objects: (Tips: Use OpenLayers plugin or some OpenStreetMap WMS layer to get a background map for you data. As you may see, the tutorial data is randomly placed in a non-relevant location.)
-
Activate layer obs_points and start editing (click the pen).
-
Select Edit – Add Feature or select Add Feature tool from editor toolbar:
-
Place an observation point on the map and a custom edit form will show up:
-
Fill in all known information. It is absolutely necessary to select an obsid which do not already exist in the database. Note: you should try to define and use an obsid that applies and is unchanged throughout the project since gets a little awkward to change it after you have added related information in any of the tables w_levels, stratigraphy, w_qual_lab etc. obsid is the primary link in tables obs_points and obs_lines, the other tables relates to the first two by the field obsid (see database design).
-
Select xyz-tab and notice that no coordinates are shown although you marked a position for the point. The coordinates will be automatically added to the table based on current position when the changes are saved for the editing session.
-
After you have given all known information (for the tutorial it is enough with just an obsid), close the edit form by clicking ”ok”.
-
Open attribute table for obs_points, then activate the ’feature list’ by selecting the left of the two small icons in the lower right corner:
-
This will switch to another attribute table view where you can select different filters in the left panel, set filter to field obsid:
-
And select your recently digitized observation point. Notice how the custom edit form now is embedded in the attribute table. This is an easy access to all main information about all observation points. Select an observation point in the list to the left and get attribute information presented in the custom edit form.
-
When ready, click the pen to stop editing.
-
To get the coordinates for the point you digitized and saved to databas, activate obs_points layer and select the obs_point. Then select Midvatten – Edit data in database – Update coordinates from map position.
-
A pop-up-window will ask you if you want to update coordinates for all or only selected objects. Press ”selected”. And then answer yes to the ’sanity check’!
-
Activate the Identify features -tool (View-Menu) and click the updated point. Verify there are coordinates in fields east and north.
-
Import stratigraphy information for observation points.* Select Midvatten – Import to database – Import stratigraphy data*: Set charset encoding = UTF-8 and select the file stratigraphy.csv.
-
Notice how the message bar will tell you how many stratigraphy layers were imported:
-
Redraw the map by the refresh button, or simply pan or zoom the map, and then you will see that you suddenly have data in the obs_p_w_strat layer: obs_p_w_strat is a database view that shows all observation points with some stratigraphy info.
-
Notice how the map layer obs_p_w_strat indicates that no stratigraphy information exists for PW1101 and PW1002. Select layer *stratigraphy *and open attribute table to verify this and get familiar with the imported data.
-
Now it is time to get quick-access to stratigraphy info by the plotting function. Open the Midvatten Settings dialog (Midvatten – Midvatten Settings, or F6) and select table stratigraphy in the Stratigraphy tab. Then select a few observation points in obs_p_w_strat and plot stratigraphy (Midvatten – View plot – Plot stratigraphy, or press F10: Try to change color coding from Geo to Hydro. Also change the text. Open the attribute table for stratigraphy and compare to the plot.
-
Try to activate obs_points layer and select a obs_point without stratigraphy and press F10 again. What happened? Why? Why is obs_p_w_strat useful?
-
Select layer stratigraphy
-
Begin editing the layer (click on the pen)
-
Open the attribute table
-
Click the plus sign (+) which can be found at the bottom of the attribute table to open an edit form:
-
Add information about your stratigraphy layer. Some constraints:
- obsid must exist in table obs_points
- stratid (integer) must not be empty or null
- depth under gs... ...from and ...to (floating point numbers, database fields depthtop and depthbot) must not be empty or null.
- depthbot must be greater than depthtop
-
When ready, click OK and then save to database by clicking the save icon in the upper left corner (floppy icon second from the left) of attribute table window.
-
Repeat steps 4-5 for each stratigraphy layer info to be added. Please note that saving to database between each layer makes this process safer since it will prevent duplicate layers for one observation point.
-
Finish editing by clicking the pen symbol.
-
Import some water level measurements to the database: Set charset encoding = UTF-8 and select the file w_levels.csv.
-
Open attribute table for layer w_levels to see the imported data. Please note that the column level_masl (i.e. water level in meter above sea level) shows dummy values of -999. Also, h_toc (i.e. measurement reference point, “top of casing”) is empty:
-
Close attribute table, activate obs_points layer and activate the “Identify features tool” and click on any observation point. A pop-up dialog will show information about the observation point, e.g. TopOfCasing: Thus there is information about the measurement reference point and we can use it to calculate the water level corresponding to our imported measurements.
-
Activate the obs_points layer and select any of the observation points. Then select Midvatten – Edit data in database – Calculate w level above sea level: When prompted, accept the full (default) date intervall and select to update the table w_levels for ALL objects. Open attribute table w_levels again to see the result of this operation.
-
Force a redraw of the map (use pan tool or zoom in and out once) and then you can see that two additional layers will be shown on map, w_lvls_last_geom and obs_p_w_lvl. Both are spatial views of data in the database. The first layer shows the latest water level measurement for each observation point. Use the info tool and point-and-click on any object in this layer to see date and result for the latest measurement.
-
The layer obs_p_w_lvl will show all observation points for which there are any water level measurements, this is very useful if the database contains a lot of points but water level is only measured in a few of them.
-
To plot some water level measurements, start with selecting *Midvatten – Midvatten Settings *(or use toolbar button or function key F6) and select *Time series *tab. Select table *w_levels *and column level_masl. Activate “Dot markers on line” and click OK:
-
Then activate layer obs_p_w_lvl and select one or a few objects. Then select Midvatten – View plot – Time Series plot or click the time series button in the Midvatten toolbar (or use function key F8) to get a zoomable and panable time series plot of water level measurements for the selected objects:
-
Select layer w_levels
-
Begin editing the layer (click on the pen)
-
Open the attribute table
-
[bkm:RefNumPara7112385576597]Click the plus sign (+) which can be found at the bottom of the attribute table to open an edit form:
-
Add information about your water level measurement. The tooltip show additional information about the fields. The color coding indicates some of the constraints:obsid must exist in table obs_pointsdate_time must be an acceptable format (yyyy-mm-dd, yyyy-mm-dd HH:MM or yyyy-mm-dd HH:MM:SS)also, each combination of obsid and date_time must be uniquelevel_masl must be a floating point number
-
[bkm:RefNumPara7114385576597]When ready, click OK and then save to database by clicking the save icon in the upper left corner (floppy icon second from the left) of attribute table window.
-
Repeat steps [bkm:RefNumPara7112385576597] - [bkm:RefNumPara7114385576597] until ready and then stop editing by clicking the pen symbol.
-
Now activate layer *obs_points *and select PW1001. Then import automatic water level measurements for this obs_point by selecting *Midvatten – Import data to database – Import w level from logger. *Answer yes to the pop-up question and select ’UTF-8’ and then the file w_levels_logger.csv
-
Now try to watch these data by plotting them in a time series, go to *Midvatten – Midvatten Settings *and select *Time Series *tab. Select w_levels_logger as the table (that is where your data was imported to) and head_cm as column. Also DESELECT “Dot markers on line” if that option was selected since earlier. Finally click OK to close settings and press “F8” (with *obs_points *activated and *PW1001 *selected) to invoke a time series plot of head_cm from the imported data:
-
Clearly you imported some data from the csv file. Try to go back to Midvatten Settings and change plot column to temp_degc and create new time series plots. Then do the same with column level_masl. (Function keys F6 and F8 very useful here!):
-
This plot does not make very much sense, it only shows default levels as -999 meters above sea level. We need to transform pressure above pressure sensor (recorded as head_cm) to level in meters above sea level. We are going to do this by a simple comparison to the manual measurements.
-
Midvatten – Edit Data – Calibrate w level from logger and a calibration dialog will be shown. Make sure layer obs_points is activated and PW1001 selected, then click “calibrate” with the default values unchanged:
-
A calibration plot will be shown where manual measurements are represented with dots and calibrated logger levels are shown with a line. There will be >1000 m difference between the two. Try to set logger position = 318 and press “Calibrate” again, a new plot will be shown:Please note: You have now altered the database! Whenever you give a value for logger position and press calibrate, then the column level_masl will be recalculated in table w_levels_logger for the given date and time interval.
-
The match is decent but could be adjusted for a better match, e.g. Logger position = 317.75 gives a good match between manual measurements and logger data until 15th of June 2011. But it seems to be a discontinuous data series and also that the logger position ha changed a couple of times:
-
Now change calibration interval so that calibration is performed from 2011-06-15 00:00:00 with a new logger position of 313.25 (note that the calibration window shows you the latest logger position):
-
There is also another window where logger data seems to be missing, last continuous series of logger data starts in december 2011. Try to set a new logger position for this period until you have satisfying correspondance between manual and automatic water level measurements. When you are ready, close all plot windows and the calibration window.
-
[bkm:RefNumPara2391675535448]Now it is time to have a look at the actual w_levels_logger table. This can be done in a number of ways, I highly recommend Spatialite-GUI, but for this tutorial we stick to qgis. Select Layer – Add Spatialite layer. Then connect to your database and (this is absolutely necessary) select “Also list tables with no geometry” and mark the table w_levels_logger and click “add”:
-
Notice how w_levels_logger is added as a layer to your layer panel. Right-click this layer and open the attribute table. There you can examine the result of your calibration. The values in column level_masl are calculated from your given logger positions and the measured pressure in head_cm. When ready, remove this layer from qgis to save some memory.
-
Now, finally time to watch a plot of your calibrated water level readings, go to* Midvatten – Midvatten Settings* (or ”F6”) and select Time Series tab:Make sure you DEactivate ”Dot markers on line”.
-
Activate layer obs_points and select the feature with logger data (in our case PW1001). Press “F8” (with *obs_points *activated and *PW1001 *selected) to invoke a time series plot of your calibrated water levels from logger readings:
-
Next step is to import water quality data, select Midvatten - Import data to database – Import w quality from lab and Import w quality from field to import w_qual_lab.csv and w_qual_field.csv. Notice how the layers (the spatial views) obs_p_w_qual_lab and obs_p_w_qual_field shows which observation points that has water quality data.
-
You may open the two water quality tables to examine data (activate layer and open attribute table). As you can see, those data includes a date_time column and can therefore be plotted as Time series.
-
[bkm:RefNumPara7352385576597]To make time series plots easier for a few water quality parameters, there are a some database views predefined in the database:w_qual_field_temp – temperature measurements from fieldw_qual_lab_dh – hardness from laboratoryw_qual_lab_hco3 – alcalinity from laboratoryw_qual_lab_kond – conductivity from laboratoryw_qual_lab_ph – ph from laboratorySelect w_qual_field_temp in Midvatten Settings as below:
-
Then select a few observations from obs_p_w_qual_field layer and plot Time Series (F8):Such plots may of course be generated for any of the database views presented in step [bkm:RefNumPara7352385576597] above. It is also possible to define additional views eg with help other tools such as spatialite-gui (or perhaps qgis plugin db manager depending on your sqlite skills).
-
For examining water quality data there is also an option of generating simple html reports. First adjust Midvatten Settings W quality report tab according to screen dump below.
-
Then select any object (only one at a time) in obs_p_w_qual_lab and select *Midvatten – View Report – Water Quality Report (or ”F12”) *to generate the simple html report which opens in your default web browser:Similar report may be generated for data in table w_qual_fr_field.
-
The last data import under point observations is water flow. First, have a quick look at the database design diagram shown under step [bkm:RefNumPara2387675535448] above. Notice how there is a constraint on flowtype, any flowtype in table w_flow must exist in table zz_flowtype. Therefore, add the table zz_flowtype as a layer to qgis (see step [bkm:RefNumPara2391675535448] above) and look at the different default flow types. Now, being aware of this, we go on with the import Midvatten - Import data to database – Import w flow measurements and select file w_flow.csv. Please read the pop-up window:Notice how any new flowtypes will be added to the zz_flowtype table but be aware, only default flow types correspondes to predefined views, see below.
-
Open layer w_flow to examine the imported data. Notice how the three different flow types are used.
-
In the database there are three predefined spatial views that shows subsets of the table w_flow, namely w_flow_momflow for Momentary water flow readings, w_flow_aveflow for average water flow and w_flow_accvol for accumulated water volume*.* Add these to qgis using the method described in step [bkm:RefNumPara2391675535448] above and have a look.
- The predefined w_flow_... views are very useful when plotting time series of water flow data. As an example, activate obs_points layer and select PW1001. Open *Midvatten Settings *– *Time Series *tab and try each one of the following settings and create a time series plots (F8):table: w_flow_aveflow, column: readingtable: w_flow_momflow, column: readingtable: w_flow_accvol, column: reading [Warning: Image ignored] Even though these tutorial data are fictive it will hopefully illustrate how flowtypes can be used to visualise pumping rates and accumulated water volumes.
-
Select layer w_flow, begin editing (click on the pen) and open the attribute table.
-
[bkm:RefNumPara71123855765971]Click the plus sign (+) which can be found at the bottom of the attribute table to open an edit form:
-
Add information about your water flow reading. The tooltip shows additional information about the fields. The color coding indicates some of the constraints:obsid must exist in table obs_pointsinstrumentid must not be null nor emptyflowtype must be found in databse table zz_flowtype (for most cases it should be enough to use the standard values as shown by the tool tip) date_time must be an acceptable format (yyyy-mm-dd, yyyy-mm-dd HH:MM or yyyy-mm-dd HH:MM:SS)reading (floating point number) must not be empty or nullunit must not be empty or nullfinally, each combination of obsid, instrumen id, flowtype and date_time must be unique
-
[bkm:RefNumPara71143855765971]When ready, click OK and then save to database by clicking the save icon in the upper left corner (floppy icon second from the left) of attribute table window.
-
Repeat steps [bkm:RefNumPara71123855765971] - [bkm:RefNumPara71143855765971] until ready and then stop editing by clicking the pen symbol.
-
Activate the layer obs_points and select one obs_point
-
Select *Midvatten - View report - General Report *(or click the button on the toolbar or press ”F11”)
-
The result is displayed in your default internet browser. The table can be highlighted, copied and pasted into Excel or Word:
- Just add an obs_point as in chapter [bkm:RefHeading72182072149825].
- Select Midvatten- import data – to database- import meteorological observations:When prompted, set charset encoding utf-8, select the file *meteo.csv *and go on with the import.At the moment, the meteorological data is related to obs_points PW1102 and PW1002. In your case you probably have specific meteorological stations. But the import routine is the same of course.
-
This is not yet implemented in the plugin. Please use plotsqlite application instead (see chapter [bkm:RefHeading64652072149825]):
-
Select table ”meteo” and filters obsid, instrumentid and parameter to obtain your plot
-
Now it is time to work with observations that are best represented along lines on a map. To begin with, import two observation lines from a text file by selecting Midvatten – Import data to database – Import obs lines table: [Warning: Image ignored] When prompted, set charset encoding UTF-8, select the file obs_lines_4326.csv and go on with the import. Afterwards you may open the attribute table to see what data has been imported. Pan or zoom the map to force a redraw and thus you will see the imported lines.NOTE 1*! This example text file includes WKT geometries of type LINESTRING with SRID corresponding to the database (EPSG 4326). Any attempt to import observation lines from a text file without valid WKT geometries will fail.NOTE 2! YOU will be prompted to select SRID. Be sure to select EPSG ID = 4326.*
-
Also try to create three (3) arbitrary observation lines (obs_lines) by yourself. Activate the layer obs_lines and then start editing (click the pen)
-
Digitize three arbitrary lines and give them obsid S1, S2 and S3 in pop-up edit form:
-
If you open attribute table and select the ”feature list” view then you will notice that the obsid fields for your new obsevation lines will be red until you save edits to database. (The same as for the observation points, see chapter [bkm:RefNumPara7475385576597], step [bkm:RefNumPara7477385576597].
- As you can see, the imported lines are named vlf01 and vlf02 indicating they correspond to some vlf measurements along profiles. Now it is time to import raw data from thes measurements .Select Midvatten – Import data to database – Import vlf data, set charset encoding = UTF-8 and select the file vlf_data.csv.
-
To plot VLF Data, go to *Midvatten – Midvatten Settings *(or use toolbar button or function key F6) and select *XY Scatter *tab. Select table vlf_data and columns length, real_comp and imag_comp according to the picture below.
-
Activate layer obs_lines and select any of the lines corresponding to vlf-profiles. Then select Midvatten – View plot – Scatter plot or click the scatter plot button in the Midvatten toolbar (or use function key F9) to get a zoomable and panable plot of raw data from vlf field measurements for the selected vlf profile:
- Select Midvatten – Import data to database – Import seismic data, set charset encoding = UTF-8 and select the file vlf_data.csv.
-
To plot interpreted data from seismic investigations, go to *Midvatten – Midvatten Settings *(or use toolbar button or function key F6) and select *XY Scatter *tab. Select table seismic_data and columns length, ground and bedrock.
-
Activate layer obs_lines and select any of the lines corresponding to vlf-profiles. Then select Midvatten – View plot – Scatter plot or click the scatter plot button in the Midvatten toolbar (or use function key F9) to get a zoomable and panable plot of interpreted seismic data:
The plugin stores information about database, tables and columns in the QGIS project file.
This may cause the plugin to crash if e.g. the database has been moved.
Therefore an option to reset the settings is included in the plugin.
The reset settings is found under the plugin meny (no toolbar icon).
A few common tasks are associated to function keys F6-F12, namely:
F6 - Midvatten Settings
F7 - Load Default Layers
F8 - Plot Time Series
F9 - Plot XY Scatter
F10 - Plot Stratigraphy
F11 - Show General Report
F12 - Show Water Quality Report
It is highly recommended that you backup your database file regularly. A suggested method could be: use file explorer and create (compressed) copies of the database file, name them with date and time, place in subfolder archive.
If you for some reason have deleted big amounts of data from the database it is recommended to perform av vacuum of the database to reduce size on disk. Use spatialite-gui or other sqlite manager to vacuum the database. Vacuuming is also silently performed after each one of the import functions described above since these import functions keeps temporary data in the database which is deleted afterwards - hence causing a possible need for vacuuming.
[bkm:RefHeading64652072149825]If you want to create professional time series plots directly from the data in your Midvatten database, then please try the tool “plotsqlite”. Download from here : plotsqlite.googlecode.com
https://sites.google.com/site/midvattenpluginforqgis/
https://code.google.com/p/midvatten-plugin-for-qgis/
http://plugins.qgis.org/plugins/midvatten/
http://plotsqlite.googlecode.com/