#
#
# Copyright (c) 2017-2023 King Abdullah University of Science and Technology
# All rights reserved.
#
# ExaGeoStat-R is a software package provided by KAUST
#
#
#
# @file plot.kriging.R.R
# ExaGeoStat R wrapper functions
#
# @version 1.2.0
#
# @author Kesen Wang
# @date 2021-06-20
#' This function plots the the diagnostics and summaries of kriging
#' one thing to note here is that x is Krig or sreg object. need to figure out x."plot.Krig" <- function(x, digits = 4, which = 1:4,
"plot.Krig" <- function(x, digits = 4, which = 1:4, ...)
{
out <- x
#
# don't do plots 2:4 if a fixed lambda
#
if (x$fixed.model) {
which <- 1
}
fitted.values <- predict(out)
std.residuals <- (out$residuals * sqrt(out$weights))/out$shat.GCV
if (any(which == 1)) {
temp <- summary(out)
plot(fitted.values, out$y, ylab = "Y", xlab = " predicted values",
bty = "n", ...)
abline(0, 1)
# hold <- par("usr")
# text(hold[1], hold[4], paste(" R**2 = ", format(round(100 *
# temp$covariance, 2)), "%", sep = ""), cex = 0.8,
# adj = 0)
}
if (any(which == 2)) {
plot(fitted.values, std.residuals, ylab = "(STD) residuals",
xlab = " predicted values", bty = "n", ...)
yline(0)
hold <- par("usr")
# text(hold[1], hold[4], paste(" RMSE =", format(signif(sqrt(sum(out$residuals^2)/(temp$num.observation -
# temp$enp)), digits))), cex = 0.8, adj = 0)
}
if (any(which == 3)) {
if (nrow(out$gcv.grid) > 1) {
ind <- out$gcv.grid[, 3] < 1e+19
out$gcv.grid <- out$gcv.grid[ind, ]
yr <- range(unlist(out$gcv.grid[, 3:5]), na.rm = TRUE)
plot(out$gcv.grid[, 2], out$gcv.grid[, 3], xlab = "Eff. number of parameters",
ylab = " GCV function", bty = "n", ylim = yr,
...)
lines(out$gcv.grid[, 2], out$gcv.grid[, 4], lty = 3)
lines(out$gcv.grid[, 2], out$gcv.grid[, 5], lty = 1)
xline(out$eff.df, lwd=2, col="grey")
usr.save<- par()$usr
usr.save[3:4]<- range( -out$gcv.grid[,7] )
par( usr= usr.save, ylog=FALSE)
lines( out$gcv.grid[, 2], -out$gcv.grid[,7] ,
lty=2, lwd=2, col="blue")
axis( side=4)
mtext( side=4, line=2, "log profile likelihood ")
title("GCV-points, solid-model, dots- single \n REML dashed",
cex = 0.5)
box()
}
}
if (any(which == 4)) {
hist(std.residuals, ylab="")
}
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.