forked from mini-pw/2021L-WB-Book
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path4-3-dl.Rmd
190 lines (132 loc) · 12.8 KB
/
4-3-dl.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
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
## Rethinking the U-Net architecture for multimodal biomedical image segmentation
*Grudzień Adrianna, Łukaszyk Marcin, Piasecki Michał *
### Abstrac
In our work we wanted to explore what reproducibility is, and how it applies to deep learning.
The articles we had choesen are An Improvement of Data Classification Using Random Multimodel Deep Learning (RMDL) and MultiResUNet : Rethinking the U-Net architecture for multimodal biomedical image segmentation.
In both papers we faced simmilar issues and limitation ,yet we have concluded our work with diffrent results for each article.
First paper is unreproducible and second one is mostly reproducible.
### What Reproducibility Is?
Reproducibility of an experiment plays crucial role in scientific community and serves as a proof for validity of both experiment and its consequences.
It constitutes a basis of scientific endeavours and enable us to use science as a method to comprehend reality around us.
This essential term means ability to repeat particular experiment and obtain similar results, while having the same conditions, data, tools and means of measurement.
Unfortunately, it is not always possible to repeat experiments and conditions required, them might prevent larger community to conduct them.
To show these difficulties, we would like to provide two examples, which clearly illustrate, that some experiments might be almost impossible to repeat.
Firstly, let’s consider repeating Galileo experiments of dropping objects from fixed height to establish, whether objects fall with the same velocity.
Such simple test is available for everyone, who is eager to explore experimentally basic Newtonian principles.
On the other hand, if we would like to switch to quantum physics and prove experimentally quantum nonlocality, we are more than likely to be unable to conduct experiments proving this theory.
The infrastructure required to conduct such experiments makes reproducibility an exclusive idea limited to only handful of people.
It is hard to underestimate the significance of reproducibility in science. We listed below main reasons for its importance:
1 Proof for correctness of experiment
Having obtained same results of an experiment conducted many times by the independent researchers, we are ensured that results are not coincidence.
As a result, we can start treating new results as a proper description of phenomena around us.
2 Different views on experiment
After repeating an experiment and acquiring same results, other researchers may draw different, interesting conclusions.
It enables to use conducted experiment to full extent, squeezing out as many conclusions about reality as it is possible.
3 Possibility of improving experiment
Other researchers may figure out how to improve experiment to obtain results in more efficient or precise way.
### First article (An Improvement of Data Classification Using Random Multimodel Deep Learning (RMDL) )
#### Summary of Article
The main purpose of the article is creating combinations of different neural networks and finding the best model.
In order to achieve these goal, authors use various optimalization methods , dropout layers and different models for prediction.
Authors describe methods used in article: TF-IDF, Word2Vec for Feature Extraction, NaïveBayesClassifier, SVM and S2GD for classification and types of neural networks : Deep Neural Network, Convolutional Neural Network and Recurrent Neural Network.
They explain all algorithms and ideas used in their work.
Consequently, they combine different architectures to obtain one model – RMDL.
Having constructed the model, authors decide to evaluate their masterpiece on different datasets.
They use it both on text data (WOS, Reuters IMDB, 20newsgroup) and image data (MNIST, Cifar-10).
Authors evaluate model with metrics like : Precision, Recall F1 and Score.
The all model is build with usage of Cuda, tensorflow and keras libraries.
At the end, authors discuss how its model might come useful in classification task.
#### Our Work with Reproducibility of First Article
We had run all our experiments in google Collaboratory.
One of the datasets was not available due to unavailability of server that article was referring to.
Rest of datasets were freely accessible.
Most of our issues were due to hardware limitations.
The predominant ones were RAM lack of free memory errors and memory leaks.
Collaboratory doesn’t allow to run program more than 12 hours straight so we couldn’t train the biggest models.
Our main goal was to explore reproducibility of given paper, and main issue that we combined were lack of definitions of terms that authors used. One of them was error rate that wasn’t defined.
They didn’t specify what depth of RMDL is and a lot of our work was to guess based of their results what is the proper definition.
#### Reproducibility of this Article
We cannot acknowledge it as reproducible.
The results that were achieved by authors are not properly documented and defined in article making it hard to check if we had similar results.
Some of our struggle results from the hardware limitations where we cannot train similar sized models or in extreme situations cannot train at all.
### Second article (MultiResUNet : Rethinking the U-Net architecture for multimodal biomedical image segmentation)
#### Introduction
Throughout XX century we have developed multiple methods for imaging human bodies.
Radiography, functional magnetic resonance and fluoroscopia are just mere examples of methods we invented.
It is hard to underestimate its benefits, they enable us to understand processes inside our bodies to much greater extent.
Thanks to them, it is possible to detect pathologies and monitor our health at scale not imaginable before.
Having been exposed to such vast amount of medical images, computer scientists started thinking about creating software, which could analyse them automatically.
Since late 60’s researchers have been attempting to build models segmenting medical images and conducting diagnosis.
Were we to create such software, we would relieve doctors from segmenting images manually and support them with independent diagnosis from computer.
As a result, it would make our healthcare system less overwhelmed and more people could seek help in predicament.
#### Summary
There were multiple ways of creating such models.
Firstly, ‘rule-based’ approach was commonplace, with scientists explicitly setting rules for model evaluation.
Poor generalization resulted in different approaches based on geometrical analysis or fuzzy logic. Nonetheless, recently we can notice general shift towards Deep Learning as a way of segmenting and diagnosing images.
Convolutional neural networks have been obtaining outstanding results, with U-Net architecture standing out of the crowd.
We would like to review article “MultiResUNet Rethinking the U-Net Architecture for biomedical image segmentation”.
In this article, modification of U-Net – MultiResUNet is proposed.
Authors are convinced that small changes in well know U-Net architecture lead to better model performance.
Authors list situations, in which U-Net architecture do not get sufficient results.
#### What is U-Net?
U-net is a deep learning architecture that was proposed in 2015.
It's a modification of simple neural network with odd number layers of convolution layers and a max-pooling or up-convolutions layers, which is used to for segmentation of images.
This modification is a series of connections between each simmilar distanced layer from middle one.
This “bends” our network making it U-shaped, thus the name.
Each level of network consists of series of convolution layers and then max-pool or up-convolution layer that depends on which side of and U shape are we in.
```{r u-net, out.width="700", fig.align="center", echo=FALSE, fig.cap='Example of U-net'}
knitr::include_graphics('images/4-3-unet.PNG')
```
In order to improve U-Net , authors decide to introduce following changes in model architecture.
They factorize the bigger and more expensive 5 × 5 and 7 × 7 filters as a succession of 3 × 3 filters.
This saves computations as we need calculate 3 3x3 convolutions layers to have similar results as calculating 3x3, 5x5 and 7x7 layers.
They concatenate all of the estimated layers with one made from 1x1 convolution layers.
This allows to better retrieve spatial features from different scales.
```{r ResBlock, out.width="700", fig.align="center", echo=FALSE, fig.cap='Example of ResBlock'}
knitr::include_graphics('images/4-3-Resblock.PNG')
```
The excellence of U-Net architecture stems mainly from the introduction of connection between layers, which enables to save spatial information while going deeper into U-Net architecture.
However, authors speculate that combination of a simple copy of an output of previous convolutional layer and information received after all transformations conducted in model results in discrepancy in information carried by both of them.
To minimize this discrepancy authors suggest “ResPath” - series of consecutive convolutional layers.
They decrease number of convolutional layers while going deeper into the architecture, due to smaller difference in information in “depth” of the model.
```{r ResPath, out.width="700", fig.align="center", echo=FALSE, fig.cap='Example of ResPath'}
knitr::include_graphics('images/4-3-Respath.PNG')
```
In the end we get simmilar looking neural network but with improvements in most places.
Authors states that their structure has simmilar computational complexity but gives better results.
```{r MultiResUNet, out.width="700", fig.align="center", echo=FALSE, fig.cap='MultiResUNet'}
knitr::include_graphics('images/4-3-multiresunet.PNG')
```
Authors test their improved architecture on 5 different datasets and compare results with “basic” U-Net.
They introduce new metric: Jacard Index to measure performance of both models. For mask A and model’s marked area B it calculates the intersection of both sets divided by their union.
Authors show that their model obtain better results, learns faster and is less vulnerable to perturbations.
#### Our Work with Reproducibility of Second Article
We decided to repeat experiments in Google Colab using Python
Unfortunately,we were not able to obtain all datasets used by authors. After long research, we managed to download datasets: Fluorescence microscopy images Murphy Lab, Electron microscopy images, Dermoscopy images IC-2017dataset
Having downloaded datasets, we encountered many problems.
There were multiple problems with transforming datasets into desired format used by authors.
Problems with conversion, partition of datasets and ambiguous files led to frustration.
Moreover, Google Colab, environment in which we tried to reproduce results, had not enough RAM to smoothly generate results.
At the end, we managed to obtain some results, which were similar to results from the article.
[Wykresy dermoskopi i endoskopi]
```{r Original Rsults, out.width="700", fig.align="center", echo=FALSE, fig.cap='Orginal Plots'}
knitr::include_graphics('images/4-3-OGPlots.PNG')
```
```{r Our Rsults, out.width="700", fig.align="center", echo=FALSE, fig.cap='Our Plots'}
knitr::include_graphics('images/4-3-OurPlots.PNG')
```
#### Reproducibility of this article
Article is reproducible. In article authors try to improve U-Net architecture.
Providing simple explanations and empirical data, they explain motivation behind their improvements.
Unfortunately, few of datasets used by authors are no longer available, which may make it harder to conduct same experiments.
However, rest of the datasets is easily accessible, so it is still possible to verify results obtained by authors.
When it comes to authors argumentation behind new architecture, we are not completely satisfied. As students, who have little expertise in using Machine Learning in medical areas, we are not satisfied with mathematical explanations provided by the authors.
No mathematical proofs and small number of datasets make us feel unease, if authors’ architecture outperforms basic U-Net architecture globally.
### Conclusion
In both articles we coudn't simply state if article are reproducible.
We had to have non-binary measure for each.
First article is mostly unreproducible due to lack of proper deffinitions thath dosn't allow us to be sure thath our experiments are conducted in the same environment.
Second article is reproducible.
Our tries of recreating simmilar results were mostly positive and most of our issues were with hardwere limitations.
The biggest truble is some missing data stes thath are not longer available from refer to sources.
Some of our worry is in how authors explained their reasoning as it's mostly based on assumption and results.