Skip to content

Commit

Permalink
fixed TwoSamplePairedTest & SignedScore
Browse files Browse the repository at this point in the history
  • Loading branch information
qddyy committed Sep 11, 2023
1 parent 0cacf11 commit f43e381
Show file tree
Hide file tree
Showing 4 changed files with 23 additions and 14 deletions.
4 changes: 2 additions & 2 deletions R/PairedComparison.R
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,8 @@ PairedComparison <- R6Class(
.define_statistic = function() {
private$.diff <- private$.data$x - private$.data$y

private$.statistic_func <- function(is_swapped, diff = private$.diff) {
mean(diff * (2 * is_swapped - 1))
private$.statistic_func <- function(swapped, diff = private$.diff) {
mean(diff * (2 * swapped - 1))
}
},

Expand Down
4 changes: 2 additions & 2 deletions R/Sign.R
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,8 @@ Sign <- R6Class(
.define_statistic = function() {
sign <- sign(private$.data$x - private$.data$y)

private$.statistic_func <- function(is_swapped, sign = sign) {
sum(sign * (2 * is_swapped - 1) == 1)
private$.statistic_func <- function(swapped, sign = sign) {
sum(sign * (2 * swapped - 1) == 1)
}
},

Expand Down
13 changes: 6 additions & 7 deletions R/SignedScore.R
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ SignedScore <- R6Class(
.correct = NULL,
.ranking_method = NULL,

.signed_score = NULL,
.score = NULL,

.define_statistic = function() {
diff <- private$.data$x - private$.data$y
Expand All @@ -48,23 +48,22 @@ SignedScore <- R6Class(
diff <- diff[diff != 0]
}

private$.signed_score <- sign(diff) * score(abs(diff), method = private$.scoring)
private$.score <- score(abs(diff), method = private$.scoring)

private$.statistic_func <- function(is_swapped, signed_score = private$.signed_score) {
mean(signed_score * (2 * is_swapped - 1))
private$.statistic_func <- function(swapped, positive = (diff > 0), score = private$.score) {
sum(score[positive != swapped])
}
},

.calculate_p = function() {
n <- nrow(private$.data)

sa <- sum(pmax.int(0, private$.signed_score))
z <- sa - 1 / 2 * sum(abs(private$.signed_score))
z <- private$.statistic - 1 / 2 * sum(private$.score)
correction <- if (private$.correct) {
switch(private$.side, lr = sign(z) * 0.5, r = 0.5, l = -0.5)
} else 0
z <- (z - correction) / sqrt(
1 / 4 * sum(private$.signed_score^2)
1 / 4 * sum(private$.score^2)
)

private$.p_value <- get_p_continous(z, "norm", private$.side)
Expand Down
16 changes: 13 additions & 3 deletions R/TwoSamplePairedTest.R
Original file line number Diff line number Diff line change
Expand Up @@ -37,15 +37,25 @@ TwoSamplePairedTest <- R6Class(

private$.data_permu <- lapply(
X = private$.swapped_permu,
FUN = function(is_swapped, x, y) {
FUN = function(swapped, x, y) {
data.frame(
x = `[<-`(x, is_swapped, y[is_swapped]),
y = `[<-`(y, is_swapped, x[is_swapped])
x = `[<-`(x, swapped, y[swapped]),
y = `[<-`(y, swapped, x[swapped])
)
}, x = private$.data$x, y = private$.data$y
)
},

.calculate_statistic = function() {
if (private$.use_swapped) {
private$.statistic <- private$.statistic_func(
rep.int(FALSE, nrow(private$.data))
)
} else {
super$.calculate_statistic()
}
},

.calculate_statistic_permu = function() {
if (private$.use_swapped) {
statistic_func <- private$.statistic_func
Expand Down

0 comments on commit f43e381

Please sign in to comment.