結果(バイナリ)との関係を調整した(つまり、モデルに含まれる交絡因子から独立した)特定の独立変数の多変量ロジスティック回帰分析(GLM)の結果をプロットしたいと思います。
predict
コマンドの後に、を使用して次の方法を推奨する投稿を見たことがありますcurve
。これが例です。
x <- data.frame(binary.outcome, cont.exposure)
model <- glm(binary.outcome ~ cont.exposure, family=binomial, data=x)
plot(cont.exposure, binary.outcome, xlab="Temperature",ylab="Probability of Response")
curve(predict(model, data.frame(cont.exposure=x), type="resp"), add=TRUE, col="red")
ただし、これは多変量回帰モデルでは機能しないようです。交絡変数として「age」(任意-同じ長さの任意の変数である可能性があります)を追加すると、次のエラーが発生します。
> x <- data.frame(binary.outcome, cont.exposure, age)
> model <- glm(binary.outcome ~ cont.exposure + age, family=binomial, data=x)
> plot(cont.exposure, binary.outcome, xlab="Temperature",ylab="Probability of Response")
> curve(predict(model, data.frame(cont.exposure=x), type="resp"), add=TRUE, col="red")
Error in model.frame.default(Terms, newdata, na.action = na.action, xlev = object$xlevels) :
variable lengths differ (found for 'age')
In addition: Warning message:
'newdata' had 101 rows but variable(s) found have 698 rows
上記のモデルは、実行したいモデルの簡略版ですが、原則は同じです。交絡因子とは無関係に、バイナリ結果変数と連続曝露の関係をプロットしたいと思います。。
上記の回避策、または私が興味を持っている関係を表示する別の方法のいずれかを取得することは素晴らしいことです。どうもありがとう。