主頁 >  其他 > NLP學習—10.回圈神經網路RNN與LSTM、GRU、雙向LSTM以及基于PyTorch的代碼實作

NLP學習—10.回圈神經網路RNN與LSTM、GRU、雙向LSTM以及基于PyTorch的代碼實作

2021-08-22 06:28:56 其他

文章目錄

      • 一、為什么需要回圈神經網路?
      • 二、RNN的原理
      • 三、RNN的型別
      • 四、RNN存在的問題
      • 五、LSTM/GRU
      • 六、Gated Recurrent Unit—GRU
      • 七、BI-LSTM
        • 1.雙向LSTM的模型代碼實作
        • 2.雙向LSTM+Attention的模型代碼實作
      • 八、Deep-BILSTM

一、為什么需要回圈神經網路?

??雖然全連接神經網路理論上只要訓練資料足夠,給定特定的x,就能得到希望的y,但是全連接神經網路只能處理獨立的輸入,前一個輸入和后一個輸入是完全沒有關系的,針對某些任務需要能夠更好的處理序列的資訊,即前面的輸入和后面的輸入是有關系的情況,此時,就需要用到回圈神經網路RNN,該神經網路能夠很好的處理序列資訊,

標準的全連接神經網路(fully connected neural network)處理序列資料會有兩個問題:
1)全連接神經網路輸入層和輸出層長度固定,而不同序列的輸入、輸出可能有不同的長度,選擇最大長度并對短序列進行填充(pad)不是一種很好的方式;
2)全連接神經網路同一層的節點之間是無連接的,當需要用到序列之前時刻的資訊時,全連接神經網路無法做到,一個序列的不同位置之間無法共享特征,

二、RNN的原理

參考于一文搞懂RNN(回圈神經網路)基礎篇
??一個簡單的回圈神經網路,它由輸入層、隱藏層(單個)、輸出層構成,
在這里插入圖片描述

x是輸入層的值
U是輸入層到隱藏層的權重矩陣
s是隱藏層的值
權重矩陣 W就是上一個時刻隱藏層的值作為這一時刻的輸入的權重,回圈神經網路的隱藏層的值s不僅僅取決于當前時刻的輸入x,還取決于前一時刻隱藏層的值s,
V是隱藏層到輸出層的權重矩陣

注意事項:引數 U 、 V 、 W U、V、W UVW在RNN中是共享的,
????下圖展示了上一時刻的隱藏層是如何影響當前時刻的隱藏層的,
在這里插入圖片描述
????回圈神經網路時間線展開圖為:
在這里插入圖片描述
這個網路在t時刻接收到輸入 x t x_t xt? 之后,隱藏層的值是 s t s_t st? ,輸出值是 o t o_t ot? s t s_t st?的值不僅僅取決于 x t x_t xt?,還取決于 s t ? 1 s_{t-1} st?1?
????回圈神經網路計算方法用公式表示為:
在這里插入圖片描述
此處的 g g g在分類中為softmax函式,
??下圖展示了一個最簡單的使用單個全連接層作為回圈體 A 的 RNN,圖中黃色的 tanh 小方框表示一個使用 tanh 作為激活函式的全連接層,
在這里插入圖片描述
t t t時刻回圈體 A 的輸入包括 X t X_t Xt?和從 t ? 1 t-1 t?1時刻傳遞來的隱藏狀態 h t ? 1 h_{t-1} ht?1?,回圈體 A 的兩部分輸入如何處理呢?將 X t X_t Xt? h t ? 1 h_{t-1} ht?1?直接拼接起來,成為一個更大的矩陣/向量 [ X t X_t Xt?, h t ? 1 h_{t-1} ht?1?],假設 X t X_t Xt? h t ? 1 h_{t-1} ht?1?的形狀分別為 [1, 3] 和 [1, 4],則最后回圈體 A 中全連接層輸入向量的形狀為 [1, 7],拼接完后按照全連接層的方式進行處理即可,
????RNN前向傳播如圖所示:
在這里插入圖片描述

  • RNN可以用于訓練語言模型 ,一個詞預測下一個詞的概率(非常稀疏的高維向量,和為1)并可以經過交叉熵進行優化,已經訓練好的RNN模型,可以生成一些文本,這個可以稱為decoding,

三、RNN的型別

??使用RNN解決特定的問題,根據不同的問題,我們可以定義出不同型別的RNN,
在這里插入圖片描述

  1. one to one:其實和全連接神經網路并沒有什么區別,這一類別算不得是 RNN,
  2. one to many:輸入不是序列,輸出是序列,輸入是靜態的資料,輸出是動態的資料,這種模型可以用于輸入圖片根據RNN模型生成圖片表示內容,即文本生成,
  3. many to one:輸入是序列,輸出不是序列,這種模型適用于文本分類(情感分析)任務或者圖片生成任務,
  4. many to many:輸入和輸出都是序列,但兩者長度可以不一樣,這種模型可以用于機器翻譯,文案生成,自動生成摘要,
  5. many to many:輸出和輸出都是序列,兩者長度一樣,這種模型可以用于詞性標注或者股票預測,

四、RNN存在的問題

??單向 RNN 的缺點是在 t t t 時刻,無法使用 t + 1 t+1 t+1 及之后時刻的序列資訊,所以就有了雙向回圈神經網路,理論上回圈神經網路可以支持任意長度的序列,然而在實際中,如果序列過長會導致優化時出現梯度消散的問題(the vanishing gradient problem),所以實際中一般會規定一個最大長度,當序列長度超過規定長度之后會對序列進行截斷,RNN 面臨的一個技術挑戰是長期依賴(long-term dependencies)問題,即當前時刻無法從序列中間隔較大的那個時刻獲得需要的資訊,在理論上,RNN 完全可以處理長期依賴問題,但實際處理程序中,RNN 表現得并不好,但是 GRU 和 LSTM 可以處理梯度消散問題和長期依賴問題,
??RNN縱向維度可能出現梯度消散與梯度爆炸問題,RNN在時間維度可能產生長期依賴問題(本質上也是梯度消散與梯度爆炸問題,梯度的問題導致了長期依賴問題),針對于RNN的梯度問題,
在這里插入圖片描述
可抽象為 W R W_R WR? k k k次方,當 W R W_R WR?較小時,梯度彌散,當 W R W_R WR?較大時,梯度爆炸,針對梯度爆炸問題,解決方案是引入Gradient Clipping(梯度裁剪),通過Gradient Clipping,將梯度約束在一個范圍內,這樣不會使得梯度過大,針對梯度消失與長期依賴問題,GRU 和 LSTM 可以處理梯度消散問題和長期依賴問題,GRU 和 LSTM只能緩解梯度消失問題,

五、LSTM/GRU

??在實際建模中,RNN 經常出現梯度爆炸或梯度消失等問題,因此我們一般使用長短期記憶單元或門控回圈單元代替基本的 RNN 回圈體,它們引入了門控機制以遺忘或保留特定的資訊而加強模型對長期依賴關系的捕捉,它們同時也大大緩解了梯度爆炸或梯度消失的問題,回圈網路的每一個隱藏層都有多個回圈單元,隱藏層 h t ? 1 h_{t-1} ht?1?的向量儲存了所有該層神經元在 t ? 1 t-1 t?1步的激活值,一般標準的回圈網路會將該向量通過一個仿射變換并添加到下一層的輸入中,即 W ? h t ? 1 + U ? X t W* h_{t-1}+U* X_t W?ht?1?+U?Xt?,而這個簡單的計算程序由于重復使用 W W W U U U 而會造成梯度爆炸或梯度消失,因此我們可以使用門控機制控制前一時間步隱藏層保留的資訊和當前時間步輸入的資訊,并選擇性地輸出一些值而作為該單元的激活值, 之所以叫“門”結構,是因為使用 s i g m o i d sigmoid sigmoid作為激活函式的全連接神經網路層會輸出一個 0 到 1 之間的數值,描述當前輸入有多少資訊量可以通過這個結構,于是這個結構的功能就類似于一扇門,當門打開時(sigmoid 全連接層輸出為 1 時),全部資訊可以通過;當門關上時(sigmoid 神經網路層輸出為 0 時),任何資訊都無法通過,
在這里插入圖片描述
????LSTM 有三個門,分別是“遺忘門”(forget gate)、“輸入門”(input gate)和“輸出門”(output gate),
“遺忘門”的作用是讓回圈神經網路“忘記”之前沒有用的資訊,控制以前記憶的資訊到底需要保留多少
在這里插入圖片描述
“輸入門”決定哪些資訊進入當前時刻的狀態,分為以前保留的資訊加上當前輸入有意義的資訊
在這里插入圖片描述

通過“遺忘門”和“輸入門”,LSTM 結構可以很有效地決定哪些資訊應該被遺忘,哪些資訊應該得到保留,且更新當前時刻狀態Ct,輸入與輸入門對應元素相乘表示當前時刻需要添加到Ct的記憶,前一時間步的記憶 Ct-1 與遺忘門 ft 對應元素相乘就表示了需要保留或遺忘的歷史資訊是多少,最后將這兩部分的資訊相加在一起就更新了記憶Ct的資訊,
在這里插入圖片描述
LSTM 在得到當前時刻狀態 Ct 之后,需要產生當前時刻的輸出,該程序通過“輸出門”完成,
LSTM 的內部狀態向量𝒄𝑡并不會直接用于輸出,這一點和基礎的RNN 不一樣,基礎的RNN 網路的狀態向量 既用于記憶,又用于輸出,所以基礎的RNN 可以理解為狀態向量𝒄和輸出向量 是同一個物件,在LSTM 內部,狀態向量并不會全部輸出,而是在輸出門的作用下有選擇地輸出,
在這里插入圖片描述
LSTM計算公式總結如下:
在這里插入圖片描述
三個門總結:遺忘門控制以前的輸入,輸入門控制當前的輸入,輸出門產生當前時刻的輸出,
直觀比較LSTM與RNN的梯度求導,會發現

RNN中有權重的n次方,易出現梯度彌散與梯度爆炸
而LSTM中是權重的累加,幾個門的相互制約不會出現梯度彌散與梯度爆炸現象

在這里插入圖片描述
在這里插入圖片描述

六、Gated Recurrent Unit—GRU

????LSTM 具有更長的記憶能力,在大部分序列任務上面都取得了比基礎的RNN 模型更好的性能表現,更重要的是,LSTM 不容易出現梯度彌散現象,但是LSTM 結構相對較復雜,計算代價較高,模型引數量較大,因此,科學家們嘗試簡化LSTM 內部的計算流程,特別是減少門控數量,研究發現,遺忘門是LSTM 中最重要的門控 ,甚至發現只有遺忘門的簡化版網路在多個基準資料集上面優于標準LSTM 網路,在眾多的簡化版LSTM中,門控回圈網路(Gated Recurrent Unit,簡稱GRU)是應用最廣泛的RNN 變種之一,GRU把內部狀態向量和輸出向量合并,統一為狀態向量 ,門控數量也減少到2 個:復位門(Reset Gate)和更新門(Update Gate),
????GRU 的兩個門:一個是“更新門”(update gate),它將 LSTM 的“遺忘門”和“輸入門”融合成了一個“門”結構;另一個是“重置門”(reset gate),
在這里插入圖片描述
??這兩個門控機制的特殊之處在于,它們能夠保存長期序列中的資訊,且不會隨時間而清除或因為與預測不相關而移除,從直觀上來說,重置門決定了如何將新的輸入資訊與前面的記憶相結合,更新門定義了前面記憶保存到當前時間步的量,如果我們將重置門設定為 1,更新門設定為 0,那么我們將再次獲得標準 RNN 模型,使用門控機制學習長期依賴關系的基本思想和 LSTM 一致,但還是有一些關鍵區別:

  • GRU 有兩個門(重置門與更新門),而 LSTM 有三個門(輸入門、遺忘門和輸出門),
  • GRU 并不會控制并保留內部記憶 ( c t ) (c_t) ct?,且沒有 LSTM 中的輸出門,
  • LSTM 中的輸入與遺忘門對應于 GRU 的更新門,重置門直接作用于前面的隱藏狀態,
    ????重置門強制隱藏狀態遺忘一些歷史資訊,并利用當前輸入的資訊,這可以令隱藏狀態遺忘任何在未來發現與預測不相關的資訊,同時也允許構建更加緊致的表征,而更新門將控制前面隱藏狀態的資訊有多少會傳遞到當前隱藏狀態,這與 LSTM 網路中的記憶單元非常相似,它可以幫助 RNN 記住長期資訊,由于每個單元都有獨立的重置門與更新門,每個隱藏單元將學習不同尺度上的依賴關系,那些學習捕捉短期依賴關系的單元將趨向于激活重置門,而那些捕獲長期依賴關系的單元將常常激活更新門,

七、BI-LSTM

??諸如在詞性標注下游任務中,我們不僅考慮上文資訊,而且還要考慮下文資訊,此時,就需要雙向LSTM,雙向LSTM可以理解為同時訓練兩個LSTM,兩個LSTM的方向、引數都不同,當前時刻的 h t h_t ht?就是將兩個方向不同的LSTM得到的兩個 h t h_t ht?向量拼接到一起,我們使用雙向LSTM捕捉到當前時刻 t t t的過去和未來的特征,通過反向傳播來訓練雙向LSTM網路,
在這里插入圖片描述
??如果是雙向LSTM+Attention,這里是靜態的Attention,則網路結構如下:
在這里插入圖片描述 h t h_t ht?是每一個詞的hidden state,而 h s  ̄ \overline{h_s} hs??是向量,開始是隨機生成的,后面經過反向傳播可以得到 ? L o s s ? h s  ̄ \frac{\partial{Loss}}{\partial{\overline{h_s}}} ?hs???Loss?,通過梯度不斷迭代更新,得到標準,
在這里插入圖片描述
score是標量,每句話進行拼接,然后做softmax得到概率,然后對hidden state進行加權平均,得到總向量,然后經過一個分類層,經softmax得到每一個類別的得分,

1.雙向LSTM的模型代碼實作

import torch
import torch.nn as nn
import torch.nn.functional as F


class LSTMModel(nn.Module):
    def __init__(self, vocab_size, embedding_dim, pretrained_weight, update_w2v, hidden_dim,
                 num_layers, drop_keep_prob, n_class, bidirectional, **kwargs):
        super(LSTMModel, self).__init__()
        self.hidden_dim = hidden_dim    # 隱藏層節點數
        self.num_layers = num_layers    # 神經元層數
        self.n_class = n_class          # 類別數

        self.bidirectional = bidirectional  # 控制是否為雙向LSTM
        self.embedding = nn.Embedding.from_pretrained(pretrained_weight)     # 讀取預訓練好的引數
        self.embedding.weight.requires_grad = update_w2v        # 控制加載的預訓練模型在訓練中引數是否更新
        # LSTM
        self.encoder = nn.LSTM(input_size=embedding_dim, hidden_size=self.hidden_dim,
                               num_layers=num_layers, bidirectional=self.bidirectional,
                               dropout=drop_keep_prob)
        # 解碼部分
        if self.bidirectional:
            self.decoder1 = nn.Linear(hidden_dim * 4, hidden_dim)
            self.decoder2 = nn.Linear(hidden_dim, n_class)
        else:
            self.decoder1 = nn.Linear(hidden_dim * 2, hidden_dim)
            self.decoder2 = nn.Linear(hidden_dim, n_class)

    def forward(self, inputs):
        """
        前向傳播
        :param inputs: [batch, seq_len]
        :return: 
        """
        # [batch, seq_len] => [batch, seq_len, embed_dim][64,75,50]
        embeddings = self.embedding(inputs)  
        # [batch, seq_len, embed_dim] = >[seq_len, batch, embed_dim]
        # 這里要結合batch_first引數的設定
        states, hidden = self.encoder(embeddings.permute([1, 0, 2]))

        # 張量拼接[32,512]
        encoding = torch.cat([states[0], states[-1]], dim=1)  
        # 解碼
        outputs = self.decoder1(encoding)
        # outputs = F.softmax(outputs, dim=1)
        outputs = self.decoder2(outputs)
        return outputs

2.雙向LSTM+Attention的模型代碼實作

import torch
import torch.nn as nn
import torch.nn.functional as F

class LSTM_attention(nn.Module):
    def __init__(self, vocab_size, embedding_dim, pretrained_weight, update_w2v, hidden_dim,
                 num_layers, drop_keep_prob, n_class, bidirectional, **kwargs):
        super(LSTM_attention, self).__init__()
        self.hidden_dim = hidden_dim    # 隱藏層節點數
        self.num_layers = num_layers   # 神經元層數
        self.n_class = n_class          # 類別數

        self.bidirectional = bidirectional  # 控制是否雙向LSTM
        self.embedding = nn.Embedding.from_pretrained(pretrained_weight)    # 讀取預訓練好的引數
        self.embedding.weight.requires_grad = update_w2v        # 控制加載的預訓練模型在訓練中引數是否更新
        # LSTM
        self.encoder = nn.LSTM(input_size=embedding_dim, hidden_size=self.hidden_dim,
                               num_layers=num_layers, bidirectional=self.bidirectional,
                               dropout=drop_keep_prob,batch_first=True)

        # weiht_w即為公式中的h_s(參考系)
        # nn. Parameter的作用是引數是需要梯度的
        self.weight_W = nn.Parameter(torch.Tensor(2 * hidden_dim, 2 * hidden_dim))
        self.weight_proj = nn.Parameter(torch.Tensor(2 * hidden_dim, 1))

        # 對weight_W、weight_proj進行初始化
        nn.init.uniform_(self.weight_W, -0.1, 0.1)
        nn.init.uniform_(self.weight_proj, -0.1, 0.1)

        if self.bidirectional:
            # self.decoder1 = nn.Linear(hidden_dim * 2, n_class)
            self.decoder1 = nn.Linear(hidden_dim * 2, hidden_dim)
            self.decoder2 = nn.Linear(hidden_dim, n_class)
        else:
            self.decoder1 = nn.Linear(hidden_dim * 2, hidden_dim)
            self.decoder2 = nn.Linear(hidden_dim, n_class)



    def forward(self, inputs):
        """
        前向傳播
        :param inputs: [batch, seq_len]
        :return:
        """
        # 編碼
        embeddings = self.embedding(inputs)  # [batch, seq_len] => [batch, seq_len, embed_dim][64,75,50]
        # 經過LSTM得到輸出,state是一個輸出序列
        states, hidden = self.encoder(embeddings.permute([0, 1, 2]))  # [batch, seq_len, embed_dim]

        # attention
        # states與self.weight_W矩陣相乘,然后做tanh
        u = torch.tanh(torch.matmul(states, self.weight_W))
        # u與self.weight_proj矩陣相乘,得到score
        att = torch.matmul(u, self.weight_proj)
        # softmax
        att_score = F.softmax(att, dim=1)
        # 加權求和
        scored_x = states * att_score
        encoding = torch.sum(scored_x, dim=1)
        # 線性層
        outputs = self.decoder1(encoding)
        outputs = self.decoder2(outputs)
        return outputs

其中代碼實作中的score與上述公式略有不同:
s c o r e ( h t , h s  ̄ ) = w p r o j T t a n h ( h t T h s  ̄ ) score(h_t,\overline{h_s})=w_{proj}^Ttanh(h_t^T\overline{h_s}) score(ht?hs??)=wprojT?tanh(htT?hs??)

八、Deep-BILSTM

?? Deep-BILSTM可以理解為同時訓練兩個深度的LSTM,然后將兩個深度的LSTM拼接到一起,在詞性標注領域、命名物體識別領域用的較多,


如果對您有幫助,麻煩點贊關注,這真的對我很重要!!!如果需要互關,請評論或者私信!
在這里插入圖片描述


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

標籤:AI

上一篇:機器學習筆記——Regression 2

下一篇:【李宏毅深度學習CP20】GPT3模型

標籤雲
其他(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