Tidy 總結了有關模型組件的信息。模型組件可能是回歸中的單個項、單個假設、聚類或類。 tidy 所認為的模型組件的確切含義因模型而異,但通常是不言而喻的。如果模型具有多種不同類型的組件,您將需要指定要返回哪些組件。
參數
- x
-
從調用
geepack::geeglm()
返回的geeglm
對象。 - conf.int
-
邏輯指示是否在整理的輸出中包含置信區間。默認為
FALSE
。 - conf.level
-
用於置信區間的置信水平(如果
conf.int = TRUE
)。必須嚴格大於 0 且小於 1。默認為 0.95,對應於 95% 的置信區間。 - exponentiate
-
邏輯指示是否對係數估計值取冪。這對於邏輯回歸和多項回歸來說是典型的,但如果沒有 log 或 logit 鏈接,那麽這是一個壞主意。默認為
FALSE
。 - ...
-
附加參數。不曾用過。僅需要匹配通用簽名。注意:拚寫錯誤的參數將被吸收到
...
中,並被忽略。如果拚寫錯誤的參數有默認值,則將使用默認值。例如,如果您傳遞conf.lvel = 0.9
,所有計算將使用conf.level = 0.95
進行。這裏有兩個異常:
細節
如果 conf.int = TRUE
,則使用內部 confint.geeglm()
函數計算置信區間。
如果模型數據中存在缺失值,則可能需要使用 na.action = na.exclude
重新擬合模型或預先處理數據中的缺失值。
值
帶有列的 tibble::tibble()
:
- conf.high
-
估計置信區間的上限。
- conf.low
-
估計置信區間的下限。
- estimate
-
回歸項的估計值。
- p.value
-
與觀察到的統計量相關的兩側 p 值。
- statistic
-
在回歸項非零的假設中使用的 T-statistic 的值。
- std.error
-
回歸項的標準誤差。
- term
-
回歸項的名稱。
例子
# load modeling library
library(geepack)
# load data
data(state)
ds <- data.frame(state.region, state.x77)
# fit model
geefit <- geeglm(Income ~ Frost + Murder,
id = state.region,
data = ds, family = gaussian,
corstr = "exchangeable"
)
#> $fct
#> function (dose, parm)
#> {
#> parmMat <- matrix(parmVec, nrow(parm), numParm, byrow = TRUE)
#> parmMat[, notFixed] <- parm
#> fd(dose, parmMat[, 1], parmMat[, 2], parmMat[, 3], parmMat[,
#> 4], parmMat[, 5])
#> }
#> <bytecode: 0x55e23e706478>
#> <environment: 0x55e24e6f80a0>
#>
#> $ssfct
#> function (dframe)
#> {
#> x <- dframe[, 1]
#> y <- dframe[, 2]
#> cdVal <- findcd(x, y)
#> if (useFixed) {
#> }
#> if (logg) {
#> bVal <- 0.75 * sd(log(x[y > quantile(y, 0.75)]))
#> }
#> else {
#> bVal <- 0.75 * sd(x[y > quantile(y, 0.75)])
#> }
#> befVal <- c(bVal, x[which.max(y)], 1)
#> return(c(befVal[1], cdVal, befVal[2:3])[is.na(fixed)])
#> }
#> <bytecode: 0x55e2489927a8>
#> <environment: 0x55e24e6f8ca8>
#>
#> $names
#> [1] "b" "c" "d" "e" "f"
#>
#> $deriv1
#> function (dose, parm)
#> {
#> parmMat <- matrix(parmVec, nrow(parm), numParm, byrow = TRUE)
#> parmMat[, notFixed] <- parm
#> attr(fd(dose, parmMat[, 1], parmMat[, 2], parmMat[, 3], parmMat[,
#> 4], parmMat[, 5]), "gradient")[, notFixed]
#> }
#> <bytecode: 0x55e23e703950>
#> <environment: 0x55e24e6f80a0>
#>
#> $deriv2
#> NULL
#>
#> $derivx
#> function (dose, parm)
#> {
#> parmMat <- matrix(parmVec, nrow(parm), numParm, byrow = TRUE)
#> parmMat[, notFixed] <- parm
#> dFct <- function(dose, b, c, d, e, f) {
#> .expr1 <- d - c
#> .expr4 <- (dose - e)/b
#> .expr5 <- .expr4^2
#> .expr6 <- sqrt(.expr5)
#> .expr9 <- exp(-0.5 * .expr6^f)
#> .value <- c + .expr1 * .expr9
#> .grad <- array(0, c(length(.value), 1L), list(NULL, c("dose")))
#> .grad[, "dose"] <- -(.expr1 * (.expr9 * (0.5 * (.expr6^(f -
#> 1) * (f * (0.5 * (2 * (1/b * .expr4) * .expr5^-0.5)))))))
#> attr(.value, "gradient") <- .grad
#> .value
#> }
#> attr(dFct(dose, parmMat[, 1], parmMat[, 2], parmMat[, 3],
#> parmMat[, 4], parmMat[, 5]), "gradient")
#> }
#> <bytecode: 0x55e23e701d40>
#> <environment: 0x55e24e6f80a0>
#>
#> $edfct
#> function (parm, respl, reference, type, ...)
#> {
#> parmVec[notFixed] <- parm
#> p <- absToRel(parmVec, abs(respl), type)
#> if (identical(type, "absolute")) {
#> p <- 100 - p
#> }
#> if (identical(type, "relative") && (parmVec[1] < 0) && (reference ==
#> "control")) {
#> p <- 100 - p
#> }
#> pProp <- 1 - (100 - p)/100
#> EDfct <- function(b, c, d, e, f) {
#> .expr2 <- -2 * log(pProp)
#> .expr4 <- sign(respl) * .expr2^(1/f)
#> .value <- b * .expr4 + e
#> .grad <- array(0, c(length(.value), 5L), list(NULL, c("b",
#> "c", "d", "e", "f")))
#> .grad[, "b"] <- .expr4
#> .grad[, "c"] <- 0
#> .grad[, "d"] <- 0
#> .grad[, "e"] <- 1
#> .grad[, "f"] <- -(b * (.expr4 * (log(.expr2) * (1/f^2))))
#> attr(.value, "gradient") <- .grad
#> .value
#> }
#> EDp <- EDfct(parmVec[1], parmVec[2], parmVec[3], parmVec[4],
#> parmVec[5])
#> EDder <- attr(EDfct(parmVec[1], parmVec[2], parmVec[3], parmVec[4],
#> parmVec[5]), "gradient")
#> return(list(EDp, EDder[notFixed]))
#> }
#> <bytecode: 0x55e23e6f8b78>
#> <environment: 0x55e24e6f80a0>
#>
#> $name
#> [1] "family"
#>
#> $text
#> [1] "Gaussian"
#>
#> $noParm
#> [1] 5
#>
#> $lowerAs
#> function (parm)
#> {
#> parmVec[indexVec] <- parm
#> parmVec[parmNo]
#> }
#> <bytecode: 0x55e23be053c0>
#> <environment: 0x55e2580f7488>
#>
#> $upperAs
#> function (parm)
#> {
#> parmVec[indexVec] <- parm
#> parmVec[parmNo]
#> }
#> <bytecode: 0x55e23be053c0>
#> <environment: 0x55e2580f76f0>
#>
#> $monoton
#> [1] NA
#>
#> $fixed
#> [1] NA NA NA NA NA
#>
#> attr(,"class")
#> [1] "gaussian"
#> Error in glm(formula = Income ~ Frost + Murder, family = gaussian, data = ds): 'family' not recognized
# summarize model fit with tidiers
tidy(geefit)
#> Error in eval(expr, envir, enclos): object 'geefit' not found
tidy(geefit, conf.int = TRUE)
#> Error in eval(expr, envir, enclos): object 'geefit' not found
相關用法
- R broom tidy.garch 整理 a(n) garch 對象
- R broom tidy.glmnet 整理 a(n) glmnet 對象
- R broom tidy.glmRob 整理 a(n) glmRob 對象
- R broom tidy.gam 整理 a(n) gam 對象
- R broom tidy.glht 整理 a(n) glht 對象
- R broom tidy.gmm 整理 a(n) gmm 對象
- R broom tidy.robustbase.glmrob 整理 a(n) glmrob 對象
- R broom tidy.acf 整理 a(n) acf 對象
- R broom tidy.robustbase.lmrob 整理 a(n) lmrob 對象
- R broom tidy.biglm 整理 a(n) biglm 對象
- R broom tidy.rq 整理 a(n) rq 對象
- R broom tidy.kmeans 整理 a(n) kmeans 對象
- R broom tidy.betamfx 整理 a(n) betamfx 對象
- R broom tidy.anova 整理 a(n) anova 對象
- R broom tidy.btergm 整理 a(n) btergm 對象
- R broom tidy.cv.glmnet 整理 a(n) cv.glmnet 對象
- R broom tidy.roc 整理 a(n) roc 對象
- R broom tidy.poLCA 整理 a(n) poLCA 對象
- R broom tidy.emmGrid 整理 a(n) emmGrid 對象
- R broom tidy.Kendall 整理 a(n) Kendall 對象
- R broom tidy.survreg 整理 a(n) survreg 對象
- R broom tidy.ergm 整理 a(n) ergm 對象
- R broom tidy.pairwise.htest 整理 a(n)pairwise.htest 對象
- R broom tidy.coeftest 整理 a(n) coeftest 對象
- R broom tidy.polr 整理 a(n) polr 對象
注:本文由純淨天空篩選整理自等大神的英文原創作品 Tidy a(n) geeglm object。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。