weatherdb 1.1.0__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- docker/Dockerfile +30 -0
- docker/docker-compose.yaml +58 -0
- docker/docker-compose_test.yaml +24 -0
- docker/start-docker-test.sh +6 -0
- docs/requirements.txt +10 -0
- docs/source/Changelog.md +2 -0
- docs/source/License.rst +7 -0
- docs/source/Methode.md +161 -0
- docs/source/_static/custom.css +8 -0
- docs/source/_static/favicon.ico +0 -0
- docs/source/_static/logo.png +0 -0
- docs/source/api/api.rst +15 -0
- docs/source/api/cli.rst +8 -0
- docs/source/api/weatherDB.broker.rst +10 -0
- docs/source/api/weatherDB.config.rst +7 -0
- docs/source/api/weatherDB.db.rst +23 -0
- docs/source/api/weatherDB.rst +22 -0
- docs/source/api/weatherDB.station.rst +56 -0
- docs/source/api/weatherDB.stations.rst +46 -0
- docs/source/api/weatherDB.utils.rst +22 -0
- docs/source/conf.py +137 -0
- docs/source/index.rst +33 -0
- docs/source/setup/Configuration.md +127 -0
- docs/source/setup/Hosting.md +9 -0
- docs/source/setup/Install.md +49 -0
- docs/source/setup/Quickstart.md +183 -0
- docs/source/setup/setup.rst +12 -0
- weatherdb/__init__.py +24 -0
- weatherdb/_version.py +1 -0
- weatherdb/alembic/README.md +8 -0
- weatherdb/alembic/alembic.ini +80 -0
- weatherdb/alembic/config.py +9 -0
- weatherdb/alembic/env.py +100 -0
- weatherdb/alembic/script.py.mako +26 -0
- weatherdb/alembic/versions/V1.0.0_initial_database_creation.py +898 -0
- weatherdb/alembic/versions/V1.0.2_more_charachters_for_settings+term_station_ma_raster.py +88 -0
- weatherdb/alembic/versions/V1.0.5_fix-ma-raster-values.py +152 -0
- weatherdb/alembic/versions/V1.0.6_update-views.py +22 -0
- weatherdb/broker.py +667 -0
- weatherdb/cli.py +214 -0
- weatherdb/config/ConfigParser.py +663 -0
- weatherdb/config/__init__.py +5 -0
- weatherdb/config/config_default.ini +162 -0
- weatherdb/db/__init__.py +3 -0
- weatherdb/db/connections.py +374 -0
- weatherdb/db/fixtures/RichterParameters.json +34 -0
- weatherdb/db/models.py +402 -0
- weatherdb/db/queries/get_quotient.py +155 -0
- weatherdb/db/views.py +165 -0
- weatherdb/station/GroupStation.py +710 -0
- weatherdb/station/StationBases.py +3108 -0
- weatherdb/station/StationET.py +111 -0
- weatherdb/station/StationP.py +807 -0
- weatherdb/station/StationPD.py +98 -0
- weatherdb/station/StationT.py +164 -0
- weatherdb/station/__init__.py +13 -0
- weatherdb/station/constants.py +21 -0
- weatherdb/stations/GroupStations.py +519 -0
- weatherdb/stations/StationsBase.py +1021 -0
- weatherdb/stations/StationsBaseTET.py +30 -0
- weatherdb/stations/StationsET.py +17 -0
- weatherdb/stations/StationsP.py +128 -0
- weatherdb/stations/StationsPD.py +24 -0
- weatherdb/stations/StationsT.py +21 -0
- weatherdb/stations/__init__.py +11 -0
- weatherdb/utils/TimestampPeriod.py +369 -0
- weatherdb/utils/__init__.py +3 -0
- weatherdb/utils/dwd.py +350 -0
- weatherdb/utils/geometry.py +69 -0
- weatherdb/utils/get_data.py +285 -0
- weatherdb/utils/logging.py +126 -0
- weatherdb-1.1.0.dist-info/LICENSE +674 -0
- weatherdb-1.1.0.dist-info/METADATA +765 -0
- weatherdb-1.1.0.dist-info/RECORD +77 -0
- weatherdb-1.1.0.dist-info/WHEEL +5 -0
- weatherdb-1.1.0.dist-info/entry_points.txt +2 -0
- weatherdb-1.1.0.dist-info/top_level.txt +3 -0
docker/Dockerfile
ADDED
@@ -0,0 +1,30 @@
|
|
1
|
+
# Use the official Python base image
|
2
|
+
FROM --platform=linux/amd64 python:3.12-rc-slim-bullseye as pythonbaseimage
|
3
|
+
|
4
|
+
# update pip and install git
|
5
|
+
RUN pip install pip --upgrade && \
|
6
|
+
apt-get update && \
|
7
|
+
apt-get install git -y
|
8
|
+
|
9
|
+
WORKDIR /src
|
10
|
+
|
11
|
+
# get the pyproject.toml file
|
12
|
+
COPY ../pyproject.toml ./pyproject.toml
|
13
|
+
|
14
|
+
# install dependencies
|
15
|
+
RUN pip install toml && \
|
16
|
+
python -c "import toml; pyproject = toml.load('pyproject.toml');\
|
17
|
+
deps = pyproject['project']['dependencies'] \
|
18
|
+
+ pyproject['project']['optional-dependencies']['optionals'] \
|
19
|
+
+ pyproject['build-system']['requires'];\
|
20
|
+
open('/src/requirements.txt', 'w').write('\\n'.join(deps))" &&\
|
21
|
+
pip install -r requirements.txt --root-user-action=ignore
|
22
|
+
|
23
|
+
# Copy the source code
|
24
|
+
COPY ../README.md ../MANIFEST.in ./
|
25
|
+
COPY ../weatherdb ./weatherdb
|
26
|
+
RUN --mount=source=../.git,target=/src/.git,type=bind \
|
27
|
+
pip install . --upgrade --upgrade-strategy only-if-needed --no-deps --no-cache-dir --root-user-action=ignore
|
28
|
+
|
29
|
+
# Copy the tests
|
30
|
+
COPY ../tests ./tests
|
@@ -0,0 +1,58 @@
|
|
1
|
+
services:
|
2
|
+
weatherdb:
|
3
|
+
build:
|
4
|
+
context: ..
|
5
|
+
dockerfile: docker/Dockerfile
|
6
|
+
depends_on:
|
7
|
+
- db
|
8
|
+
environment:
|
9
|
+
WEATHERDB_DB_HOST: db
|
10
|
+
WEATHERDB_DB_PORT: 5432
|
11
|
+
WEATHERDB_DB_DATABASE: weatherdb
|
12
|
+
WEATHERDB_DB_USER: postgres
|
13
|
+
WEATHERDB_DB_PASSWORD: /run/secrets/db_password
|
14
|
+
WEATHERDB_USER_CONFIG_FILE: /home/config_user.yaml
|
15
|
+
WEATHERDB_DATA_BASE_DIR: /home/data
|
16
|
+
WEATHERDB_HANDLE_NON_EXISTING_CONFIG: create
|
17
|
+
DOCKER_ENV: main
|
18
|
+
volumes:
|
19
|
+
- weatherdb_home:/home
|
20
|
+
command: ["sleep", "infinity"] # to keep awake
|
21
|
+
secrets:
|
22
|
+
- db_password
|
23
|
+
develop:
|
24
|
+
watch:
|
25
|
+
- action: rebuild
|
26
|
+
path: ../weatherdb
|
27
|
+
target: /src/weatherdb
|
28
|
+
- action: rebuild
|
29
|
+
path: ../MANIFEST.in
|
30
|
+
target: /src/MANIFEST.in
|
31
|
+
- action: rebuild
|
32
|
+
path: ../pyproject.toml
|
33
|
+
target: /src/pyproject.toml
|
34
|
+
- action: sync
|
35
|
+
path: ../tests
|
36
|
+
target: /src/tests
|
37
|
+
|
38
|
+
db:
|
39
|
+
image: postgis/postgis:16-3.4
|
40
|
+
environment:
|
41
|
+
POSTGRES_DB: weatherdb
|
42
|
+
POSTGRES_USER: postgres
|
43
|
+
POSTGRES_PASSWORD_FILE: /run/secrets/db_password
|
44
|
+
ports:
|
45
|
+
- 5454:5432
|
46
|
+
volumes:
|
47
|
+
- postgres_data:/var/lib/postgresql/data
|
48
|
+
secrets:
|
49
|
+
- db_password
|
50
|
+
volumes:
|
51
|
+
postgres_data:
|
52
|
+
weatherdb_home:
|
53
|
+
secrets:
|
54
|
+
db_password:
|
55
|
+
file: ./db_password.docker-secret
|
56
|
+
|
57
|
+
# start from parent folder with `docker compose -f docker\\docker-compose.yaml up --build`
|
58
|
+
# To connect to ther weatherdb service use `docker-compose exec weatherdb bash`
|
@@ -0,0 +1,24 @@
|
|
1
|
+
services:
|
2
|
+
weatherdb:
|
3
|
+
environment:
|
4
|
+
WEATHERDB_DB_DATABASE: weatherdb_test
|
5
|
+
WEATHERDB_USER_CONFIG_FILE: /home/config_user.yaml
|
6
|
+
WEATHERDB_LOGGING_HANDLER: console
|
7
|
+
WEATHERDB_LOGGING_LEVEL: DEBUG
|
8
|
+
WEATHERDB_HORIZON_RADIUS: 40000
|
9
|
+
DOCKER_ENV: test
|
10
|
+
WEATHERDB_HANDLE_NON_EXISTING_CONFIG: create
|
11
|
+
# command: ["python", "-m", "unittest", "discover", "tests"] # to run tests
|
12
|
+
|
13
|
+
db:
|
14
|
+
environment:
|
15
|
+
POSTGRES_DB: weatherdb_test
|
16
|
+
volumes: !reset []
|
17
|
+
|
18
|
+
|
19
|
+
# start with `docker compose -f docker-compose.yaml -f docker-compose_test.yaml up --build`
|
20
|
+
# To connect to ther weatherdb service use `docker-compose exec weatherdb bash`
|
21
|
+
# You can also comment out the command line and start the tests manualy via:
|
22
|
+
# `docker compose exec weatherdb python -m unittest discover tests`
|
23
|
+
# Or single tests with :
|
24
|
+
# `docker compose exec weatherdb python tests/test_setup.py EmptyDBTestCases.test_download_raw`
|
docs/requirements.txt
ADDED
docs/source/Changelog.md
ADDED
docs/source/License.rst
ADDED
docs/source/Methode.md
ADDED
@@ -0,0 +1,161 @@
|
|
1
|
+
# Method
|
2
|
+
|
3
|
+
Behind this package/website is a PostGreSQL-database. This database is build and updated with the same package, as for downloading the data. The only difference is, that the given connection in the user configuration needs to have write permissions for the database.
|
4
|
+
Therefor everyone can look into the code to find out exactly how the database creation works. But as an overview this page will give basic explanations of the processes behind it.
|
5
|
+
|
6
|
+
The timeseries for Temperature, Evapotranspiration and Precipitation are going through a 3-4 step process.The result of every process is saved and can get downloaded, with the corresponding abbreviation:
|
7
|
+
|
8
|
+
**Table 1: The 4 steps of the WeatherDB process, with their abbreviation and explanation**
|
9
|
+
| step | abreviation | explanation |
|
10
|
+
|:--:|:--:|--|
|
11
|
+
| 1 | raw | downloading the raw data |
|
12
|
+
| 2 | qc | quality check the data |
|
13
|
+
| 3 | fillup | fillup the data |
|
14
|
+
| 4 | corr | richter correct the values |
|
15
|
+
|
16
|
+
In the following chapters the processes will get explained furthermore.
|
17
|
+
|
18
|
+
## 1. downloading the data
|
19
|
+
|
20
|
+
The raw data is downloaded from the [DWD-CDC server](https://opendata.dwd.de/climate_environment/CDC/). The timeseries are downloaded and saved from the 1.1.1994 on. If there is historical data available for a measurement, they are preferred over recent values, because they are already quality checked a bit. The Temperature (T) and potential Evapotranspiration (ET) is downloaded on daily resolution. Where as the Precipitation (P) is downloaded as 10 minute and daily values, but only the 10 minute values are the basis for the downloads.
|
21
|
+
|
22
|
+
**Table 2: The downloaded raw data, resolution and their source**
|
23
|
+
| parameter | resolution | <div style="text-align: center">source</div> |
|
24
|
+
|:---:|:---:|---|
|
25
|
+
| Temperature | daily | <ul><li><div>DWD Climate Data Center (CDC):<br> Historical daily station observations (temperature, pressure, precipitation, sunshine duration, etc.) for Germany, version v21.3, 2021, <br>[online available](https://opendata.dwd.de/climate_environment/CDC/observations_germany/climate/daily/kl/historical/) </div></li><li><div>DWD Climate Data Center (CDC): <br>Recent daily station observations (temperature, pressure, precipitation, sunshine duration, etc.) for Germany, quality control not completed yet, version recent, <br>[online available](https://opendata.dwd.de/climate_environment/CDC/observations_germany/climate/daily/kl/recent/)</div></li></ul>||
|
26
|
+
| pot. Evapotranspiration | daily | <ul><li><div>DWD Climate Data Center: <br>Berechnete historische Tageswerte von charakteristischen Elementen aus dem Boden und dem Pflanzenbestand, historic values, Version v2, parameter "VPGFAO"<br>[online available](https://opendata.dwd.de/climate_environment/CDC/derived_germany/soil/daily/historical/) </div></li><li><div>DWD Climate Data Center: <br>Berechnete historische Tageswerte von charakteristischen Elementen aus dem Boden und dem Pflanzenbestand, recent values, Version v2, parameter "VPGFAO"<br>[online available](https://opendata.dwd.de/climate_environment/CDC/derived_germany/soil/daily/recent/)</div></li></ul>|
|
27
|
+
| Precipitation | 10 minutes | <ul><li><div>DWD Climate Data Center (CDC): <br>Historical 10-minute station observations of precipitation for Germany, version V1, 2019, <br>[online available](https://opendata.dwd.de/climate_environment/CDC/observations_germany/climate/10_minutes/precipitation/historical/)</div></li><li><div>DWD Climate Data Center (CDC): <br>Recent 10-minute station observations of precipitation for Germany,version recent, 2019, <br>[online available](https://opendata.dwd.de/climate_environment/CDC/observations_germany/climate/10_minutes/precipitation/recent)</div></li></ul>|
|
28
|
+
| Precipitation | daily | <ul><li><div>DWD Climate Data Center (CDC): <br>Historical daily station observations (temperature, pressure, precipitation, sunshine duration, etc.) for Germany, version v21.3, 2021, <br>[online available](https://opendata.dwd.de/climate_environment/CDC/observations_germany/climate/daily/kl/historical/) </div></li><li><div>DWD Climate Data Center (CDC): <br>Recent daily station observations (temperature, pressure, precipitation, sunshine duration, etc.) for Germany, quality control not completed yet, version recent, <br>[online available](https://opendata.dwd.de/climate_environment/CDC/observations_germany/climate/daily/kl/recent/)</div></li></ul>||
|
29
|
+
|
30
|
+
For computation improvements the downloaded files and their modification time is saved to the database, to be able to only download the updated data.
|
31
|
+
|
32
|
+
## 2. quality check
|
33
|
+
|
34
|
+
To quality check the data it is very dependent on which parameter is treated. Therefor this chapter is grouped into subchapters per parameter.
|
35
|
+
|
36
|
+
### Temperature and Evapotranspiration
|
37
|
+
|
38
|
+
For T and ET quality check the data is compared to the 5 nearest neighbors data.
|
39
|
+
To get the nearest stations, the selection is done on a yearly basis. For this neighbor stations having data for more than 6 months in that year are considered.
|
40
|
+
|
41
|
+
Furthermore also the difference in elevation between the two stations is considered to select the closest stations. This is done, because the topographie has a big influence on the Temperature and Evapotranspiration. The weighted distance is thereby calculated with the LARSIM formula:
|
42
|
+
|
43
|
+
$L_{gewichtet} = L_{horizontal} * (1 + (\frac{|\delta H|}{P_1})^{P_2})$
|
44
|
+
|
45
|
+
In Larsim those parameters are defined as $P_1 = 500$ and $P_2 = 1$.
|
46
|
+
<br>Stoelzle et al. (2016) found that $P_1 = 100$ and $P_2 = 4$ is better for Baden-Württemberg to consider the quick changes in topagraphie.
|
47
|
+
<br>or all of Germany, those parameter values are giving too much weight to the elevation difference, which can result in getting neighbor stations from the border of the Czech Republic for the Feldberg station. Therefor the values $P_1 = 250$ and $P_2 = 1.5$ are used as default values.
|
48
|
+
|
49
|
+
The data of every neighbor station is regionalized, based on the DWD grids (see chapter regionalisation), to the examined station. Then the mean value of those 5 values is taken to compare to the station data. If this mean value is too far away from the own value, then the measurement point is deleted.
|
50
|
+
|
51
|
+
**Table 3: Limits for the quality check of the T and ET measurements, when compared with neighbor stations**
|
52
|
+
| parameter | compare equation | lower limit | upper limit| treshold |
|
53
|
+
|:---:|:---:|:---:|:---:|:---:|
|
54
|
+
| Temperature | $\Delta T = T_{Stat} - \overline{T}_{neighbors}$ | $\Delta T < -5°C$ | $\Delta T > 5°C$ | $-50°C < T_{Stat} < 50°C$ |
|
55
|
+
| pot. Evapotranspiration | $\delta ET = \dfrac{ET_{Stat}}{\overline{ET}_{neighbors}}$ | $\begin{cases}\delta ET< 25\% \\ ET_{Stat}> 2 \frac{mm}{d}\end{cases}$|$\begin{cases}\delta ET> 200\% \\ ET_{Stat}> 3 \frac{mm}{d}\end{cases}$| $0\frac{mm}{d} =< ET_{Stat} < 200\frac{mm}{d}$ |
|
56
|
+
|
57
|
+
For the evapotranspiration there are two rules that need to be fulfilled to be unplausible. One relative and one nominal. This is because, low measurement values tend to have high relative differences and would then get deleted too often.
|
58
|
+
|
59
|
+
To consider the possible inversion weather phenomena, stations higher than 800 m.a.S. are only tested against the lower limit in winter months (October-March).
|
60
|
+
|
61
|
+
Furthermore there are maximum and minimum treshold values to which the ET and T values are compared to. Those treshold values are set to reasonable values for germany.
|
62
|
+
|
63
|
+
### Precipitation
|
64
|
+
|
65
|
+
The precipitation measurements must pass through multiple quality checks.
|
66
|
+
|
67
|
+
#### daily sum is zero
|
68
|
+
|
69
|
+
As some precipitation station (e.g. Feldberg station) have measurements of 0mm in the 10 minutes dataset even though the daily dataset has measurements. This is especially true for the measurement points in 20th and early 21th century. This is probably the result of new measurement equipment to measure the 10 minutes values, but without a good quality control. back then the daily values are often measured with other equipments and have a better quality check they are going through, so that the values are more reliable.
|
70
|
+
|
71
|
+
To filter those wrongly measurements of 0 mm out of the data, the data is compared to the daily values from the DWD at the same location. For this reason the daily measurements are first filled up (see next chapter). <br>
|
72
|
+
The 10 minutes measurements get aggregated to daily values. If this daily sum is 0 mm, even though the daily data from the DWD is not 0, all the 10 minutes measurements of that day are deleted. Furthermore if the daily measurement is more than twice the aggregated 10 minutes values, all the 10 minutes data of that day are removed.
|
73
|
+
|
74
|
+
This check is the only reason why the daily precipitation values were downloaded in the first place.
|
75
|
+
|
76
|
+
#### consecutive equal values
|
77
|
+
|
78
|
+
Sometimes there are several consecutive 10 minutes values that are exactly the same. As the accuracy of the measurement is 0.01 mm, this is very improbable to be a real measurement and is more likely the result of splitting e.g. an hourly value into 6 values.
|
79
|
+
|
80
|
+
It is assumed, that filling the measurements up with values from the neighbor stations is more accurate than this dissemination. Therefor 3 consecutive same measurements are deleted, if their "Qualitätsnorm" from the DWD is not 3 (meaning that the measurements didn't get a good quality control from the DWD).
|
81
|
+
|
82
|
+
#### treshold
|
83
|
+
|
84
|
+
Sometimes there are very high measurement values in the DWD data. Therefor a treshold of $50 mm / 10 min$ is applied. This treshold is higher then any KOSTRA 2020 precipitation with a return period of 100 years, which are around $30 mm / 10 min$. Values above this treshold are considered as erroneous.
|
85
|
+
|
86
|
+
Furthermore negativ values are filtered.
|
87
|
+
|
88
|
+
#### single peaks
|
89
|
+
|
90
|
+
Sometimes there are very high single peaks in the DWD raw data. As high precipitations are highly unprobable to happen only in one 10 minute range, those data points are regarded as faulty. More precisely data points higher than $5 mm / 10 min$ where there was no rain before and after the measurement is removed.
|
91
|
+
|
92
|
+
## 3. gap filling
|
93
|
+
|
94
|
+
To have complete timeseries, the gaps in the quality checked timeseries are filled with data from the neighbor stations. The neighboring stations are selected in the order of horizontal difference for the precipitation stations and in order of the elevation weighted distance (see chapter quality check - Temperature and Evapotranspiration) for T and ET stations. This is done by regionalising the neighbors measurements value to the station that is gap filled. Starting with the nearest neighbor station all available stations are taken until the timeserie is completely filled.
|
95
|
+
|
96
|
+
As the regionalised grids from the DWD have a coarse resolution with 1 km<sup>2</sup>, they got refined to a resolution of 25 meters, on the basis of a DEM25 (Copernicus). To refine the rasters the 1 km<sup>2</sup> DEM that was used by the DWD, was used. Together with the multi-annual raster value of the neighbor cells a linear regression is defined for every cell. The size of the window to produce the linear regression depends on the topology. Starting with a 5 x 5 km window, the standard deviation of the topology is computed. If this is smaller than 4 meters, than the window is increased by 1 km to each side. This step is repeated until the standard deviation is greater than 4 meters or the size of the window is greater than 13 x 13 km. This regression is then used on the DEM25 cells inside the 1 km<sup>2</sup> cell, to calculate the new multi-annual values.<br>
|
97
|
+
Those refined rasters got published under:
|
98
|
+
> Schmit, M., & Weiler, M. (2023). German weather services (DWD) multi annual meteorological rasters for the climate period 1991-2020 refined to 25m grid (1.0.0) [Data set]. Zenodo. [DOI:10.5281/zenodo.10066045](https://doi.org/10.5281/zenodo.10066045)
|
99
|
+
|
100
|
+
The used regionalisation grids, their original data and the corresponding refined raster from this source are listed in table 4.
|
101
|
+
|
102
|
+
**Table 4: The original raster grids from the DWD that are the basis for the regionalisation and their corresponding file in the refined dataset**
|
103
|
+
| parameter | original source | refined source |
|
104
|
+
|---|---|---|
|
105
|
+
| Precipitation | DWD Climate Data Center (CDC): <br>HYRAS grids of multi-annual precipitation, period 1991-2020, <br>[online available](https://opendata.dwd.de/climate_environment/CDC/grids_germany/multi_annual/hyras_de/precipitation/)| HYRAS_ma_1991_2020_DGM25.tif |
|
106
|
+
| Temperature | DWD Climate Data Center (CDC): <br>Multi-annual means of grids of air temperature (2m) over Germany, period 1991-2020, version v1.0. <br>[online available](https://opendata.dwd.de/climate_environment/CDC/grids_germany/multi_annual/air_temperature_mean)| DWD-grid_ma_1991_2020_DGM25.tif |
|
107
|
+
| potential Evapotranspiration | DWD Climate Data Center (CDC): <br>Multi-annual grids of potential evapotranspiration over grass, 0.x, period 1991-2020, <br>[online available](https://opendata.dwd.de/climate_environment/CDC/grids_germany/multi_annual/evapo_p)| DWD-grid_ma_1991_2020_DGM25.tif |
|
108
|
+
|
109
|
+
Then to get a regionalisation factor the multi-annual values of both stations are compared. For T and ET only the yearly mean is taken into account. For the precipitation one winter(October-March) and one summer (April-September) factor is computed. The following equation explain the calculation of the filling values for the different parameters, based on their multi-annual mean(ma).
|
110
|
+
|
111
|
+
$T_{fillup} = T_{neighbor} + (T_{station,ma}-T_{neighbor,ma})$
|
112
|
+
|
113
|
+
$ET_{fillup} = ET_{neighbor} * \dfrac{ET_{station,ma}}{ET_{neighbor,ma}}$
|
114
|
+
|
115
|
+
$N_{fillup} = \begin{cases}
|
116
|
+
N_{neighbor} * \dfrac{N_{station,ma,winter}}{N_{neighbor,ma,winter}} \space if\space month\in[4:9]\\
|
117
|
+
N_{neighbor} * \dfrac{N_{station,ma,summer}}{N_{neighbor,ma,summer}} \space if\space month\notin[4:9]
|
118
|
+
\end{cases}$
|
119
|
+
|
120
|
+
For the precipitation stations only stations within a 100 km radius are taken to fill missing values. For the potential Evapotranspiration and the temperature this radius is 150km. For the temperature stations the median of the regionalised values from the 5 closest stations (but not more than 150 km away) is taken to fill missing values.
|
121
|
+
|
122
|
+
### adjusting precipitation to daily station measurements
|
123
|
+
|
124
|
+
For the precipitation values the 10 minutes values are furthermore adjusted to the daily measurements. Therefor the daily sum is computed from the 10 minutes data. Then the quotient with the daily measurement is calculated and multiplied to every 10 minute measurement. So the difference to the daily measurement is added relatively to the measured value. In the end the gap filled 10 minutes precipitation values sum up to the same daily values as the daily values from the DWD.
|
125
|
+
|
126
|
+
But to prevent creating high peaks, there is an additional routine. If e.g. the neighbooring station has only one 10 minute measurement with rain, but the daily station measurement is high (e.g. $50mm/day$), this scaling routine would create a very high 10 minutes measurement ( in this example $50mm/10min$). To prevent this, the scalling can add at maximum $10mm/10min$ and is not allowed to create single peaks with more than $5mm/10min$ (see chapter about single peaks in the quality control chapter). If the scaling would exceed those tresholds, it is cutten to those tresholds, which has the side effect, that the daily measurement of that day isn't matching the 10 minute measurements anymore. But this is seen as the best compromise.
|
127
|
+
|
128
|
+
## 4. Richter correction
|
129
|
+
|
130
|
+
This step is only done for the 10 minutes precipitation values. Here the filled precipitation values, get corrected like defined in Richter (1995).
|
131
|
+
|
132
|
+
First of all, the horizon angle ("Horizontabschirmung") is calculated from a DGM25 and if the DGM25 was out of bound also from a DGM80. The DGM80 is bigger than the german border and therefor for stations around the border this is gives better results than the DGM20 which is only for the german territory. Therefore the rasters are sampled for their values on one single line of 75km, starting from the station. Then the angle to every point from the station is calculated. The Point with the biggest angle is taken as horizon angle for this line. This step is repeated for several lines ranging from north to south in 3° steps. Afterwards the Richter horizon angle is computed as:
|
133
|
+
|
134
|
+
$H’=0,15*H_{S-SW} + 0,35*H_{SW-W} +0,35*H_{W-NW} +0, 15*H_{NW-N}$
|
135
|
+
|
136
|
+
With this horizon angle the Richter exposition class is defined for every station.
|
137
|
+
|
138
|
+
Afterwards the daily correction is calculated with the following table and equation, based on the filled daily temperature at the station.
|
139
|
+
|
140
|
+
$\Delta N = b * N^E$
|
141
|
+
|
142
|
+
**Table 4: The Richter correction coeeficients. (Richter (1995) S. 67)**
|
143
|
+
|precipitation typ|temperature|E|b<br>no-protection|b<br>little-protection|b<br>protected|b<br>heavy-protection|
|
144
|
+
|:---:|:---:|:---:|:---:|:---:|:---:|:---:|
|
145
|
+
|precip_sommer|>= 3 °C | 0,38 | 0,345 | 0,31 | 0,28 | 0,245 |
|
146
|
+
|precip_winter| >= 3 °C | 0,46 | 0,34 | 0,28 | 0,24 | 0,19 |
|
147
|
+
|mix|-0,7 °C < T < 3 °C | 0,55 | 0,535 | 0,39 | 0,305 | 0,185 |
|
148
|
+
|snow|<= -0,7°C|0,82 | 0,72 | 0,51 | 0,33 | 0,21 |
|
149
|
+
|
150
|
+
The daily correction ($\Delta N$) is then distributed to every 10 minute measurement where precipitation was measured. So the daily correction is applied as a block to the 10 minutes values. This results in relatively high corrections, when there was only little precipitation and relatively low corrections when the measured precipitation was high. As the systematic error is mostly due to wind and has therefor more effect, when there is low precipitation, this approach is better than adding it relatively to the measurement.
|
151
|
+
|
152
|
+
<br>
|
153
|
+
|
154
|
+
-------------------------
|
155
|
+
|
156
|
+
## Sources
|
157
|
+
|
158
|
+
- Richter, D. 1995. Ergebnisse methodischer Untersuchungen zur Korrektur des systematischen Meßfehlers des Hellmann-Niederschlagsmessers. Offenbach am Main: Selbstverl. des Dt. Wetterdienstes.
|
159
|
+
- Copernicus. 2016. European Digital Elevation Model (EU-DEM), version 1.1. [online available](https://land.copernicus.eu/imagery-in-situ/eu-dem/eu-dem-v1.1)
|
160
|
+
- Stoelzle, Michael & Weiler, Markus & Steinbrich, Andreas. (2016) Starkregengefährdung in Baden-Württemberg – von der Methodenentwicklung zur Starkregenkartierung. Tag der Hydrologie.
|
161
|
+
- LARSIM Dokumentation, Stand 06.04.2023, online unter https://www.larsim.info/dokumentation/LARSIM-Dokumentation.pdf
|
Binary file
|
Binary file
|
docs/source/api/api.rst
ADDED
@@ -0,0 +1,15 @@
|
|
1
|
+
=============
|
2
|
+
API reference
|
3
|
+
=============
|
4
|
+
|
5
|
+
The API reference is organized in a python package structure and a CLI-API.
|
6
|
+
|
7
|
+
.. toctree::
|
8
|
+
:maxdepth: 1
|
9
|
+
|
10
|
+
Python package <weatherdb>
|
11
|
+
CLI <cli>
|
12
|
+
|
13
|
+
.. autosummary::
|
14
|
+
:toctree: _autosummary
|
15
|
+
:recursive:
|
docs/source/api/cli.rst
ADDED
@@ -0,0 +1,23 @@
|
|
1
|
+
db
|
2
|
+
==
|
3
|
+
|
4
|
+
In this module there are all the database setups and models used by the WeatherDB package, you shouldn't need to use them directly.
|
5
|
+
|
6
|
+
models
|
7
|
+
------
|
8
|
+
|
9
|
+
Those are the database models
|
10
|
+
|
11
|
+
.. automodule:: weatherdb.db.models
|
12
|
+
|
13
|
+
base models
|
14
|
+
^^^^^^^^^^^
|
15
|
+
|
16
|
+
.. autoclass:: weatherdb.db.models.ModelBase
|
17
|
+
|
18
|
+
.. autoclass:: weatherdb.db.models.MetaBase
|
19
|
+
|
20
|
+
.. autoclass:: weatherdb.db.models.MetaBaseQC
|
21
|
+
|
22
|
+
|
23
|
+
|
@@ -0,0 +1,22 @@
|
|
1
|
+
weatherdb
|
2
|
+
=========
|
3
|
+
|
4
|
+
|
5
|
+
.. toctree::
|
6
|
+
:maxdepth: 2
|
7
|
+
|
8
|
+
weatherdb.station
|
9
|
+
weatherdb.stations
|
10
|
+
weatherdb.broker
|
11
|
+
weatherdb.config
|
12
|
+
|
13
|
+
internal modules
|
14
|
+
----------------
|
15
|
+
|
16
|
+
Those modules are used internally by weatherDb and should not get used by the user.
|
17
|
+
|
18
|
+
.. toctree::
|
19
|
+
:maxdepth: 2
|
20
|
+
|
21
|
+
weatherdb.db
|
22
|
+
weatherdb.utils
|
@@ -0,0 +1,56 @@
|
|
1
|
+
station
|
2
|
+
-------
|
3
|
+
.. module:: weatherdb.station
|
4
|
+
|
5
|
+
StationP
|
6
|
+
^^^^^^^^
|
7
|
+
.. autoclass:: weatherdb.station.StationP
|
8
|
+
|
9
|
+
.. autoclasstoc::
|
10
|
+
|
11
|
+
StationT
|
12
|
+
^^^^^^^^
|
13
|
+
.. autoclass:: weatherdb.station.StationT
|
14
|
+
|
15
|
+
.. autoclasstoc::
|
16
|
+
|
17
|
+
StationET
|
18
|
+
^^^^^^^^^
|
19
|
+
|
20
|
+
.. autoclass:: weatherdb.station.StationET
|
21
|
+
|
22
|
+
.. autoclasstoc::
|
23
|
+
|
24
|
+
StationPD
|
25
|
+
^^^^^^^^^
|
26
|
+
.. autoclass:: weatherdb.station.StationPD
|
27
|
+
:exclude-members: quality_check, last_imp_quality_check, get_corr, get_adj, get_qc
|
28
|
+
|
29
|
+
.. autoclasstoc::
|
30
|
+
|
31
|
+
GroupStation
|
32
|
+
^^^^^^^^^^^^
|
33
|
+
.. autoclass:: weatherdb.station.GroupStation
|
34
|
+
|
35
|
+
.. autoclasstoc::
|
36
|
+
|
37
|
+
StationBase...
|
38
|
+
^^^^^^^^^^^^^^
|
39
|
+
Those are the base station classes on which the real station classes above depend on.
|
40
|
+
None of them is working on its own, because the class variables are not yet set correctly.
|
41
|
+
|
42
|
+
.. autoclass:: weatherdb.station.StationBases.StationBase
|
43
|
+
|
44
|
+
.. autoclasstoc::
|
45
|
+
|
46
|
+
.. autoclass:: weatherdb.station.StationBases.StationPBase
|
47
|
+
|
48
|
+
.. autoclasstoc::
|
49
|
+
|
50
|
+
.. autoclass:: weatherdb.station.StationBases.StationCanVirtualBase
|
51
|
+
|
52
|
+
.. autoclasstoc::
|
53
|
+
|
54
|
+
.. autoclass:: weatherdb.station.StationBases.StationTETBase
|
55
|
+
|
56
|
+
.. autoclasstoc::
|
@@ -0,0 +1,46 @@
|
|
1
|
+
stations
|
2
|
+
--------
|
3
|
+
.. module:: weatherdb.stations
|
4
|
+
|
5
|
+
StationsP
|
6
|
+
^^^^^^^^^
|
7
|
+
.. autoclass:: weatherdb.stations.StationsP
|
8
|
+
|
9
|
+
.. autoclasstoc::
|
10
|
+
|
11
|
+
StationsT
|
12
|
+
^^^^^^^^^
|
13
|
+
.. autoclass:: weatherdb.stations.StationsT
|
14
|
+
|
15
|
+
.. autoclasstoc::
|
16
|
+
|
17
|
+
StationsET
|
18
|
+
^^^^^^^^^^
|
19
|
+
.. autoclass:: weatherdb.stations.StationsET
|
20
|
+
|
21
|
+
.. autoclasstoc::
|
22
|
+
|
23
|
+
StationsPD
|
24
|
+
^^^^^^^^^^
|
25
|
+
.. autoclass:: weatherdb.stations.StationsPD
|
26
|
+
|
27
|
+
.. autoclasstoc::
|
28
|
+
|
29
|
+
GroupStations
|
30
|
+
^^^^^^^^^^^^^
|
31
|
+
.. autoclass:: weatherdb.stations.GroupStations
|
32
|
+
|
33
|
+
.. autoclasstoc::
|
34
|
+
|
35
|
+
StationsBase...
|
36
|
+
^^^^^^^^^^^^^^^
|
37
|
+
Those are the base stations classes on which the real stations classes above depend on.
|
38
|
+
None of them is working on its own, because the class variables are not yet set correctly.
|
39
|
+
|
40
|
+
.. autoclass:: weatherdb.stations.StationsBase.StationsBase
|
41
|
+
|
42
|
+
.. autoclasstoc::
|
43
|
+
|
44
|
+
.. autoclass:: weatherdb.stations.StationsBaseTET.StationsBaseTET
|
45
|
+
|
46
|
+
.. autoclasstoc::
|
@@ -0,0 +1,22 @@
|
|
1
|
+
utils
|
2
|
+
=====
|
3
|
+
|
4
|
+
In this module there are several utilities used by the WeatherDB package, you shouldn't need to use them directly.
|
5
|
+
|
6
|
+
.. autoclass:: weatherdb.utils.TimestampPeriod
|
7
|
+
|
8
|
+
dwd
|
9
|
+
---
|
10
|
+
.. automodule:: weatherdb.utils.dwd
|
11
|
+
|
12
|
+
geometry
|
13
|
+
--------
|
14
|
+
.. automodule:: weatherdb.utils.geometry
|
15
|
+
|
16
|
+
get_data
|
17
|
+
--------
|
18
|
+
.. automodule:: weatherdb.utils.get_data
|
19
|
+
|
20
|
+
logging
|
21
|
+
-------
|
22
|
+
.. automodule:: weatherdb.utils.logging
|