經(jīng)過了前面的開胃菜,項目正式開始。一步步講解這個模型怎么玩起來的。從C 到 matlab 到 FPGA ,三個平臺聯(lián)合起來完成這個 由 RTL 實現(xiàn) CNN 的項目。
第一步,講解深度學(xué)習(xí)模型在C中是怎么實現(xiàn)的,也就是梳理數(shù)據(jù)流怎么運算的。
第二步,講解這個數(shù)據(jù)怎么使用,如何去一步步驗證自己的設(shè)計。
第三步,根據(jù)前面的理解,在FPGA中如何去設(shè)計自己的代碼。
首先,C的源碼前面的文章中已經(jīng)公開了,第一步當然是理解深度學(xué)習(xí)模型在C中是怎么實現(xiàn)的。
這個深度學(xué)習(xí)的模型 LeNet5 實現(xiàn)的功能是 MNIST 數(shù)據(jù)識別。MNIST數(shù)據(jù)集是一個手寫數(shù)字的圖片集,然后被制作成了一個特殊的文件格式 —— 已經(jīng)不是圖片了,變成了這么一個東西:
網(wǎng)站上下載下來的是一個gz壓縮文件,解壓之后就是一個idx3-ubyte格式的文件。它包含了6w張用來做網(wǎng)絡(luò)模型訓(xùn)練的圖片,和1w張用來測試網(wǎng)絡(luò)模型的圖片。每張圖片再搭配一個標簽 —— 表明它是數(shù)據(jù)幾。所以整個數(shù)據(jù)集就是 7w張圖片 加 7w個標簽。
不過你可以通過python輕松導(dǎo)出來,可以看到具體的圖片和標簽。解釋這么多也夠用了,有興趣的朋友可以百度一下 MNIST ,比如下圖,就是一個博主從數(shù)據(jù)集里扒出來的圖。
先理解了數(shù)據(jù)集,再看看 C語言源碼。第一步先分別導(dǎo)入訓(xùn)練數(shù)據(jù)集和標簽,再導(dǎo)入里測試數(shù)據(jù)集和標簽,然后開始 load 模型 —— 第一次運行模型為空,于是對模型進行初始化。細心一點往下看這個初始化過程會覺得很有特色 —— 刻意讓數(shù)據(jù)很隨機,讓它們都不相同是有好處,具體什么好處可以去看看吳恩達的視頻。(我看了,云里霧里的還是不懂,所以也解釋不清楚)
后面就是訓(xùn)練和測試了,for是我后面添加的,可以讓它訓(xùn)練很多次,提升精度。下面就是測試和打印,然后保存模型,釋放空間。主程序完畢。
拿到開源代碼,運行一下,結(jié)果就是這樣子的
我就是在這個代碼基礎(chǔ)上,理解LeNet5的結(jié)構(gòu),然后量化。量化后再驗證精度,然后導(dǎo)出模型,導(dǎo)出計算的中間數(shù)據(jù)。這個 C 代碼就算物盡其用了。
有人覺得難懂?沒關(guān)系,對于這個項目而言,我已經(jīng)把C程序簡化成了一張圖,你可以忽略上述所有文字和程序,記住這張圖就行。圖的解釋可以看QQ群中的文檔,后面我還會詳細講解這張圖的,以及圖中用到的數(shù)據(jù)。
原文標題:LeNet5 MNIST 的 FPGA實現(xiàn) 3
文章出處:【微信公眾號:FPGA攻城獅之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
-
FPGA
+關(guān)注
關(guān)注
1643文章
21960瀏覽量
614061 -
數(shù)據(jù)
+關(guān)注
關(guān)注
8文章
7241瀏覽量
91001 -
代碼
+關(guān)注
關(guān)注
30文章
4886瀏覽量
70253 -
cnn
+關(guān)注
關(guān)注
3文章
354瀏覽量
22633
原文標題:LeNet5 MNIST 的 FPGA實現(xiàn) 3
文章出處:【微信號:gh_99a29eb83412,微信公眾號:FPGA攻城獅之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
基于FPGA的CNN加速項目案例解析

FPGA如何從入門到高手?

評論