# The following code is copied from broom, and modified afterwards
#' @importFrom broom fix_data_frame
#' @importFrom plyr ldply
#' @importFrom stringr str_replace
#' @importFrom broom tidy glance
#' @importFrom magrittr %>%
#' @export
magrittr::`%>%`
#' @export
tidymod_tidy <- function(object, conf_int = FALSE, conf_level = 0.95) {
tidy(object, conf_int, conf_level)
}
#' @export
tidymod_glance <- function(object) {
glance(object)
}
#' @export
tidy.tidymod_lm <- function(x, conf.int = FALSE, conf.level = .95, ...) {
s <- summary(x)
ret <- tidy.summary.tidymod_lm(s)
process_tidymod_lm(ret, x, conf.int = conf.int, conf.level = conf.level)
}
#' @export
tidy.summary.tidymod_lm <- function(x, ...) {
co <- coef(x)
nn <- c("estimate", "std.error", "statistic", "p.value")
if(inherits(co, "listof")) {
ret <- ldply(co, fix_data_frame, nn[1:ncol(co[[1]])],
.id = "response")
ret$response <- str_replace(ret$response, "Response ", "")
} else {
ret <- fix_data_frame(co, nn[1:ncol(co)])
}
ret
}
process_tidymod_lm <- function(ret, x, conf.int = FALSE, conf.level = .95, ...) {
if(conf.int) {
CI <- suppressMessages(stats::confint(x, level = conf.level))
colnames(CI) = c("conf.low", "conf.high")
ret <- cbind(ret, identity(unrowname(CI)))
}
ret$estimate <- identity(ret$estimate)
ret
}
#' @export
glance.tidymod_lm <- function(object, ...) {
s <- summary(object)
ret <- glance(s, ...)
ret
}
#' @export
glance.summary.tidymod_lm <- function(object, ...) {
ret <- with(object, cbind(data.frame(r.squared = r.squared,
adj.r.squared = adj.r.squared,
sigma = sigma,
df = df)))
unrowname(ret)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.