R Under development (unstable) (2024-01-25 r85826 ucrt) -- "Unsuffered Consequences" Copyright (C) 2024 The R Foundation for Statistical Computing Platform: x86_64-w64-mingw32/x64 R is free software and comes with ABSOLUTELY NO WARRANTY. You are welcome to redistribute it under certain conditions. Type 'license()' or 'licence()' for distribution details. R is a collaborative project with many contributors. Type 'contributors()' for more information and 'citation()' on how to cite R or R packages in publications. Type 'demo()' for some demos, 'help()' for on-line help, or 'help.start()' for an HTML browser interface to help. Type 'q()' to quit R. > #' > #' Header for all (concatenated) test files > #' > #' Require spatstat.geom > #' Obtain environment variable controlling tests. > #' > #' $Revision: 1.5 $ $Date: 2020/04/30 05:31:37 $ > > require(spatstat.geom) Loading required package: spatstat.geom Loading required package: spatstat.data spatstat.geom 3.2-8 > FULLTEST <- (nchar(Sys.getenv("SPATSTAT_TEST", unset="")) > 0) > ALWAYS <- TRUE > cat(paste("--------- Executing", + if(FULLTEST) "** ALL **" else "**RESTRICTED** subset of", + "test code -----------\n")) --------- Executing **RESTRICTED** subset of test code ----------- > # > # tests/utils.R > # > # Tests of miscellaneous utilities > # > # $Revision: 1.1 $ $Date: 2023/05/07 08:59:32 $ > > local({ + if(FULLTEST) { + ## test code blocks in 'progressreport' + pstate <- list() + for(i in 1:10) { + Sys.sleep(1) + pstate <- progressreport(i, 10, + formula = (time ~ i + I(i^2) + I(i^3)), + showtime=TRUE, + savehistory=TRUE, + state=pstate) + } + } + }) > > # tests/weightedstats.R > # $Revision: 1.2 $ $Date: 2023/11/05 01:40:53 $ > > local({ + if(ALWAYS) { # depends on hardware + ## whist() + ## check agreement between C and interpreted code for whist() + set.seed(98123) + x <- runif(1000) + w <- sample(1:5, 1000, replace=TRUE) + b <- seq(0,1,length=101) + aC <- whist(x,b,w, method="C") + aR <- whist(x,b,w, method="interpreted") + if(!all(aC == aR)) + stop("Algorithms for whist disagree") + } + if(FULLTEST) { + ## cases of 'unnormdensity()' + x <- rnorm(20) + d0 <- unnormdensity(x, weights=rep(0, 20)) + dneg <- unnormdensity(x, weights=c(-runif(19), 0)) + } + + }) > > # > # tests/windows.R > # > # Tests of owin geometry code > # > # $Revision: 1.18 $ $Date: 2023/07/11 06:21:37 $ > > local({ + if(ALWAYS) { # C code + ## Ege Rubak spotted this problem in 1.28-1 + A <- as.owin(ants) + B <- dilation(A, 140) + if(!is.subset.owin(A, B)) + stop("is.subset.owin fails in polygonal case") + + ## thanks to Tom Rosenbaum + A <- shift(square(3), origin="midpoint") + B <- shift(square(1), origin="midpoint") + AB <- setminus.owin(A, B) + D <- shift(square(2), origin="midpoint") + if(is.subset.owin(D,AB)) + stop("is.subset.owin fails for polygons with holes") + + ## thanks to Brian Ripley / SpatialVx + M <- as.mask(letterR) + stopifnot(area(bdry.mask(M)) > 0) + stopifnot(area(convexhull(M)) > 0) + R <- as.mask(square(1)) + stopifnot(area(bdry.mask(R)) > 0) + stopifnot(area(convexhull(R)) > 0) + } + + if(FULLTEST) { + RR <- convexify(as.mask(letterR)) + CC <- covering(letterR, 0.05, eps=0.1) + + #' as.owin.data.frame + V <- as.mask(letterR, eps=0.2) + Vdf <- as.data.frame(V) + Vnew <- as.owin(Vdf) + zz <- mask2df(V) + } + + if(ALWAYS) { # C code + RM <- owinpoly2mask(letterR, as.mask(Frame(letterR)), check=TRUE) + } + + if(FULLTEST) { + #' as.owin + U <- as.owin(quadscheme(cells)) + U2 <- as.owin(list(xmin=0, xmax=1, ymin=0, ymax=1)) + } + + if(ALWAYS) { + #' validity of as.mask applied to rectangles with additional raster info + Z <- as.im(unit.square()) + R <- square(0.5) + aR <- area(R) + a <- area(as.mask(R, xy=Z)) + if(abs(a-aR) > aR/20) + stop("Problem with as.mask(rectangle, xy=image)") + a <- area(as.mask(R, xy=list(x=Z$xcol, y=Z$yrow))) + if(abs(a-aR) > aR/20) + stop("Problem with as.mask(rectangle, xy=list(x,y))") + } + + if(FULLTEST) { + #' intersections involving masks + B1 <- square(1) + B2 <- as.mask(shift(B1, c(0.2, 0.3))) + o12 <- overlap.owin(B1, B2) + o21 <- overlap.owin(B2, B1) + i12 <- intersect.owin(B1, B2, eps=0.01) + i21 <- intersect.owin(B2, B1, eps=0.01) + E2 <- emptywindow(square(2)) + e12 <- intersect.owin(B1, E2) + e21 <- intersect.owin(E2, B1) + + #' geometry + inradius(B1) + inradius(B2) + inradius(letterR) + inpoint(B1) + inpoint(B2) + inpoint(letterR) + is.convex(B1) + is.convex(B2) + is.convex(letterR) + volume(letterR) + perimeter(as.mask(letterR)) + boundingradius(cells) + + boundingbox(letterR) + boundingbox(letterR, NULL) + boundingbox(solist(letterR)) + + } + + if(ALWAYS) { # C code + spatstat.options(Cbdrymask=FALSE) + bb <- bdry.mask(letterR) + spatstat.options(Cbdrymask=TRUE) + } + + if(FULLTEST) { + X <- longleaf[square(50)] + marks(X) <- marks(X)/8 + D <- discs(X) + D <- discs(X, delta=5, separate=TRUE) + } + + if(ALWAYS) { # C code + AD <- dilated.areas(cells, + r=0.01 * matrix(1:10, 10,1), + constrained=FALSE, exact=FALSE) + } + + if(FULLTEST) { + periodify(B1, 2) + periodify(union.owin(B1, B2), 2) + periodify(letterR, 2) + } + + if(ALWAYS) { + #' Ancient bug in inside.owin + W5 <- owin(poly=1e5*cbind(c(-1,1,1,-1),c(-1,-1,1,1))) + W6 <- owin(poly=1e6*cbind(c(-1,1,1,-1),c(-1,-1,1,1))) + i5 <- inside.owin(0,0,W5) + i6 <- inside.owin(0,0,W6) + if(!i5) stop("Wrong answer from inside.owin") + if(i5 != i6) stop("Results from inside.owin are scale-dependent") + } + + if(FULLTEST) { + #' miscellaneous utilities + thrash <- function(f) { + f(letterR) + f(Frame(letterR)) + f(as.mask(letterR)) + } + thrash(meanX.owin) + thrash(meanY.owin) + thrash(intX.owin) + thrash(intY.owin) + + interpretAsOrigin("right", letterR) + interpretAsOrigin("bottom", letterR) + interpretAsOrigin("bottomright", letterR) + interpretAsOrigin("topleft", letterR) + interpretAsOrigin("topright", letterR) + } + + if(ALWAYS) { # depends on polyclip + A <- break.holes(letterR) + B <- break.holes(letterR, splitby="y") + plot(letterR, col="blue", use.polypath=FALSE) + } + + if(ALWAYS) { # C code + #' mask conversion + M <- as.mask(letterR) + D2 <- as.data.frame(M) # two-column + D3 <- as.data.frame(M, drop=FALSE) # three-column + M2 <- as.owin(D2) + M3 <- as.owin(D3) + W2 <- owin(mask=D2) + W3 <- owin(mask=D3) + } + + if(FULLTEST) { + #' void/empty cases + nix <- nearest.raster.point(numeric(0), numeric(0), M) + E <- emptywindow(Frame(letterR)) + print(E) + #' cases of summary.owin + print(summary(E)) # empty + print(summary(Window(humberside))) # single polygon + #' additional cases of owin() + B <- owin(mask=M$m) # no pixel size or coordinate info + xy <- as.data.frame(letterR) + xxyy <- split(xy[,1:2], xy$id) + spatstat.options(checkpolygons=TRUE) + H <- owin(poly=xxyy, check=TRUE) + } + + #' Code for/using intersection and union of windows + + if(FULLTEST) { + Empty <- emptywindow(Frame(letterR)) + a <- intersect.owin() + a <- intersect.owin(Empty) + a <- intersect.owin(Empty, letterR) + a <- intersect.owin(letterR, Empty) + b <- intersect.owin() + b <- intersect.owin(Empty) + b <- intersect.owin(Empty, letterR) + b <- intersect.owin(letterR, Empty) + d <- union.owin(as.mask(square(1)), as.mask(square(2))) + #' [.owin + A <- erosion(letterR, 0.2) + Alogi <- as.im(TRUE, W=A) + B <- letterR[A] + B <- letterR[Alogi] + #' miscellaneous + D <- convexhull(Alogi) + } + }) > > reset.spatstat.options() > ## > ## tests/xysegment.R > ## [SEE ALSO tests/segments.R] > ## > ## Test weird problems and boundary cases for line segment code > ## > ## $Version$ $Date: 2022/10/23 01:21:09 $ > ## > > local({ + if(FULLTEST) { + ## segment of length zero + B <- psp(1/2, 1/2, 1/2, 1/2, window=square(1)) + BB <- angles.psp(B) + A <- runifrect(3) + AB <- project2segment(A,B) + + ## mark inheritance + X <- psp(runif(10), runif(10), runif(10), runif(10), window=owin()) + marks(X) <- 1:10 + Y <- selfcut.psp(X) + marks(X) <- data.frame(A=1:10, B=factor(letters[1:10])) + Z <- selfcut.psp(X) + #' psp class support + S <- unmark(X) + marks(S) <- sample(factor(c("A","B")), nobjects(S), replace=TRUE) + intensity(S) + intensity(S, weights=runif(nsegments(S))) + } + }) > > > > proc.time() user system elapsed 1.56 0.28 1.82