R/FitEva.R

#' Evaluate the fitting result.
#' 
#' Evaluate the fitting result by calculating the \strong{\code{TPR}} (ratio of true positives to real positives), \strong{\code{FPR}} (ratio of false positives to real negatives), \strong{\code{precision}} (ratio of true positives to predicted positives) , \strong{\code{accuracy}} (ratio of the sum of true positives and true negatives to total number of predictions) and \strong{\code{F1 score}} (the harmonic average of the precision and recall (TPR)). 
#' 
#' @usage FitEva(Beta.simulate, Beta.fit, Gm, cutoff.sc, cutoff.g)
#' 
#' @param Beta.simulate The simulated or golden standarded \code{B} matrix.
#' @param Beta.fit The fitted \code{B} matrix using \code{\link{PgaMsgl}} or other algorithms.
#' @param Gm Matrix of the group structure of coefficient matrix \code{B}. It is the a matrix of group boundaries, with each row indicating a group, four columns indicate the row-start, row-end, column-start and column-end of the group. The row/column index is 1-based.
#' @param cutoff.sc A non-negative number indicates the cutoff of a single coefficient in \code{B} to be positive in the fitted \code{B} matrix.
#' @param cutoff.g A non-negative number indicates the cutoff of the norm of a group (a sub-matrix in truth) in the fitted \code{B} matrix to be positive.
#' 
#' @return \item{sc.TPR}{The true positive rate of single coefficients prediction.}
#' @return \item{sc.FPR}{The false positive rate of single coefficients prediction.}
#' @return \item{sc.TTPR}{The "true" true positive rate of single coefficients prediction.}
#' @return \item{sc.precision}{The precision of single coefficients prediction.}
#' @return \item{sc.accuracy}{The accuracy of single coefficients prediction.}
#' @return \item{sc.F1}{The F1 score of single coefficients prediction.}
#' @return \item{g.TPR}{The true positive rate of group prediction.}
#' @return \item{g.FPR}{The false positive rate of group prediction}
#' @return \item{g.precision}{The precision of goup prediction.}
#' @return \item{g.accuracy}{The accuracy of group prediction.}
#' @return \item{g.F1}{The F1 score of group prediction.}
#'      
#' @examples
#' 
#' data(lowD)
#' result <- PgaMsgl(lowD$X, lowD$Y, lowD$B0, model="L121", lowD$Gm, lowD$mi, lowD$mg, lowD$mc)
#' FitEva_result <- FitEva(lowD$Beta, result$Beta, lowD$Gm, cutoff.sc=0, cutoff.g=0)
#' 
#' @useDynLib PgaMsgl
#' 
#' @export
FitEva <- function(Beta.simulate, Beta.fit, Gm, cutoff.sc, cutoff.g)
{
  if(cutoff.sc < 0) {
    stop("Please indicate a non-negative cutoff of coefficient.")
  }
  TP.sc = sum( which( abs(Beta.fit) > cutoff.sc ) %in% which( abs(Beta.simulate) > 0 ))
  TTP.sc = sum( Beta.fit*Beta.simulate > 0 )
  FP.sc = sum(! which( abs(Beta.fit) > cutoff.sc ) %in% which( abs(Beta.simulate) > 0 ))
  P.sc = sum( abs(Beta.fit) > cutoff.sc )
  
  TN.sc = sum(which( abs(Beta.fit) <= cutoff.sc ) %in% which( abs(Beta.simulate) <= 0 ))
  
  CP.sc = sum(abs(Beta.simulate) > 0)
  CN.sc = sum(abs(Beta.simulate) <= 0)
  
  TPR.sc = TP.sc / CP.sc
  TTPR.sc = TTP.sc / CP.sc
  FPR.sc = FP.sc / CN.sc
  precision.sc = TP.sc / P.sc
  accuracy.sc = (TP.sc + TN.sc) / (CP.sc + CN.sc)
  F1.sc = 2 * precision.sc * TPR.sc/ (precision.sc + TPR.sc)
  
  if(cutoff.g < 0) {
    stop("Please indicate a non-negative cutoff of group norm.")
  }
  n.g = NROW(Gm)
  simulate.g.norm = rep(0,n.g)
  try.g.norm = rep(0,n.g)
  
  for (i in 1:n.g)
  {
    simulate.g.norm[i]=norm(as.matrix(Beta.simulate[Gm[i,1]:Gm[i,2],Gm[i,3]:Gm[i,4]]) , 'F')
    try.g.norm[i]=norm(as.matrix(Beta.fit[Gm[i,1]:Gm[i,2],Gm[i,3]:Gm[i,4]]) , 'F')
  }
  
  TP.g = sum(which(try.g.norm > cutoff.g) %in% which(simulate.g.norm > 0))
  FP.g = sum(! which(try.g.norm > cutoff.g) %in% which(simulate.g.norm > 0))
  P.g = sum(try.g.norm > cutoff.g)
  TN.g = sum(which(try.g.norm <= cutoff.g) %in% which(simulate.g.norm <= 0))
  CP.g = sum(simulate.g.norm > 0)
  CN.g = sum(simulate.g.norm <= 0)
  
  TPR.g = TP.g / CP.g
  FPR.g = FP.g / CN.g
  precision.g = TP.g / P.g
  accuracy.g = (TP.g + TN.g) / (CP.g + CN.g)
  F1.g = 2 * precision.g * TPR.g/ (precision.g + TPR.g)
  
  return(list(sc.TPR=TPR.sc, 
              sc.FPR=FPR.sc, 
              sc.TTPR=TTPR.sc, 
              sc.precision=precision.sc, 
              sc.accuracy=accuracy.sc, 
              sc.F1=F1.sc,
              g.TPR=TPR.g, 
              g.FPR=FPR.g, 
              g.precision=precision.g, 
              g.accuracy=accuracy.g, 
              g.F1=F1.g))
}
TriangularCell/PgaMsgl documentation built on May 28, 2019, 9:33 a.m.