# Jest.S
#
# Usual invocation to compute J function
# if F and G are not required
#
# $Revision: 4.26 $ $Date: 2022/01/04 05:30:06 $
#
#
#
Jest <- function(X, ..., eps=NULL, r=NULL, breaks=NULL, correction=NULL) {
X <- as.ppp(X)
W <- Window(X)
brks <- handle.r.b.args(r, breaks, window=W, pixeps=eps,
rmaxdefault=rmax.rule("J", W, intensity(X)))
checkspacing <- !isFALSE(list(...)$checkspacing)
#' compute F and G
FF <- Fest(X, eps, breaks=brks, correction=correction,
checkspacing=checkspacing)
G <- Gest(X, breaks=brks, correction=correction)
# initialise fv object
rvals <- FF$r
rmax <- max(rvals)
Z <- fv(data.frame(r=rvals, theo=1),
"r", substitute(J(r), NULL),
"theo",
. ~ r,
c(0,rmax),
c("r", "%s[pois](r)"),
c("distance argument r", "theoretical Poisson %s"),
fname="J")
# compute J function estimates
# this has to be done manually because of the mismatch between names
Fnames <- names(FF)
Gnames <- names(G)
bothnames <- intersect(Fnames, Gnames)
if("raw" %in% bothnames) {
Jun <- ratiotweak(1-G$raw, 1-FF$raw)
Z <- bind.fv(Z, data.frame(un=Jun), "hat(%s)[un](r)",
"uncorrected estimate of %s", "un")
attr(Z, "alim") <- range(rvals[FF$raw <= 0.9])
}
if("rs" %in% bothnames) {
Jrs <- ratiotweak(1-G$rs, 1-FF$rs)
Z <- bind.fv(Z, data.frame(rs=Jrs), "hat(%s)[rs](r)",
"border corrected estimate of %s", "rs")
attr(Z, "alim") <- range(rvals[FF$rs <= 0.9])
}
if("han" %in% Gnames && "cs" %in% Fnames) {
Jhan <- ratiotweak(1-G$han, 1-FF$cs)
Z <- bind.fv(Z, data.frame(han=Jhan), "hat(%s)[han](r)",
"Hanisch-style estimate of %s", "han")
attr(Z, "alim") <- range(rvals[FF$cs <= 0.9])
}
if("km" %in% bothnames) {
Jkm <- ratiotweak(1-G$km, 1-FF$km)
Z <- bind.fv(Z, data.frame(km=Jkm), "hat(%s)[km](r)",
"Kaplan-Meier estimate of %s", "km")
attr(Z, "alim") <- range(rvals[FF$km <= 0.9])
}
if("hazard" %in% bothnames) {
Jhaz <- G$hazard - FF$hazard
Z <- bind.fv(Z, data.frame(hazard=Jhaz), "hazard(r)",
"Kaplan-Meier estimate of derivative of log(%s)")
}
# set default plotting values and order
nama <- names(Z)
fvnames(Z, ".") <- rev(nama[!(nama %in% c("r", "hazard"))])
# add more info
attr(Z, "F") <- FF
attr(Z, "G") <- G
attr(Z, "conserve") <- attr(FF, "conserve")
unitname(Z) <- unitname(X)
return(Z)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.