-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy path1-3-articles-aging.Rmd
170 lines (114 loc) · 13.4 KB
/
1-3-articles-aging.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
## Aging articles. How time affects reproducibility of scientific papers?
*Authors: Paweł Morgen, Piotr Sieńko, Konrad Welkier (Warsaw University of Technology)*
### Abstract
Reproduction of a code presented in scientific papers tend to be a laborious yet important process since it enables readers a better understanding of the tools proposed by the authors. While recreating an article various difficulties are faced what can result in calling the paper irreproducible. Some reasons why such situations occur stem from the year when the article was published (for example usage of no more supported packages). The purpose of the following paper is to prove whether this is a general trend which means answering the question: is the year when the article was published related to the reproducibility of the paper. To do so a package CodeExtractorR was created that enables extracting code from PDF files. By using this tool a significant number of articles could be analyzed and therefore results received enabled us to give an objective answer to the stated question.
### Introduction
Every article published in a scientific journal is aimed at improving our knowledge in a certain field. To prove their theories, authors should provide papers with detailed, working examples and extensive supplementary materials to reproduce results. Unfortunately, these conditions are not always fulfilled. In such a case, other researchers are not able to verify and accept the solutions presented by the author. Moreover, the article is not only useless for the scientific community but also for business recipients.
Over the years, several different definitions of reproducibility have been proposed. According to @gentleman2007statistical, reproducible research are papers with accompanying software tools that allow the reader to directly reproduce methods that are presented in the research paper. Other authors suggest that scientific paper is reproducible only if text, data and code are made available and allow an independent researcher to recreate the results [@vandewalle2009reproducible]. Second definition emphasizes the importance of accessibility to data used in researches, therefore it seems to be more suitable and complete interpretation of reproducibility. In addition, in this article, we used scale based on the spectrum of reproducibility, proposed by @Peng1226. In his work, he also mentioned reproducibility as a minimal requirement for assessing the scientific value of the paper. In the past few years, computing has become an essential part of scientific workflow. Some best practices for writing and publishing reproducible scientific article were presented by @Stodden2013SettingTD. Furthermore, she made a brief overview of existing tools and software that facilitate this task. Similar issue was closely described by @kitzes2017practice. Tools created solely for reproducibility in R were proposed by @marwickrrtools in package rrtools.
Although many articles focus on software or framework solutions for reproducibility problems, analysis of scientific papers reproducibility in the context of release date has, to the best of the authors’ knowledge, not been described before. The intention of such research is to find correlations between age of article and its reproducibility. Authors believe that finding these dependencies will allow to calculate the estimated life span of data science article. Furthermore, as replicability helps with applying proposed methods and tools, its approximated level might be helpful in estimating usefulness of every scientific article.
### CodeExtractoR package
To examine sufficent number of articles, package _CodeExtractoR_ has been used. Its main functions - _extract_code_from_pdf()_ and _extract_code_from_html()_, automatically extract code snippets from pdf and html files into R files.
```{r eval=FALSE, warning=FALSE, comment="Example of extract_code_from_html() funtion usage."}
# install.packages("devtools")
devtools::install_github("MrDomani/CodeExtractoR")
library(CodeExtractoR)
# Path to file
path_file <- "filepath.html"
# Path to R file output
output <- "output.R"
# Extracting code
extract_code_from_html(input_file = path_file, output_file = output, console_char = ">")
```
To extract code from pdf, API key to https://cloudconvert.com/ is required.
### Methodology
The first issue that should be touched upon, while considering the methodology behind preparing this article, is the scale used to assess the reproducibility of the papers. In the Introduction it was already mentioned how the scale was created but a more detailed description is required. The authors decided that the scale should consist of 4 levels (from 0 up to 3):
1. The 0 grade was given in case when no chunk of code gave the anticipated results and no figure was reproduced successfully (in practice such situation occurred mainly when the package described in the article was no more available).
2. The 1 grade means that at least one example gave the results that the authors waited for, while it also includes situations when about half of the code in the chunks behaved as expected.
3. The 2 grade was awarded to the articles that were reproducible “in the majority”
what also means that they were not reproducible in 100%.
4. The 3 grade was received by the articles that were fully reproducible and no problems were encountered in the process. Such a result was highly anticipated by the authors but the criteria for this grade were rather strict.
The second issue that also played a vital role in the authors’ work was the scope of the analysis. It was decided that in order to maintain “other thing equal” according to a well-known Latin phrase “ceteris paribus” only one online journal – The R Journal – was taken into account. Being equipped with a tool for faster reproduction of articles – the CodeExtractoR package – the authors agreed to examine about 20 articles that were published across a few years. Such a great number of papers meant that the approach taken could be described as holistic. It is also worth mentioning that usually 30 articles from each year were analyzed (at least whenever it was possible). Finally, it should be noted that in the case of the date when they were published the examined articles range from 2009 up to 2019. The third and final issue that should be considered in this part of the article focuses on the measures undertaken by the authors in order to tackle the problem of biased assessment. Although the scale that was proposed was not totally dependent on the person who was using it, it still left someplace for personal liking and disliking of the paper. As a way of marginalization of this trend the authors have taken part in many conversations when the facts that led to specific grading of the articles were shared. This enabled awarding the grades even more fairly. However, the final measure was much more simple and it was believed to be much more effective as well when compared to the previous one. The articles for each year were divided into 3 groups and assigned to one author each. Thus each author has examined the papers from the whole range of release dates that were taken into account.
### Results
Specific results are presented in _Table 1.1_, which shows the number of examined articles from 2009 up to 2019, grouped by received grade. The column "Grade" represents the 0 - III scale of reproducibility. The rest of the columns shows a number of papers that achieved a particular grade in each year.
<p> </p>
| Grade | 09' | 10' | 11' | 12' | 13' | 14' | 15' | 16' | 17' | 18' | 19' |
|---------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 0 | 3 | 2 | 6 | 4 | 6 | 8 | 5 | 9 | 5 | 9 | 9 |
| I | 4 | 2 | 0 | 2 | 3 | 6 | 6 | 10 | 3 | 2 | 2 |
| II | 3 | 7 | 8 | 4 | 13 | 6 | 10 | 7 | 14 | 6 | 6 |
| III | 6 | 7 | 6 | 5 | 8 | 10 | 9 | 4 | 8 | 13 | 13 |
| SUM | 16 | 18 | 20 | 15 | 30 | 30 | 30 | 30 | 30 | 30 | 30 |
<p> </p>
```{r echo=FALSE, fig.cap="Number of papers by publication year", warning=FALSE}
library(ggplot2)
wyniki <- as.data.frame(matrix(ncol = 4, nrow = 44))
wyniki$V2 <- as.factor(c(rep("09'", 4), rep("10'", 4), rep("11'", 4), rep("12'", 4), rep("13'", 4),
rep("14'", 4), rep("15'", 4), rep("16'", 4), rep("17'", 4), rep("18'", 4), rep("19'", 4)))
wyniki$V3 <- rep(c("0", "I", "II", "III"), 11)
wyniki[1:4, 1] <- c(3, 4, 3, 6)
wyniki[5:8, 1] <- c(2, 2, 7, 7)
wyniki[9:12, 1] <- c(6, 0, 8, 6)
wyniki[13:16, 1] <- c(4, 2, 4, 5)
wyniki[17:20, 1] <- c(6, 3, 13, 8)
wyniki[21:24, 1] <- c(8, 6, 6, 10)
wyniki[25:28, 1] <- c(5, 6, 10, 9)
wyniki[29:32, 1] <- c(9, 10, 7, 4)
wyniki[33:36, 1] <- c(5, 3, 14, 8)
wyniki[37:40, 1] <- c(9, 2, 6, 13)
wyniki[41:44, 1] <- c(9, 2, 6, 13)
colnames(wyniki) <- c("Number", "Year", "Class", "Type")
wyniki$Type <- ifelse(wyniki$Class== "0" | wyniki$Class== "I", "Non-reproducible", "Reproducible")
colors <- rep("black", 11)
colors[5] <- "red"
```
<p> </p>
_Figure 1.1_ shows the results in the original 4-level scale. Although, the number of papers varies throughout the years in every reproducibility class, it is observable that intermediate ones - I and II, are less common in the oldest and newest papers. In addition, results in 2018 and 2019 are identical. It is important to remember that from 2009 to 2012, the overall number of papers oscillated around 18 per year. After 2013, the number of researched articles was constant.
<p> </p>
```{r echo=FALSE, fig.cap= "Number of papers by class and publication year", warning=FALSE}
p2 <- ggplot(wyniki, aes(x = Year, y = Number, fill = Class)) +
geom_bar(position = "dodge", stat = "identity") +
facet_wrap(~ Class)+
theme_minimal(base_size = 16) +
scale_fill_manual(values = c("#e41a1c","#fc9272", "#9ecae1", "#377eb8")) +
theme(legend.position = "bottom",
#axis.text.x = element_text(colour = colors)
) #+
#ggtitle("Number of papers by class and years")
p2
```
<p> </p>
After calculating the percentage of each class in a specific year ( _Figure 1.2_, _Figure 1.3_), it is observed, that in the two oldest examined years - 2009 and 2010 - a ratio of completely unreproducible papers (with 0 or I class ) is surprisingly low. Furthermore, papers with III class of reproducibility are nearly 40% of all articles in these years.
<p> </p>
```{r, echo=FALSE, fig.cap= "Ratio of each class throughout years", warning=FALSE, message=FALSE }
library(dplyr)
wyniki_sum <- aggregate(wyniki$Number, by = list(Category = wyniki$Year), FUN = sum)
wyniki_per <- left_join(wyniki, wyniki_sum, by = c("Year" = "Category"))
wyniki_per$Ratio <- wyniki_per$Number / wyniki_per$x
p3 <- ggplot(wyniki_per, aes(x = Year, y = Ratio, fill = Class)) +
geom_bar(position = "dodge", stat = "identity") +
facet_wrap(~ Class)+
theme_minimal(base_size = 16) +
scale_fill_manual(values = c("#e41a1c","#fc9272", "#9ecae1", "#377eb8")) +
theme(legend.position = "bottom") #+
#ggtitle("Ratio of each class throughout years")
p3
```
<p> </p>
Except for 2019, 2018 and 2016, percentage of fully reproducible papers (III class) is stable. In the newest articles, this percentage is slightly higher. Year 2016 is the only one, where unreproducible papers were in the majority. Only in 3 cases, percentage of reproducible articles dropped below 60%.
<p> </p>
```{r, echo=FALSE, fig.cap= "Summarized results throughout years", warning=FALSE, message=FALSE}
p4 <- ggplot(wyniki_per, aes(x = Year, y = Ratio, fill = Class)) +
geom_bar(data = wyniki_per[wyniki_per$Type == "Non-reproducible", ], stat = "identity", aes(y= Ratio * (-1))) +
geom_bar(data = wyniki_per[wyniki_per$Type == "Reproducible", ], stat = "identity") +
theme_minimal(base_size = 16) +
scale_fill_manual(values = c("#e41a1c","#fc9272", "#9ecae1", "#377eb8")) +
theme(legend.position = "bottom") +
coord_flip() +
scale_y_continuous(labels = abs)
#+ ggtitle("Articles reproducibility throughout years")
p4
```
<p> </p>
### Summary and conclusions
This article has presented an analysis of scientific papers reproducibility in the context of publication date. As a part of this work, 280 articles from RJournal have been verified. Collected results show that even though recently published articles are more likely to be fully reproducible than older ones, time does not affect reproducibility as we could have expected. A higher ratio of complete reproducibility occurs only for papers from the last 2 years. In articles from 2009 – 2017 there is no evident correlation between reproducibility and year of publication. However, several patterns are possible to recognize. Firstly, except for the year 2016, in each year percentage of reproducible articles (class II or III) was higher than unreproducible ones (class 0 or I). Secondly, the proportion of fully reproducible articles seems to oscillate between 30% - 40%. Moreover, the earliest years have a similar or even lower ratio of complete irreproducibility than later ones. These unexpected observations might be explained by the fact that older packages appear to be less dependent on other libraries. Additionally, modern packages contain more complex and dedicated functions, therefore they are more vulnerable to changes.
Undoubtedly, this paper does not cover all aspects of scientific articles obsolescence, however, we believe that the data we have collected might be a valuable starting point for further research.