-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMain.R
64 lines (53 loc) · 2.61 KB
/
Main.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
### Aquatic Forecast Workflow ###
# devtools::install_github("eco4cast/neon4cast")
library(tidyverse)
library(neon4cast)
library(lubridate)
install.packages("rMR")
library(rMR)
forecast_date <- Sys.Date()
noaa_date <- Sys.Date() - days(1) #Need to use yesterday's NOAA forecast because today's is not available yet
#Step 0: Define team name and team members
team_info <- list(team_name = "air2waterSat_MCD",
team_list = list(list(individualName = list(givenName = "Mike",
surName = "Dietze"),
organizationName = "Boston University",
electronicMailAddress = "[email protected]"))
)
## Load required functions
if(file.exists("01_download_data.R")) source("01_download_data.R")
if(file.exists("02_calibrate_forecast.R")) source("02_calibrate_forecast.R")
if(file.exists("03_run_forecast.R")) source("03_run_forecast.R")
if(file.exists("04_submit_forecast.R")) source("04_submit_forecast.R")
### Step 1: Download Required Data
target <- download_targets() ## Y variables
site_data <- download_site_meta()
target <- merge_met_past(target) ## append met data (X) into target file
met_future <- download_met_forecast(forecast_date) ## Weather forecast (future X)
## visual check of data
ggplot(target, aes(x = temperature, y = air_temperature)) +
geom_point() +
labs(x = "NEON water temperature (C)", y = "NOAA air temperature (C)") +
facet_wrap(~site_id)
met_future %>%
ggplot(aes(x = datetime, y = air_temperature, group = parameter)) +
geom_line() +
facet_grid(~site_id, scale ="free")
### Step 2: Calibrate forecast model
model <- calibrate_forecast(target)
### Step 3: Make a forecast into the future
forecast <- run_forecast(model,met_future,site_data)
#Visualize forecast. Is it reasonable?
forecast %>%
ggplot(aes(x = datetime, y = prediction, group = parameter)) +
geom_line() +
facet_grid(variable~site_id, scale ="free")
### Step 4: Save and submit forecast and metadata
submit_forecast(forecast,team_info,submit=FALSE)
## aquatics-2024-02-14-air2waterSat_MCD.csv.gz
## ✔ file has model_id column✔ forecasted variables found correct variable + prediction column✔ file has correct family and parameter columns✔ file has site_id column✔ file has datetime column✔ file has correct datetime column
## Warning: file missing duration column (values for the column: daily = P1D,
## 30min = PT30M)
## Warning: file missing project_id column (use `neon4cast` as the project_id
## ✔ file has reference_datetime column
## Forecast format is valid