1
0
Fork 0
mirror of https://github.com/sensebox/opensensmapr synced 2025-02-22 14:53:57 +01:00
opensensmapR/inst/doc/intro-deutsch.html

661 lines
73 KiB
HTML
Raw Normal View History

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="generator" content="pandoc" />
<meta http-equiv="X-UA-Compatible" content="IE=EDGE" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<meta name="author" content="Jan Stenkamp" />
<meta name="date" content="2023-03-30" />
<title>Einführung in opensensmapR</title>
<script>// Pandoc 2.9 adds attributes on both header and div. We remove the former (to
// be compatible with the behavior of Pandoc < 2.8).
document.addEventListener('DOMContentLoaded', function(e) {
var hs = document.querySelectorAll("div.section[class*='level'] > :first-child");
var i, h, a;
for (i = 0; i < hs.length; i++) {
h = hs[i];
if (!/^h[1-6]$/i.test(h.tagName)) continue; // it should be a header h1-h6
a = h.attributes;
while (a.length > 0) h.removeAttribute(a[0].name);
}
});
</script>
<style type="text/css">
code{white-space: pre-wrap;}
span.smallcaps{font-variant: small-caps;}
span.underline{text-decoration: underline;}
div.column{display: inline-block; vertical-align: top; width: 50%;}
div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;}
ul.task-list{list-style: none;}
</style>
<style type="text/css">
code {
white-space: pre;
}
.sourceCode {
overflow: visible;
}
</style>
<style type="text/css" data-origin="pandoc">
pre > code.sourceCode { white-space: pre; position: relative; }
pre > code.sourceCode > span { display: inline-block; line-height: 1.25; }
pre > code.sourceCode > span:empty { height: 1.2em; }
.sourceCode { overflow: visible; }
code.sourceCode > span { color: inherit; text-decoration: inherit; }
div.sourceCode { margin: 1em 0; }
pre.sourceCode { margin: 0; }
@media screen {
div.sourceCode { overflow: auto; }
}
@media print {
pre > code.sourceCode { white-space: pre-wrap; }
pre > code.sourceCode > span { text-indent: -5em; padding-left: 5em; }
}
pre.numberSource code
{ counter-reset: source-line 0; }
pre.numberSource code > span
{ position: relative; left: -4em; counter-increment: source-line; }
pre.numberSource code > span > a:first-child::before
{ content: counter(source-line);
position: relative; left: -1em; text-align: right; vertical-align: baseline;
border: none; display: inline-block;
-webkit-touch-callout: none; -webkit-user-select: none;
-khtml-user-select: none; -moz-user-select: none;
-ms-user-select: none; user-select: none;
padding: 0 4px; width: 4em;
color: #aaaaaa;
}
pre.numberSource { margin-left: 3em; border-left: 1px solid #aaaaaa; padding-left: 4px; }
div.sourceCode
{ }
@media screen {
pre > code.sourceCode > span > a:first-child::before { text-decoration: underline; }
}
code span.al { color: #ff0000; font-weight: bold; }
code span.an { color: #60a0b0; font-weight: bold; font-style: italic; }
code span.at { color: #7d9029; }
code span.bn { color: #40a070; }
code span.bu { color: #008000; }
code span.cf { color: #007020; font-weight: bold; }
code span.ch { color: #4070a0; }
code span.cn { color: #880000; }
code span.co { color: #60a0b0; font-style: italic; }
code span.cv { color: #60a0b0; font-weight: bold; font-style: italic; }
code span.do { color: #ba2121; font-style: italic; }
code span.dt { color: #902000; }
code span.dv { color: #40a070; }
code span.er { color: #ff0000; font-weight: bold; }
code span.ex { }
code span.fl { color: #40a070; }
code span.fu { color: #06287e; }
code span.im { color: #008000; font-weight: bold; }
code span.in { color: #60a0b0; font-weight: bold; font-style: italic; }
code span.kw { color: #007020; font-weight: bold; }
code span.op { color: #666666; }
code span.ot { color: #007020; }
code span.pp { color: #bc7a00; }
code span.sc { color: #4070a0; }
code span.ss { color: #bb6688; }
code span.st { color: #4070a0; }
code span.va { color: #19177c; }
code span.vs { color: #4070a0; }
code span.wa { color: #60a0b0; font-weight: bold; font-style: italic; }
</style>
<script>
// apply pandoc div.sourceCode style to pre.sourceCode instead
(function() {
var sheets = document.styleSheets;
for (var i = 0; i < sheets.length; i++) {
if (sheets[i].ownerNode.dataset["origin"] !== "pandoc") continue;
try { var rules = sheets[i].cssRules; } catch (e) { continue; }
var j = 0;
while (j < rules.length) {
var rule = rules[j];
// check if there is a div.sourceCode rule
if (rule.type !== rule.STYLE_RULE || rule.selectorText !== "div.sourceCode") {
j++;
continue;
}
var style = rule.style.cssText;
// check if color or background-color is set
if (rule.style.color === '' && rule.style.backgroundColor === '') {
j++;
continue;
}
// replace div.sourceCode by a pre.sourceCode rule
sheets[i].deleteRule(j);
sheets[i].insertRule('pre.sourceCode{' + style + '}', j);
}
}
})();
</script>
<style type="text/css">body {
background-color: #fff;
margin: 1em auto;
max-width: 700px;
overflow: visible;
padding-left: 2em;
padding-right: 2em;
font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
font-size: 14px;
line-height: 1.35;
}
#TOC {
clear: both;
margin: 0 0 10px 10px;
padding: 4px;
width: 400px;
border: 1px solid #CCCCCC;
border-radius: 5px;
background-color: #f6f6f6;
font-size: 13px;
line-height: 1.3;
}
#TOC .toctitle {
font-weight: bold;
font-size: 15px;
margin-left: 5px;
}
#TOC ul {
padding-left: 40px;
margin-left: -1.5em;
margin-top: 5px;
margin-bottom: 5px;
}
#TOC ul ul {
margin-left: -2em;
}
#TOC li {
line-height: 16px;
}
table {
margin: 1em auto;
border-width: 1px;
border-color: #DDDDDD;
border-style: outset;
border-collapse: collapse;
}
table th {
border-width: 2px;
padding: 5px;
border-style: inset;
}
table td {
border-width: 1px;
border-style: inset;
line-height: 18px;
padding: 5px 5px;
}
table, table th, table td {
border-left-style: none;
border-right-style: none;
}
table thead, table tr.even {
background-color: #f7f7f7;
}
p {
margin: 0.5em 0;
}
blockquote {
background-color: #f6f6f6;
padding: 0.25em 0.75em;
}
hr {
border-style: solid;
border: none;
border-top: 1px solid #777;
margin: 28px 0;
}
dl {
margin-left: 0;
}
dl dd {
margin-bottom: 13px;
margin-left: 13px;
}
dl dt {
font-weight: bold;
}
ul {
margin-top: 0;
}
ul li {
list-style: circle outside;
}
ul ul {
margin-bottom: 0;
}
pre, code {
background-color: #f7f7f7;
border-radius: 3px;
color: #333;
white-space: pre-wrap;
}
pre {
border-radius: 3px;
margin: 5px 0px 10px 0px;
padding: 10px;
}
pre:not([class]) {
background-color: #f7f7f7;
}
code {
font-family: Consolas, Monaco, 'Courier New', monospace;
font-size: 85%;
}
p > code, li > code {
padding: 2px 0px;
}
div.figure {
text-align: center;
}
img {
background-color: #FFFFFF;
padding: 2px;
border: 1px solid #DDDDDD;
border-radius: 3px;
border: 1px solid #CCCCCC;
margin: 0 5px;
}
h1 {
margin-top: 0;
font-size: 35px;
line-height: 40px;
}
h2 {
border-bottom: 4px solid #f7f7f7;
padding-top: 10px;
padding-bottom: 2px;
font-size: 145%;
}
h3 {
border-bottom: 2px solid #f7f7f7;
padding-top: 10px;
font-size: 120%;
}
h4 {
border-bottom: 1px solid #f7f7f7;
margin-left: 8px;
font-size: 105%;
}
h5, h6 {
border-bottom: 1px solid #ccc;
font-size: 105%;
}
a {
color: #0033dd;
text-decoration: none;
}
a:hover {
color: #6666ff; }
a:visited {
color: #800080; }
a:visited:hover {
color: #BB00BB; }
a[href^="http:"] {
text-decoration: underline; }
a[href^="https:"] {
text-decoration: underline; }
code > span.kw { color: #555; font-weight: bold; }
code > span.dt { color: #902000; }
code > span.dv { color: #40a070; }
code > span.bn { color: #d14; }
code > span.fl { color: #d14; }
code > span.ch { color: #d14; }
code > span.st { color: #d14; }
code > span.co { color: #888888; font-style: italic; }
code > span.ot { color: #007020; }
code > span.al { color: #ff0000; font-weight: bold; }
code > span.fu { color: #900; font-weight: bold; }
code > span.er { color: #a61717; background-color: #e3d2d2; }
</style>
</head>
<body>
<h1 class="title toc-ignore">Einführung in opensensmapR</h1>
<h4 class="author">Jan Stenkamp</h4>
<h4 class="date">2023-03-30</h4>
<p>Das package opensensmapR kann dazu genutzt werden Daten von der <a href="https://opensensemap.org">openSenseMap</a> in R abzufragen und zu
analysieren. Damit lassen sich sowohl die Daten einzelner senseBoxen,
aber vor allem auch mehrere senseBoxen gleichzeitig analysieren.</p>
<div id="installation" class="section level3">
<h3>Installation</h3>
<p>Um das package in R zu nutzen, muss dieses zuerst installiert werden.
Das ist möglich mit dem Befehl
<code>install.packages(&#39;opensensmapr&#39;)</code>. Danach kann das package
geladen werden durch den Befehl <code>library(opensensmapr)</code>.</p>
</div>
<div id="alle-boxen-abfragen" class="section level3">
<h3>Alle Boxen abfragen</h3>
<p>Um einen Überblick über alle auf der openSenseMap registrierten Boxen
zu bekommen, kann man diese mit dem Befehl <code>osem_boxes()</code>
über die API beziehen. Außerdem werden die Boxen dabei automatisch
vorbereitet, um sie für weitere Analysen zu nutzen. Die Daten werden
dann in der Variablen <code>all_sensors</code> gespeichert, um diese
weiter zu verwenden.</p>
<div class="sourceCode" id="cb1"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb1-1"><a href="#cb1-1" aria-hidden="true" tabindex="-1"></a><span class="fu">library</span>(opensensmapr)</span>
<span id="cb1-2"><a href="#cb1-2" aria-hidden="true" tabindex="-1"></a>all_sensors <span class="ot">=</span> <span class="fu">osem_boxes</span>()</span></code></pre></div>
<p>Daraufhin ermöglicht die Funktion <code>summary(boxes)</code>, eine
Zusammenfassung der Metadaten aller Boxen anzuzeigen:</p>
<div class="sourceCode" id="cb2"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb2-1"><a href="#cb2-1" aria-hidden="true" tabindex="-1"></a><span class="fu">summary</span>(all_sensors)</span></code></pre></div>
<pre><code>## boxes total: 11589
##
## boxes by exposure:
## indoor mobile outdoor unknown
## 2435 598 8537 19
##
## boxes by model:
## custom hackair_home_v2 homeEthernet
## 2917 75 73
## homeEthernetFeinstaub homeV2Ethernet homeV2EthernetFeinstaub
## 55 20 40
## homeV2Lora homeV2Wifi homeV2WifiFeinstaub
## 248 595 751
## homeWifi homeWifiFeinstaub luftdaten_pms1003
## 214 223 9
## luftdaten_pms1003_bme280 luftdaten_pms3003 luftdaten_pms3003_bme280
## 10 1 7
## luftdaten_pms5003 luftdaten_pms5003_bme280 luftdaten_pms7003
## 7 61 6
## luftdaten_pms7003_bme280 luftdaten_sds011 luftdaten_sds011_bme280
## 81 287 3103
## luftdaten_sds011_bmp180 luftdaten_sds011_dht11 luftdaten_sds011_dht22
## 116 135 2555
##
## $last_measurement_within
## 1h 1d 30d 365d never
## 3659 3778 4319 6029 2094
##
## oldest box: 2016-08-09 19:34:42 (OBS Bohmte UK_02)
## newest box: 2023-03-29 17:40:59 (Test Nr.1)
##
## sensors per box:
## Min. 1st Qu. Median Mean 3rd Qu. Max.
## 1.00 4.00 5.00 5.02 5.00 76.00</code></pre>
<p>So werden hier unter anderem die Anzahl aller Boxen in dem Datensatz
(<code>boxes total</code>), die Anzahl der Boxen die Messungen in
verschiedenen Zeitintervallen durchgeführt haben
(<code>$last_measurement_within</code>) und die zuletzt erstellte Box
dargestellt (<code>newest_box</code>).</p>
<p>Mit der Funktion <code>plot(boxes)</code> können wir dann auch noch
alle Stationen auf einer Karte anzeigen.</p>
<div class="sourceCode" id="cb4"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb4-1"><a href="#cb4-1" aria-hidden="true" tabindex="-1"></a><span class="fu">plot</span>(all_sensors)</span></code></pre></div>
<p><img src="
<p>Die Funktion <code>osem_phenomena(boxes)</code> gibt uns außerdem
Informationen darüber, welche Phänomene von den Stationen gemessen
werden.</p>
<div class="sourceCode" id="cb5"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb5-1"><a href="#cb5-1" aria-hidden="true" tabindex="-1"></a>phenoms <span class="ot">=</span> <span class="fu">osem_phenomena</span>(all_sensors)</span>
<span id="cb5-2"><a href="#cb5-2" aria-hidden="true" tabindex="-1"></a><span class="fu">str</span>(phenoms)</span></code></pre></div>
<pre><code>## List of 3640
## $ Temperatur : int 9560
## $ rel. Luftfeuchte : int 8436
## $ PM10 : int 8239
## $ PM2.5 : int 8224
## $ Luftdruck : int 5776
## $ Beleuchtungsstärke : int 1712
## $ UV-Intensität : int 1700
## $ Temperature : int 663
## $ Humidity : int 489
## $ VOC : int 432
## $ Lufttemperatur : int 373
## $ Luftfeuchte : int 371
## $ CO₂ : int 325
## $ Pressure : int 308
## $ Bodenfeuchte : int 302
## $ Luftfeuchtigkeit : int 275
## $ Lautstärke : int 255
## $ atm. Luftdruck : int 251
## $ PM01 : int 213
## $ Bodentemperatur : int 163
## $ IAQ : int 162
## $ Kalibrierungswert : int 156
## $ rel. Luftfeuchte SCD30 : int 156
## $ Temperatur SCD30 : int 154
## $ CO2eq : int 153
## $ Windgeschwindigkeit : int 153
## $ pH-Wert : int 143
## $ Gesamthärte : int 142
## $ Blei : int 140
## $ Eisen : int 140
## $ Gesamthärte 2 : int 140
## $ Kupfer C : int 140
## $ Kupfer D : int 140
## $ Kupfer1 : int 140
## $ Kupfer2 : int 140
## $ Nitrat : int 140
## $ Nitrit : int 140
## $ GesamthaerteLabor : int 120
## $ CO2 : int 118
## $ Feinstaub PM10 : int 101
## $ Windrichtung : int 82
## $ rel. Luftfeuchte (HECA) : int 78
## $ Temperatur (HECA) : int 76
## $ Helligkeit : int 70
## $ Temperatura : int 69
## $ Feinstaub PM2.5 : int 68
## $ Taupunkt : int 62
## $ Latitude : int 61
## $ Longtitude : int 58
## $ Durchschnitt Umgebungslautstärke : int 51
## $ Minimum Umgebungslautstärke : int 51
## $ UV-Index : int 49
## $ temperature : int 49
## $ Batterie : int 46
## $ Feinstaub PM1.0 : int 44
## $ Umgebungslautstärke : int 41
## $ humidity : int 41
## $ UV : int 40
## $ Abstand nach links : int 34
## $ Beschleunigung Z-Achse : int 34
## $ Beschleunigung X-Achse : int 33
## $ Beschleunigung Y-Achse : int 33
## $ Geschwindigkeit : int 33
## $ Niederschlag : int 33
## $ PM1 : int 33
## $ Feinstaub PM25 : int 32
## $ PM1.0 : int 32
## $ Relative Humidity : int 32
## $ Abstand nach rechts : int 31
## $ rel. Luftfeuchtigkeit : int 30
## $ Sonnenstrahlung : int 29
## $ Luftdruck relativ : int 28
## $ Luftdruck absolut : int 26
## $ Rain : int 26
## $ Regenrate : int 26
## $ CO2 Konzentration : int 25
## $ RSSI : int 22
## $ gefühlte Temperatur : int 22
## $ Battery : int 21
## $ PM 2.5 : int 21
## $ Ciśnienie : int 20
## $ EisenLabor : int 20
## $ Air Pressure : int 19
## $ PM4 : int 19
## $ Regen : int 19
## $ Schall : int 19
## $ Signal : int 19
## $ UV Index : int 19
## $ Ilmanpaine : int 18
## $ Lämpötila : int 18
## $ Wind Direction : int 18
## $ Wind speed : int 18
## $ PM 10 : int 17
## $ Air pressure : int 16
## $ Altitude : int 16
## $ Illuminance : int 16
## $ Power Supply : int 16
## $ Temperatur DHT22 : int 16
## $ Wind Speed : int 16
## [list output truncated]</code></pre>
</div>
<div id="daten-filtern" class="section level3">
<h3>Daten filtern</h3>
<p>Mit PM10 als einem der am häufigsten gemessenen Phänomene, wollen wir
nun weiterarbeiten. Dazu können wir zum Beispiel mit den folgenden
Parametern, nur die Boxen abfragen, die PM10 gemessen haben. Dabei wird
die Abfrage durch das setzen der Parameter in der Klammer wie folgt
gefiltert:</p>
<ul>
<li><code>exposure = &#39;outdoor&#39;</code> : gib nur Boxen zurück die draußen
stehen.</li>
<li><code>date = Sys.time()</code> : gib nur Boxen zurück, die zum Datum
Sys.time() (+-4 Stunden) eine Messung geschickt haben. Sys.time() steht
dabei für die aktuelle Zeit.</li>
<li><code>phenomenon = &#39;PM10&#39;</code> : gib nur Boxen zurück, die einen
PM10 Sensor haben.</li>
</ul>
<p>Die Abfrage der gefilterten Boxen kann ggfs. ein paar Minuten dauern,
da die openSenseMap API zuerst die prall gefüllte Datenbank entsprechend
filtern muss.</p>
<div class="sourceCode" id="cb7"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb7-1"><a href="#cb7-1" aria-hidden="true" tabindex="-1"></a>pm10_sensors <span class="ot">=</span> <span class="fu">osem_boxes</span>(</span>
<span id="cb7-2"><a href="#cb7-2" aria-hidden="true" tabindex="-1"></a> <span class="at">exposure =</span> <span class="st">&#39;outdoor&#39;</span>,</span>
<span id="cb7-3"><a href="#cb7-3" aria-hidden="true" tabindex="-1"></a> <span class="at">date =</span> <span class="fu">Sys.time</span>(), <span class="co"># ±4 hours</span></span>
<span id="cb7-4"><a href="#cb7-4" aria-hidden="true" tabindex="-1"></a> <span class="at">phenomenon =</span> <span class="st">&#39;PM10&#39;</span></span>
<span id="cb7-5"><a href="#cb7-5" aria-hidden="true" tabindex="-1"></a>)</span></code></pre></div>
<p>Auch von den gefilterten Daten können wir uns wieder die
Zusammenfassung und eine Karte anschauen:</p>
<div class="sourceCode" id="cb8"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb8-1"><a href="#cb8-1" aria-hidden="true" tabindex="-1"></a><span class="fu">summary</span>(pm10_sensors)</span></code></pre></div>
<pre><code>## boxes total: 3009
##
## boxes by exposure:
## outdoor
## 3009
##
## boxes by model:
## custom hackair_home_v2 homeEthernetFeinstaub
## 172 7 13
## homeV2EthernetFeinstaub homeV2Lora homeV2Wifi
## 7 23 2
## homeV2WifiFeinstaub homeWifi homeWifiFeinstaub
## 125 2 30
## luftdaten_pms1003 luftdaten_pms1003_bme280 luftdaten_pms5003
## 1 4 3
## luftdaten_pms5003_bme280 luftdaten_pms7003 luftdaten_pms7003_bme280
## 11 2 30
## luftdaten_sds011 luftdaten_sds011_bme280 luftdaten_sds011_bmp180
## 110 1382 60
## luftdaten_sds011_dht11 luftdaten_sds011_dht22
## 40 985
##
## $last_measurement_within
## 1h 1d 30d 365d never
## 2985 3009 3009 3009 0
##
## oldest box: 2017-03-03 18:20:43 (Witten Heven Dorf)
## newest box: 2023-03-26 17:59:20 (airRohr)
##
## sensors per box:
## Min. 1st Qu. Median Mean 3rd Qu. Max.
## 2.000 4.000 5.000 4.849 5.000 29.000</code></pre>
<div class="sourceCode" id="cb10"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb10-1"><a href="#cb10-1" aria-hidden="true" tabindex="-1"></a><span class="fu">plot</span>(pm10_sensors)</span></code></pre></div>
<p><img src="
<p>Wie man sieht, sind jetzt alle Stationen outdoor und es gibt keine
Station mehr, die noch nie eine Messung durchgeführt hat. Das liegt an
den Parametern, die wir bei der Abfrage der Daten in der Funktion
gesetzt haben; alle Stationen sollten draußen sein und vor kurzem eine
Messung geschickt haben.</p>
</div>
<div id="daten-analysieren" class="section level3">
<h3>Daten analysieren</h3>
<p>Bis jetzt haben wir uns ja nur die Stationen angeschaut. Nun wollen
wir auch einen genaueren Blick auf die eigentlichen Messungen werfen.
Die Messungen die an die openSenseMap geschickt werden, können wir mit
der Funktion <code>osem_measurements()</code> abfragen.</p>
<p>Auch dabei können wir verschiedene Filter setzen. Unter anderem
wollen wir nur Messungen von Stationen in der Nähe von Münster erhalten.
Dazu erstellen wir zunächst ein Objekt, dass die Koordinaten von Münster
enthält:</p>
<div class="sourceCode" id="cb11"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb11-1"><a href="#cb11-1" aria-hidden="true" tabindex="-1"></a><span class="co"># Zunächst werden ein paar Pakete geladen, die es uns ermöglichen mit den räumlichen Daten zu arbeiten</span></span>
<span id="cb11-2"><a href="#cb11-2" aria-hidden="true" tabindex="-1"></a><span class="fu">library</span>(sf)</span>
<span id="cb11-3"><a href="#cb11-3" aria-hidden="true" tabindex="-1"></a><span class="fu">library</span>(units)</span>
<span id="cb11-4"><a href="#cb11-4" aria-hidden="true" tabindex="-1"></a><span class="fu">library</span>(lubridate)</span>
<span id="cb11-5"><a href="#cb11-5" aria-hidden="true" tabindex="-1"></a><span class="fu">library</span>(dplyr)</span>
<span id="cb11-6"><a href="#cb11-6" aria-hidden="true" tabindex="-1"></a><span class="co"># Dann erstellen wir eine sogenannte Boundingbox, in unserem Fall ein 20 km x 20 km Quadrat um das Zentrum von Münster.</span></span>
<span id="cb11-7"><a href="#cb11-7" aria-hidden="true" tabindex="-1"></a>muenster <span class="ot">=</span> <span class="fu">st_point</span>(<span class="fu">c</span>(<span class="fl">7.63</span>, <span class="fl">51.95</span>)) <span class="sc">%&gt;%</span> <span class="co"># Koordinate Münster Zentrum</span></span>
<span id="cb11-8"><a href="#cb11-8" aria-hidden="true" tabindex="-1"></a> <span class="fu">st_sfc</span>(<span class="at">crs =</span> <span class="dv">4326</span>) <span class="sc">%&gt;%</span> <span class="co"># Koordinatensystem für geographische Koordinaten</span></span>
<span id="cb11-9"><a href="#cb11-9" aria-hidden="true" tabindex="-1"></a> <span class="fu">st_transform</span>(<span class="dv">3857</span>) <span class="sc">%&gt;%</span> <span class="co"># Koordinatensystem das Meter versteht</span></span>
<span id="cb11-10"><a href="#cb11-10" aria-hidden="true" tabindex="-1"></a> <span class="fu">st_buffer</span>(<span class="fu">set_units</span>(<span class="dv">10</span>, km)) <span class="sc">%&gt;%</span> <span class="co"># 10 km Radius um Münster</span></span>
<span id="cb11-11"><a href="#cb11-11" aria-hidden="true" tabindex="-1"></a> <span class="fu">st_transform</span>(<span class="dv">4326</span>) <span class="sc">%&gt;%</span> <span class="co"># Wieder Umwandlung in geographische Koordinaten, welche die openSenseMap API erwartet</span></span>
<span id="cb11-12"><a href="#cb11-12" aria-hidden="true" tabindex="-1"></a> <span class="fu">st_bbox</span>() <span class="co"># erstellen eines boundingbox objektes</span></span></code></pre></div>
<p><code>osem_measurements()</code> nimmt ähnliche Parameter wie
<code>osem_boxes()</code> entgegen.</p>
<ul>
<li><code>bbox = muenster</code> : Gib nur Messungen von Boxen zurück,
die innerhalb unserer boundingbox liegen.</li>
<li><code>phenomenon = &#39;PM10&#39;</code> : Gib nur PM10 Messungen
zurück.</li>
<li><code>from = now() - days(3)</code>: Gib Messungen zurück, die nicht
älter als drei Tage sind.</li>
<li><code>to = now()</code> : Gib nur Messungen zurück, die bis jetzt
gemessen wurden.</li>
</ul>
<p>Hierbei ersetzen die Parameter <code>from</code> und <code>to</code>,
den Parameter <code>date</code>, den wir zuvor in der Funktion
<code>osem_boxes()</code> benutzt haben. Beide Arten von Datumsfilter,
können in beiden Funktionen genutzt werden.</p>
<div class="sourceCode" id="cb12"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb12-1"><a href="#cb12-1" aria-hidden="true" tabindex="-1"></a>pm10_muenster <span class="ot">=</span> <span class="fu">osem_measurements</span>(</span>
<span id="cb12-2"><a href="#cb12-2" aria-hidden="true" tabindex="-1"></a> muenster, </span>
<span id="cb12-3"><a href="#cb12-3" aria-hidden="true" tabindex="-1"></a> <span class="at">phenomenon =</span> <span class="st">&#39;PM10&#39;</span>,</span>
<span id="cb12-4"><a href="#cb12-4" aria-hidden="true" tabindex="-1"></a> <span class="at">from =</span> <span class="fu">now</span>() <span class="sc">-</span> <span class="fu">days</span>(<span class="dv">3</span>), <span class="co"># defaults to 2 days</span></span>
<span id="cb12-5"><a href="#cb12-5" aria-hidden="true" tabindex="-1"></a> <span class="at">to =</span> <span class="fu">now</span>()</span>
<span id="cb12-6"><a href="#cb12-6" aria-hidden="true" tabindex="-1"></a>)</span></code></pre></div>
<p>Die PM10-Messungen können wir nun einfach als Zeitreihe
darstellen:</p>
<div class="sourceCode" id="cb13"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb13-1"><a href="#cb13-1" aria-hidden="true" tabindex="-1"></a><span class="fu">plot</span>(pm10_muenster)</span></code></pre></div>
<p><img src="
<p>Jeder Punkt stellt hier eine Messung dar und jede Box hat eine andere
Farbe. Wie man sieht sind die meisten Messungen unter einem Wert von 50,
jedoch gibt es auch ein paar Ausreißer und eine Station die dauerhaft
Werte um 150 misst.</p>
<p>Für weitere Beispiele lohnt sich ein Blick in die folgenden
Dokumente: - <a href="https://github.com/sensebox/opensensmapR/blob/master/inst/doc/osem-history_revised.html" class="uri">https://github.com/sensebox/opensensmapR/blob/master/inst/doc/osem-history_revised.html</a>
- <a href="https://sensebox.github.io/opensensmapR/inst/doc/osem-intro.html" class="uri">https://sensebox.github.io/opensensmapR/inst/doc/osem-intro.html</a></p>
</div>
<!-- code folding -->
<!-- dynamically load mathjax for compatibility with self-contained -->
<script>
(function () {
var script = document.createElement("script");
script.type = "text/javascript";
script.src = "https://mathjax.rstudio.com/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML";
document.getElementsByTagName("head")[0].appendChild(script);
})();
</script>
</body>
</html>