5 B( m: n9 \" d7 m9 F2 r3 V 去年11月有相关的报道,谷歌用深度学习守卫海洋:如何在 4.5 万张照片中找到一只濒危的“美人鱼”?- D% N& c& ]: r# J8 }
4 q( ?- }, _1 L: A
今年TensorFlow-dev-summit中又提到了这个是利用tensorflow自动化构建的海洋生物系统,使用的是大量的高像素的无人机航拍图片,然后在图片中找出到了”海牛“这种濒临物种。 C; E* j1 {2 W7 c1 ]! L
. e8 o- x e3 _$ i 前几天我看到了报道中的内容,然后提问了 用Tensorflow自动化构建海洋生物系统,利用上万的图片训练,找到濒临物种“海牛”是什么原理? - 人工智能 - 知乎 ,后来经过回答者给出了该应用的相关论文《Automating Marine Mammal Detection in Aerial Images Captured During Wildlife Surveys: a Deep Learning Approach》,看了论文后发现,报道有误导,因为报道中给出的图片非常模糊,显得识别的效果非常出人意料,但是在论文中使用的训练数据和人工标注数据其实是非常高像素的无人机航拍图片,如图:
* m" n% u1 M3 O* b
0 b# Q7 n D2 a& R3 w' v/ W 论文使用的方法其实也是非常常规的方法,而且主要也是有非常优质的数据,我们来看看。
8 W/ W3 h# A; H2 }6 x) t 1. 系统概述 ; U- t/ @3 N! w" w$ w& v
8 M/ E$ Z( D% ?, c 首先使用Simple Linear Iterative Clustering (SLIC)做图像分割,然后把每一个分割区块看做一个region proposal,然后对候选窗口使用DCNN做one-hot分类。
1 l) u) w3 D& }& H" m8 a3 K" R+ K" ] 2. SLIC参数设置 SLIC中最重要的一个参数设置就是把像素分类的个数,论文中设置的个数的计算方式为:6 r2 q: \; W" [; P3 T. G4 y" z
0 T1 Z. L, o! Q, w$ w. Z' J
其中,w,h分别是整个画面的宽和长,d是一个预测的每个bounding box的长,这个其实可以理解为就是”海牛“在画面中的大小。 0 R! p# e5 S. @8 d; O
3. CNN结构
! f: [' {; I% l+ T 文中的CNN结构对比了两种结构, 第一种是没有使用maxout的结构:) o: r" G2 p& |% e2 a! P1 u
3 }9 L* c. Y, K i2 E 第二种是使用了maxout的结构: 4 g5 N) X! A6 g) W1 f1 R
- q8 W; x: U1 k! z$ i) K 4. 实验结果 3 W! K* h- j5 a# L O' S6 M( l
" ], @- `+ F8 [( _0 h; F # W0 d$ I6 X% M" A% E
准确度其实还不是很高,不过训练还是挺快的,文中用GPU训练,大概就训练了半天,实际应用中,据说可以帮助解决80%的海牛检测。
1 e- X' y w/ R- u7 ]1 ? 5. 延伸 [1]实验数据的HDF5格式和python code[2]另外一个关于bowhead whale的研究:《Trends in bowhead whales in West Greenland: Aerial
9 g( B9 x+ g7 q4 j6 f1 _ surveys vs. genetic capture-recapture analyses》
% A4 i% h4 D8 N+ ?; F ---人工智能应用系列·介绍---
7 d2 @6 |: u2 S2 X 本系列介绍各领域的一些有趣的人工智能应用,原理可能并没有那么复杂,目的是开拓大家的视野和思路,也许人工智能能做的事情比我们想象的还要多。 专栏地址:人工智能应用系列 - 知乎专栏 (欢迎投稿和关注)# D7 h: K# v3 W( n2 T/ f+ R
本人的Live:「跨领域人工智能应用」系列Live的开篇--如何做跨领域人工智能应用 # p4 g# u. }, b3 B0 H6 t. f" N1 T& Q
8 C; V$ Y6 v1 q9 J! b* N
/ n& u+ u* g* U
8 I1 w3 c) T" s: W$ L7 T+ ^
* W3 H" h% M, F# p* Z, b |