女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

PyTorch已為我們實現了大多數常用的非線性激活函數

人工智能君 ? 來源:人工智能君 ? 作者:人工智能君 ? 2022-07-06 14:47 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

PyTorch已為我們實現了大多數常用的非線性激活函數,我們可以像使用任何其他的層那樣使用它們。讓我們快速看一個在PyTorch中使用ReLU激活函數的例子:

在上面這個例子中,輸入是包含兩個正值、兩個負值的張量,對其調用ReLU函數,負值將取為0,正值則保持不變。

現在我們已經了解了構建神經網絡架構的大部分細節,我們來構建一個可用于解決真實問題的深度學習架構。上一章中,我們使用了簡單的方法,因而可以只關注深度學習算法如何工作。后面將不再使用這種方式構建架構,而是使用PyTorch中正常該用的方式構建。

1.PyTorch構建深度學習算法的方式

PyTorch中所有網絡都實現為類,創建PyTorch類的子類要調用nn.Module,并實現__init__和forward方法。在init方法中初始化層,這一點已在前一節講過。在forward方法中,把輸入數據傳給init方法中初始化的層,并返回最終的輸出。非線性函數經常被forward函數直接使用,init方法也會使用一些。下面的代碼片段展示了深度學習架構是如何用PyTrorch實現的:

如果你是Python新手,上述代碼可能會比較難懂,但它全部要做的就是繼承一個父類,并實現父類中的兩個方法。在Python中,我們通過將父類的名字作為參數傳入來創建子類。init方法相當于Python中的構造器,super方法用于將子類的參數傳給父類,我們的例子中父類就是nn.Module。

2.不同機器學習問題的模型架構

待解決的問題種類將基本決定我們將要使用的層,處理序列化數據問題的模型從線性層開始,一直到長短期記憶(LSTM)層。基于要解決的問題類別,最后一層是確定的。使用機器學習或深度學習算法解決的問題通常有三類,最后一層的情況通常如下。

?對于回歸問題,如預測T恤衫的銷售價格,最后使用的是有一個輸出的線性層,輸出值為連續的。

?將一張給定的圖片歸類為T恤衫或襯衫,用到的是sigmoid激活函數,因為它的輸出值不是接近1就是接近0,這種問題通常稱為二分類問題。

?對于多類別分類問題,如必須把給定的圖片歸類為T恤、牛仔褲、襯衫或連衣裙,網絡最后將使用softmax層。讓我們拋開數學原理來直觀理解softmax的作用。舉例來說,它從前一線性層獲取輸入,并輸出給定數量樣例上的概率。在我們的例子中,將訓練它預測每個圖片類別的4種概率。記住,所有概率相加的總和必然為1。

3.損失函數

一旦定義好了網絡架構,還剩下最重要的兩步。一步是評估網絡執行特定的回歸或分類任務時表現的優異程度,另一步是優化權重。

優化器(梯度下降)通常接受一個標量值,因而loss函數應生成一個標量值,并使其在訓練期間最小化。某些用例,如預測道路上障礙物的位置并判斷是否為行人,將需要兩個或更多損失函數。即使在這樣的場景下,我們也需要把損失組合成一個優化器可以最小化的標量。最后一章將詳細討論把多個損失值組合成一個標量的真實例子。

上一章中,我們定義了自己的loss函數。PyTorch提供了經常使用的loss函數的實現。我們看看回歸和分類問題的loss函數。

回歸問題經常使用的loss函數是均方誤差(MSE)。它和前面一章實現的loss函數相同。可以使用PyTorch中實現的loss函數,如下所示:

對于分類問題,我們使用交叉熵損失函數。在介紹交叉熵的數學原理之前,先了解下交叉熵損失函數做的事情。它計算用于預測概率的分類網絡的損失值,損失總和應為1,就像softmax層一樣。當預測概率相對正確概率發散時,交叉熵損失增加。例如,如果我們的分類算法對圖3.5為貓的預測概率值為0.1,而實際上這是只熊貓,那么交叉熵損失就會更高。如果預測的結果和真實標簽相近,那么交叉熵損失就會更低。

下面是用Python代碼實現這種場景的例子。

為了在分類問題中使用交叉熵損失,我們真的不需要擔心內部發生的事情——只要記住,預測差時損失值高,預測好時損失值低。PyTorch提供了loss函數的實現,可以按照如下方式使用。

PyTorch包含的其他一些loss函數如表3.1所示。

表3.1

L1 loss 通常作為正則化器使用;第4章將進一步講述

MSE loss 均方誤差損失,用于回歸問題的損失函數

Cross-entropy loss 交叉熵損失,用于二分類和多類別分類問題

NLL Loss 用于分類問題,允許用戶使用特定的權重處理不平衡數據集

NLL Loss2d 用于像素級分類,通常和圖像分割問題有關

4.優化網絡架構

計算出網絡的損失值后,需要優化權重以減少損失,并改善算法準確率。簡單起見,讓我們看看作為黑盒的優化器,它們接受損失函數和所有的學習參數,并微量調整來改善網絡性能。PyTorch提供了深度學習中經常用到的大多數優化器。如果大家想研究這些優化器內部的動作,了解其數學原理,強烈建議瀏覽以下博客:

PyTorch提供的一些常用的優化器如下:

?ADADELTA

?Adagrad

?Adam

?SparseAdam

?Adamax

?ASGD

?LBFGS

?RMSProp

?Rprop

?SGD

審核編輯 黃昊宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 非線性
    +關注

    關注

    1

    文章

    217

    瀏覽量

    23656
  • 函數
    +關注

    關注

    3

    文章

    4381

    瀏覽量

    64907
  • pytorch
    +關注

    關注

    2

    文章

    809

    瀏覽量

    13966
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    為什么高壓電機大多數采用星型接法?

    高壓電機大多數采用星型接法的原因,主要與電機的啟動、運行、負載能力、保護要求等方面的性能需求密切相關。以下是詳細解釋: 一、星型接法的基本原理 星型接法是指將三相電動機的定子繞組接成星形,其中
    的頭像 發表于 03-03 07:36 ?928次閱讀
    為什么高壓電機<b class='flag-5'>大多數</b>采用星型接法?

    ADS8472采集進來的數據大多數是1039(040F),3087(0C0F),為什么?

    進來的數據大多數是1039(040F),3087(0C0F),難道這是芯片出廠設置的測試數據嗎? 2、既然是采樣的正弦波信號,按照我的理解,芯片理論上在每個采樣周期采集到的數據都應該不同,頂多有兩三
    發表于 12-24 08:13

    非線性負載分為哪些類型

    非線性負載是指其電流波形與電壓波形不成線性關系的負載,這類負載在電力系統中較為常見,會對電網產生一系列不良影響。根據不同的分類標準,非線性負載可以分為以下幾種類型: 一、按負載性質分 電阻性
    發表于 12-18 15:18

    stdio.h實現printf函數?

    我們平時包含的 stdio.h 頭文件,里面是不是實現 printf 函數? 為什么會有這個疑問?因為每次使用 printf,就得包含 stdio.h ,這就導致很多同學誤以為,st
    的頭像 發表于 12-18 10:28 ?617次閱讀

    線性光學和非線性光學有什么區別?

    密切相關的其他現象有關的科學 ”。 根據光與物質相互作用的方式,光學可分為線性光學和非線性光學。線性光學(LO)是經典光學的基礎,側重于光的可預測線性相互作用。 相比之下,
    的頭像 發表于 12-10 06:31 ?896次閱讀

    非線性負載產生諧波的原因及危害

    在現代電力系統中,非線性負載的應用日益廣泛,隨之而來的諧波問題也引起了廣泛關注。諧波的產生不僅影響電力系統的穩定運行,還會對各類電氣設備造成嚴重危害。本文將深入探討非線性負載為什么會產生諧波,并分析
    的頭像 發表于 12-04 16:51 ?1893次閱讀

    RCD非線性負載:原理、應用與優勢

    在現代電力電子系統中,非線性負載的應用越來越廣泛,其重要性也日益凸顯。RCD非線性負載作為一種典型的非線性模擬負載,廣泛應用于測試數據中心發電機組、UPS等供電設備,以確保其在實際使用中的安全性
    的頭像 發表于 12-03 17:49 ?2512次閱讀
    RCD<b class='flag-5'>非線性</b>負載:原理、應用與優勢

    求助,關于ADS1278在不同采樣頻率下的非線性問題求解

    1278在采樣頻率為512 fps和50 fps時芯片隨溫度變化的輸出,輸出信號如下圖1,圖2所示。可以發現,采樣頻率降低之后,輸出信號的非線性得到明顯改善。 請問這種現象是ads1278自身的特性引起的嗎?有沒有辦法實現在512 fps的采樣頻率下仍能保持較好的
    發表于 11-22 07:03

    二極管的非線性特性對電路的影響

    二極管的非線性特性對電路的影響是深遠且重要的。以下是對這一影響的分析: 一、二極管的非線性特性 二極管是一種典型的非線性器件,其電流與電壓之間的關系不滿足歐姆定律,而是呈現出獨特的非線性
    的頭像 發表于 11-18 09:40 ?1449次閱讀

    非線性光耦與線性光耦的差別

    非線性光耦與線性光耦的不同 在電路中光耦的電路非常常見,光耦在電路中的作用是進行隔離并對光電進行轉換,光耦的種類當中,包括線性光耦與非線性光耦。雖然都是光耦,但是這兩種光耦的區別在哪?
    的頭像 發表于 11-16 10:28 ?1257次閱讀

    射頻放大器的的線性非線性特性

    在無線通信系統中,我們應該聽說過線性系統和非線性系統。它通常是指系統的輸入和輸出的關系是否成線性關系。在早期的2G時代的GSM就是非線性系統
    的頭像 發表于 10-23 10:32 ?1430次閱讀
    射頻放大器的的<b class='flag-5'>線性</b>和<b class='flag-5'>非線性</b>特性

    正弦振蕩電路的非線性部分是什么

    ,而非線性部分則負責提供必要的非線性特性,以確保振蕩的持續和穩定。 非線性部分的作用 非線性部分在正弦振蕩電路中的作用至關重要,它確保振蕩
    的頭像 發表于 09-29 09:11 ?1012次閱讀

    集成運放電路非線性應用要求是什么

    集成運算放大器(簡稱運放)是一種具有高增益、高輸入阻抗、低輸出阻抗的放大器,廣泛應用于模擬信號處理、信號放大、濾波、波形生成等領域。在非線性應用中,運放可以進行函數運算、波形變換、信號處理等操作
    的頭像 發表于 09-03 09:24 ?1612次閱讀

    PGA309一旦校準非線性就不準,為什么?

    我自己寫了一個程序做PGA309的校準,現在如果不做非線性校準的話可以把零點和滿點校準到很精確,但是一旦校準非線性就不準。 我的校準方法是先按照非線性為0來校準一遍,這樣可以把零點和
    發表于 08-15 08:31

    放大器的非線性工作方式

    放大器的非線性工作方式是一個復雜而廣泛的主題,它涉及到電子學、信號處理以及電路設計等多個領域。在非線性工作方式下,放大器的輸出信號不再是輸入信號的簡單線性放大,而是會引入各種非線性效應
    的頭像 發表于 08-08 17:32 ?1346次閱讀