Agreement for dichotomous outcomes
This document describes the use of the Agree package for the data example that was used in the paper on specific agreement on dichotomous outcomes in the situation of more than two raters. The method was fully explained an described in de Vet, Dikmans, and Eekhout (2017).
library(Agree)
##
## Attaching package: 'Agree'
## The following object is masked from 'package:base':
##
## kappa
Description of data example
For the data example we used data from a study by Dikmans et al. (2017). This data is based on photographs of breasts of 50 women after breast reconstruction. The photographs are independently scored by 5 surgeons, the patient, and three mothers. They each rated the quality of the reconstruction on a 5 point ordinal scale with the verbal anchors on the left side ‘very dissatisfied’ on the left end and on the right end ‘very satisfied’ on the right end. They specifically rated the volume, shape, symmetry, scars and nipple. In this paper we use the data of 4 surgeons because one surgeon had some missing values and we look at the rates for symmetry. The satisfaction scores were dichotomised into satisfied (scores 4 and 5) and not satisfied (scores 1,2, and 3).
data(breast)
variable <- "symmetry"
raters <- c("PCH1", "PCH2", "PCH3", "PCH4")
ratersvars <- paste(raters, variable, sep="_")
data1 <- data.frame(breast[ratersvars])
for (r in 1:length(ratersvars)){
data1[ratersvars[r]] <- ifelse(data1[ratersvars[r]]=="very satisfied"|data1[ratersvars[r]]=="satisfied","satisfied","not satisfied")
}
data1 <- data.frame(apply(data1[ratersvars], 2, as.factor), stringsAsFactors = TRUE)
head(data1)
## PCH1_symmetry PCH2_symmetry PCH3_symmetry PCH4_symmetry
## 1 satisfied satisfied satisfied satisfied
## 2 not satisfied not satisfied not satisfied not satisfied
## 3 satisfied not satisfied not satisfied not satisfied
## 4 not satisfied not satisfied not satisfied not satisfied
## 5 not satisfied satisfied not satisfied satisfied
## 6 satisfied not satisfied satisfied satisfied
Agreement table
First the agreement tables are summed for all rater combinations into one agreement table. Then the off diagonal cells are averaged to obtain symmetry agreement tables. Note that data1 contains a column per rater for the variable of interest.
sumtable(data1,offdiag = FALSE) %>% kable()
not satisfied | satisfied | |
---|---|---|
not satisfied | 106 | 42 |
satisfied | 34 | 118 |
sumtable(data1,offdiag = TRUE) %>% kable()
not satisfied | satisfied | |
---|---|---|
not satisfied | 106 | 38 |
satisfied | 38 | 118 |
Agreement
From the agreement table we can calculate the agreement. And we can calculate the confidence interval around this agreement.
agreement(data1)
## overall agreement
## 0.7466667
agreement(data1, confint = TRUE)
## overall agreement lower upper
## 0.7466667 0.6608408 0.8215369
Specific agreement
The specific agreement for dichotomous data can be evaluated for the satisfied scores and for the not satisfied scores.
agreement(data1, specific="satisfied", confint = TRUE)
## p lower upper
## overall agreement 0.7466667 0.6608408 0.8215369
## specific agreement: satisfied 0.7564103 0.6407977 0.8505168
agreement(data1, specific="not satisfied", confint = TRUE)
## p lower upper
## overall agreement 0.7466667 0.6608408 0.8215369
## specific agreement: not satisfied 0.7361111 0.6156558 0.8355576
Validation of Confidence interval
Simulation to compare the Fleis correction
Follows….