主頁 >  其他 > 回圈神經網路(RNN)

回圈神經網路(RNN)

2020-09-11 10:43:01 其他

<style></style> <style></style> <style></style> <style></style>  

1 引言¶

 

在此前的多篇博客中,我花了很大的精力研究卷積神經網路相關內容,見證了卷積網路從最初的LeNet一步步發展到ResNet,在深度學習領域,卷積網路占據了半壁江山,例如在影像分類、目標檢測等應用中, 卷積神經網路所取得的成就遠不是其他演算法模型可以比擬的,然而,不得不承認,卷積神經網路說擅長的領域資料大多是靜態的,輸入資料間相互獨立,例如影像這種二維的資料,而對于語意識別,時間序列分析等應用,卷積神經網路就稍顯不足,這是因為語意識別、時間序列等等應用中,資料呈序列狀,前后輸入相互關聯,卷積神經網路在這些應用中難以兼顧資料間的關聯關系,導致性能變差,
幸運的是,在神經網路演算法家族中,也有一類演算法專門用于處理此類序列資料,那就是本篇的主角——回圈神經網路,回圈神經網路(Recurrent Neural Network,RNN)是一種別具一格的網路模型,其回圈元節點不僅可以接上來自上層的輸入資料,也可以接收自身上一次迭代的輸出,基于這種特殊的結構,回圈神經網路擁有了短期記憶能力,通過“記憶”保存了資料間的關聯關系,所以尤為適合處理語言、文本、視頻等時序相關的資料,接下來,我們來具體剖析回圈神經網路的特殊結構,

 

2 回圈神經網路¶

 

2.1 為什么需要RNN¶

 

在前面引言中對RNN誕生的意義說的不夠淺顯,這里舉個例子來說,語意識別,文本分類是回圈神經網路的重點應用領域,當然,并不是說其他的神經網路演算法在這些領域就毫無作用,只是效果較差而已,加入有下面一句話:
我是中國人,我會說 _

對于這句話,我想無論是一般的升級網路模型還是回圈神經網路模型,都一顆預測出,橫線上的內容應該是“漢語”,

繼續,我們把這句話說完整:
我是中國人,我會說漢語,但是我成年后移民到美國,所以我也會說_

在一般的神經網路模型中,會孤立地分析每一個詞,因為句子中同時出現了中國和美國,所以預測得到的詞是“漢語”和“英語”概率相仿,但是在回圈神經網路中,模型具有一定的短期記憶功能,能夠根據背景關系進行語意的預測,所以在較的位置上的“美國”一詞有著更大的影響,最終預測結果更有可能是“英語”,這就是為什么回圈神經網路在序列相關應用中表現優異的原因,

 

2.2 單向回圈神經網路結構¶

 

與前饋神經網路結構相比,回圈神經網路最大的不同在于其回圈神經網路輸出不僅能夠往下一層傳播,也能夠傳遞給同層下一時刻,也就是說,對于回圈網路中某一神經元節點,其內部運算資料不僅包含上一層的輸出,同時也包含同層上一時刻的輸出,如下圖所示:

 

 

上圖是一個簡化的回圈網路結構,只包含了一個隱藏層,圖中,$X$我們可以理解為一個完整的時間序列(例如一句語意完整的文本),$x_t$是指的$t$個時刻的測度(文本中的第$t$個詞的向量表示),$h_t$是第$t$個時刻的輸出,也就是$x_t$和上一時刻的輸出$h_t$在隱藏層中合并運算后的輸出,同時可以看到,輸出的$h_t$流向輸出層的同時,還有流向了延遲期,留待第$t+1$次與$x_{t+1}$共同參與隱藏層運算,對于上圖,按時間順序(在時間維度)上展開,如下圖所示:

 

 

注意,上圖是在時間維度上進行展開,也就是上圖三個部分其實是同一網路(而不是三個部分共同組成一個網路),而是在同一個網路在不同時間順序上的展開,我剛接觸回圈神經網路看到這個圖時,以為多個隱藏層是隱藏層的多個節點,$h$的值不過是在同層節點間進行傳遞,這是錯誤的,
圖中,$U$和$W$分別是$x$和$h$的權值,所以,在隱藏層節點內的運算可以如下表示:
$$h_t=f(U \times x_t + w \times h_{t-1} + b) \tag{1} $$

 

式中,$f$是激活函式,$b$是偏置,可見,在計算第$t$時刻輸出$h_t$時,上一時刻的輸出狀態$h_{t-1}$也參與了運算,對$h_{t-1}$也有:
$$h_{t-1}=f(U \times x_{t-1} + w \times h_{t-2} + b) \tag{2} $$ 將(1)式和(2)式結合,也就有: $$h_t=f(U \times x_t + w \times f(U \times x_{t-1} + w \times h_{t-2} + b) + b) \tag{3} $$ 通過這種方式,第$t$時刻的輸出與之前時刻的輸出關聯起來,也就有了之前的“記憶”,
在我理解看來,回圈神經網路與卷積等前饋神經網路最大的不同就在于多了一個時間維度,這就要求回圈神經網路中的輸入是 有序的(順序對最終結果有影響),以對一個句子進行情感分類為例,假設這個句子有10個詞,每個詞表示為長度為100向量(假設為$X=[x_1,…,x_{10}]$),如果是在前饋神經網路,就回將[10 * 100]的向量$X=[x_1,…,x_{10}]$一次性傳遞給網路,而在回圈網路中,第一次是將第一個詞的對應的長度為100的向量傳遞給網路,經過第一個回圈時,神經元節點接收到兩個輸入,一個是詞向量$x_1$,另一個是初始狀態$h_0$(一般初始狀態為全為0的向量),運算后輸出為$h_1$,$h_1$輸出到下一層的同時,也就等待下一個$x_2$的輸入然后一同進行運算產生$h_2$……

有一點必須注意,在RNN回圈層中,同一層的引數$U$、$W$和$b$,甚至包括激活函式$f$,是在不同時刻是完全共享的,這種特性大大減少了回圈神經網路的引數量,其實在我理解看來,與其說引數共享,倒不如說不同時刻的資料使用的就是相同的神經元,

 

2.3 雙向回圈網路結構¶

 

在單向回圈網路中,輸出取決于當前的輸入和之前時刻的“記憶”,但在有些應用場景中,最終的決策不僅受之前的“記憶”的影響,還需要綜合考慮之后事件的發展,這就類似于做英文閱讀理解,最終的答案需要我們找準對應的句子(當前時刻的輸入$x_t$)還要綜合前文($h_{t-1}$)和下文($h_{t+1}$)進行作答,在回圈神經網路家族有,有一種雙向回圈網路結構(Bidirectional Recurrent Neural Network,Bi-RNN)就專用于此類場景,

雙向回圈神經網路每一層回圈運算可以拆分為兩層,這兩層網路都輸入序列$X$,但是資訊傳遞方向相反,如下圖所示:

 

 

圖中回圈運算公式如下:

 

 

第一行是順序運算,第二行是逆序運算,第三行是將兩種順序的輸出狀態進行組合,

 

3 TensorFlow2實作回圈神經網路¶

 

3.1 單層節點¶

In [1]:
import tensorflow as tf
 

假設有4個句子,每個句子有80個詞匯,每個詞匯表示為一個100維向量(有4個時間序列資料,每個序列有80個時間測度,每個測度有100個屬性值),我們隨機初始化來模擬這種資料結構:

In [2]:
x = tf.random.normal([4, 80, 100])
 

創建一個RNN神經元:

In [9]:
cell = tf.keras.layers.SimpleRNNCell(64)  # 64的意思是經過神經元后,維度轉化為64維,[b, 100] -> [b, 64],b是句子數量
 

初始化最初時刻的狀態,因為有4個句子(4個batch),且輸出為64維,所以最初的狀態初始化為[4, 64],值全為零的矩陣,

In [10]:
ht0 = tf.zeros([4, 64])  # 因為
In [6]:
xt0 = x[:, 0, :]
In [18]:
out, ht1 = cell(xt0, [h0])
 

out是傳遞給下一層的值,ht1經過一次神經元后的轉臺,我們看看這兩者的狀態:

In [22]:
out.shape, ht1[0].shape
Out[22]:
(TensorShape([4, 64]), TensorShape([4, 64]))
 

輸出為[4, 64]的矩陣,確實如我們上面所指定的一樣,繼續:

In [23]:
id(out), id(ht1[0])
Out[23]:
(140525368605520, 140525368605520)
 

可以看到,id是一樣的,也就是說,這兩者其實就是同一個物件,正如前文所說,RNN神經元有兩個相同的輸出,一個傳遞到下一層節點,也就是out,一個傳遞給下一時間節點回圈,也就是ht1[0],

 

3.2 多層節點¶

 

同樣,我們先模擬構造一些資料

In [25]:
x = tf.random.normal([4, 80, 100])
xt0 = x[:, 0, :]
 

創建多層節點:

In [26]:
# 第一層節點
cell = tf.keras.layers.SimpleRNNCell(64)
# 第二層節點
cell2 = tf.keras.layers.SimpleRNNCell(64) 
 

因為有多個層了,每個層都必須有一個初始狀態,所以這里也必須創建多個初始狀態矩陣:

In [27]:
state0 = [tf.zeros([4, 64])]
state1 = [tf.zeros([4, 64])]
 

下面就可以進行資料在神經元間的傳遞了:

In [29]:
out0, state0 = cell(xt0, state0)
out1, state1 = cell2(out, state1)
 

在上述運算中,因為只有一次值傳遞運算,所以對于“回圈”表現的不明顯,在完整RNN網路中,上述運算將會放在一個回圈中,如下所示:

In [ ]:
for word in tf.unstack(x, axis=1):
    out0, state0 = cell(xt0, state0)
    out1, state1 = cell2(out, state1)
 

第一層的cell每次運算都會對state0進行更新,然后通過state0記錄這一次狀態在下一次回圈,同時,通過out0將輸出值傳遞給下一層的cell2,

 

3.3 SimpleRNNCell實作完整RNN實作文本分類¶

In [30]:
import os 
import tensorflow as tf
import numpy as np
from tensorflow import keras
from tensorflow.keras import layers
In [33]:
tf.random.set_seed(22)
np.random.seed(22)
os.environ['TF_CPP_MIN_LOG_LEVEL'] = '2'
 

加載資料,電影評價資料:

In [59]:
total_words = 10000  # 常見詞匯數量
batchsz = 128
embedding_len = 100
(x_train, y_train), (x_test, y_test) = keras.datasets.imdb.load_data(num_words=total_words)
In [60]:
max_review_len = 80  # 每個句子最大長度
x_train = keras.preprocessing.sequence.pad_sequences(x_train, maxlen=max_review_len)
x_test = keras.preprocessing.sequence.pad_sequences(x_test, maxlen=max_review_len)
In [61]:
db_train = tf.data.Dataset.from_tensor_slices((x_train, y_train))
db_train = db_train.shuffle(1000).batch(batchsz, drop_remainder=True)  # drop_remainder是指最后一個batch不足128個則丟棄
db_test = tf.data.Dataset.from_tensor_slices((x_test, y_test))
db_test = db_test.batch(batchsz, drop_remainder=True)
In [62]:
print('x_train shape:', x_train.shape, tf.reduce_max(y_train), tf.reduce_min(y_train))
print('x_test shape:', x_test.shape)
 
x_train shape: (25000, 80) tf.Tensor(1, shape=(), dtype=int64) tf.Tensor(0, shape=(), dtype=int64)
x_test shape: (25000, 80)
 

接下來創建網路結構:

In [72]:
class RNN(keras.Model):
    def __init__(self, units):
        super(RNN, self).__init__()
        # 創建初始狀態矩陣
        self.state0 = [tf.zeros([batchsz, units])]
        self.state1 = [tf.zeros([batchsz, units])]
        # 對文本資料進行轉換為矩陣
        # 每句80個單詞,每個單詞100維矩陣表示  [b, 80]  --> [b, 80, 100]
        self.embedding = layers.Embedding(total_words, embedding_len, input_length=max_review_len)
        # 回圈網路層, 語意提取
        # [b, 80, 100]--> [b, 64]
        self.rnn_cell0 = layers.SimpleRNNCell(units, dropout=0.2)  # 第一層rnn
        self.rnn_cell1 = layers.SimpleRNNCell(units, dropout=0.2)  # 第二層rnn
        # 全連接層
        # [b, 64] --> [b, 1]
        self.outlayer = layers.Dense(1)
        
    def call(self, inputs, training=None):
        # [b, 80]
        x = inputs
        # embedding: [b, 80] -->[b, 80, 100]
        x = self.embedding(x)
        # rnn cell:  [b, 80, 100] --> [b, 64]
        state0 = self.state0
        state1 = self.state1
        for word in tf.unstack(x, axis=1): # 在第二個維度展開,遍歷句子的每一個單詞
            # 
            out0, state0 = self.rnn_cell0(word, state0, training)
            out1, state1 = self.rnn_cell1(out0, state1, training)
        # out: [b, 64]
        x = self.outlayer(out1)
        prob = tf.sigmoid(x)
        return prob
In [73]:
units = 64
epochs = 4
model = RNN(units)
model.compile(optimizer=keras.optimizers.Adam(0.001),
             loss=tf.losses.BinaryCrossentropy(),
              metrics=['accuracy'],
              experimental_run_tf_function = False
             )
model.fit(db_train, epochs=epochs, validation_data=db_test)
 
Epoch 1/4
193/195 [============================>.] - ETA: 0s - loss: 0.5973 - accuracy: 0.5506Epoch 1/4
195/195 [==============================] - 3s 15ms/step - loss: 0.4002 - accuracy: 0.8220
195/195 [==============================] - 13s 65ms/step - loss: 0.5958 - accuracy: 0.5520 - val_loss: 0.4002 - val_accuracy: 0.8220
Epoch 2/4
193/195 [============================>.] - ETA: 0s - loss: 0.3326 - accuracy: 0.8490Epoch 1/4
195/195 [==============================] - 1s 7ms/step - loss: 0.4065 - accuracy: 0.8224
195/195 [==============================] - 5s 28ms/step - loss: 0.3315 - accuracy: 0.8492 - val_loss: 0.4065 - val_accuracy: 0.8224
Epoch 3/4
193/195 [============================>.] - ETA: 0s - loss: 0.1839 - accuracy: 0.9180Epoch 1/4
195/195 [==============================] - 1s 7ms/step - loss: 0.5103 - accuracy: 0.8193
195/195 [==============================] - 6s 28ms/step - loss: 0.1841 - accuracy: 0.9182 - val_loss: 0.5103 - val_accuracy: 0.8193
Epoch 4/4
193/195 [============================>.] - ETA: 0s - loss: 0.0960 - accuracy: 0.9574Epoch 1/4
195/195 [==============================] - 1s 7ms/step - loss: 0.6747 - accuracy: 0.8083
195/195 [==============================] - 5s 28ms/step - loss: 0.0958 - accuracy: 0.9575 - val_loss: 0.6747 - val_accuracy: 0.8083
Out[73]:
<tensorflow.python.keras.callbacks.History at 0x7fce3bc7d390>
 

3.4 高層API實作RNN¶

 

資料加載和預處理還是使用上一章節的代碼,這里主要是使用TensorFlow中高層API

In [76]:
model = keras.Sequential([
    layers.Embedding(total_words, embedding_len, input_length=max_review_len),
    layers.SimpleRNN(units, dropout=0.2, return_sequences=True, unroll=True),
    layers.SimpleRNN(units, dropout=0.2,  unroll=True),
    layers.Dense(1, activation='sigmoid')
])
model.compile(loss='binary_crossentropy', optimizer='adam',
              metrics=['accuracy'])
history1 = model.fit(db_train, epochs=epochs, validation_data=db_test)
loss, acc = model.evaluate(db_test)
print('準確率:', acc) # 0.81039
 
Train for 195 steps, validate for 195 steps
Epoch 1/4
195/195 [==============================] - 11s 54ms/step - loss: 0.6243 - accuracy: 0.6187 - val_loss: 0.4674 - val_accuracy: 0.7830
Epoch 2/4
195/195 [==============================] - 6s 29ms/step - loss: 0.3770 - accuracy: 0.8352 - val_loss: 0.4061 - val_accuracy: 0.8230
Epoch 3/4
195/195 [==============================] - 6s 29ms/step - loss: 0.2527 - accuracy: 0.9007 - val_loss: 0.4337 - val_accuracy: 0.8201
Epoch 4/4
195/195 [==============================] - 6s 29ms/step - loss: 0.1383 - accuracy: 0.9493 - val_loss: 0.5847 - val_accuracy: 0.8076
195/195 [==============================] - 1s 7ms/step - loss: 0.5847 - accuracy: 0.8076
準確率: 0.8075721

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/5344.html

標籤:其他

上一篇:人臉識別學習筆記二:進階篇

下一篇:神經網路學習筆記2-多層感知機,激活函式

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more