- 追加された行はこの色です。
- 削除された行はこの色です。
ウィルコクスンの符合付き順位検定
統計検定量は以下のように求める.
標本番号 1 ( &mathml{x_1};) の対応するふたつの数値の差を求め,その絶対値を &mathml{|d_1|}; とする.
# ウィルコクスンの符合付き順位和検定
tmpC <- c(54,49,73,65,89,85,78,93,60,79,84)
tmpD <- c(61,47,64,60,77,85,70,95,56,73,79)
tmpCD <- tmpC -tmpD
tmpCD <- tmpC -tmpD # 差を求める
いま求めた絶対値を元に順番に並び替える.
rankCD <- rank(abs(tmpCD[tmpCD != 0]))
length(rankCD)
tmpFlag <- ifelse( tmpCD[tmpCD != 0] > 0, -1, 1)
rankCD <- rank(abs(tmpCD[tmpCD != 0])) # 差の絶対値を昇順に並べる
# ただし 0 は含まない
N <- length(rankCD)
tmpFlag <- ifelse( tmpCD[tmpCD != 0] > 0, -1, 1) # 差の符号を取得
length(tmpCD)
rankCD <- rankCD * tmpFlag
sum(rankCD) / sqrt(sum(rankCD^2))
rankCD <- rankCD * tmpFlag # 符号付きランクを作成
Tplus <- sum(rankCD[rankCD>0])
Tminus <- sum(rankCD[rankCD<0])*-1
Tsmall <- ifelse(Tplus > Tminus, Tminus, Tplus)
# この数値が表に記載の数値よりも小さければ有意
pnorm(-1.939179,0,1)
qnorm(0.01,0,1)
# 正規近似する
(wilcoxZ <- abs(Tsmall - N*(N+1)/4) / sqrt( N*(N+1)*(2*N+1) /24 ))
(wilcoxZ <- sum(rankCD) / sqrt(sum(rankCD^2))) # 統計量 T
pnorm(wicoxZ,0,1) * 2 # 片側なら 2 倍する