R/map.overlap.R

Defines functions map.overlap Map.Overlap

Documented in map.overlap Map.Overlap

## function computes the fractional (i.e., 0->1) overlap between the 
## stochastic maps of two trees
## written by Liam Revell 2011, 2015, 2016

Map.Overlap<-function(tree1,tree2,tol=1e-06,standardize=TRUE,...){
	if(hasArg(check.equal)) check.equal<-list(...)$check.equal
	else check.equal<-TRUE
	if(!inherits(tree1,"phylo")||!inherits(tree2,"phylo")) 
		stop("Both input trees should be objects of class \"phylo\".")
	if(check.equal&&!all.equal.phylo(tree1,tree2,tolerance=tol)) 
		stop("Mapped trees must have the same underlying structure.")
	if(!inherits(tree1,"simmap")||!inherits(tree2,"simmap")) 
		stop("Both input trees should be objects of class \"simmap\".")
	s1<-mapped.states(tree1)
	s2<-mapped.states(tree2)
	R<-matrix(0,length(s1),length(s2),dimnames=list(s1,s2))
	for(i in 1:nrow(tree1$edge)){
		XX<-matrix(0,length(tree1$maps[[i]]),2,
			dimnames=list(names(tree1$maps[[i]]),c("start","end")))
		XX[1,2]<-tree1$maps[[i]][1]
		if(length(tree1$maps[[i]])>1){
			for(j in 2:length(tree1$maps[[i]])){
				XX[j,1]<-XX[j-1,2]
				XX[j,2]<-XX[j,1]+tree1$maps[[i]][j]
			}
		}
		YY<-matrix(0,length(tree2$maps[[i]]),2,
			dimnames=list(names(tree2$maps[[i]]),c("start","end")))
		YY[1,2]<-tree2$maps[[i]][1]
		if(length(tree2$maps[[i]])>1){		
			for(j in 2:length(tree2$maps[[i]])){
				YY[j,1]<-YY[j-1,2]
				YY[j,2]<-YY[j,1]+tree2$maps[[i]][j]
			}
		}
		for(j in 1:nrow(XX)){
			lower<-max(which(YY[,1]<=XX[j,1]))
			upper<-which(YY[,2]>=(XX[j,2]-tol))[1]
			for(k in lower:upper){
				R[rownames(XX)[j],rownames(YY)[k]]<-
					R[rownames(XX)[j],rownames(YY)[k]]+
					min(YY[k,2],XX[j,2])-max(YY[k,1],XX[j,1])
			}
		}
	}	
	if(standardize) R/sum(R) else R
}

map.overlap<-function(tree1,tree2,tol=1e-6,...){
	if(hasArg(check.equal)) check.equal<-list(...)$check.equal
	else check.equal<-TRUE
	if(!inherits(tree1,"phylo")||!inherits(tree2,"phylo")) 
		stop("Both input trees should be objects of class \"phylo\".")
	if(check.equal&&!all.equal.phylo(tree1,tree2,tolerance=tol)) 
		stop("Mapped trees must have the same underlying structure.")
	if(!inherits(tree1,"simmap")||!inherits(tree2,"simmap")) 
		stop("Both input trees should be objects of class \"simmap\".")
	overlap<-0
	for(i in 1:nrow(tree1$edge)){
		XX<-matrix(0,length(tree1$maps[[i]]),2,
			dimnames=list(names(tree1$maps[[i]]),c("start","end")))
		XX[1,2]<-tree1$maps[[i]][1]
		if(length(tree1$maps[[i]])>1){
			for(j in 2:length(tree1$maps[[i]])){
				XX[j,1]<-XX[j-1,2]
				XX[j,2]<-XX[j,1]+tree1$maps[[i]][j]
			}
		}
		YY<-matrix(0,length(tree2$maps[[i]]),2,
			dimnames=list(names(tree2$maps[[i]]),c("start","end")))
		YY[1,2]<-tree2$maps[[i]][1]
		if(length(tree2$maps[[i]])>1){		
			for(j in 2:length(tree2$maps[[i]])){
				YY[j,1]<-YY[j-1,2]
				YY[j,2]<-YY[j,1]+tree2$maps[[i]][j]
			}
		}
		for(j in 1:nrow(XX)){
			lower<-which(YY[,1]<=XX[j,1])
			lower<-lower[length(lower)]
			upper<-which(YY[,2]>=(XX[j,2]-tol))[1]
			for(k in lower:upper){
				if(rownames(XX)[j]==rownames(YY)[k])
					overlap<-overlap+min(YY[k,2],XX[j,2])-
						max(YY[k,1],XX[j,1])
			}
		}
	}
	overlap/sum(tree1$edge.length)
}

	
liamrevell/phytools documentation built on March 4, 2024, 3:27 a.m.