我的目标是模拟一个可用于测试竞争风险模型的数据集。我只是尝试使用该survsim::crisk.sim
函数的一个简单示例,但它不会导致我期望的结果。
require(survival)
simulated_data <- survsim::crisk.sim(n = 100,
foltime = 200,
dist.ev = rep("weibull", 2),
anc.ev = c(0.8, 0.9),
beta0.ev = c(2, 4),
anc.cens = 1,
beta0.cens = 5,
nsit = 2)
model <- survreg(Surv(time, status) ~ 1 + strata(cause), data = simulated_data)
exp(model$scale)
## cause=1 cause=2
## 4.407839 2.576357
我希望这些数字与beta0.ev
. 任何指向我可能做错的地方或其他如何模拟竞争风险数据的建议。
为了完成:我希望模拟数据中的事件遵循每个风险不同的 Weibull 分布。我希望能够在数据中指定一个层次和集群。审查可以遵循 Weibull 或 Bernouli 分布。