公众号关注 “GitHubDaily”

设为 “星标”,每天带你逛 GitHub!

转自机器之心

前不久,图灵奖得主 Yann LeCun 公开质疑谷歌大脑的论文无法复现,引起了社区热议。Lecun 表示,即使是 NLP 的一些顶级研究人员也无法复现谷歌大脑的语言模型 Transformer-XL 所得到的结果。此外,有人还面向广大研发人员发出了「江湖悬赏令」,称成功复现者将获得「酬劳」。

迄今为止,行业内仍有相当数量的优质研究未能复现,这也使得后来的研究工作多多少少受到影响。但由于各项研究的本质各不相同,所以这类问题需要多维度地去看待。例如,一篇偏理论的论文其算法可能不是核心,又或者由于研究所用数据涉及所有权问题,因此代码无法公开,从而导致可复现性受到阻碍。

那么研究论文的代码是否应该「开源」?我们来看开发者们的观点。

论文代码是否应该「强制」开源?

近日,一位网友在 Reddit 社区呼吁,希望所有研究者都能在发表论文的同时公开自己的代码,否则应该被直接拒绝。

发起人认为,任何形式的研究行为均可看做对知识体系的贡献,并终将造福于人类社会。在他看来,不将论文代码公开阻碍了这一进程,这样的行为不应受到鼓励。

他表示自己经常听到类似这样的评论:「如果我需要用代码申请专利并用它赚钱怎么办?」发起人给出了如下解决方案:不要写研究论文,而是为专利准备相关项目和文档。

此外也有这样的评论:「如果有人剽窃我的想法怎么办?」发起人建议,可以将论文先上传到 arXiv 这样的论文预印版平台上。

发起人同时表示,审稿人在论文代码没有公开的情况下就接收论文,这点让他感到理解无能。难道科学领域的审稿过程不应该确保其研究结果的可复现性吗?审稿人是如何做到在论文代码未公开的情况下进行测试的呢?

就目前的情况而言,公开代码并不是研究者发表论文时的「硬性规定」。在这一话题的评论区,许多人表达了自己的观点:

观点 1:研究本来就是要共享

写论文之前,就要准备好为新技术的研究和开发做贡献,因为研究本来就是要共享的。隐瞒那些公开后能够造福大众的重要信息,这样的行为是卑劣的。

观点 2:有些数据、代码是保密的,不能也不愿公开

我在石油领域做 ML 工作,这个领域的数据和代码都没有人公开,因为这些东西是保密的。那些论文的作者仅抛出一些方程来「解释」他们的神经网络是如何工作的。这些方法都是使用 Keras、PyTorch 等框架基于现有方法实现的,但作者仍然选择不公开他们的代码。

为什么会这样?很大程度上是为了避免别人仔细检查他们所提出的方法。每个人都会在论文中写道「我们进行了超参数调整并选择了最优的参数」。但这些超参数到底是多少,谁又知道呢?

因为它们属于 ML 应用研究,严格来说并不是 ML 本身,所以这些研究全部基于现有实现是没有问题的,但是这类研究也没有什么价值。

很多时候情况确实非常荒谬——「未完全解释的方法」使用「未公开的数据」在「未共享的模型」上取得了 98%的准确率。这就像是一篇删除了你想知道的所有研究重点的 Medium 文章。

神回复:

我做了一个准确率为 100% 的人脸识别项目。来源:相信我就好了,哥们儿。

观点 3:论文本身应该包含足够多的细节,但是否开源是各人的自由

论文本身就应该包含足够多的细节,这样其他人才能了解如何复现。分享代码可以让他人轻松地复现,但如果论文作者不愿分享的话,则需要在方法部分提供更多的细节,这样读者才能自行复现。决定是否分享代码是研究者的自由,别人无权干涉。

观点 4:是否公开代码需根据研究类型而定

我是做理论研究的,甚至不知道如何创建 docker 容器。我发表了很多论文,并在 GitHub 上公开了所有的代码。有时候我会使用不同的编程语言来实现我的论文,那些方法依然有效。

如果论文所提出的方法无法从外部验证,那么它是否缺乏作为有用工具的依据?方法的设计应独立于其编程方式。在我看来,决定论文是否需要公开代码时,根据论文的具体贡献来做判断是更明智的做法,而不是一概而论。

观点 5:不会拒绝没有代码的论文,但会有疑虑

他们并不是不能写方法实现,但是「令」他们这么做可能毫无意义。你已经有了可以生成结果的脚本,为什么不直接把它们放到 GitHub 上呢?

我从未因为论文没有代码而拒绝一篇论文,但是没有代码会让我产生很多疑虑。

强制提交代码可能不切实际

ICML、ICLR 和 NeurIPS 都在努力推进将实验代码和数据作为评审材料的一部分提交,并鼓励作者在评审或出版过程中提交代码以帮助结果可复现。

以机器之心近期报道的 NeurIPS 为例:NeurIPS 组委会从 2019 年起就鼓励论文作者提交代码(非强制),而且成效显著。在 NeurIPS 2019 的最后提交阶段,有 75% 的被接收论文附带了代码。今年,NeuIPS 将代码提交从「鼓励」变成了「强烈建议」(仍不强制),还提供了提交代码的准则和模板。

目前依然有很多研究结果缺乏可复现性,很多优秀研究没有提供对应的代码。从可复现性层面看,每一年相较上一年都有不错的进步,同时也受到越来越多的关注。从研究角度来说,很多后来的研究者会基于先驱工作做一些新的探索,而缺乏可复现性将使其变得举步维艰。

此外,秉承着辩证思考的观点,有些研究者会对前沿工作有些怀疑,认为其研究结果存在水分。而提供可复现的代码能在一定程度上消除这样的质疑。

但不公开代码就直接拒绝未免过于「一刀切」,毕竟,可复现性并不是评价论文的唯一标准。

可复现性是重要的属性,但不是唯一的属性

如果对强制要求可复现性进行「一刀切」,将导致非常糟糕的后果。举例而言,部分研究真正有价值的部分是展示可能性,「什么是可能的?」这个问题也很关键,部分研究连代码也未发布,如果将可复现性作为绝对价值来看待,那么就会大概率错失这类研究成果。

采用「放之四海皆准」的策略是一种错误,要求每一篇论文都是可编程复现的会降低各类研究社区的活力与创新。机器之心早期报道过微软研究院 John Langford 的观点,值得借鉴。

从机器学习角度出发,John Langford 认为其研究类型至少有三种:

  • 算法:研究目标是发现一些更好的算法以解决各种学习问题,是顶会中最典型的类型。

  • 理论:研究目标是一般性地理解哪些学习算法是可能的,哪些是不可能的。虽然这些论文同样可能提出算法,但它们通常并不要求一定要实现,因为这会浪费作者、评审者和读者的时间。

  • 应用:这些研究的目标是解决特定的任务。AlphaGoZero 就是一个例子,它在围棋领域中用算法击败了世界冠军。对于这类研究而言,由于计算量大、数据所有权等特点,编程的可复现性可能不切实际。

而另一种可行方案是将代码作为补充资料进行定位,例如像附录那样查看代码(和数据)的提交,以便于评审探究和使用。而对于作者本人而言,提供额外的代码也便于说服那些善于质疑的评审。

值得肯定的是,各大顶会的组委会都在积极尝试探索针对提交代码的「平衡」,没有所谓的「一刀切」,从 19 年的尝试到今年初看效果,还是能感受到长足的进步。找到最适合各社区的「平衡」才是长久之道。

参考链接:https://www.reddit.com/r/MachineLearning/comments/fzss9t/d_if_a_paper_or_project_doesnt_publicly_release/


推荐阅读:
霸榜 GitHub,一款开源的 Linux 神器!这张「二维码」在 GitHub 上火了...
写一个开源的 macOS 软件可以赚多少钱?
如果你觉得学习 Git 很枯燥,那是因为你还没玩过这款游戏!学不会设计模式,是因为你还没用过这个神奇的网站!

论文代码不开源,应该被直接拒稿?相关推荐

  1. AI论文代码强制开源?“我反对!”

    晓查 发自 凹非寺  量子位 报道 | 公众号 QbitAI AI论文,到底该不该强制开源代码? NeurIPS 2020官方近日发布了一份开源指南.从2019开始,NeurIPS就"强烈建 ...

  2. NeurIPS 2020论文评审结果出炉,提前拒稿、作者审稿惹争议,网友:改投别家吧...

    点击蓝字  关注我们 来源|机器之心 NeurIPS 2020 论文评审结果出来了,你有被评审结果「摧残」到吗? 经历了两次 deadline 推迟之后,NeurIPS 2020 的论文评审结果终于出 ...

  3. 约束多目标优化 约束多目标进化/演化算法入门论文文献推荐 大部分论文代码已开源

      在实际生活中常常会碰到需要同时优化多个目标的应用问题,这些问题又往往包含许多个约束条件,这样的问题通常被称为约束多目标优化问题,它的数学表达式为: minimizeF(x)=(f1(x),f2(x ...

  4. 论文写作 N: 为什么我被花式拒稿?

    写论文的时候要换位思考: 如果我是审稿人或读者, 我会怎么批评这篇论文? 强烈建议写完论文之后不要急着投, 在手里放一周, 然后给自己写一个尽可能详细的审稿意见. 如果你不会, 就从本贴描述的几个方面 ...

  5. 论文投稿后,还能更改作者吗?这样操作或将遭到拒稿

    今天小编Unionpub 学术来分享一下关于作者变更的问题. 学术论文署名需要严肃对待.但在实际投稿时,有些作者会因为各种原因,在投稿后随意更改论文作者署名,比如增添新作者或是删减现有作者,又或是对作 ...

  6. 完整复现何恺明ICCV获奖论文结果并开源 !(附论文开源代码)

    ICCV 作为计算机视觉的顶级会议,2017年共收到2143篇论文投稿,比上一届ICCV2015的1698篇增加了26.2%.共621篇被选为大会论文,录用比例28.9%:poster.spotlig ...

  7. 论文不公开代码,应该被直接拒稿?

    点击上方"小白学视觉",选择加"星标"或"置顶" 重磅干货,第一时间送达 论文代码是否应该公开已是争论已久的问题,有从业者呼吁通过代码提交减 ...

  8. NVIDIA ECCV18论文:超像素采样网络助力语义分割与光流估计(代码将开源)

    (欢迎关注"我爱计算机视觉"公众号,一个有价值有深度的公众号~) 计算机视觉中超像素指具有相似纹理.颜色.亮度等特征的相邻像素构成的具有一定视觉意义的不规则像素块.它利用像素之间特 ...

  9. c++实验总结_史上最全场景文字检测资源合集(70篇重要论文 + 15个开源代码 + 176个实验结果 + 1305个统计信息)...

    本文总结了2012年以来在场景文本检测领域的70篇代表性论文.21个常用数据集.15份开源代码,包含176个实验结果以及超过1300条统计信息.Github资源链接见文末. 一.前言 许多自然场景中包 ...

最新文章

  1. 【每日一英语】“baker's dozen”是“十几”呢?
  2. React多页面应用脚手架-v1.3.0
  3. Silverlight学习之——事件编程
  4. Qt中应用程序的打包与发布
  5. JAVA正则表达式实例教程(转帖收藏)
  6. Windbg教程-调试非托管程序的基本命令上
  7. 通过Java反编译揭开一些问题的真相
  8. ssl1341-Asteroids【最大匹配,最小点覆盖,图论】
  9. 【错误记录】Invalid character found in method name. HTTP method names must be tokens
  10. 云原生与AI时代的存储该是什么样?新华三发布全NVMe智能闪存与智慧中枢数据平台
  11. nextcloud icon_聊一聊爱车吉利ICON带给我的用车感受
  12. 01背包 (dp专题)
  13. camera驱动电源配置_基于AD7656-1和ADuC7026评估电源时序控制影响
  14. 1.性能之巅 洞悉系统、企业与云计算 --- 绪论
  15. 同步与异步、异步与回调
  16. golang copy-on-write思想应用
  17. 74CMS_v4.2.1-v4.2.129后台Getshell
  18. while循环python次数定义_Python学习笔记之While循环用法分析
  19. 51单片机KEILC51的安装
  20. 新浪微博SSO登陆机制

热门文章

  1. 如何重构J2EE应用程序以使用 ring功能
  2. 618值得买手机排行:1500~4500元手机推荐来了,Top3闭眼买
  3. Flutter学习之路 AspectRatio 组件
  4. java截取倒数后六位的字符串_java 字符串截取的三种方法(推荐)
  5. Kali linux 学习笔记(十九)缓冲区溢出——linux(crossfire) 2020.3.1
  6. 在linux用utorrent下载文件,在Ubuntu 10.04下使用uTorrent下载六维空间资源
  7. Python正则表达式: 元字符/转义/分组/匹配原则/re模块属性方法大全
  8. 【Vue】如何使用vuex解决兄弟组件传值?
  9. 2014年博创杯参赛历程记
  10. oracle通配符过滤(模糊匹配)