R/raoDmod.R

# Modification of raoD function from package "picante" to accept a matrix of trait differences instead of ultrametric trees.
# We eliminate some operations that we do not need.
#The result by default is alpha diversity

raoDmod<-
function (comm, phy = NULL) 
{
    res <- list()
    if (is.null(phy)) {
        tij <- 1 - diag(x = rep(1, length(comm[1, ])))
    }
    else {
     
        #if(class(phy)!="phylo"){ # !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! CAMBIADO 04/12/2019 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
       if(!inherits(phy, what="phylo")){
          # modificactions in the case a matrix enters instead of a tree
           # if(!is.matrix(phy) & class(phy)!="dist") stop("Phy must be a distance matrix") ## !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! CAMBIADO 04/12/2019 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
	   if(!is.matrix(phy) &  !inherits(phy, what="dist")) stop("Phy must be a distance matrix") 

          if (is.matrix(phy)) phy <- as.dist(phy) #++
          dat <- match.comm.dist(comm, phy)#++
          comm <- dat$comm
          phy <- dat$dist #++
          tij <-as.matrix( phy/2) #++
         }
        #if(class(phy)=="phylo"){ ## !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! CAMBIADO 04/12/2019 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
	if(inherits(phy, what="phylo")){
          if(!is.ultrametric(phy)) stop("Phylogeny must be ultrametric") 
          dat <- match.phylo.comm(phy, comm)
          comm <- dat$comm
          phy <- dat$phy
          tij <- cophenetic(phy)/2
         }# ++
     
      }
    x <- as.matrix(comm)
    S <- length(x[1, ])
    N <- length(x[, 1])
    total <- apply(x, 1, sum)
    samp.relabund <- total/sum(x)
    x.combined <- matrix(apply(x, 2, sum), nrow = 1)/sum(x)
    x <- sweep(x, 1, total, "/")
    D <- vector(length = N)
    names(D) <- rownames(x)
    for (k in 1:N) D[k] <- sum(tij * outer(as.vector(t(x[k, ])), 
        as.vector(t(x[k, ]))))
    res$Dkk <- D
    
   # All this is for obtaining matrix H (Among-community diversities excluding within-community diversity )
    # that we are not interested in.
   #
   #    Dkl <- matrix(nrow = N, ncol = N)
   #for (k in 1:N) {
    #    for (l in 1:N) {
     #       Dkl[k, l] <- sum(tij * outer(as.vector(t(x[k, ])), 
      #          as.vector(t(x[l, ]))))
       # }
    #}
    #row.names(Dkl) <- row.names(x)
    #colnames(Dkl) <- row.names(x)
    #H <- Dkl
    #res$Dkl <- Dkl
    #for (k in 1:N) {
    #    for (l in 1:N) {
    #        H[k, l] <- Dkl[k, l] - (Dkl[k, k] + Dkl[l, l])/2
    #    }
   # }
    #res$H <- H
    
    #res$total <- sum(tij * outer(as.vector(t(x.combined)), as.vector(t(x.combined))))
    
     res$alpha <- sum(res$Dkk * samp.relabund)
     
     #res$total <- sum(tij * outer(as.vector(t(x.combined)), as.vector(t(x.combined))), na.rm=TRUE)
     #res$beta <- res$total - res$alpha
     #res$Fst <- res$beta/res$total
     #res$tij<-tij
    return(res$alpha)
}

Try the idar package in your browser

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

idar documentation built on Jan. 5, 2023, 5:10 p.m.