R/utilindex.R

Defines functions matchIntegerDataFrames

Documented in matchIntegerDataFrames

#'    utilindex.R
#'
#'    Copyright (c) Adrian Baddeley
#'
#'    GNU Public Licence >= 2
#'

matchIntegerDataFrames <- function(X, Y, sort=TRUE) {
  X <- as.data.frame(X)
  Y <- as.data.frame(Y)
  stopifnot(ncol(X) == ncol(Y))
  if(!all(sapply(X, storage.mode) == "integer"))
    X <- as.data.frame(lapply(X, as.integer))
  if(!all(sapply(Y, storage.mode) == "integer"))
    Y <- as.data.frame(lapply(Y, as.integer))
  ans <- rep(NA_integer_, nrow(X))
  switch(ncol(X),
         {
	    #' one column
            ans <- match(X[,1], Y[,1])
	 },
	 {
	    #' two columns
	    if(sort) {
  	      #' order them
	      oX <- order(X[,1], X[,2])
	      oY <- order(Y[,1], Y[,2])
	      XX <- X[oX, , drop=FALSE]
	      YY <- Y[oY, , drop=FALSE]
  	      z <- .C(C_CSmatch2int,
	              na = as.integer(nrow(XX)),
		      xa = as.integer(XX[,1]),
		      ya = as.integer(XX[,2]),
	       	      nb = as.integer(nrow(YY)),
	       	      xb = as.integer(YY[,1]),
	       	      yb = as.integer(YY[,2]),
	       	      match = as.integer(integer(nrow(XX))),
	       	      PACKAGE="spatstat.utils")
		      zz <- z$match
		      zz[zz == 0] <- NA
		      ans[oX] <- oY[zz]
	    } else {
  	      z <- .C(C_CUmatch2int,
	              na = as.integer(nrow(X)),
		      xa = as.integer(X[,1]),
		      ya = as.integer(X[,2]),
	       	      nb = as.integer(nrow(Y)),
	       	      xb = as.integer(Y[,1]),
	       	      yb = as.integer(Y[,2]),
	       	      match = as.integer(integer(nrow(X))),
	       	      PACKAGE="spatstat.utils")
		      zz <- z$match
		      zz[zz == 0] <- NA
		      ans <- zz
	    }
	 },
	 {
	    #' three columns
	    if(sort) {
	      #' order them
	      oX <- order(X[,1], X[,2], X[,3])
	      oY <- order(Y[,1], Y[,2], Y[,3])
	      XX <- X[oX, , drop=FALSE]
	      YY <- Y[oY, , drop=FALSE]
	      z <- .C(C_CSmatch3int,
	         na = as.integer(nrow(XX)),
	         xa = as.integer(XX[,1]),
	         ya = as.integer(XX[,2]),
	         za = as.integer(XX[,3]),
	         nb = as.integer(nrow(YY)),
	         xb = as.integer(YY[,1]),
	         yb = as.integer(YY[,2]),
	         zb = as.integer(YY[,3]),
	         match = as.integer(integer(nrow(XX))),
	         PACKAGE="spatstat.utils")
	      zz <- z$match
	      zz[zz == 0] <- NA
	      ans[oX] <- oY[zz]
	    } else {
	      z <- .C(C_CUmatch3int,
	         na = as.integer(nrow(X)),
	         xa = as.integer(X[,1]),
	         ya = as.integer(X[,2]),
	         za = as.integer(X[,3]),
	         nb = as.integer(nrow(Y)),
	         xb = as.integer(Y[,1]),
	         yb = as.integer(Y[,2]),
	         zb = as.integer(Y[,3]),
	         match = as.integer(integer(nrow(X))),
	         PACKAGE="spatstat.utils")
	      zz <- z$match
	      zz[zz == 0] <- NA
	      ans <- zz
	    }
	 },
	 stop("Sorry, not implemented for more than 3 columns", call.=FALSE))
    return(ans)
}

   
spatstat/spatstat.utils documentation built on Oct. 25, 2023, 10:07 p.m.