Updating meteorological forecasts, part 1
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.
As Mark Twain said “the
art of prophecy is very difficult, especially about the future” (well, actually I am not sure Mark Twain was the first one to say so,
but if you’re interested by that sentence, you can look here). I have been rather surprised to see how Canadians can
be interested in weather, and weather forecasts (see e.g. here for a
first study). For instance, on that website (here),
we can have forecasts of the temperature (but also rain and wind, which
is interesting when you ride a bike) over the next week, almost on an
hourly basis (I show here only GFS forecasts (Global Forecast System,here), which is quite standard, see here or there, but other meteorological models are considered on the website)
data:image/s3,"s3://crabby-images/200c6/200c6efd76af5496e4ae83358ceb32d8f4c81199" alt=""
So, to look at this problem, Vincent (alias @Vicnent) helped me (again, since he helped me already to get backups of betting websites during the soccer world cup, in June) to make backups of those tables…
- A descriptive study
data:image/s3,"s3://crabby-images/5bdd4/5bdd433f11bf9e2698d050bc734e97574ca73660" alt=""
Here, it is difficult to observe the scatterplot of temperature,
donnees=read.table("http://perso.univ-rennes1.fr/ arthur.charpentier/pred-meteo2.txt") x=donnees$DATE1+donnees$HEURE1/24 x[x<15]=x[x<15]+31 y=donnees$DATE2+donnees$HEURE2/24 y[y<15]=y[y<15]+31 z=y-x h=donnees$TEMPERATURE D=data.frame(x,y,z,h) X0=sort(unique(x)) Y0=sort(unique(y)) Z0=sort(unique(z)) matY.X=matrix(NA,length(X0),length(Y0)) library(splines) for(i in 1:length(X0)){ dd=D[D$x==X0[i],] ax=dd$y ay=dd$h a=data.frame(ax,ay) ra=lm(ay~bs(ax,df=5),data=ba) X=Y0[(Y0>min(ax))&(Y0<max(ax))] iX=which((Y0>min(ax))&(Y0<max(ax))) Y=predict(ra,newdata=data.frame(ax=X)) matY.X[i,iX]=Y }So, let us look at levels of iso-temperature, as a function of the date the prediction is made (the x-axis) and the horizon (the y-axis). First, we we fix the date of the prediction, we get (from the code above)
- Modeling predicted temperatures
data:image/s3,"s3://crabby-images/c6c3f/c6c3f4ed1d1adf51f17f8eae2a1c4e77bdda1555" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp01.png"
data:image/s3,"s3://crabby-images/53bb1/53bb186fe3eeec7fd33ac712c1e38c252c75d83a" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp0x.png"
data:image/s3,"s3://crabby-images/0428c/0428c214f3941bea3892e8bab49207edd6da9c33" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp0y.png"
data:image/s3,"s3://crabby-images/cd9f2/cd9f25efc31f67bc7228fe0c725a30a0ecfbd60f" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp02.png"
library(mgcv) library(splines) REG1=gam(h~s(x,y),data=D,family=gaussian) REG2=lm(h~bs(x)+bs(y),data=D) REG3=gam(h~s(x)+s(y),data=D,family=gaussian) REG4=gam(h~s(x)+s(y),data=D,family=gaussian(link="log")) REG5=gam(h~s(y),data=D,family=gaussian) D$e=residuals(REG5) REG6=gam(e~s(x,y),data=D,family=gaussian)Here is the prediction we had with the additive model
data:image/s3,"s3://crabby-images/51d01/51d014a145230cabf8cd5d6ae21e9668c000ef9f" alt=""
(colors are different because of the log scaling but the shape is similar).
For the component ondata:image/s3,"s3://crabby-images/53bb1/53bb186fe3eeec7fd33ac712c1e38c252c75d83a" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp0x.png"
data:image/s3,"s3://crabby-images/0428c/0428c214f3941bea3892e8bab49207edd6da9c33" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp0y.png"
data:image/s3,"s3://crabby-images/f9a63/f9a63088c0dc5413dc221d42e9465bb6e20babd7" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp04.png"
data:image/s3,"s3://crabby-images/0428c/0428c214f3941bea3892e8bab49207edd6da9c33" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp0y.png"
data:image/s3,"s3://crabby-images/46cc5/46cc50cf675799f24daf7d50760ec489436252a3" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp05.png"
data:image/s3,"s3://crabby-images/94b41/94b41f0a1d7eadaff842f1d6bdc1f1dce9626b38" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp07.png"
data:image/s3,"s3://crabby-images/56dda/56dda775e80238d1738fbd99b5e787146dfc0ef5" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp06.png"
data:image/s3,"s3://crabby-images/cb617/cb6179febc1fd47ae8eea7c5c86d44bffe1791ca" alt="http://perso.univ-rennes1.fr/arthur.charpentier/latex/predictemp0h.png"
* perhaps I should mention that we do not have backups of tables, but backups of html pages... then I use simple linguistic tools available on R to extract the information where it should be....
R-bloggers.com offers daily e-mail updates about R news and tutorials about learning R and many other topics. Click here if you're looking to post or find an R/data-science job.
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.