R/multi_rereg.R

Defines functions multi_rereg

Documented in multi_rereg

#' @title Two-Stage Multi-Registration of images
#'
#' @description Takes a list of images and registers them to a template, 
#' takes a statistic image, and registers the list of images back to this 
#' statistic image.
#' @param infiles Input image files
#' @param template.file Template image to register to for first pass.
#' Second pass will be statistic image
#' @param func Function to be passed to 
#' @param ... Arguments to be passed to \code{\link{multi_reg}}. 
#' @note The second stage will use the same arguments passed in \code{...}, but
#' the \code{template.file} will be the statistic image
#' @export
#' @return Output list of statistic image, 
#' registered images to statistic image 
#' and transformations
multi_rereg <- function(infiles, 
                        template.file,
                        func = "mean",
                        ...){
  
  res = multi_reg(infiles = infiles, template.file = template.file, ...)
  outfiles = lapply(res, function(x) x$outfile)
  run_stat_img = stat_img(outfiles, func = func)
  res = multi_reg(infiles = infiles, template.file = run_stat_img, ...)
  
#   e = new.env()
#   fixed = res$stat_img
#   assign("fixed", fixed, envir = e)
#   tlist2 = sapply(res$results, `[[`, 
#                   "fwdtransforms")
#   interpolator2 = sapply(res$results, `[[`, 
#                          "interpolator")  
#   assign("interpolator", 
#          interpolator2, 
#          envir = e)
#   assign("tlist", 
#          tlist2, 
#          envir = e)  
#   assign("apply_fun", function(infiles, ...){
#     apply_multi_reg(
#       infiles,
#       fixed = fixed,
#       transformlist = tlist,
#       ...)  
#   }, envir = e)
  L = list(stat_img = run_stat_img, results = res)
  return(L)
}
muschellij2/extrantsr documentation built on July 27, 2021, 7:41 a.m.