/
model_get_assign.R
58 lines (52 loc) · 1.44 KB
/
model_get_assign.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#' Get the assign attribute of model matrix of a model
#'
#' Return the assign attribute attached to the object returned by
#' [stats::model.matrix()].
#'
#' @param model a model object
#' @export
#' @family model_helpers
#' @seealso [stats::model.matrix()]
#' @examples
#' lm(hp ~ mpg + factor(cyl), mtcars) %>%
#' model_get_assign()
model_get_assign <- function(model) {
UseMethod("model_get_assign")
}
#' @export
#' @rdname model_get_assign
model_get_assign.default <- function(model) {
model_matrix <- model_get_model_matrix(model)
get_assign <- purrr::attr_getter("assign")
assign <- model_matrix %>% get_assign()
if (is.null(assign)) {
# an alternative generic way to compute assign
# (e.g. for felm models)
model_matrix <- tryCatch(
stats::model.matrix(stats::terms(model), stats::model.frame(model)),
error = function(e) {
NULL # nocov
}
)
assign <- model_matrix %>% get_assign()
}
if (!is.atomic(assign)) {
return(NULL)
} # nocov
attr(assign, "model_matrix") <- model_matrix
assign
}
#' @export
#' @rdname model_get_assign
model_get_assign.vglm <- function(model) {
model_matrix <- model_get_model_matrix(model)
get_assign <- purrr::attr_getter("orig.assign.lm")
assign <- model_matrix %>% get_assign()
attr(assign, "model_matrix") <- model_matrix
assign
}
#' @export
#' @rdname model_get_assign
model_get_assign.model_fit <- function(model) {
model_get_assign(model$fit)
}