-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
- Loading branch information
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
#' @include SurvivalModel.R | ||
NULL | ||
|
||
|
||
#' `SurvivalGamma` | ||
#' | ||
#' This class extends the general [`SurvivalModel`] class for using the | ||
#' Gamma survival model. | ||
#' | ||
#' @exportClass SurvivalGamma | ||
.SurvivalGamma <- setClass( | ||
Class = "SurvivalGamma", | ||
contains = "SurvivalModel" | ||
) | ||
|
||
# SurvivalGamma-constructors ---- | ||
|
||
#' @rdname SurvivalGamma-class | ||
#' | ||
#' @param k (`Prior`)\cr for the shape `k`. | ||
#' @param theta (`Prior`)\cr for the scale `theta`. | ||
#' @param beta (`Prior`)\cr for covariates coefficients `beta`. | ||
#' | ||
#' @export | ||
SurvivalGamma <- function( | ||
k = prior_gamma(2, 0.5), | ||
theta = prior_gamma(2, 0.5), | ||
beta = prior_normal(0, 2) | ||
) { | ||
|
||
k <- set_limits(k, lower = 0) | ||
theta <- set_limits(theta, lower = 0) | ||
|
||
.SurvivalGamma( | ||
SurvivalModel( | ||
name = "Gamma", | ||
stan = StanModule(x = "sm-gamma/model.stan"), | ||
parameters = ParameterList( | ||
Parameter(name = "sm_gamma_k", prior = k, size = 1), | ||
Parameter(name = "sm_gamma_theta", prior = theta, size = 1), | ||
Parameter(name = "beta_os_cov", prior = beta, size = "p_os_cov_design") | ||
) | ||
) | ||
) | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
|
||
|
||
functions { | ||
// | ||
// Source - sm-gamma/model.stan | ||
// | ||
matrix log_h0(matrix time, vector pars_os) { | ||
real k = pars_os[1]; | ||
real theta = pars_os[2]; | ||
matrix[rows(time), cols(time)] result; | ||
result = (k - 1) .* log(time) - (time ./ theta) - | ||
(k * log(theta)) - log(tgamma(k) * (1 - gamma_p(k, time ./ theta))); | ||
return result; | ||
} | ||
} | ||
|
||
|
||
parameters { | ||
// | ||
// Source - sm-gamma/model.stan | ||
// | ||
real<lower={{ machine_double_eps }}> sm_gamma_k; | ||
real<lower={{ machine_double_eps }}> sm_gamma_theta; | ||
} | ||
|
||
|
||
transformed parameters { | ||
// | ||
// Source - sm-gamma/model.stan | ||
// | ||
vector[2] pars_os = [sm_gamma_k, sm_gamma_theta]'; | ||
} | ||
|
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
# Print method for SurvivalGamma works as expected | ||
|
||
Code | ||
x <- SurvivalGamma() | ||
print(x) | ||
Output | ||
Gamma Survival Model with parameters: | ||
sm_gamma_k ~ gamma(alpha = 2, beta = 0.5) | ||
sm_gamma_theta ~ gamma(alpha = 2, beta = 0.5) | ||
beta_os_cov ~ normal(mu = 0, sigma = 2) | ||
|
||
--- | ||
|
||
Code | ||
x <- SurvivalGamma(k = prior_gamma(3, 4), theta = prior_cauchy(0, 1)) | ||
print(x) | ||
Output | ||
Gamma Survival Model with parameters: | ||
sm_gamma_k ~ gamma(alpha = 3, beta = 4) | ||
sm_gamma_theta ~ cauchy(mu = 0, sigma = 1) | ||
beta_os_cov ~ normal(mu = 0, sigma = 2) | ||
|