Wilcoxon検定 のバックアップ差分(No.2) - アールメカブ

アールメカブ


Wilcoxon検定 のバックアップ差分(No.2)


  • 追加された行はこの色です。
  • 削除された行はこの色です。
ウィルコクスンの符合付き順位検定

統計検定量は以下のように求める.
標本番号 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 倍する