forked from hainh/sea-thru
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreport.tex
381 lines (332 loc) · 20.7 KB
/
report.tex
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
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
\documentclass[10pt,twocolumn,letterpaper]{article}
\usepackage[margin=2.5cm]{geometry}
\usepackage{times,epsfig,graphicx,amsmath,amssymb}
\usepackage[breaklinks=true,colorlinks=true,bookmarks=false]{hyperref}
\date{}
%%%%%%%%%%%%%%%%
\title{Improving Sea-Thru With Monocular Depth Estimation Methods}
\author{%
John Gibson\\
{\tt [email protected]}
}
\begin{document}
\maketitle
\begin{center}\textbf{Abstract}\\~\\\parbox{0.475\textwidth}{\em
% Abstract goes here
A recent advance in underwater imaging is the Sea-Thru method,
which uses a physical model of light attenuation to reconstruct
the colors in an underwater scene. This method utilizes a known
range map to estimate backscatter and wideband attenuation
coefficients. This range map is generated using structure-from-motion (SFM),
which requires multiple underwater images from various perspectives and
long processing time. In addition, SFM gives very accurate results, which are
generally not required for this method. In this work, we implement and
extend Sea-Thru to take advantage of convolutional monocular depth
estimation methods, specifically the Monodepth2 network. We obtain
satisfactory results with the lower-quality depth estimates with
some color inconsistencies using only one image.
}\end{center}
\section{Introduction}
%\begin{figure}[!t]
%\begin{center}
%\fbox{\rule{0pt}{3in} \rule{0.9\linewidth}{0pt}} % Place holder, replace with \includegraphics, etc.
%\end{center}
% \caption{Example of caption.}
%\label{fig:twocol}
%\end{figure}
%
%\begin{figure*}[!t]
%\begin{center}
%\fbox{\rule{0pt}{4in} \rule{0.9\linewidth}{0pt}} % Place holder, replace with \includegraphics, etc.
%\end{center}
% \caption{Example of caption.}
%\label{fig:onecol}
%\end{figure*}
Underwater image datasets must be color-reconstructed for species identification, salvage operations, and
other tasks requiring accurate visual information. Most datasets are manually color balanced using a color
chart, requiring human interaction and the presence of a color chart in the scene. Recently, a method called
Sea-Thru utilizing a physical model of light attenuation and backscatter in water was published~\cite{seathru},
and gained both media and scientific attention. Sea-Thru reconstructs colors in a physics-accurate way and
produces high-quality images that can be used as inputs to other machine learning algorithms or more easily
analyzed by humans. However, this method uses depth maps generated using Structure-from-Motion (SFM), a technique
that requires many images of the scene from different perspectives. This limits use of this technique to certain
classes of datasets that either contain these images or already include depth information.
In order to address this shortcoming, we turn to recent advances in monocular depth estimation. These convolutional
neural network-based methods use visual cues in the scene to produce a rough estimate of depth~\cite{bhoi2019monocular}.
Although these methods are generally trained using above-water images, with appropriate preprocessing we can obtain
a reasonable depth estimate for underwater images. This technique opens up Sea-Thru to applications where color
correctness is not necessarily crucial, but a more accurate rendition of colors is desired.
In order to evaluate our method, we use the underwater RGBD dataset provided by~\cite{seathru} and estimate depth
for these test images using monodepth2~\cite{monodepth2}, a monocular depth estimation framework by Godard
\textit{et al.} We then visually compare results from the two methods to determine color reconstruction accuracy,
as a direct comparison without accurate depth information is quite difficult.
\begin{figure}[!t]
\begin{center}
\includegraphics[width=3.0in]{out/example_1/orig.jpg}\newline
\includegraphics[width=3.0in]{out/example_1/depth_from_monodepth.png}
\end{center}
\caption{\small{Example of original image and recovered, color-corrected image from monocular depth estimation. Note
the red color shading in some areas of differing illumination and the image artifacts near the border. However, the
coloring is much improved.}}
\label{fig:exampleout}
\end{figure}
\section{Background \& Related Work}
\subsection{Underwater Imaging}
% Backscatter, wideband attenuation, depth dependence, etc.
Underwater imaging is inherently different from atmospheric imaging due to the nature of the medium.
Although backscatter and wideband attenuation occur in media such as air, the extent to which
these phenomena affect the image at normal depths is negligible. These phenomena
severely affect the image underwater, as if taking an image through a thick, colored fog
with uneven illumination -- clearly a challenging setting. Previous models based on atmospheric imaging
neglect the wavelength-dependency of the underwater setting and assume these coefficients to be the same,
in contrast to the Sea-Thru model, which evaluates the effects independently.
In the Sea-Thru model, underwater image formation can be modeled as the following:
\begin{equation}
\label{eqn:imageformation}
I_c = D_c + B_c
\end{equation}
where $c$ is an RBG channel, $I_c$ is the observed image for the channel, $D_c$ is the direct signal from the scene,
and $B_c$ is the effect of backscattering. As the medium has different attenuation coefficients and backscatter for
each wavelength of light, we must calculate these values independently for each color channel. Values closer to red
are more subject to attenuation, thus decreasing the intensity of the red channel and lending water its characteristic
blue-green cast, and backscatter contributes heavily the cloudiness in underwater scenes. If we can describe the
effect of backscatter and attenuation at each depth, we can reconstruct the image as follows:
\begin{equation}
\label{eqn:scenereconstruction}
J_c = D_c \exp(\beta_c^D(z)z)
\end{equation}
where $J_c$ is the true image, $D_c = I_c - B_c$, and $\beta_c^D(z)$ is the depth-dependent wideband attenuation
coefficient.
Backscattering is dependent on color channel $c$ as well as depth and can be modelled as
\begin{equation}
\label{eqn:backscatter}
\hat{B}_c = B^\infty_c\left(1 - \exp(-\beta^B_c z)\right) + J'_c \exp(-\beta^{D'}_c z)
\end{equation}
where $\hat{B}_c$ corresponds to the contribution of the backscattering in the
scene, $B^\infty_c$ corresponds to the global veiling light of the scene, and
$J'_c \exp(-\beta^{D'}_c z)$ corresponds to a residual term that behaves like the
image (e.g. to account for patches that are not truly black).
Thus, the image formation can be expanded as:
\begin{equation}
\label{eqn:imageformationexpanded}
I_c = J_c e^{\beta_c^D(z)z} + B^\infty_c \left( 1 - e^{-\beta_c^B(z)z} \right)
\end{equation}
\subsection{Monocular Depth Estimation}
Classical depth estimation pipelines use pairs of aligned stereo images. A physical model of disparity can therefore
be calculated from corresponding parts of the aligned imges. The fundamental challenge of monocular depth estimation is
that this physical model cannot be used, and therefore depth must be estimated from visual cues in the image. Many
approaches exist for this task, most trained end-to-end using depth maps from stereo images. These can give a reasonable
approximation of depth for many tasks, but generally only generalize well to images like the training sets.
\subsubsection*{Monodepth}
A recent advance in monocular depth estimation is the development of an end-to-end self-supervised network for depth
estimation. We briefly describe the method; for more details see ~\cite{monodepth2}. The network takes in a pair
of images of the scene from different viewpoints and trains both a depth and pose network based on those images.
Instead of the classical minimization of the error in the depth maps, the network instead estimates the pose
between the two images, computes the depth map, and then calculates the reprojection of the first image onto the
second using the estimated pose and depth map. The loss to be minimized is the reconstruction error of this estimation.
This allows the network to be trained purely from stereo images, instead of relying on complicated and expensive
depth map estimates.
\section{Method}
\subsection{Preprocessing Depth Maps}
\subsubsection*{Structure-from-Motion Maps}
The provided structure-from-motion maps have depths provided in meters.
However, depth information is provided for only a portion of the scene, and the other depth
values must be imputed.
In addition, some areas of the depth map have invalid (e.g. negative)
values.
We first find the minimum and maxiumum depth values in the map. Then, for some user-defined
percentage $p$, (default 1\%), we set the values in the lowest $p$ percent of depths to the maximum
value in that range.
We observe that missing values in the depth maps correspond to far-off areas, and thus we set the
missing values to the maximum value of the depth map.
This assumption produces images with inaccurate colors in some areas of the scene with missing values,
but still generally offers improvement over the raw image.
\subsubsection*{Monodepth Maps}
Raw underwater images are first fed through an adaptive histogram equalization pipeline before being used
as input to the monodepth2 network.
In contrast to depth maps determined from SFM and provided in the dataset, depth maps from monodepth2 and other monocular
methods are generally relative depths instead of absolute depths;
e.g. depth values are dimensionless and only given in relation to other objects in the scene as
opposed to absolute depths in meters.
We must therefore estimate absolute depths from the provided relative depths. Visibility in water declines
rapidly with distance, and therefore we define a maximum visibility in meters (default 10) by which to scale the
relative depths. In addition, due to the field of view of the specific lens, elements at small depths
are generally not visible when imaging the scene. To account for this, we simply add a value in meters (default 1)
to each depth in the scene. These maps can then be used in the Sea-Thru algorithm.
As code for Sea-Thru is not provided by the authors, we first implement the method, with
some modifications.
\subsection{Estimating Backscatter}
\label{sec:estbackscatter}
Backscatter values are estimated as in the Sea-Thru paper.
The authors of Sea-Thru observe that image values corresponding to black
or completely shadowed regions of the scene are entirely determined by
backscatter, as there is no light reflected from the scene itself in those
areas.
To estimate backscatter, the authors divide the region into evenly-spaced depth
intervals and take the bottom 1\% of RGB triplets in that interval. These pixels
are then split into individual RGB values, and values for $B^\infty_c$, $\beta^B_c$,
$J'_c$, and $\beta^{D'}_c$ (equation~\ref{eqn:backscatter}) are then estimated for each color channel using the
corresponding depth values, thus giving a model for backscatter at all depths for
each color channel. We used scipy's \texttt{curve\_fit} function to perform this optimization
and found that the method works well in practice when taking the parameters with minimum reconstruction
error after 10 random restarts. However, we found data at very small depths
to be quite noisy, and therefore we set a minimum cutoff for the depths of colors used in
the estimations (default 0.1st percentile of the depth values).
\subsection{Estimating Attenuation Coeffcients}
\subsubsection*{Course Estimate}
Although we estimated a single scalar value for $\beta^D_c$ in section~\ref{sec:estbackscatter},
in the Sea-Thru model the wideband attenuation coefficients take into account regions of the scene
not in shadow, thus reflecting light to the sensor through the
water medium. Therefore, we must refine our estimate of $\beta^D_c$ to account for varying depths.
Empirical results and simulations support modeling $\beta^D_c(z)$ as a two term exponential:
\begin{equation}
\label{eq:attenuation}
\beta^D_c(z) = a \exp(b z) + c \exp(d z)
\end{equation}
where $a, b, c, d$ are scalars. Recall from equation~\ref{eqn:scenereconstruction} that
$J_c = D_c \exp(\beta_c^D(z)z)$, and thus:
\begin{align}
\label{eqn:courseest}
\frac{\log{J_c} - \log{D_c}}{z} &= \beta_c^D(z) \nonumber \\
\frac{-\log{E_c}}{z} &= \beta_c^D(z)
\end{align}
Where $E_c$ corresponds to the illuminant map of the scene. This allows us to obtain
a rough estimate of $\beta_c^D(z)$ for the scene.
\subsubsection*{Estimating Illuminant Map}
The authors of Sea-Thru use local space average color (LSAC) to esstimate the illuminant
map using a range map. This consists of updating the following equations for each pixel
location $(x,y)$:
\begin{align}
a'(x, y) &= \frac1{|N_\epsilon(x, y)|} \sum_{(x', y') \in N_e(x, y)} {a_c(x', y')} \label{eqn:lsac1} \\
a_c(x, y) &= D_c(x, y) \ p + a'_c(x, y)(1-p) \label{eqn:lsac2}
\end{align}
where $p$ controls the locality of the neighborhood (default 0.01), and
$N_\epsilon(x, y)$ is the neighborhood of $(x, y)$ such that
\begin{equation}
N_e(x, y) = \lbrace (x', y') \: : \: |z(x, y) - z(x', y')| \leq \epsilon \rbrace
\end{equation}
Then $\hat{E}_c = fa_c$, where $f$ is a constant depending on scene geometry and controls global illumination.
The authors of Sea-Thru suggest $f=2$.
In addition, we set the minimum size of a neighborhood to be 50 pixels, and reassign smaller neighborhoods
to the closest neighborhood of large enough size. In addition, we perform morphological closing on the
neighborhood map with a square structural element of side length 3 to remove holes and refine edges.
We also perform bilateral filtering on the illumination map to smooth regions inside neighborhoods
while paying attention to neighborhood boundaries.
\subsubsection*{Refined Estimate}
To refine the estimate, the authors of Sea-Thru suggest minimizing the reconstruction error of depths as follows:
first, rewrite equation~\ref{eqn:courseest} as
\begin{equation}
\label{eqn:reconstructedz}
\hat{z} = \frac{-\log{E_c}}{\beta_c^D(z)}
\end{equation}
and finding the values of $a, b, c, d$ that satisfy
\begin{equation}
\label{eqn:minimizationZ}
\min_{\beta_c^D(z)} \lVert z - \hat{z} \rVert
\end{equation}
We formulate the problem as suggested, but failed to achieve consistent convergence. Instead, we minimize
\begin{equation}
\label{eqn:minimizationB}
\min_{a,b,c,d} \lVert \beta_c^D(z) - \hat{\beta_c^D} \rVert
\end{equation}
with 10 random restarts, bounding $a,b,c,d$ to obtain decaying exponentials, and taking the parameter set that
minimizes the reconstruction error in equation~\ref{eqn:minimizationZ}. This has good convergence performance
and performs well in practice. If this still does not converge, we use a linear model instead of the two-term
exponential. We also add a multiplier $l$ to counteract the overestimation from the illumination map's value of
$f$ (default 0.5). In addition, we filter the input data such that successive data points are at least 1\% of the
full depth range away from each other; this balances the data set such that an exponential trend can be estimated
instead of being dominated by the clusters of datapoints at minimum and maximum depth.
\subsection{White Balancing}
After reconstructing the image using equation~\ref{eqn:scenereconstruction}, we perform white balancing.
Sae-Thru uses the Gray World Hypothesis assumption for white balancing, but we find a more visually appealing
image from calculating the channel scaling factors as the inverse of the average of the top 10\% of the values
in each channel.
\section{Experimental Results}
\subsection{Comparison of Results}
We compare the estimated values for parameters on the same image in figures~\ref{fig:Bccomparison}
and~\ref{fig:betaDcomparison}, and compare the final images in figure~\ref{fig:imgcomparison}.
The results are visually similar for both depth estimation methods. In addition, example neighborhood maps,
lighting maps, etc. are shown in figure~\ref{fig:components}.
\begin{figure}[!t]
\begin{center}
\includegraphics[width=3.0in]{out/example_1/Bc_values_sfm.png}\newline
\includegraphics[width=3.0in]{out/example_1/Bc_values_monodepth.png}
\end{center}
\caption{\small{Comparison of estimated $B_c(z)$ values between SFM depth maps (top) and monodepth maps (bottom).
The results are quite similar, lending support to this method.}}
\label{fig:Bccomparison}
\end{figure}
\begin{figure}[!t]
\begin{center}
\includegraphics[width=3.0in]{out/example_1/betaD_values_sfm.png}\newline
\includegraphics[width=3.0in]{out/example_1/betaD_values_monodepth.png}
\end{center}
\caption{\small{Comparison of estimated $\beta^D_c(z)$ values between SFM depth maps (top) and monodepth maps (bottom).
Although the monodepth values are generally noisier, an exponential curve is still produced, and the final results
are still visually similar.}}
\label{fig:betaDcomparison}
\end{figure}
\begin{figure}[!t]
\begin{center}
\includegraphics[width=3.0in]{out/example_1/depth_from_sfm_processed.jpg}\newline
\includegraphics[width=3.0in]{out/example_1/depth_from_monodepth_processed.jpg}
\end{center}
\caption{\small{Comparison of final images using SFM (top) and monodepth2 (bottom). Images were run
with identical parameters, and min and max depths for monodepth were estimated using
the SFM depth map to increase correspondence between the images. Both images have had exposure
increased by 1 stop for the purposes of comparison. Artifacts due to inaccurate depth are present in each image;
in the SFM image, depth information is only present for the seafloor and part of the reef. One can see where
this information ends by the thin black line on the top image.
Areas with depth values from SFM have excellent reconstruction, but areas without depth information
were set the the maximum depth in the image, and have color artifacts. The monodepth map also has color artifacts
from inaccurate depth values.}}
\label{fig:imgcomparison}
\end{figure}
\begin{figure*}[!t]
\begin{center}
\includegraphics[width=7.0in]{out/example_1/components_monodepth.png}\newline
\end{center}
\caption{\small{From left-to-right, top-to-bottom: input, neighborhood map, backscatter coefficients, illumination map,
attenuation coefficients, and unprocessed output for a monodepth-processed image.}}
\label{fig:components}
\end{figure*}
\subsection{Success and Failure Cases of Monocular Depth Estimation}
In images with depth maps that smoothly vary or vary by small amounts, monocular depth estimation (coupled with
semi-accurate estimation of min and max depths by eye) can give results that are very similar to the true values.
An example of this is shown in figure~\ref{fig:imgcomparison2}.
This is mainly due to the smoothness of the estimated depth map and the estimation of minimum depth instead of
and intrinsic strength of the network. In other cases where the image is of a scene where multiple objects and
the sea floor are visible, the network also gives reasonable results. This is likely due to the similarity of
the scene to stereo training data.
\begin{figure}[!t]
\begin{center}
\includegraphics[width=3.0in]{out/example_2/depth_from_sfm.png}\newline
\includegraphics[width=3.0in]{out/example_2/depth_from_monodepth.png}
\end{center}
\caption{\small{An example where both methods produce the same results given accurate min and max depth values.
SFM is top, monodepth is bottom.}}
\label{fig:imgcomparison2}
\end{figure}
In scenes with little depth information or those very different from a scene above water, however, the network
produces considerably less appealing images. Although the adaptive contrast stretching helps, the scene is
simply too attenuated and unfamiliar to produce a good estimate.
\section{Conclusion}
In this work, we implement and extend the Sea-Thru method to take advantage of monocular depth estimation.
Although this does not produce as accurate results as using depth maps from Structure-from-Motion, monocular
depth estimation methods can produce visually appealing results on real data with minimal user interaction.
We show samples of images computed using both methods and discuss where monocular depth estimation fails to
produce accurate results.
In the future, we hope to enable the training of monocular depth estimation networks on this kind of color-corrected
underwater scene data to hopefully improve the accuracy of this method in underwater and heavily obscured scenes.
In fact, iterative rounds of color correction and retraining of the monocular depth network on this data could
rapidly improve performance on underwater scenes.
We hope that this method proves useful to those wishing to view the beautiful colors of coral reefs and ocean floors
without the use of specialized equipment.
\section*{Acknowledgments}
Thank you to the original authors for providing the training data and Gabriel Brostow and Niantic, Inc. for
releasing and maintaining monodepth2.
{\small
\bibliographystyle{unsrt}
\bibliography{refs} % Create file refs.bib, and run bibtex.
}
\end{document}