深度學習、圖像算法學習記錄

深度學習加速

綜述文檔: https://chenzomi12.github.io/02Hardware01Foundation/02ArchSlim.html
winograd: https://zhuanlan.zhihu.com/p/260109670
ncnn

1.修改模型結構,優化模型內存訪問次數,加速。
VGG 和 InceptionNet : 將5x5卷積替換成兩個3x3卷積,既提升了網絡深度,又減少了參數量.
MobileNet :深度可分離卷積,最后用1x1卷積組合,直接大量縮減模型參數量。
DenseNet 和 GhostNet :Reuse Feature Map,復用之前層的featureMap。

2.分布式訓練
torch.nn.parallel.DistributedDataParallel: 在多個GPU復制一份模型副本,單獨計算batch,計算完后,平均梯度值再廣播到所有GPU,更新。

3.矩陣乘法(卷積轉為矩陣乘法)

  • 多線程
  • 算法改進(Fast Fourier Transform、Strassen、Winograd)

知識蒸餾

1.自蒸餾:Be Your Own Teacher: Improve thePerformance of Convolutional Neural Networks viaSelf Distillation;

經典論文:

attention: https://arxiv.org/pdf/1706.03762
mobilenet系列
pix2pix
ALIKED

論文解讀

ALIKED
1.結構?
4個block,通過1x1卷積+上采樣組合所有block的特征,然后通過一個SMH (Score Map Head )得到Score Map,再通過DKD模塊(NMS)得到特征點位置(64x64x128),同時得到對應點的描述子。

2.卷積無法保證提取到的點是仿射不變的?aliked中怎么解決該問題的?
答:因為卷積帶有特定模式,比如檢測橫線的卷積,在特征圖做仿射變換后變成非橫線,卷積就檢測不到了。

ATTENTION IS ALL YOU NEED
1.QKV結構,QKV是通過輸入做Linear得到,Linear的權重為可學習參數;
2.通過QK點乘,得到對應的V的重要程度權重,再用權重與V乘,得到每個v加權后的注意力值;
3.QK點乘實際是計算的余弦相似度。

工具:

神經網絡可視化工具(每一層輸出的可視化,用以指導每層網絡的設計是否合理):https://blog.51cto.com/u_16099181/8552104

Winograd

卷積運算轉為矩陣乘法后,存在很多重復值,等效稀疏矩陣,比普通矩陣實際少很多計算量。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/75316.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/75316.shtml
英文地址,請注明出處:http://en.pswp.cn/web/75316.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java中的Exception和Error有什么區別?還有更多擴展

概念 在Java中,Exception和Error都是Throwable的子類,用于處理程序中的錯誤和異常情況。 然而,它們在用途和處理方式上有顯著的不同: Exception: 用于表示程序在正常運行過程中可能出現的錯誤,如文件未找…

文章記單詞 | 第26篇(六級)

一,單詞釋義 actor:名詞,演員mask:名詞,面具;口罩;遮蓋物;動詞,掩飾;戴面具;遮蓋construct:動詞,建造;構造&a…

LeetCode算法題(Go語言實現)_38

題目 給定一個二叉樹, 找到該樹中兩個指定節點的最近公共祖先。 一、代碼實現 type TreeNode struct {Val intLeft *TreeNodeRight *TreeNode }func lowestCommonAncestor(root, p, q *TreeNode) *TreeNode {if root nil || root p || root q {return root}left : lowes…

Java 基礎語法、Java注釋

Java 基礎語法 一個 Java 程序可以認為是一系列對象的集合,而這些對象通過調用彼此的方法來協同工作。下面簡要介紹下類、對象、方法和實例變量的概念。 對象:對象是類的一個實例,有狀態和行為。例如,一條狗是一個對象,它的狀態有:顏色、名字、品種;行為有:搖尾巴、叫…

用VScode來編寫前后端——構建基礎框架

前言 我寫這一個板塊的原因是我參加了我們學校的新生項目課,需要創立一個系統,我們小組選的標題的基于計算機視覺的商品識別系統,那么我們需要一個網站來展示我們的功能,故寫這些來記錄一下自己,大家如果有什么問題的話…

git clone阻塞問題

問題描述 git clone采用的ssh協議,在克隆倉庫的時候,會經常卡一下,亦或是直接卡死不動。 最開始以為是公司電腦配置的問題,想著自己實在解決不了找it幫忙。 查閱資料發現,最終發現是git版本的問題,這個是…

WEB攻防-Java安全JNDIRMILDAP五大不安全組件RCE執行不出網不回顯

目錄 1. RCE執行-5大類函數調用 1.1 Runtime方式 1.2 Groovy執行命令 1.3 腳本引擎代碼注入 1.4 ProcessImpl 1.5 ProcessBuilder 2. JNDI注入(RCE)-RMI&LDAP&高版本 2.1 RMI服務中的JNDI注入場景 2.2 LDAP服務中的JNDI注入場景 攻擊路徑示例&#…

【Hadoop入門】Hadoop生態之Sqoop簡介

1 什么是Sqoop? 在企業的數據架構中,關系型數據庫與Hadoop生態系統之間的數據流動是常見且關鍵的需求。Apache Sqoop(SQL-to-Hadoop)正是為解決這一問題而生的高效工具,它專門用于在結構化數據存儲(如RDBMS…

如何自動檢測使用的組件庫有更新

🤖 作者簡介:水煮白菜王,一位前端勸退師 👻 👀 文章專欄: 前端專欄 ,記錄一下平時在博客寫作中,總結出的一些開發技巧和知識歸納總結?。 感謝支持💕💕&#…

Go語言編寫一個進銷存Web軟件的demo

Go語言編寫一個進銷存Web軟件的demo 用戶現在要求用。之前他們已經討論了用Django實現的方案,現在突然切換到Go,可能有幾個原因。首先,用戶可能對Go語言感興趣,或者他們公司的技術棧轉向了Go。其次,用戶可能希望比較不…

【前綴和】矩陣區域和(medium)

矩陣區域和(medium) 題?描述:解法:代碼Java 算法代碼:C 算法代碼: 題?描述: 題?鏈接:1314. 矩陣區域和 給你?個 m x n 的矩陣 mat 和?個整數 k ,請你返回?個矩陣 …

Java學習手冊:Java發展歷史與版本特性

Java作為全球最流行的編程語言之一,其發展歷程不僅見證了技術的演進,也反映了軟件開發模式的變革。從1995年的首次發布到如今的持續更新,Java始終保持著強大的生命力和廣泛的影響力。本文將簡要回顧Java的發展歷程,并重點介紹其關…

winserver2022備份

安裝備份,然后等待安裝完成即可 然后可以在這里看到安裝好的win server2022備份 一直下一步然后到這里 不要用本地文件夾備份 備份到遠程服務器,遠程服務器路徑 然后確定備份即可 如何恢復呢? 點擊右側的恢復就可以了 打開任務計劃程序 這…

Unity 設置彈窗Tips位置

根據鼠標位于屏幕的區域&#xff0c;設置彈窗錨點以及位置 public static void TipsPos(Transform tf) {//獲取ui相機var uiCamera GetUICamera();var popup tf.GetComponent<RectTransform>();//獲取鼠標位置Vector2 mousePos Input.mousePosition;float screenWidt…

【C++基礎-關鍵字】:extern

深入理解 C++ 關鍵字 extern 在 C++ 編程中,extern 關鍵字扮演著重要角色,主要用于聲明全局變量或函數,使其在多個源文件間共享。本文將詳細探討 extern 的用法及其在實際開發中的應用。 1. 什么是 extern? extern 關鍵字用于聲明一個變量或函數的引用,表示該變量或函數…

我為女兒開發了一個游戲網站

大家好&#xff0c;我是星河。 自從協助妻子為女兒開發了算數射擊游戲后&#xff0c;星河就一直有個想法&#xff1a;為女兒打造一個專屬的學習游戲網站。之前的射擊游戲雖然有趣&#xff0c;但缺乏難度分級&#xff0c;無法根據女兒的學習進度靈活調整。而且&#xff0c;僅僅…

基于 Python 卷積神經網絡的新聞文本分類系統,附源碼

大家好&#xff0c;我是徐師兄&#xff0c;一個有著7年大廠經驗的程序員&#xff0c;也是一名熱衷于分享干貨的技術愛好者。平時我在 CSDN、掘金、華為云、阿里云和 InfoQ 等平臺分享我的心得體會。今天我來跟大家聊聊一個用 Python 和 Django 打造的人臉識別考勤系統&#xff…

ngx_cycle_modules

Ubuntu 下 nginx-1.24.0 源碼分析 - ngx_cycle_modules-CSDN博客 定義在 src/core/ngx_module.c ngx_int_t ngx_cycle_modules(ngx_cycle_t *cycle) {/** create a list of modules to be used for this cycle,* copy static modules to it*/cycle->modules ngx_pcalloc(…

AI 代碼生成工具如何突破 Java 單元測試效能天花板?

一、傳統單元測試的四大痛點 時間黑洞&#xff1a;根據 JetBrains 調研&#xff0c;Java 開發者平均花費 35% 時間編寫測試代碼覆蓋盲區&#xff1a;手工測試覆蓋率普遍低于 60%&#xff08;Jacoco 全球統計數據&#xff09;維護困境&#xff1a;業務代碼變更導致 38% 的測試用…

【保姆級圖解】插入排序 算法詳解:直接插入排序、希爾排序

總體引入 在計算機科學的算法領域中&#xff0c;排序是一項基礎且重要的操作。它旨在將一組無序的數據元素重新排列為有序序列&#xff0c;以滿足特定的順序要求&#xff0c;如升序或降序。常見的排序算法可分為不同類別&#xff0c;像插入排序&#xff0c;包含直接插入排序和…