0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

TensorFlow的衰落與PyTorch的崛起

jf_WZTOguxH ? 來(lái)源:AI前線 ? 作者:Comnavitottori ? 2022-11-04 14:23 ? 次閱讀

谷歌于 2015 年開放了一種小型資源,即 2015 年谷歌大腦研究項(xiàng)目,名為 TensorFlow,實(shí)質(zhì)上創(chuàng)造了現(xiàn)代機(jī)器學(xué)習(xí)的生態(tài)系統(tǒng)。其普及速度之快,令谷歌成為了主流人工智能產(chǎn)品的擁有者。

但是現(xiàn)在,情況已經(jīng)完全不同了,谷歌已經(jīng)喪失了開發(fā)者的人心,轉(zhuǎn)向了 Meta。

谷歌的 TensorFlow 曾經(jīng)是一款無(wú)所不在的機(jī)器學(xué)習(xí)工具,但后來(lái)卻落后于 Meta 機(jī)器學(xué)習(xí)工具 PyTorch。PyTorch 首次在 Facebook 開發(fā),在 2017 年作為測(cè)試版開源,PyTorch 逐漸成為了領(lǐng)軍人物。

在采訪開發(fā)者、硬件專家、云提供商以及熟悉谷歌機(jī)器學(xué)習(xí)工作的人士時(shí),他們的觀點(diǎn)也是相同的。TensorFlow 在爭(zhēng)奪開發(fā)者人心的競(jìng)爭(zhēng)中落敗。其中有些人甚至使用了令人難以理解的確切說(shuō)法:“PyTorch 正在享用 TensorFlow 的午餐”。

專家稱,經(jīng)過(guò) Meta 在開源社區(qū)中的一系列戰(zhàn)術(shù)失誤、開發(fā)決策和智勝策略,谷歌引領(lǐng)未來(lái)互聯(lián)網(wǎng)上的機(jī)器學(xué)習(xí)的機(jī)遇可能將會(huì)慢慢消逝。自那以后,PyTorch 就成了開發(fā)人員和科學(xué)研究人員的機(jī)器學(xué)習(xí)開發(fā)工具。

谷歌在 PyTorch 的陰影下,悄悄地研發(fā)了一種 名為 JAX(一度是“JustAfter eXecution”的縮寫,但是正式意義上已經(jīng)沒有什么意義了)的機(jī)器學(xué)習(xí)框架,許多人認(rèn)為它是 TensorFlow 的繼承者。

該項(xiàng)目的知情人士向 Insider 透露,谷歌大腦和谷歌的 DeepMind 人工智能公司基本上都放棄了 TensorFlow,轉(zhuǎn)而改用 JAX,以便為谷歌其他部門的跟進(jìn)鋪平道路。一位谷歌代表向 Insider 證實(shí),JAX 目前已經(jīng)在谷歌大腦和 DeepMind 中得到了廣泛的采用。

項(xiàng)目地址:https://github.com/google/jax/releases

熟悉谷歌機(jī)器學(xué)習(xí)工作的人士稱,JAX 起初受到了很大的內(nèi)部阻力。他們表示,谷歌員工過(guò)去一直使用 TensorFlow。盡管它使用起來(lái)可能很困難,但是在谷歌的雇員中,這始終是一個(gè)讓人困擾的統(tǒng)一因素。JAX 的方法更加簡(jiǎn)單得多,但是他們說(shuō),這也改變了谷歌在內(nèi)部構(gòu)建軟件的方式。

熟悉該項(xiàng)目的人表示,這款工具將會(huì)有望在今后數(shù)年內(nèi)成為所有使用機(jī)器學(xué)習(xí)的谷歌產(chǎn)品的支柱,就像 2010 年代末 TensorFlow 所做的那樣。

而 JAX 似乎已經(jīng)從谷歌的邊緣走向了中心。Salesforce 告訴 Insider,她已經(jīng)在自己的研究團(tuán)隊(duì)中采用了 JAX。

“JAX 是一項(xiàng)工程壯舉,”Julia 編程語(yǔ)言的創(chuàng)建者 Viral Shah 說(shuō),專家們經(jīng)常將其與 JAX 相提并論。“我認(rèn)為 JAX 是一種獨(dú)立的編程語(yǔ)言,通過(guò) Python 進(jìn)行實(shí)例化。如果你堅(jiān)持 JAX 想要的規(guī)則,它就能發(fā)揮它的神奇力量,而且可以做到讓人嘆為觀止?!?/p>

谷歌現(xiàn)在想要重回霸主的位置,同時(shí)也從開發(fā) TensorFlow 時(shí)犯下的錯(cuò)誤中汲取教訓(xùn)。但是,專家們說(shuō),由于他現(xiàn)在不得不放棄這個(gè)已經(jīng)贏得了開發(fā)者人心的開源工具,這將是一項(xiàng)很大的挑戰(zhàn)。

TensorFlow 的衰落與 PyTorch 的崛起

據(jù)提供給 Insider 的數(shù)據(jù)顯示,PyTorch 在一家必讀的開發(fā)者論壇上的帖子正在迅速追趕 TensorFlow。來(lái)自 Stack Overflow 的參與度數(shù)據(jù)表明,以其在論壇問(wèn)題中的份額衡量,TensorFlow 在最近幾年中的人氣一直處于停滯狀態(tài),而 PyTorch 的參與度卻在持續(xù)上升。

TensorFlow 一開始就有很強(qiáng)勁的勢(shì)頭,并且隨著其發(fā)布而越來(lái)越流行。像 Uber 和 Airbnb 這樣的公司,以及像 NASA 這樣的組織很快就選擇了 TensorFlow,并將 TensorFlow 應(yīng)用到更復(fù)雜的項(xiàng)目中,這些項(xiàng)目要求在巨大的數(shù)據(jù)集上訓(xùn)練算法。截至 2020 年 11 月,TensorFlow 已累計(jì)下載 1.6 億次。

但是,谷歌不斷增量的功能更新使 TensorFlow 變得很不方便,而且對(duì)用戶來(lái)說(shuō)也很不友好,即使是谷歌內(nèi)部的雇員、開發(fā)者和接近該項(xiàng)目的人也會(huì)這么認(rèn)為。隨著機(jī)器學(xué)習(xí)領(lǐng)域以驚人的速度發(fā)展,谷歌必須 經(jīng)常使用新的工具來(lái)更新其框架。熟悉該項(xiàng)目的人士表示,由于更多的人參與進(jìn)來(lái),這個(gè)項(xiàng)目已經(jīng)開始向公司內(nèi)部擴(kuò)展,而不是將重點(diǎn)放在那些原本讓 TensorFlow 成為首選工具的部分。

專家告訴 Insider,這種狂熱的貓鼠游戲在很多率先推出的公司中是很常見的。舉例來(lái)說(shuō),谷歌并非首家創(chuàng)立搜索引擎的公司,它只是能夠 從 AltaVista 或雅虎等祖先的錯(cuò)誤中學(xué)習(xí)。

與此同時(shí),PyTorch 在 2018 年在 Facebook 人工智能研究實(shí)驗(yàn)室 發(fā)布了其完整版本。盡管 TensorFlow 和 PyTorch 都是基于 Python,而 Python 是機(jī)器學(xué)習(xí)專家的首選語(yǔ)言,但是 Meta 已經(jīng)在迎合開源社區(qū)的需求方面投入了大量資金。據(jù)了解 TensorFlow 項(xiàng)目的人說(shuō),PyTorch 在一定程度上得益于專注小而美的產(chǎn)品,而 TensorFlow 團(tuán)隊(duì)一直在錯(cuò)過(guò)。

“我們主要使用 PyTorch;它擁有最廣泛的社區(qū)支持,”機(jī)器學(xué)習(xí)創(chuàng)業(yè)公司 Hugging Face 的研究工程師 Patrick von Platten 說(shuō)?!拔覀冋J(rèn)為 PyTorch 可能在開源方面做得最好。他們確保問(wèn)題能夠得到在線解答。所有的例子都有效。PyTorch 一直有一個(gè)非常開源的方法?!?/p>

有些最大的組織(包括那些依賴 TensorFlow 的組織),Weave 項(xiàng)目是在 PyTorch 上運(yùn)行 的 。不久之后,像特斯拉和 Uber 這樣的公司 開始在 PyTorch 上進(jìn)行最艱難的機(jī)器學(xué)習(xí)研究項(xiàng)目。

每一個(gè)額外的特性,有時(shí)會(huì)復(fù)制那些讓 PyTorch 非常受歡迎的元素,使得 TensorFlow 對(duì)其最初的研究人員和用戶而言,變得越來(lái)越臃腫了。其中一個(gè)例子是,它在 2017 年增加了一個(gè)“敏銳執(zhí)行”(Keen Execution)的特性,這是 Python 的原生特性,可以讓開發(fā)者很容易對(duì)自己的代碼進(jìn)行分析和調(diào)試。

進(jìn)入 JAX,谷歌機(jī)器學(xué)習(xí)的未來(lái)

隨著 PyTorch 和 TensorFlow 之間的戰(zhàn)斗爆發(fā),谷歌內(nèi)部的一支小型研究團(tuán)隊(duì)致力于開發(fā)一種新的框架,以便更容易訪問(wèn)專門設(shè)計(jì)的芯片(稱為張量處理單元,或 TPU),這些芯片是其人工智能方法的基礎(chǔ),只能通過(guò) TensorFlow 獲得。

團(tuán)隊(duì)研究人員包括 Roy Frostige、Matthew James Johnson 和 Leary 在 2018 年發(fā)布了一篇題為《通過(guò)高級(jí)可追溯性編譯機(jī)器學(xué)習(xí)軟件》(Compilation of machine learning software through high-level traceability)的論文,描述了最終成為 JAX 的內(nèi)容。

Adam Paszky 是之前在 Facebook 工作期間 PyTorch 的原作者之一,他在 2019 年開始以學(xué)生身份與 Johnson 合作,并在 2020 年初全職加入 JAX 團(tuán)隊(duì)。

新項(xiàng)目 JAX 提出了一種更加直觀的設(shè)計(jì),他可以處理最復(fù)雜的機(jī)器學(xué)習(xí)問(wèn)題:將一個(gè)大問(wèn)題的工作分散到多個(gè)芯片上。JAX 不是為不同的芯片運(yùn)行單一的代碼位,而是自動(dòng)分配工作。這個(gè)要求來(lái)自在谷歌工作的一個(gè)很大的特點(diǎn):只要你需要,就可以立即使用大量的 TPU 來(lái)完成任何你想要的一切。

JAX 解決了谷歌研究人員在處理需要越來(lái)越多計(jì)算能力的大型問(wèn)題時(shí)所面臨的一個(gè)基本問(wèn)題。

JAX Wind Catch,這個(gè) skunkworks 項(xiàng)目正在被谷歌內(nèi)部的開發(fā)者和研究人員所接受。熟悉該項(xiàng)目的人士說(shuō),這是一種繞開許多開發(fā)者對(duì) TensorFlow 不敬的做法,并且能夠很快地把復(fù)雜的技術(shù)問(wèn)題分散到多個(gè) TPU 上。

谷歌在 JAX 方面的最大挑戰(zhàn) 是用 PyTorch 實(shí)施其 Meta 戰(zhàn)略

同時(shí),PyTorch 和 TensorFlow 都是以同樣的方式開始的。它們一開始是研究項(xiàng)目,然后是好奇心,接著成為機(jī)器學(xué)習(xí)研究中的標(biāo)準(zhǔn)。最后,研究人員將它們從學(xué)術(shù)界傳播到了世界其他地方。

但是,JAX 也面臨著許多挑戰(zhàn)。首先,在許多方面,它對(duì)其他框架的依賴性還很強(qiáng)。開發(fā)者和專家們表示,JAX 沒有提供一種加載數(shù)據(jù)和預(yù)處理數(shù)據(jù)的方法,它需要 TensorFlow 或 PyTorch 來(lái)處理大量的設(shè)置。

JAX 基本框架 XLA,它也為谷歌 TPU 設(shè)備進(jìn)行了極大的優(yōu)化。該框架還能與更傳統(tǒng)的 GPUCPU 協(xié)同工作,不過(guò),據(jù)了解該項(xiàng)目的人表示,該項(xiàng)目仍有辦法通過(guò)優(yōu)化 GPU 和 CPU,從而達(dá)到與 TPU 的同等水平。

谷歌發(fā)言人表示,對(duì) TPU 的關(guān)注源于 2018 年至 2021 年的監(jiān)管和戰(zhàn)略上的混亂,造成了缺乏投資和對(duì) GPU 支持的次優(yōu)優(yōu)先級(jí),以及缺乏與大型 GPU 提供商 Nvidia 的合作,這兩方面都在迅速改善。這位發(fā)言人說(shuō),谷歌自己的內(nèi)部研究也非常關(guān)注 TPU,導(dǎo)致缺乏良好的 GPU 使用反饋。

Cerebras Systems 公司首席執(zhí)行官 Andrew Feldman 說(shuō),隨著各公司希望將其工作分散到不同類型的機(jī)器上,專注于機(jī)器學(xué)習(xí),因此這種改進(jìn)將成為未來(lái)的關(guān)鍵。這家市值 40 億美元的初創(chuàng)公司,制造專注于機(jī)器學(xué)習(xí)的大型芯片。

他說(shuō):“任何以一種設(shè)備為特色而非另一種設(shè)備的行為,都會(huì)立刻被認(rèn)為是一種惡劣的行為,并且會(huì)受到開源社區(qū)的排斥。沒有人愿意被限制在一個(gè)單一的硬件提供商,這就是機(jī)器學(xué)習(xí)框架出現(xiàn)的原因。機(jī)器學(xué)習(xí)從業(yè)者希望確保他們的模型是可移植的,他們可以將其移植到他們選擇的任何硬件平臺(tái)上,而不是被鎖定在一個(gè)平臺(tái)上。”

同時(shí),PyTorch 本身現(xiàn)在已經(jīng)有將近 6 年的歷史了,遠(yuǎn)遠(yuǎn)超過(guò)了 TensorFlow 首次開始出現(xiàn)放緩跡象的年齡。目前還不清楚 Meta 項(xiàng)目是否會(huì)面臨與其谷歌支持的前輩類似的命運(yùn),但這可能意味著新事物出現(xiàn)的時(shí)機(jī)已經(jīng)成熟。有些專家和接近該項(xiàng)目的人士指出了谷歌的規(guī)模過(guò)大,并告誡批評(píng)家千萬(wàn)別把希望寄托在這個(gè)搜索巨頭身上。

審核編輯 :李倩

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 機(jī)器學(xué)習(xí)

    關(guān)注

    66

    文章

    8428

    瀏覽量

    132832
  • 生態(tài)系統(tǒng)
    +關(guān)注

    關(guān)注

    0

    文章

    703

    瀏覽量

    20750
  • pytorch
    +關(guān)注

    關(guān)注

    2

    文章

    808

    瀏覽量

    13282

原文標(biāo)題:JAX正從谷歌的邊緣項(xiàng)目走向核心

文章出處:【微信號(hào):AI前線,微信公眾號(hào):AI前線】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    利用Arm Kleidi技術(shù)實(shí)現(xiàn)PyTorch優(yōu)化

    PyTorch 是一個(gè)廣泛應(yīng)用的開源機(jī)器學(xué)習(xí) (ML) 庫(kù)。近年來(lái),Arm 與合作伙伴通力協(xié)作,持續(xù)改進(jìn) PyTorch 的推理性能。本文將詳細(xì)介紹如何利用 Arm Kleidi 技術(shù)提升 Arm
    的頭像 發(fā)表于 12-23 09:19 ?226次閱讀
    利用Arm Kleidi技術(shù)實(shí)現(xiàn)<b class='flag-5'>PyTorch</b>優(yōu)化

    PyTorch 數(shù)據(jù)加載與處理方法

    PyTorch 是一個(gè)流行的開源機(jī)器學(xué)習(xí)庫(kù),它提供了強(qiáng)大的工具來(lái)構(gòu)建和訓(xùn)練深度學(xué)習(xí)模型。在構(gòu)建模型之前,一個(gè)重要的步驟是加載和處理數(shù)據(jù)。 1. PyTorch 數(shù)據(jù)加載基礎(chǔ) 在 PyTorch
    的頭像 發(fā)表于 11-05 17:37 ?461次閱讀

    Pytorch深度學(xué)習(xí)訓(xùn)練的方法

    掌握這 17 種方法,用最省力的方式,加速你的 Pytorch 深度學(xué)習(xí)訓(xùn)練。
    的頭像 發(fā)表于 10-28 14:05 ?234次閱讀
    <b class='flag-5'>Pytorch</b>深度學(xué)習(xí)訓(xùn)練的方法

    pytorch怎么在pycharm中運(yùn)行

    第一部分:PyTorch和PyCharm的安裝 1.1 安裝PyTorch PyTorch是一個(gè)開源的機(jī)器學(xué)習(xí)庫(kù),用于構(gòu)建和訓(xùn)練神經(jīng)網(wǎng)絡(luò)。要在PyCharm中使用PyTorch,首先需
    的頭像 發(fā)表于 08-01 16:22 ?1508次閱讀

    pycharm如何調(diào)用pytorch

    引言 PyTorch是一個(gè)開源的機(jī)器學(xué)習(xí)庫(kù),廣泛用于計(jì)算機(jī)視覺、自然語(yǔ)言處理等領(lǐng)域。PyCharm是一個(gè)流行的Python集成開發(fā)環(huán)境(IDE),提供了代碼編輯、調(diào)試、測(cè)試等功能。將PyTorch
    的頭像 發(fā)表于 08-01 15:41 ?669次閱讀

    TensorFlow是什么?TensorFlow怎么用?

    TensorFlow是由Google開發(fā)的一個(gè)開源深度學(xué)習(xí)框架,它允許開發(fā)者方便地構(gòu)建、訓(xùn)練和部署各種復(fù)雜的機(jī)器學(xué)習(xí)模型。TensorFlow憑借其高效的計(jì)算性能、靈活的架構(gòu)以及豐富的工具和庫(kù),在學(xué)
    的頭像 發(fā)表于 07-12 16:38 ?755次閱讀

    pytorch如何訓(xùn)練自己的數(shù)據(jù)

    本文將詳細(xì)介紹如何使用PyTorch框架來(lái)訓(xùn)練自己的數(shù)據(jù)。我們將從數(shù)據(jù)準(zhǔn)備、模型構(gòu)建、訓(xùn)練過(guò)程、評(píng)估和測(cè)試等方面進(jìn)行講解。 環(huán)境搭建 首先,我們需要安裝PyTorch。可以通過(guò)訪問(wèn)PyTorch官網(wǎng)
    的頭像 發(fā)表于 07-11 10:04 ?573次閱讀

    PyTorch的介紹與使用案例

    PyTorch是一個(gè)基于Python的開源機(jī)器學(xué)習(xí)庫(kù),它主要面向深度學(xué)習(xí)和科學(xué)計(jì)算領(lǐng)域。PyTorch由Meta Platforms(原Facebook)的人工智能研究團(tuán)隊(duì)開發(fā),并逐漸發(fā)展成為深度
    的頭像 發(fā)表于 07-10 14:19 ?427次閱讀

    tensorflowpytorch哪個(gè)更簡(jiǎn)單?

    PyTorch更簡(jiǎn)單。選擇TensorFlow還是PyTorch取決于您的具體需求和偏好。如果您需要一個(gè)易于使用、靈活且具有強(qiáng)大社區(qū)支持的框架,PyTorch可能是一個(gè)更好的選擇。如果
    的頭像 發(fā)表于 07-05 09:45 ?920次閱讀

    tensorflowpytorch哪個(gè)好

    tensorflowpytorch都是非常不錯(cuò)的強(qiáng)大的框架,TensorFlow還是PyTorch哪個(gè)更好取決于您的具體需求,以下是關(guān)于這兩個(gè)框架的一些關(guān)鍵點(diǎn):
    的頭像 發(fā)表于 07-05 09:42 ?730次閱讀

    tensorflow簡(jiǎn)單的模型訓(xùn)練

    在本文中,我們將詳細(xì)介紹如何使用TensorFlow進(jìn)行簡(jiǎn)單的模型訓(xùn)練。TensorFlow是一個(gè)開源的機(jī)器學(xué)習(xí)庫(kù),廣泛用于各種機(jī)器學(xué)習(xí)任務(wù),包括圖像識(shí)別、自然語(yǔ)言處理等。我們將從安裝
    的頭像 發(fā)表于 07-05 09:38 ?732次閱讀

    keras模型轉(zhuǎn)tensorflow session

    在這篇文章中,我們將討論如何將Keras模型轉(zhuǎn)換為TensorFlow session。 Keras和TensorFlow簡(jiǎn)介 Keras是一個(gè)高級(jí)神經(jīng)網(wǎng)絡(luò)API,它提供了一種簡(jiǎn)單、快速的方式來(lái)構(gòu)建
    的頭像 發(fā)表于 07-05 09:36 ?570次閱讀

    TensorFlow的定義和使用方法

    TensorFlow是一個(gè)由谷歌人工智能團(tuán)隊(duì)谷歌大腦(Google Brain)開發(fā)和維護(hù)的開源機(jī)器學(xué)習(xí)庫(kù)。它基于數(shù)據(jù)流編程(dataflow programming)的概念,將復(fù)雜的數(shù)學(xué)運(yùn)算表示為
    的頭像 發(fā)表于 07-02 14:14 ?839次閱讀

    如何使用PyTorch建立網(wǎng)絡(luò)模型

    PyTorch是一個(gè)基于Python的開源機(jī)器學(xué)習(xí)庫(kù),因其易用性、靈活性和強(qiáng)大的動(dòng)態(tài)圖特性,在深度學(xué)習(xí)領(lǐng)域得到了廣泛應(yīng)用。本文將從PyTorch的基本概念、網(wǎng)絡(luò)模型構(gòu)建、優(yōu)化方法、實(shí)際應(yīng)用等多個(gè)方面,深入探討使用PyTorch
    的頭像 發(fā)表于 07-02 14:08 ?440次閱讀

    TensorFlowPyTorch深度學(xué)習(xí)框架的比較與選擇

    深度學(xué)習(xí)作為人工智能領(lǐng)域的一個(gè)重要分支,在過(guò)去十年中取得了顯著的進(jìn)展。在構(gòu)建和訓(xùn)練深度學(xué)習(xí)模型的過(guò)程中,深度學(xué)習(xí)框架扮演著至關(guān)重要的角色。TensorFlowPyTorch是目前最受歡迎的兩大深度
    的頭像 發(fā)表于 07-02 14:04 ?1007次閱讀