主頁 >  其他 > 【入門教程】?TensorFlow 2.0 模型:卷積神經網路

【入門教程】?TensorFlow 2.0 模型:卷積神經網路

2021-01-13 12:36:27 其他

文 / 李錫涵,Google Developers Expert

本文節選自《簡單粗暴 TensorFlow 2.0》

圖片

在《【入門教程】TensorFlow 2.0 模型:多層感知機》 里,我們以多層感知機(Multilayer Perceptron)為例,總體介紹了 TensorFlow 2.0 的模型構建、訓練、評估全流程,

本篇文章則以在影像領域常用的卷積神經網路為主題,介紹以下內容:

  • 如何使用 tf.keras 構建卷積神經網路模型;

  • 如何在自己的專案中快速載入并使用經典的卷積神經網路模型;

  • 為深度學習的入門者簡介 卷積層 池化層 的原理,

使用 tf.keras 構建卷積神經網路模型

卷積神經網路 (Convolutional Neural Network, CNN) 是一種結構類似于人類或動物的視覺系統的人工神經網路,包含一個或多個卷積層 (Convolutional Layer)、池化層 (Pooling Layer) 和全連接層 (Fully-connected Layer),

基礎知識和原理

  • 臺灣大學李宏毅教授的《機器學習》課程的 Convolutional Neural Network 一章

  • UFLDL 教程 Convolutional Neural Network 一節

  • 斯坦福課程 CS231n: Convolutional Neural Networks for Visual Recognition 中的 “Module 2: Convolutional Neural Networks” 部分

卷積神經網路的一個示例實作如下所示,和上節中的 多層感知機 在代碼結構上很類似,只是新加入了一些卷積層和池化層,這里的網路結構并不是唯一的,可以增加、洗掉或調整 CNN 的網路結構和引數,以達到更好的性能,

 1class CNN(tf.keras.Model):
 2    def __init__(self):
 3        super().__init__()
 4        self.conv1 = tf.keras.layers.Conv2D(
 5            filters=32,             # 卷積層神經元(卷積核)數目
 6            kernel_size=[5, 5],     # 感受野大小
 7            padding='same',         # padding策略(vaild 或 same)
 8            activation=tf.nn.relu   # 激活函式
 9        )
10        self.pool1 = tf.keras.layers.MaxPool2D(pool_size=[2, 2], strides=2)
11        self.conv2 = tf.keras.layers.Conv2D(
12            filters=64,
13            kernel_size=[5, 5],
14            padding='same',
15            activation=tf.nn.relu
16        )
17        self.pool2 = tf.keras.layers.MaxPool2D(pool_size=[2, 2], strides=2)
18        self.flatten = tf.keras.layers.Reshape(target_shape=(7 * 7 * 64,))
19        self.dense1 = tf.keras.layers.Dense(units=1024, activation=tf.nn.relu)
20        self.dense2 = tf.keras.layers.Dense(units=10)
21
22    def call(self, inputs):
23        x = self.conv1(inputs)                  # [batch_size, 28, 28, 32]
24        x = self.pool1(x)                       # [batch_size, 14, 14, 32]
25        x = self.conv2(x)                       # [batch_size, 14, 14, 64]
26        x = self.pool2(x)                       # [batch_size, 7, 7, 64]
27        x = self.flatten(x)                     # [batch_size, 7 * 7 * 64]
28        x = self.dense1(x)                      # [batch_size, 1024]
29        x = self.dense2(x)                      # [batch_size, 10]
30        output = tf.nn.softmax(x)
31        return output

圖片

示例代碼中的 CNN 結構圖示

上一篇文章 我們介紹了 TensorFlow 2.0 的模型構建、訓練、評估全流程,此處,我們只需要將上一篇文章實體化模型時的代碼 model = MLP() 更換成我們上面實作的 CNN 模型類,即 model = CNN() ,即可使用新的模型在 MNIST 資料集上進行訓練,輸出如下:

1test accuracy: 0.988100

可以發現準確率相較于上篇文章的 多層感知機 有非常顯著的提高,事實上,通過改變模型的網路結構(比如加入 Dropout 層防止過擬合),準確率還有進一步提升的空間,

快速載入并使用經典的 CNN 模型

tf.keras.applications 中有一些預定義好的經典卷積神經網路結構,如 VGG16VGG19 ResNetMobileNet 等,我們可以直接呼叫這些經典的卷積神經網路結構,而無需手動定義網路結構,

例如,我們可以使用以下代碼來實體化一個 MobileNetV2 網路結構:

1model = tf.keras.applications.MobileNetV2()

當執行以上代碼時,TensorFlow 會自動從網路上下載 MobileNetV2 網路結構,因此在第一次執行代碼時需要具備網路連接,每個網路結構具有自己特定的詳細引數設定,常用引數如下:

  • input_shape :輸入張量的形狀 (不含第一維的 Batch),大多默認為 224 × 224 × 3 ,一般而言,模型對輸入張量的大小有下限限制,長和寬至少為 32 × 3275 × 75

  • include_top :在網路的最后是否包含全連接層,默認為 True

  • weights :預訓練權值,默認為 'imagenet' ,即為當前模型載入在 ImageNet 資料集上預訓練的權值,如需隨機初始化變數可設為 None

  • classes :分類數,默認為 1000,修改該引數需要 include_top 引數為 Trueweights 引數為 None

各網路模型引數的詳細介紹可參考 Keras 檔案 ,

以下展示一個例子,使用 MobileNetV2 網路在 tf_flowers 五分類資料集上進行訓練(為了代碼的簡短高效,在該示例中我們使用了 TensorFlow Datasets 和 tf.data 載入和預處理資料,在后面的連載中會專題介紹,或可參考手冊(TensorFlow Datasets、tf.data),通過將 weights 設定為 None ,我們隨機初始化變數而不使用預訓練權值,同時將 classes 設定為 5,對應于 5 分類的資料集,

 1import tensorflow as tf
 2import tensorflow_datasets as tfds
 3
 4num_batches = 1000
 5batch_size = 50
 6learning_rate = 0.001
 7
 8dataset = tfds.load("tf_flowers", split=tfds.Split.TRAIN, as_supervised=True)
 9dataset = dataset.map(lambda img, label: (tf.image.resize(img, [224, 224]) / 255.0, label)).shuffle(1024).batch(32)
10model = tf.keras.applications.DenseNet121(weights=None, classes=5)
11optimizer = tf.keras.optimizers.Adam(learning_rate=learning_rate)
12for images, labels in dataset:
13    with tf.GradientTape() as tape:
14        labels_pred = model(images)
15        loss = tf.keras.losses.sparse_categorical_crossentropy(y_true=labels, y_pred=labels_pred)
16        loss = tf.reduce_mean(loss)
17        print("loss %f" % loss.numpy())
18    grads = tape.gradient(loss, model.trainable_variables)
19    optimizer.apply_gradients(grads_and_vars=zip(grads, model.trainable_variables))

后文連載文章中,我們也會直接呼叫這些經典的網路結構來進行訓練,

卷積層和池化層的作業原理

卷積層(Convolutional Layer,以 tf.keras.layers.Conv2D 為代表)是 CNN 的核心組件,其結構與大腦的視覺皮層有類似之處,


回憶我們之前建立的 神經細胞的計算模型 以及全連接層,我們默認每個神經元與上一層的所有神經元相連,不過,在視覺皮層的神經元中,情況并不是這樣,你或許在生物課上學習過 感受野 (Receptive Field)這一概念,即視覺皮層中的神經元并非與前一層的所有神經元相連,而只是感受一片區域內的視覺信號,并只對區域區域的視覺刺激進行反應,CNN 中的卷積層正體現了這一特性,


例如,下圖是一個 7×7 的單通道圖片信號輸入:

圖片

如果使用之前基于全連接層的模型,我們需要讓每個輸入信號對應一個權值,即建模一個神經元需要 7×7=49 個權值(加上偏置項是 50 個),并得到一個輸出信號,如果一層有 N 個神經元,我們就需要 49N 個權值,并得到 N 個輸出信號,


而在 CNN 的卷積層中,我們這樣建模一個卷積層的神經元:

圖片

圖中 3×3 的紅框代表該神經元的感受野,由此,我們只需 3×3=9 個權值 ,外加 1 個偏置項 ,即可得到一個輸出信號,例如,對于紅框所示的位置,輸出信號即為對矩陣 的所有元素求和并加上偏置項 ,記作

不過,3×3 的范圍顯然不足以處理整個影像,因此我們使用滑動視窗的方法,使用相同的引數 ,但將紅框在影像中從左到右滑動,進行逐行掃描,每滑動到一個位置就計算一個值,例如,當紅框向右移動一個單位時,我們計算矩陣 的所有元素的和并加上偏置項 ,記作 ,由此,和一般的神經元只能輸出 1 個值不同,這里的卷積層神經元可以輸出一個 5×5 的矩陣

圖片

卷積示意圖,一個單通道的 7×7 影像在通過一個感受野為 3×3 ,引數為 10 個的卷積層神經元后,得到 5×5 的矩陣作為卷積結果

下面,我們使用 TensorFlow 來驗證一下上圖的計算結果,

將上圖中的輸入影像、權值矩陣 圖片 和偏置項 圖片 表示為 NumPy 陣列 image , W , b 如下:

1#TensorFlow 的影像表示為 [影像數目,長,寬,色彩通道數] 的四維張量
2#這里我們的輸入影像 image 的張量形狀為 [1, 7, 7, 1]
3image = np.array([[
4    [0, 0, 0, 0, 0, 0, 0],
5    [0, 1, 0, 1, 2, 1, 0],
6    [0, 0, 2, 2, 0, 1, 0],
7    [0, 1, 1, 0, 2, 1, 0],
8    [0, 0, 2, 1, 1, 0, 0],
9    [0, 2, 1, 1, 2, 0, 0],
10    [0, 0, 0, 0, 0, 0, 0]
11]], dtype=np.float32)
12image = np.expand_dims(image, axis=-1)  
13W = np.array([[
14    [ 0, 0, -1], 
15    [ 0, 1, 0 ], 
16    [-2, 0, 2 ]
17]], dtype=np.float32)
18b = np.array([1], dtype=np.float32)

然后建立一個僅有一個卷積層的模型,用 Wb 初始化 [4] :

1model = tf.keras.models.Sequential([
2    tf.keras.layers.Conv2D(
3        filters=1,              # 卷積層神經元(卷積核)數目
4        kernel_size=[3, 3],     # 感受野大小
5        kernel_initializer=tf.constant_initializer(W),
6        bias_initializer=tf.constant_initializer(b)
7    )]
8)

最后將影像資料 image 輸入模型,列印輸出:

1output = model(image)
2print(tf.squeeze(output))

程式運行結果為:

1tf.Tensor(
2[[ 6.  5. -2.  1.  2.]
3 [ 3.  0.  3.  2. -2.]
4 [ 4.  2. -1.  0.  0.]
5 [ 2.  1.  2. -1. -3.]
6 [ 1.  1.  1.  3.  1.]], shape=(5, 5), dtype=float32)

可見與上圖中矩陣 的值一致,

還有一個問題,以上假設圖片都只有一個通道(例如灰度圖片),但如果影像是彩色的(例如有 RGB 三個通道)該怎么辦呢?此時,我們可以為每個通道準備一個 3×3 的權值矩陣,即一共有 3×3×3=27 個權值,對于每個通道,均使用自己的權值矩陣進行處理,輸出時將多個通道所輸出的值進行加和即可,

可能有讀者會注意到,按照上述介紹的方法,每次卷積后的結果相比于原始影像而言,四周都會 “少一圈”,比如上面 7×7 的影像,卷積后變成了 5×5 ,這有時會為后面的作業帶來麻煩,因此,我們可以設定 padding 策略,在 tf.keras.layers.Conv2D 中,當我們將 padding 引數設為 same 時,會將周圍缺少的部分使用 0 補齊,使得輸出的矩陣大小和輸入一致,

最后,既然我們可以使用滑動視窗的方法進行卷積,那么每次滑動的步長是不是可以設定呢?答案是肯定的,通過 tf.keras.layers.Conv2Dstrides 引數即可設定步長(默認為 1),比如,在上面的例子中,如果我們將步長設定為 2,輸出的卷積結果即會是一個 3×3 的矩陣,

事實上,卷積的形式多種多樣,以上的介紹只是其中最簡單和基礎的一種,更多卷積方式的示例可見 Convolution arithmetic ,

池化層(Pooling Layer)的理解則簡單得多,其可以理解為對影像進行降采樣的程序,對于每一次滑動視窗中的所有值,輸出其中的最大值(MaxPooling)、均值或其他方法產生的值,例如,對于一個三通道的 16×16 影像(即一個 16163 的張量),經過感受野為 2×2,滑動步長為 2 的池化層,則得到一個 883 的張量,

[4]
這里使用了較為簡易的 Sequential 模式建立模型,具體介紹可參考手冊,

福利 | 問答環節

在上一篇文章《TensorFlow 2.0 模型:多層感知機》中,我們對于部分具有代表性的問題回答如下:

Q1:有 labelimg 標注過了的 datasets 下載庫推薦嗎?自己標幾萬張是不可能完成的任務……
A:對于已有的經典資料集,可以參考 TensorFlow Datasets,TensorFlow Datasets 是一個開箱即用的資料集集合,包含數十種常用的機器學習資料集,通過簡單的幾行代碼即可將資料以 tf.data.Datasets 的格式載入,

Q2:Release版本啥時候出來呀?
A:目前 TensorFlow 2.0 已發布了 RC1 (Release Candidate 1)版本,可使用 pip install tensorflow==2.0.0-rc1 安裝,相信距離正式發布已經不會太遠了,

Q3:TensorFlow 的 keras 和 keras 庫本身性能有區別么?
A:TensorFlow 的 Keras(tf.keras)可以理解為與 TensorFlow 緊密整合的 Keras,支持 TensorFlow 的更多獨有特性(如 Eager Execution、TPU、基于 tf.distribution 的多 GPU 和多機訓練等),而這些特性能夠幫助你更高效地訓練模型,同時建議參考知乎問題:tf.keras 和 keras有什么區別?,

Q4:每次都是 mnist ,能不能在資料 pipeline 上面多一些敘述?
A:其實,在本文的“快速載入并使用經典的卷積神經網路模型”部分,我們已經開始使用 TensorFlow Datasets(TFDS) 和 tf.data ,僅用短短數行就載入了 tf_flowers 花朵五分類資料集,并進行了影像大小轉換、打散及分批次等預處理,在后面的連載中,我們會專題介紹 TensorFlow Datasets(TFDS) 和 tf.data,這兩個工具能夠幫助你高效、靈活地載入和處理大規模訓練資料,可參考 :

Q5:最近在研究 object detection,想用 tensorflow-datasets 匯入 voc2007 資料集,但不知道怎么匯入,請問官方有比較好的演示代碼嗎?
A:您可以嘗試使用 TensorFlow Datasets 載入 voc2007 資料集,演示代碼如下:

1import tensorflow_datasets as tfds
2dataset = tfds.load("voc2007", split=tfds.Split.TRAIN)

是的,你沒看錯,就兩行哦!將資料集載入后,就可以使用 tf.data 方便高效地預處理和迭代讀取資料,以上是載入訓練集,載入測驗集和驗證集可將split=tfds.Split.TRAIN換為split=tfds.Split.TESTsplit=tfds.Split.VALIDATION

  • TensorFlow Datasets 的使用簡介及
  • TFDS 中載入 voc2007 資料集

Q6:資料集大,怎么處理?
A:在后面的連載中,我們會專題介紹 TensorFlow Datasets(TFDS) 和 tf.data,這兩個工具能夠幫助你高效、靈活地載入和處理訓練大規模資料,

Q7:可不可以出點系統性的教程,入門好難
A:本系列教程《簡單粗暴 TensorFlow 2.0》即希望為 TensorFlow 初學者提供易于上手的系統指導,另外,TensorFlow的官方教程也經過了大量的更新以改善易讀性,可參考本鏈接,

如果也想像大神一樣快速進步,別錯過 TensorFlow 官方團隊在中國大學慕課平臺推出的《TensorFlow 入門實操課程》,幫助你了解更多機器學習設計思路和實踐模式,立即點擊此處學習吧!

有任何學習疑問,歡迎移步“問答”版塊發帖提問,你的問題有機會得到 CSDN 百大熱門技術博主、資深社區作者或者 TensorFlow 資深開發者的解答哦!同時,我們也歡迎你積極地在這個版塊里,回答其他小伙伴提出的問題,成為 CSDN 社區貢獻者,邁出出道第一步!馬上開始討論吧!

還想獲取更多入門課程和產品資訊?記得掃碼關注 TensorFlow 官方微信公眾號( TensorFlow_official )!

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

標籤:AI

上一篇:SCI-HUB 印度被訴、twitter賬號被封,是梁上君子還是羅賓漢?

下一篇:CSDN:2020年度CSDN博客之星評選競賽——180號【一個處女座的程式猿】,感謝您,投上的寶貴一票,感謝!感恩!

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