逐层阅读 research paper:Dmitry Berenson 的方法论
本博客翻译了 这篇文章,包含很实用的 读论文的方法论。
读论文的四个 layers
在读论文之前,要首先搞清楚,自己读论文的目的是什么,或者 希望读到什么程度。
下表列出了常见的读论文目的,以及相应的理解程度 layers(1 最浅 4 最深):
目的 | layer | 目的 | layer |
---|---|---|---|
了解领域背景 | 1 | 评估是否引用论文(相同主题,方法非常不同) | 1 |
评估自己对该领域是否感兴趣 | 1 | 评估是否引用论文(相同主题,方法有些不同) | 2 |
关键词搜寻 | 1 | 思考自己如何引用该论文(相同主题,方法有些相似) | 3 |
课堂演示(5~10 min) | 2 | 思考自己如何引用该论文(相同主题,方法非常相似) | 4 |
课堂演示(>10 min) | 3 | 复现 | 4 |
review | 3 |
然后,分别介绍各个 layer 所需的理解程度 + 阅读论文方法。
layer 1:知道 main idea
如果只想 对该领域产生一些感性了解、看看自己是否感兴趣,或者 看看是否引用这篇论文(方法非常不同),读到 layer 1 就足够了。
- 需要回答以下问题:
- 【问题定义】作者试图解决 / 研究什么类型的问题 / 现象?
- 【问题重要性】读者为什么要关心这个问题 / 现象?
- 【novelty】proposed method 与 previous works 有什么不同?
- 【为何胜出】比 previous works 好在哪里?(比如 性能更好 / 更 general / 更快)
- 【论文在文献树上的位置】这是什么类型的方法?(通常有几种方法可以解决相同的问题)
- 【实际应用】这项工作有哪些应用?
- 需要阅读:
- abstract + intro + conclusion,获得全文概览。
- 图、表,有助于快速获取感性认知。
- related work,有助于理解 这篇论文在整个文献树上的位置。
- 如果搞 engineering,还需要看实验结果(小心 demoware)。
layer 2:知道 proposed method 的 structure
(首先确保已经做完 layer 1)
如果需要做个 5~10min 的 pre,或者 看看是否引用这篇论文(方法还是有些不同的),需要读到 layer 2。
- 需要做到以下内容:
- 【画出整个 method 的框图】,每一模块的 目的功能 + 输入输出。
- 通常,大多数模块我们都不关心(和论文主旨无关 / 自己不感兴趣),仅关心个别模块。
- 需要阅读:
- 图、表,原文直接给出 structure 图最好。
- method(以及 abstract intro 等),标注不清楚的地方(layer 3 再去 check),注意不要陷到细节里。
layer 3:比较重要的细节
(首先确保已经做完 layer 1 2)
如果需要做个超过 10min 的 pre,或者 决定如何引用这篇论文(方法有些类似),需要读到 layer 3。
▷▷▷ 是时候深入研究细节了!
- 需要做到以下内容:
- 密切关注作者的 main contribution,并确保理解 他们所谈论的每一步。
- 一个有用的实践,是想象一个给定的输入,模拟 proposed method 如何处理它。
- 例如,对于 A* 算法,想象一个有起点和目标的迷宫环境,并画出 A* 算法在搜索时会扩展的单元格(不需要全部画出,足以获得直觉)。甚至可以想象该方法的一个困难案例(例如 A* 的死胡同),并考虑 A* 如何应对它。
- 如果在做 engineering,也请仔细 check 实验结果:
- 【result & conclusion 匹配吗】结果是否证明了 该方法的合理性?
- 【有无遗漏的实验】是否有 应该测试但没测试的 案例 / 场景?
- 【performance & complexity 的权衡】(对于某些可量化的指标),proposed method 相比于其他方法的优势,能否使人接受 它新引入的 complexity?
- 【不 work 的场景】方法在哪些情况下失败?
- 密切关注作者的 main contribution,并确保理解 他们所谈论的每一步。
- 需要阅读:
- 追踪 有关 main method 的、自己不熟悉的引文。
- 我们应该遍历关键的引文,并至少通读一层的深度;但如果真的很重要,那么可能读两层。
- 如果在做 engineering,实验结果部分。
- 追踪 有关 main method 的、自己不熟悉的引文。
layer 4:其他细节
(首先确保已经做完 layer 1 2 3)
如果需要 决定如何引用这篇论文(方法非常相似,正在寻找它与我们的细微差别 ),或者 打算复现论文,或许需要读到 layer 4。
作者并不推荐读的那么细。
- 需要做到以下内容:
- 查看 structure 框图中,不是 main contribution 的所有其他模块,并研究如何实现它们。
- 或许我们还在寻找 实现过程的细微细节,这些 tricks 或许能改进 performance。
- 需要阅读:
- 不幸的是,在这一点上,原文作者能给出的一般性建议很少,除了 ① 理解要彻底,② 如果想实现这个方法,我们可能会在一开始就出错。(别担心,出错是自然的,因为论文在描述 implementation 时,不可避免会遗漏一些东西。)
往后退一步
如果想在它的基础上 继续前进一步,则在视野上 需要往后退一步,更加宏观 更加整体。
- 询问以下关键问题:
- 论文的优点是什么,即 它在哪些方面做得很好。
- 【论文合理性】实验结果真的能证明 他们 claim 的结论吗?
- 论文做了哪些假设?
- 【论文合理性】假设可能会限制 该方法对某些重要场景的适用性,甚至不适用于实际情况。
- 【论文完备性】有时候假设很清楚,但通常也有一些隐藏的假设。发现隐性假设的一个好方法是,试着想一个 “打破” 该方法的例子。
- 【进一步改进】可以通过 考虑拿掉某些假设的情况,来做下一步的改进。
- 如何改进这项工作?(可能是一些冒出来的想法)
- 某些 “未来展望” 章节的内容,很可能是事后诸葛亮,并不值得做。
- 论文的优点是什么,即 它在哪些方面做得很好。
逐层阅读 research paper:Dmitry Berenson 的方法论的更多相关文章
- 如何写出优秀的研究论文 Chapter 1. How to Write an A+ Research Paper
This Chapter outlines the logical steps to writing a good research paper. To achieve supreme excelle ...
- How to Read an Engineering Research Paper
How to Read an Engineering Research Paper William G. Griswold Department of Computer Science & E ...
- 写essay和research paper必用的17个网站
1.http://scholar.google.com/ 虽然还是Beta版,但个人已觉得现在已经是很好很强大了,Google学术搜索滤掉了普通搜索结果中大量的垃圾信息,排列出文章的不同版本以及被其它 ...
- ### Paper about Event Detection
Paper about Event Detection. #@author: gr #@date: 2014-03-15 #@email: forgerui@gmail.com 看一些相关的论文. 1 ...
- 译文 - Recommender Systems: Issues, Challenges, and Research Opportunities
REF: 原文 Recommender Systems: Issues, Challenges, and Research Opportunities Shah Khusro, Zafar Ali a ...
- 【文献阅读】Densely Connected Convolutional Networks-best paper-CVPR-2017
Densely Connected Convolutional Networks,CVPR-2017-best paper之一(共两篇,另外一篇是apple关于GAN的paper),早在去年八月 De ...
- 【机器学习Machine Learning】资料大全
昨天总结了深度学习的资料,今天把机器学习的资料也总结一下(友情提示:有些网站需要"科学上网"^_^) 推荐几本好书: 1.Pattern Recognition and Machi ...
- Awesome Deep Vision
Awesome Deep Vision A curated list of deep learning resources for computer vision, inspired by awes ...
- 机器学习(Machine Learning)&深度学习(Deep Learning)资料【转】
转自:机器学习(Machine Learning)&深度学习(Deep Learning)资料 <Brief History of Machine Learning> 介绍:这是一 ...
随机推荐
- c++ 关于二分的STL 详解
一.解释 以前遇到二分的题目都是手动实现二分,不得不说错误比较多,关于返回值,关于区间的左闭右开等很容易出错,最近做题发现直接使用STL中的二分函数方便快捷还不会出错,不过对于没有接触过的同学,二分函 ...
- Redis初启(一)
1.数据库存存储性能优化 在mysql的文章专题中我写过了关于传统关系型数据库的一些优化思路,整体来说,通过优化之后能够提升程序访问数据库的计算性能.但是还是有一些情况,即便是优化之后,使用传统关系型 ...
- ExtJS 布局-Anchor 布局(Anchor layout)
更新记录: 2022年5月30日 发布本篇 1.说明 anchor布局类似auto布局从上到下进行堆叠,但不同的是其可以指定每个元素相对于容器大小的比例. 当调整父容器大小,容器根据指定的规则调整所有 ...
- JavaScript与Node.js一起打造一款聊天App
聊天是我们人与人交流最直接的方式,互联网的加入使我们交流更加便捷.我们手机上的微信.QQ是我们手机必不可少的应用软件.那么,我们是否可以做一款聊天应用呢? 之前我自己闲着没事,研究过一些技术,做了一款 ...
- Node.js精进(5)——HTTP
HTTP(HyperText Transfer Protocol)即超文本传输协议,是一种获取网络资源(例如图像.HTML文档)的应用层协议,它是互联网数据通信的基础,由请求和响应构成. 在 Node ...
- Docker 与 K8S学习笔记(二十五)—— Pod的各种调度策略(上)
上一篇,我们学习了各种工作负载的使用,工作负载它会自动帮我们完成Pod的调度和部署,但有时我们需要自己定义Pod的调度策略,这个时候该怎么办呢?今天我们就来看一下如何定义Pod调度策略. 一.Node ...
- bat-注册表
注册表 注册表就像于是配置文件 linux下一切皆文件,windows下一切皆注册表 注册表(各种配置文件:系统设置.用户设置.软件的配置) HKEY_CLASSES_ROOT 超级管理员.系 ...
- NC207028 第k小数
NC207028 第k小数 题目 题目描述 给你一个长度为 \(n\) 的序列,求序列中第 \(k\) 小数的多少. 输入描述 多组输入,第一行读入一个整数 \(T\) 表示有 \(T\) 组数据. ...
- Phabricator Conduit API介绍
在Phabricator页面,可以完成创建和编辑Project.Task等操作.但是如果想实现外部系统可以自主操作Phabricator,那么就需要调用Phabricator Conduit API, ...
- IDEA快捷键之html篇-1
前端IDE中Emmet插件快捷输入HTML代码 前端IDE如VSCode.Atom.Sublime Text和Intellij Idea中使用Emmet插件快捷输入HTML代码的介绍 前端IDE中 ...