Nothing
# The handwriter R package performs writership analysis of handwritten documents.
# Copyright (C) 2021 Iowa State University of Science and Technology on behalf of its Center for Statistics and Applications in Forensic Evidence
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# EXPORTED ----------------------------------------------------------------
#' Extract Graphs
#'
#' `r lifecycle::badge("superseded")`
#'
#' Development on `extractGraphs()` is complete. We recommend using `process_batch_dir()` instead.
#'
#' Extracts graphs from .png images and saves each by their respective writer.
#'
#' @import foreach
#' @import doParallel
#'
#' @param source_folder path to folder containing .png images
#' @param save_folder path to folder where graphs are saved to
#' @return saves graphs in an rds file
#' @examples
#' \dontrun{
#' sof = "path to folder containing .png images"
#' saf = "path to folder where graphs will be saved to"
#' extractGraphs(sof, saf)
#' }
#' @export
extractGraphs = function(source_folder = getwd(), save_folder = getwd()){
# bind global variable to fix check() note
i <- NULL
doParallel::registerDoParallel(1)
#setwd(source_folder)
filenames = as.list(list.files(source_folder, pattern = ".png"))
foreach(i = 1:length(filenames)) %dopar%{
path = paste0(source_folder,"/", filenames[[i]])
writer_id = paste0(substr(basename(path), start = 0, stop = nchar(basename(path))-17))
#setwd(save_folder)
ifelse(!dir.exists(file.path(save_folder, writer_id)), dir.create(file.path(save_folder, writer_id)), FALSE)
graph_writer = paste0(save_folder, writer_id, "/")
getGraphs(filenames[[i]], source_folder = source_folder, save_folder = graph_writer)
}
}
# Internal Functions ------------------------------------------------------
#' Extracts graphs from a .png image using handwriter functions
#'
#' extractGraphs
#'
#' @param image .png image to be processed
#' @param source_folder path to folder containing .png images
#' @param save_folder path to folder where graphs are saved to
#' @return saves proclist to an rds file
#'
#' @noRd
getGraphs = function(image, source_folder = getwd(), save_folder = getwd()){
#setwd(source_folder)
doc = proclist = list()
doc$image = readPNGBinary(image)
doc$thin = thinImage(doc$image)
proclist[["process"]] = processHandwriting(doc$thin, dim(doc$image))
proclist[["docname"]] = substr(basename(image), start = 0, stop = nchar(basename(image))-4)
proclist[["thin"]] = doc$thin
proclist[["image"]] = doc$image
#setwd(save_folder)
saveRDS(object = proclist, file = paste0(save_folder, "/", substr(basename(image), start = 0, stop = nchar(basename(image))-4), "_proclist.rds"))
gc()
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.