inst/doc/nsRFA_ex02.R

### R code from vignette source 'nsRFA_ex02.Rnw'

###################################################
### code chunk number 1: nsRFA_ex02.Rnw:38-39
###################################################
library(nsRFA)


###################################################
### code chunk number 2: nsRFA_ex02.Rnw:42-43
###################################################
data(FEH1000)


###################################################
### code chunk number 3: nsRFA_ex02.Rnw:46-48 (eval = FALSE)
###################################################
## ls()
## help(FEH1000)


###################################################
### code chunk number 4: nsRFA_ex02.Rnw:56-65
###################################################
n <- tapply(am[,4],am[,1],length)
urbext <- cd[,"urbext1990"]
area <- cd[,"dtm_area"]
cd696 <- cd[(!is.nan(cd[,"dtm_area"]))&(!is.nan(cd[,"saar"]))&
            (!is.nan(cd[,"bfihost"]))&(n>7)&(urbext<0.025)&(area>0.5),]

fac <- factor(am[,"number"],levels=cd696[,"number"])
am696 <- am[!is.na(fac),]
#nlevels(as.factor(am696[,"number"]))


###################################################
### code chunk number 5: nsRFA_ex02.Rnw:74-78
###################################################
layout(matrix(c(1,2,3), 1, 3))
plot(cd696[c("dtm_area","saar")], pch=".", cex=2, log="x")
plot(cd696[c("dtm_area","bfihost")], pch=".", cex=2, log="x")
plot(cd696[c("saar","bfihost")], pch=".", cex=2)


###################################################
### code chunk number 6: nsRFA_ex02.Rnw:91-93
###################################################
Lmomenti696 <- t(sapply(split(am696[,4],am696[,1]),Lmoments))
Di <- discordancy(am696[,"am"], am696[,"number"])


###################################################
### code chunk number 7: nsRFA_ex02.Rnw:99-105
###################################################
par(mfrow=c(1,2))
 plot(Lmomenti696[,c("lca","lcv")],xlab="L-CA",ylab="L-CV",pch=".",cex=2); grid()
 points(Lmomenti696[(Di>3),c("lca","lcv")],pch=19,cex=.7)
 plot(Lmomenti696[,c("lca","lkur")],xlab="L-CA",ylab="L-kur",pch=".",cex=2); grid()
 points(Lmomenti696[(Di>3),c("lca","lkur")],pch=19,cex=.7)
par(mfrow=c(1,1))


###################################################
### code chunk number 8: nsRFA_ex02.Rnw:120-123
###################################################
sd(log(cd696[,"dtm_area"])) # 1.345515 (vs 1.34)
sd(log(cd696[,"saar"]))     # 0.38534 (vs 0.38)
sd(cd696[,"bfihost"])       # 0.1485239 (vs 0.15)


###################################################
### code chunk number 9: nsRFA_ex02.Rnw:125-133
###################################################
AREAterm <- log(cd696[,"dtm_area"])/(sd(log(cd696[,"dtm_area"]))*sqrt(2))
SAARterm <- log(cd696[,"saar"])/sd(log(cd696[,"saar"]))
BFIHOSTterm <- cd696[,"bfihost"]/sd(cd696[,"bfihost"])

distFEH <- dist(cbind(AREAterm,SAARterm,BFIHOSTterm))

roi.cd <- data.frame(cbind(AREAterm,SAARterm,BFIHOSTterm))
row.names(roi.cd) <- cd696[,"number"]


###################################################
### code chunk number 10: nsRFA_ex02.Rnw:136-144 (eval = FALSE)
###################################################
## roi01.50year <- new.env()
## for(i in 1:696) {
##  print(paste(i,"/ 696"))
##  assign(as.character(row.names(roi.cd)[i]), roi.st.year(roi.cd[i,],as.data.frame(roi.cd),
##      row.names(roi.cd),am696[,"am"],am696[,"number"],test="HW",station.year=250,Nsim=100), 
##      env=roi01.50year)
## }
## roi01.50year <- as.list(roi01.50year)


###################################################
### code chunk number 11: nsRFA_ex02.Rnw:146-148
###################################################
estrai.region <- function (x) {x$region}
estrai.test <- function (x) {x$test}


###################################################
### code chunk number 12: nsRFA_ex02.Rnw:150-156 (eval = FALSE)
###################################################
## regioni.50year <- sapply(roi01.50year, estrai.region)
## test.50year <- sapply(roi01.50year, estrai.test)
## mL.50year <- mean(sapply(regioni.50year,length)) #  11.2
## mH2.50year <- mean(test.50year["H2",]) #   1.53
## gH2gr2.50year <- sum(test.50year["H2",]>2)/696 #   0.34
## gH2gr4.50year <- sum(test.50year["H2",]>4)/696 #   0.07


###################################################
### code chunk number 13: nsRFA_ex02.Rnw:159-167 (eval = FALSE)
###################################################
## roi01.100year <- new.env()
## for(i in 1:696) {
##  print(paste(i,"/ 696"))
##  assign(as.character(row.names(roi.cd)[i]), roi.st.year(roi.cd[i,],as.data.frame(roi.cd),
##      row.names(roi.cd),am696[,"am"],am696[,"number"],test="HW",station.year=500,Nsim=100), 
##      env=roi01.100year)
## }
## roi01.100year <- as.list(roi01.100year)


###################################################
### code chunk number 14: nsRFA_ex02.Rnw:169-175 (eval = FALSE)
###################################################
## regioni.100year <- sapply(roi01.100year, estrai.region)
## test.100year <- sapply(roi01.100year, estrai.test)
## mL.100year <- mean(sapply(regioni.100year,length)) #  21.8
## mH2.100year <- mean(test.100year["H2",]) #   2.19
## gH2gr2.100year <- sum(test.100year["H2",]>2)/696 #   0.52
## gH2gr4.100year <- sum(test.100year["H2",]>4)/696 #   0.15


###################################################
### code chunk number 15: nsRFA_ex02.Rnw:178-184 (eval = FALSE)
###################################################
## table16.2 <- data.frame(signif(rbind(c(mL.50year,mH2.50year,
##                                        gH2gr2.50year*100,gH2gr4.50year*100),
##               c(mL.100year,mH2.100year,gH2gr2.100year*100,gH2gr4.100year*100)),3), 
##               row.names=c("50-year","100-year"))
## names(table16.2) <- c("Avg. n sites","m(H2)","% H2>2","% H2>4")
## print(table16.2)


###################################################
### code chunk number 16: nsRFA_ex02.Rnw:186-190
###################################################
table16.2 <- data.frame(signif(rbind(c(11.2,1.53,0.34*100,0.07*100),
              c(21.8,2.19,0.52*100,0.15*100)),3), row.names=c("50-year","100-year"))
names(table16.2) <- c("Avg. n sites","m(H2)","% H2>2","% H2>4")
print(table16.2)


###################################################
### code chunk number 17: nsRFA_ex02.Rnw:196-201
###################################################
prova54088 <- roi.st.year(roi.cd["54088",],roi.cd,row.names(roi.cd),am696[,"am"],
                         am696[,"number"],test="HW",station.year=250,Nsim=500)

prova28018 <- roi.st.year(roi.cd["28018",],roi.cd,row.names(roi.cd),am696[,"am"],
                          am696[,"number"],test="HW",station.year=250,Nsim=500)


###################################################
### code chunk number 18: nsRFA_ex02.Rnw:207-222
###################################################
Lmomenti696 <- as.data.frame(Lmomenti696)
par(mfrow=c(1,2))
 plot(Lmomenti696[c("lca","lcv")], xlab="L-CA", ylab="L-CV",
      pch=".", cex=2, main="54088"); grid()
 points(Lmomenti696[c("54088"), c("lca","lcv")],
        pch=19, col="red", cex=1)
 points(Lmomenti696[prova54088$region[-1], c("lca","lcv")],
        pch=19, cex=1)
 plot(Lmomenti696[,c("lca","lkur")], xlab="L-CA", ylab="L-kur",
      pch=".", cex=2, main="28018"); grid()
 points(Lmomenti696[c("28018"), c("lca","lcv")],
        pch=19, col="red", cex=1)
 points(Lmomenti696[prova28018$region[-1], c("lca","lcv")],
        pch=19, cex=1)
par(mfrow=c(1,1))


###################################################
### code chunk number 19: nsRFA_ex02.Rnw:236-296
###################################################
figure16.9a <- function (x,r,cd) {
 # x = station of interest (e.g. "28018")
 # r = output of roi.st.year()

 if(!r$region[1]==x) r$region <- c(x,r$region)
 row.names(cd) <- cd[,"number"]
 n <- length(cd[,"number"])
 cd.r <- cd[r$region,]
 par(mfrow=c(2,3))
  hist(log(cd[,"dtm_area"]),col="lightgray",border="lightgray",
       main="",xlab="AREA",axes=FALSE)
  axis(1,at=c(log(1),log(10),log(100),log(1000),log(10000)),
       label=c("1","10","100","1000","10000"))
  axis(2,at=seq(0,1,by=.05)*n,label=seq(0,1,by=.05))
  box()
  points(cbind(log(cd.r[-1,"dtm_area"]),0),pch=19,cex=.7)
  points(cbind(log(cd.r[1,"dtm_area"]),0),pch=4,cex=2,lwd=2)

  hist(cd[,"saar"],col="lightgray",border="lightgray",
       main="",xlab="SAAR",axes=FALSE)
  axis(1)
  axis(2,at=seq(0,1,by=.05)*n,label=seq(0,1,by=.05))
  box()
  points(cbind(cd.r[-1,"saar"],0),pch=19,cex=.7)
  points(cbind(cd.r[1,"saar"],0),pch=4,cex=2,lwd=2)

  hist(cd[,"bfihost"],col="lightgray",border="lightgray",
       main="",xlab="BFIHOST",axes=FALSE)
  axis(1)
  axis(2,at=seq(0,1,by=.05)*n,label=seq(0,1,by=.05))
  box()
  points(cbind(cd.r[-1,"bfihost"],0),pch=19,cex=.7)
  points(cbind(cd.r[1,"bfihost"],0),pch=4,cex=2,lwd=2)

  hist(cd[,"farl"],col="lightgray",border="lightgray",
       main="",xlab="FARL",axes=FALSE)
  axis(1)
  axis(2,at=seq(0,1,by=.05)*n,label=seq(0,1,by=.05))
  box()
  points(cbind(cd.r[-1,"farl"],0),pch=19,cex=.7)
  points(cbind(cd.r[1,"farl"],0),pch=4,cex=2,lwd=2)

  hist(cd[,"propwet"],col="lightgray",border="lightgray",
       main="",xlab="PROPWET",axes=FALSE)
  axis(1)
  axis(2,at=seq(0,1,by=.05)*n,label=seq(0,1,by=.05))
  box()
  points(cbind(cd.r[-1,"propwet"],0),pch=19,cex=.7)
  points(cbind(cd.r[1,"propwet"],0),pch=4,cex=2,lwd=2)

  hist(cd[,"urbext1990"],col="lightgray",border="lightgray",
       main="",xlab="URBEXT",axes=FALSE)
  axis(1)
  axis(2,at=seq(0,1,by=.05)*n,label=seq(0,1,by=.05))
  box()
  points(cbind(cd.r[-1,"urbext1990"],0),pch=19,cex=.7)
  points(cbind(cd.r[1,"urbext1990"],0),pch=4,cex=2,lwd=2)
 par(mfrow=c(1,1))
 title(main=x,cex.main=1,font.main=1)
}


###################################################
### code chunk number 20: nsRFA_ex02.Rnw:298-300
###################################################
prova40009 <- roi.st.year(roi.cd["40009",],roi.cd,row.names(roi.cd),am696[,"am"],
                          am696[,"number"],test="HW",station.year=500,Nsim=500)


###################################################
### code chunk number 21: nsRFA_ex02.Rnw:306-307
###################################################
figure16.9a("40009",prova40009,cd696)


###################################################
### code chunk number 22: nsRFA_ex02.Rnw:319-394
###################################################
figure16.9b <- function (x,r,am,cd) {
 # x = station of interest (e.g. "28018")
 # r = output of roi.st.year()

 row.names(cd) <- cd[,"number"]
 n <- length(cd[,"number"])
 cd.r <- cd[r$region,]
 cd.x <- cd[x,]
 fac <- factor(am[,"number"],levels=cd.r[,"number"])
 am.r <- am[!is.na(fac),]
 fac <- factor(am[,"number"],levels=x)
 am.x <- am[!is.na(fac),]
 am.xr <- rbind(am.x,am.r)
 QMED.r <- tapply(am.r[,4],am.r[,1],median)
 QMED.x <- median(am.x[,4])
 am.r.adim <- am.r; am.r.adim[,4] <- am.r[,4]/unsplit(QMED.r,am.r[,1])
 am.x.adim <- am.x; am.x.adim[,4] <- am.x[,4]/QMED.x
 lcv <- tapply(am[,4],am[,1],LCV)
 lca <- tapply(am[,4],am[,1],LCA)
 lkur <- tapply(am[,4],am[,1],Lkur)
 lcv.r <- tapply(am.r[,4],am.r[,1],LCV)
 lca.r <- tapply(am.r[,4],am.r[,1],LCA)
 lkur.r <- tapply(am.r[,4],am.r[,1],Lkur)
 lcv.x <- LCV(am.x[,4])
 lca.x <- LCA(am.x[,4])
 lkur.x <- Lkur(am.x[,4])
 days <- as.numeric(format(as.Date(am[,2]),"%j"))
 days.r <- as.numeric(format(as.Date(am.r[,2]),"%j"))
 days.x <- as.numeric(format(as.Date(am.x[,2]),"%j"))

 par(mfrow=c(2,3))
  lognormplot(am.r.adim[,4],line=FALSE,xlab="Q/QMED",type="n")
  for(i in r$region) {
   xxx <- am.r.adim[am.r.adim[,1]==i,4]
   normpoints(xxx,type="l",col="gray")
  }
  normpoints(am.r.adim[,4],type="l",lwd=2)
  normpoints(am.x.adim[,4],type="l",col=2,lwd=2)

  plot(lca,lcv,pch=".",cex=2)
  points(lca.r,lcv.r,pch=19)
  points(lca.x,lcv.x,pch=4,cex=2,lwd=2)

  plot(lca,lkur,pch=".",cex=2)
  points(lca.r,lkur.r,pch=19)
  points(lca.x,lkur.x,pch=4,cex=2,lwd=2)

  plot(cd[c("ihdtm_ngr_x","ihdtm_ngr_y")],pch=".",cex=2,xlab="",ylab="",axes=FALSE)
  points(cd.r[c("ihdtm_ngr_x","ihdtm_ngr_y")],pch=19)
  points(cd.x[c("ihdtm_ngr_x","ihdtm_ngr_y")],pch=4,cex=2,lwd=2)

  consistencyplot (am.r[,3],am.r[,1])

  dummy <- seq(0,2*pi,length=100)
  plot(cos(dummy),sin(dummy),type="l",xlab="",ylab="",axes=FALSE)
  abline(h=0,lty=3); abline(v=0,lty=3)
  radd <- days*pi/180
  XFLOOD <- tapply(cos(radd),am[,1],mean)
  YFLOOD <- tapply(sin(radd),am[,1],mean)
  points(XFLOOD,YFLOOD,pch=".",cex=2)
  radd <- days.r*pi/180
  XFLOOD <- tapply(cos(radd),am.r[,1],mean)
  YFLOOD <- tapply(sin(radd),am.r[,1],mean)
  points(XFLOOD,YFLOOD,pch=19,cex=1)
  radd <- days.x*pi/180
  XFLOOD <- tapply(cos(radd),am.x[,1],mean)
  YFLOOD <- tapply(sin(radd),am.x[,1],mean)
  points(XFLOOD,YFLOOD,pch=4,cex=2,lwd=2)
  axis(1,at=0,label="Oct 1")
  axis(2,at=0,label="Jul 1")
  axis(3,at=0,label="Apr 1")
  axis(4,at=0,label="Jan 1")
 par(mfrow=c(1,1))
 title(main=x,cex.main=1,font.main=1)
}


###################################################
### code chunk number 23: nsRFA_ex02.Rnw:400-401
###################################################
figure16.9b("40009",prova40009,am696,cd696)


###################################################
### code chunk number 24: nsRFA_ex02.Rnw:418-420
###################################################
prova45001 <- roi.st.year(roi.cd["45001",],roi.cd,row.names(roi.cd),am696[,"am"],
                          am696[,"number"],test="HW",station.year=250,Nsim=500)


###################################################
### code chunk number 25: nsRFA_ex02.Rnw:426-427
###################################################
figure16.9a("45001",prova45001,cd696)


###################################################
### code chunk number 26: nsRFA_ex02.Rnw:442-443
###################################################
figure16.9b("45001",prova45001,am696,cd696)

Try the nsRFA package in your browser

Any scripts or data that you put into this service are public.

nsRFA documentation built on Nov. 13, 2023, 5:07 p.m.