在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

在TensorFlow中對Tensor進行拆和裝

wFVr_Hardware_1 ? 來源:硬十AI ? 2022-12-29 09:24 ? 次閱讀

我們在深度學習框架(4)-TensorFlow中執(zhí)行計算,不同激活函數(shù)各有妙用中學習了TensorFlow中執(zhí)行張量的計算,并重點討論一下不同的激活函數(shù)。

今天我們在TensorFlow中對Tensor進行“拆”和“裝”。

7c03064e-7806-11ed-8abf-dac502259ad0.png

說明

(1)張量創(chuàng)建、轉化請參考深度學習框架(3)-TensorFlow中張量創(chuàng)建和轉化,妙用“稀疏性”提升效率(2)張量計算請參考深度學習框架(4)-TensorFlow中執(zhí)行計算,不同激活函數(shù)各有妙用

1、矩陣運算的必要性

(1)Tensor是基礎的數(shù)據(jù)結構

我們在深度學習框架(1)-各顯神通提升Tensor效率,讓Tensor流動還靠深度學習框架中討論過深度學習依賴Tensor運算,我們再補充一點背景知識。

Tensor是深度學習中廣泛使用的數(shù)據(jù)結構,TensorFlow雖然形象的把它加入到命名中,但它并不是TensorFlow特有的,在Pytroch、PaddlePaddle等眾多深度學習框架中Tensor也是基本的數(shù)據(jù)結構。

Tensor本質(zhì)上就是一個高維的矩陣,在深度學習領域中,以它作為基本數(shù)據(jù)結構是出于實際應用的需求。

深度學習當前最成熟的應用方向有計算機視覺(CV,Compute Vision)和自然語言處理(NLP,Natural Language Processing)兩大領域。其中CV對象主要是圖像和視頻,NLP的對象以語音和文本為主;CV的基礎模塊是卷積神經(jīng)網(wǎng)絡(CNN,Convolutional Neural Network),NLP的基礎模塊是循環(huán)神經(jīng)網(wǎng)絡(RNN,Recurrent Neural Network)。這兩個應用中標準的輸入數(shù)據(jù)集都至少是三維以上,例如:

圖像數(shù)據(jù):包含三個維度,N×H×W,即樣本數(shù)×圖像高×圖像寬;如果是彩色圖像,那么還要增加一個通道C,變?yōu)镹×C×H×W;如果是視頻圖像,那么可能還要再增加一個維度T,N×C×H×W×T。

文本數(shù)據(jù):包含三個維度:N×L×H,即樣本數(shù)×序列長度×特征數(shù)。

源于應用需要,深度學習模型的輸入數(shù)據(jù)結構一般都要三維以上,而Tensor是好的選擇,用于支撐深度學習模型和訓練時更為便利。

(2)矩陣運算是基礎

我們在深度學習框架(4)-TensorFlow中執(zhí)行計算,不同激活函數(shù)各有妙用用TensorFlow中的不同函數(shù)執(zhí)行了加法、乘法等各種運算。

加法:矩陣的加法只有同型矩陣之間才可以進行加法,所謂同型矩陣是兩個矩陣的行數(shù)、列數(shù)必須相等。

7c2bd70e-7806-11ed-8abf-dac502259ad0.png

轉置:把矩陣的行和列互相交換所產(chǎn)生的矩陣稱轉置矩陣。

7c41b740-7806-11ed-8abf-dac502259ad0.png

乘法:兩個矩陣乘法的必要條件是,第一個矩陣A的列數(shù)和另一個矩陣B的行數(shù)相等時才能相乘。如矩陣A是m×n矩陣和B是n×p矩陣,它們的乘積C是一個m×p矩陣。

7c4b65a6-7806-11ed-8abf-dac502259ad0.png

分解:矩陣分解是將一個矩陣分解為簡單的或具有某種特性的若干矩陣的和或乘積 ,矩陣分解法有三角分解、譜分解、奇異值分解、滿秩分解等。

我們可以把矩陣的各種操作想象為它在一定空間內(nèi),按照一定的規(guī)則進行的運動(或變換)。比如一個向量和一個矩陣相乘,我們可以想象為在線性空間中,向量刻畫了對象,矩陣刻畫了對象的運動,用矩陣與向量的乘法施加了運動。因此,“矩陣的本質(zhì)是運動的描述”,而想要執(zhí)行運動必須要要有約束,包括自身的形狀,運動的規(guī)則等等。

(3)從英偉達的Tensor Core了解Tenosr索引、重構、切片的價值

我們在深度學習框架(1)-各顯神通提升Tensor效率,讓Tensor流動還靠深度學習框架中討論過,為滿足深度學習激增的計算量,英偉達在volta架構上推出了第一代TensorCore,以后每一代產(chǎn)品都對TensorCore不斷升級優(yōu)化。

TensorCore是專為深度學習而設計的,它在Tensor場景下算得更快,對于特定大小和精度的矩陣乘法實現(xiàn)了性能的突破,與前一代Pascal相比,Volta用于訓練的峰值性能提升12倍,用于推理的峰值性能提升了6倍。

TensorCore改進的方向就是針對矩陣乘法(GEMM,General Matrix Mulitiplicaiton)運算進行優(yōu)化。矩陣運算是神經(jīng)網(wǎng)絡訓練和推理的核心,下圖以4×4矩陣為例,每個TensorCore都在重復執(zhí)行以下操作 D = A×B + C

7c67c6ec-7806-11ed-8abf-dac502259ad0.png

Tensor Core在執(zhí)行矩陣乘法和加法運算時整個裝置可簡化為下圖,我們在前面幾章中討論的Tensor的convert,matual,add等操作這里均包含了,我們要注意的是,比如上圖D =A×B+C是以4×4矩陣為基礎的,那么在執(zhí)行這個指令前,矩陣必須通過裁剪或者整型成為一個4×4矩陣,標準的input才能在這個裝置結構中完成指令。

7c7af780-7806-11ed-8abf-dac502259ad0.png

Tensor的索引、切片、重構、填充等操作非常常見,因為整個計算系統(tǒng)中從實際應用的輸入數(shù)據(jù)轉為了Tensor形式的數(shù)據(jù)結構,到轉化為適合放置于內(nèi)存中的數(shù)據(jù)模塊,再到轉化為計算裝置執(zhí)行計算指令的數(shù)據(jù)單元,這每個步驟中都涉及到了Tensor的“拆”和“裝”的操作。對Tensor進行索引、重構、切片都是程序員的必備技能。

2、如何對一個Tensor進行“拆”和“裝”

(1)導入TensorFlow,創(chuàng)建tensor

import tensorflow as tf
importnumpyasnp


rank_1_tensor = tf.constant([0, 1, 1, 2, 3, 5, 8, 13, 21, 34])


rank_2_tensor=tf.constant([[1,2], [3,4], [5,6]])


rank_3_tensor=tf.constant([
  [[0, 1, 2, 3, 4],
   [5, 6, 7, 8, 9]],
  [[10, 11, 12, 13, 14],
   [15, 16, 17, 18, 19]],
  [[20, 21, 22, 23, 24],
   [25, 26, 27, 28, 29]],])

(2)索引(indexing)

通過索引我們可以在Tensor中提取數(shù)據(jù),包括單軸索、多軸索引等。

單軸索引(single-axis indexing)

print("First:", rank_1_tensor[0].numpy())
print("From 4 to the end:", rank_1_tensor[4:].numpy())
print("From2,before7:",rank_1_tensor[2:7].numpy())

打印結果>>>

First: 0
From 4 to the end: [ 3  5  8 13 21 34]
From 2, before 7: [1 2 3 5 8]

多軸索引(muti-axis indexing)

print(rank_3_tensor[:,:,4])

打印結果>>>

tf.Tensor(
[[ 4  9]
 [14 19]
 [24 29]], shape=(3, 2), dtype=int32)

7c9ece1c-7806-11ed-8abf-dac502259ad0.png

(3)切片(Slice)

通過tf.slice()函數(shù)可以對不同維度的張量進行切片,通過tf.gather_nd()函數(shù)可以從多個軸中提取切片。

Tensorslice

print(tf.slice(rank_3_tensor, begin=[1,1,0],size=[1,1,2]))

打印結果>>>

tf.Tensor([[[1516]]],shape=(1,1,2),dtype=int32)

Tensor gather

print(tf.gather_nd(rank_3_tensor,indices=[[2],[0]]))

打印結果>>>

tf.Tensor(
[[[20 21 22 23 24]
[2526272829]]

 [[ 0  1  2  3  4]
  [ 5  6  7  8  9]]], shape=(2, 2, 5), dtype=int32)

(4)形狀的整理變換(Reshaping)

通過tf.reshape()可改變張量形狀,重構速度快,資源消耗低。

reshape matrix

var_x = tf.Variable(tf.constant([[1], [2], [3]]))
print(var_x.shape.as_list)
reshaped = tf.reshape(var_x, [1,3])
print(var_x.shape)
print(reshaped.shape)

打印結果>>>


(3, 1)
(1, 3)

reshape tensor

print(tf.reshape(rank_3_tensor,[3*2,5]),"n")

打印結果>>>

tf.Tensor(
[[ 0  1  2  3  4]
 [ 5  6  7  8  9]
 [10 11 12 13 14]
 [15 16 17 18 19]
 [20 21 22 23 24]
 [25 26 27 28 29]], shape=(6, 5), dtype=int32)

7cd956e0-7806-11ed-8abf-dac502259ad0.png

reshape tensor

print(tf.reshape(rank_3_tensor,[3,-1]))

打印結果>>>

tf.Tensor(
[[ 0  1  2  3  4  5  6  7  8  9]
 [10 11 12 13 14 15 16 17 18 19]
 [20 21 22 23 24 25 26 27 28 29]], shape=(3, 10), dtype=int32)

7cf3b31e-7806-11ed-8abf-dac502259ad0.png

(5)數(shù)據(jù)的插入(insert)

通過tf.tensor_scatter_nd()可實現(xiàn)在不同維度的張量中插入數(shù)據(jù)。

insert data into vector

t1 = tf.constant([10])
indices = tf.constant([[1], [3], [5], [7], [9]])
data = tf.constant([2, 4, 6, 8, 10])


print(tf.scatter_nd(indices=indices, updates=data, shape=t1))

打印結果>>>

tf.Tensor([ 0  2  0  4  0  6  0  8  0 10], shape=(10,), dtype=int32)

insert data into tensor

t2 = tf.constant([[2, 7, 0],
                   [9, 0, 1],
                   [0, 3, 8]])


print(tf.tensor_scatter_nd_add(t2, indices=[[0,2],[1,1],[2,0]], updates=[6,5,4]))

打印結果>>>

tf.Tensor(
[[2 7 6]
 [9 5 1]
 [4 3 8]], shape=(3, 3), dtype=int32)

今天我們學習了如何在TensorFlow中對Tensor進行“拆”和“裝”,掌握對Tensor進行索引、重構、切片等操作非常重要。到這里我們張量部分知識討論了很多了,下一步我們學習如何使用TensorFlow中的變量






審核編輯:劉清

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

    關注

    42

    文章

    4774

    瀏覽量

    100902
  • tensorflow
    +關注

    關注

    13

    文章

    329

    瀏覽量

    60543
  • nlp
    nlp
    +關注

    關注

    1

    文章

    489

    瀏覽量

    22058

原文標題:深度學習框架(5)-TensorFlow中對Tensor進行“拆”和“裝”

文章出處:【微信號:Hardware_10W,微信公眾號:硬件十萬個為什么】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    關于 TensorFlow

    節(jié)點間相互聯(lián)系的多維數(shù)據(jù)數(shù)組,即張量(tensor)。它靈活的架構讓你可以多種平臺上展開計算,例如臺式計算機的一個或多個CPU(或GPU),服務器,移動設備等等。
    發(fā)表于 03-30 19:57

    使用 TensorFlow, 你必須明白 TensorFlow

    tensorflow::Tensor 實例.計算圖TensorFlow 程序通常被組織成一個構建階段和一個執(zhí)行階段. 構建階段, op 的執(zhí)行步驟 被描述成一個圖.
    發(fā)表于 03-30 20:03

    情地使用Tensorflow吧!

    節(jié)點間相互聯(lián)系的多維數(shù)據(jù)數(shù)組,即張量(tensor)。它靈活的架構讓你可以多種平臺上展開計算,例如臺式計算機的一個或多個CPU(或GPU),服務器,移動設備等等。
    發(fā)表于 07-22 10:13

    TensorFlow是什么

    更長。TensorFlow 使這一切變得更加簡單快捷,從而縮短了想法到部署之間的實現(xiàn)時間。本教程,你將學習如何利用 TensorFlow 的功能來實現(xiàn)深度神經(jīng)網(wǎng)絡。
    發(fā)表于 07-22 10:14

    第一個TensorFlow程序(hello world)詳解

    在任何計算機語言中學習的第一個程序是都是 Hello world,本教程也將遵守這個慣例,從程序 Hello world 開始。上一節(jié)進行 TensorFlow 安裝驗證的代碼如下: 下面一起
    發(fā)表于 07-22 10:26

    TensorFlow教程|術語表

    API TensorFlow 僅僅在第一維上對 Tensor 有所體現(xiàn)。如果一個 Tensor 有k維,那么一個 IndexedSlices 實例
    發(fā)表于 07-27 18:32

    TensorFlow教程|常見問題

    = tf.matmul(a, b) 不立即執(zhí)行矩陣相乘? TensorFlow 的 Python API , a , b , and c 都是 Tensor 對象. 一個
    發(fā)表于 07-27 18:33

    使用RTL8722DM運行 TensorFlow Lite Hello World 示例

    指南 ambiot/ambd_arduino 下載 Ameba 定制版 TensorFlow Lite for Microcontrollers 庫。按照 Arduino - 庫的說明進行
    發(fā)表于 06-21 15:48

    關于TensorFlowGPU的使用規(guī)則

    一套標準系統(tǒng)通常有多臺計算設備。TensorFlow 支持 CPU 和 GPU 這兩種設備。它們均用 strings 表示。
    的頭像 發(fā)表于 12-04 09:27 ?3575次閱讀

    如何基于 ES6 的 JavaScript 進行 TensorFlow.js 的開發(fā)

    環(huán)境,如果有 CUDA 環(huán)境支持,或者瀏覽器環(huán)境,有 WebGL 環(huán)境支持,那么 TensorFlow.js 可以使用硬件進行加速。
    的頭像 發(fā)表于 10-31 11:16 ?3134次閱讀

    tensorflow能做什么_tensorflow2.0和1.0區(qū)別

     TensorFlow是谷歌基于DistBelief進行研發(fā)的第二_代人工智能學習系統(tǒng),其命名來源于本身的運行原理。Tensor (張量)意味著N維數(shù)組, Flow (流)意味著基于數(shù)據(jù)流圖的計算
    的頭像 發(fā)表于 12-04 14:45 ?8045次閱讀

    五個簡單步驟掌握TensorFlowTensor

    在這篇文章,我們將深入研究Tensorflow Tensor的實現(xiàn)細節(jié)。我們將在以下五個簡單步驟中介紹與TensorflowTensor
    的頭像 發(fā)表于 12-24 14:35 ?958次閱讀

    Google的深度學習框架TensorFlow的優(yōu)勢分析

    TensorFlow命名源于其運行原理,即“讓張量(Tensor)流動起來(Flow)”,這是深度學習處理數(shù)據(jù)的核心特征。TensorFlow顯示了張量從數(shù)據(jù)流圖的一端流動到另一端的整個計算過程,生動形象地描述了復雜數(shù)據(jù)結構
    的頭像 發(fā)表于 11-21 10:21 ?1806次閱讀

    使用Arduino和TensorFlow進行喚醒詞檢測

    電子發(fā)燒友網(wǎng)站提供《使用Arduino和TensorFlow進行喚醒詞檢測.zip》資料免費下載
    發(fā)表于 12-02 11:24 ?0次下載
    使用Arduino和<b class='flag-5'>TensorFlow</b><b class='flag-5'>進行</b>喚醒詞檢測

    使用Home Assistant進行TensorFlow對象檢測

    電子發(fā)燒友網(wǎng)站提供《使用Home Assistant進行TensorFlow對象檢測.zip》資料免費下載
    發(fā)表于 12-14 09:30 ?0次下載
    使用Home Assistant<b class='flag-5'>進行</b><b class='flag-5'>TensorFlow</b>對象檢測
    主站蜘蛛池模板: 性喷潮久久久久久久久| 正在播放国产乱子伦视频| 啪视频免费| 日本黄色网址免费| 美女久久久久久| 久久国产成人午夜aⅴ影院| 国产一区二区三区波多野吉衣| 人人爱天天做夜夜爽毛片| 久久精品系列| 91大神大战高跟丝袜美女| 四虎在线最新永久免费| 一级特黄特黄的大片免费| 婷婷六月在线| 日本黄色一级大片| 国产精品久久久久免费| julia一区二区三区中文字幕| 在线播放你懂得| 天堂bt| 男女做视频网站免费观看| 狠狠躁夜夜躁人人爽天天3| 成人毛片在线播放| 天天插天天干天天操| 狠狠干2019| 在线毛片免费| 最新色站| 狠狠色狠狠干| 偷偷要色偷偷| 美女毛片免费| 伊人天天操| 国产黄mmd在线观看免费| 中国男女全黄大片一级| 亚洲香蕉影视在线播放| 日韩一级片在线观看| 久青草国产手机在线观| 11111日本网站| 91精品啪国产在线观看免费牛牛| 亚洲一区三区| 四虎影视色费永久在线观看| 久久综合九色综合精品| 午夜久久久| 奇米影视久久|