House holder reflections and Givens rotations

House holder reflections and Givens rotations

Householder反射和Givens旋轉是兩種常見的線性代數方法,用于將一個矩陣分解為正交矩陣(Q)和上三角矩陣?,即QR分解。它們在數值線性代數中非常重要,特別是在求解線性方程組和特征值問題中。以下是這兩種方法的原理及它們與QR分解的關系:

Householder反射 (Householder Reflection)

Householder反射是一種利用反射將一個向量轉換為另一個向量的方法。具體來說,Householder反射可以用于將一個向量變成一個特定方向的向量,比如將一個向量變成與標準基向量平行的向量。這種方法的主要特點是,它可以在很少的運算步驟中完成這一操作,因此在數值計算中非常高效。

原理

  1. 給定一個向量 x x x,我們希望將其轉換為與標準基向量 e 1 e_1 e1? 平行的向量。為此,我們構造一個Householder矩陣 H H H
  2. Householder矩陣 H H H 的形式為:
    H = I ? 2 v v T v T v H = I - 2 \frac{vv^T}{v^Tv} H=I?2vTvvvT?
    其中, v v v 是一個特定構造的向量,使得 H x Hx Hx e 1 e_1 e1? 平行。

步驟

  1. 選擇 v = x + sign ( x 1 ) ∥ x ∥ 2 e 1 v = x + \text{sign}(x_1) \|x\|_2 e_1 v=x+sign(x1?)x2?e1?,其中 ∥ x ∥ 2 \|x\|_2 x2? x x x 的2-范數, sign ( x 1 ) \text{sign}(x_1) sign(x1?) x 1 x_1 x1? 的符號。
  2. 計算 H H H 并使用 H H H 對原矩陣 A A A 進行反射,得到一個新的矩陣 A ′ A' A ,其中v對應的列被轉換為與標準基向量平行,即列中對應行的元素不為0,其余元素均為0。

通過多次應用Householder反射,我們可以將矩陣 A A A 轉換為一個上三角矩陣 R R R,同時累積這些反射矩陣以形成正交矩陣 Q Q Q

Givens旋轉 (Givens Rotation)

Givens旋轉是一種通過旋轉將一個向量的某個分量置零的方法。這種方法非常適合用于稀疏矩陣,因為它可以有選擇地僅對矩陣的某些元素進行操作。

原理

  1. Givens旋轉通過構造一個旋轉矩陣 G G G 來對兩個元素進行旋轉,使得其中一個元素變為零。
  2. Givens旋轉矩陣 G ( i , j , θ ) G(i,j,\theta) G(i,j,θ) 的形式為:
    G = [ 1 ? c s 1 ? s c ? 1 ] G = \begin{bmatrix} 1 & & & & & \\ & \ddots & & & & \\ & & c & & s & \\ & & & 1 & & \\ & & -s & & c & \\ & & & & & \ddots \\ & & & & & & 1 \\ \end{bmatrix} G= ?1???c?s?1?sc???1? ?
    其中, c = cos ? ( θ ) c = \cos(\theta) c=cos(θ) s = sin ? ( θ ) s = \sin(\theta) s=sin(θ)

步驟

  1. 選擇 θ \theta θ 使得 c = a a 2 + b 2 c = \frac{a}{\sqrt{a^2 + b^2}} c=a2+b2 ?a? s = b a 2 + b 2 s = \frac{b}{\sqrt{a^2 + b^2}} s=a2+b2 ?b?,其中 a a a b b b 是矩陣中要被操作的兩個元素。
  2. 通過旋轉矩陣 G G G 對矩陣進行操作,將其中一個元素置零。

eg:
G = [ c s ? s c ] , v = [ a b ] G= \begin{bmatrix} c & s\\ -s & c \end{bmatrix}, v=\begin{bmatrix} a\\b\end{bmatrix} G=[c?s?sc?],v=[ab?]
則可得:
G v = [ c o s θ ? a + s i n θ ? b ? s i n θ ? a + c o s θ ? b ] = [ a + b 0 ] Gv=\begin{bmatrix} cos\theta *a+sin\theta *b\\-sin\theta *a+cos\theta *b\end{bmatrix} =\begin{bmatrix} a+b\\0\end{bmatrix} Gv=[cosθ?a+sinθ?b?sinθ?a+cosθ?b?]=[a+b0?]

通過多次應用Givens旋轉,可以將矩陣 A A A 轉換為上三角矩陣 R R R,同時累積這些旋轉矩陣以形成正交矩陣 Q Q Q

Householder反射和Givens旋轉與QR分解的關系

這兩種方法都可以用于QR分解,但它們有各自的優缺點:

  • Householder反射通常在處理密集矩陣時更有效,因為它每次操作可以消去一個向量中的多個元素,從而減少總的運算次數。
  • Givens旋轉在處理稀疏矩陣時更有效,因為它可以有選擇地僅對矩陣的某些元素進行操作,從而保持矩陣的稀疏性。

總體來說,QR分解的目標是通過一系列的正交變換(Householder反射或Givens旋轉)將原矩陣 A A A 分解為一個正交矩陣 Q Q Q 和一個上三角矩陣 R R R
A = Q R A = QR A=QR
其中, Q Q Q 是一個正交矩陣, R R R 是一個上三角矩陣。Householder反射和Givens旋轉提供了實現這一目標的兩種不同方法。

參考鏈接

《2013 Matrix Computations 4th》

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

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

相關文章

【若依管理系統】注意事項

1.前端字段必填 rules: {sceneName: [{ required: true, message: "場景名稱不能為空", trigger: "blur" }],orderNum: [{ required: true, message: "顯示排序不能為空", trigger: "blur" }], }, 2.IDEA,默認以debug模式…

python | pyvips,一個神奇的 Python 庫

本文來源公眾號“python”,僅用于學術分享,侵權刪,干貨滿滿。 原文鏈接:pyvips,一個神奇的 Python 庫! 大家好,今天為大家分享一個神奇的 Python 庫 - pyvips。 Github地址:https…

Agents 要點

一、Agents概念 人類是這個星球上最強大的 Agent。Agent是一個能感知并自主地采取行動的實體,這里的自主性極其關鍵,Agent要能夠實現設定的目標,其中包括具備學習和獲取知識的能力以提高自身性能。 關鍵點:感知環境、自主決策、具…

前端項目筆記經驗-001

做項目有一段時間了,利用下班或者零碎時間的功夫,想分享一些個人心得和感受。與君共勉。 前端應該具備的幾個能力: (1)準備假數據(模擬數據)的能力,因為后端有時候接口沒有準備好&…

element plus 實現跨頁面+跨tab欄多選

文章目錄 element plus 層面數據層面 菜鳥好久沒寫博客了,主要是沒遇見什么很難的問題,今天碰見了一個沒有思路的問題,解決后立馬來和大家伙分享了! 菜鳥今天要實現一個需求,就是:實現跨頁面跨 tab欄 多選…

力學篤行(四)Qt 線程與信號槽

線程與信號槽 1. 主窗口(MainWindow)主線程2. 線程2.1 QThread2.2 QtConcurrent::run()2.3 thread 的調用方式 3. 信號槽3.1 connect3.2 元對象系統中注冊自定義數據類型 附錄一 信號槽機制與主線程進行通信示例 1. 主窗口(MainWindow&#x…

MySQL聯合索引最左匹配原則

MySQL中的聯合索引(也叫組合索引)遵循最左匹配原則,即在創建聯合索引時,查詢條件必須從索引的最左邊開始,否則索引不會被使用。在聯合索引的情況下,數據是按照索引第一列排序,第一列數據相同時才會按照第二列排序。 例…

CVE-2024-27292:Docassemble任意文件讀取漏洞復現 [附POC]

文章目錄 CVE-2024-27292:Docassemble任意文件讀取漏洞復現 [附POC]0x01 前言0x02 漏洞描述0x03 影響版本0x04 漏洞環境0x05 漏洞復現1.訪問漏洞環境2.構造POC3.復現 0x06 修復建議 CVE-2024-27292:Docassemble任意文件讀取漏洞復現 [附POC] 0x01 前言 …

冒泡排序與其C語言通用連續類型排序代碼

冒泡排序與其C語言通用連續類型排序代碼 冒泡排序冒泡排序為交換排序的一種:動圖展示:冒泡排序的特性總結:冒泡排序排整型數據參考代碼(VS2022C語言環境): 冒泡排序C語言通用連續類型排序代碼對比較的方式更…

法律行業守護神:知識庫+AI大模型,解鎖企業知識全周期管理

在法律行業中,搭建一個有效的知識庫并進行企業知識全生命周期管理確實是一項不小的挑戰。法律環境的復雜性和不斷變化的法規要求企業必須持續更新和維護其知識庫,以確保所有信息的準確性和實時性。 這種系統化的信息管理不僅有助于提高律師和法律顧問的…

打卡第9天-----字符串

我在自學的時候,看了卡爾的算法公開課了,有些題目我就照葫蘆畫瓢寫了一遍js代碼,差不多都寫出來了,有暴力解法,有卡爾推薦的思路和方法。話不多說,直接上題上代碼吧: 一、翻轉字符串里的單詞 leetcode題目鏈接:151. 反轉字符串中的單詞 題目描述: 給你一個字符串 s…

5個自動化面試題,助你過關斬將!

面試時,自動化是軟件測試高頻面試內容,通過學習和準備面試題,你會對可能遇到的問題有所準備,從而減輕面試時的緊張感,讓你在面試中穩操勝券! 今天,分享一些在面試中可能會遇到的自動化測試面試…

軟件架構之測評方法

軟件架構之測評方法 第 11 章:測試評審方法11.1 測試方法11.1.1 軟件測試階段11.1.2 白盒測試和黑盒測試11.1.3 缺陷的分類和級別11.1.4 調試 11.2 評審方法11.3 驗證與確認11.4 測試自動化11.5 面向對象的測試 第 11 章:測試評審方法 軟件測試與評審是…

大學生暑假“三下鄉”社會實踐工作新聞投稿指南請查收!

近年來,大學生暑期“三下鄉”社會實踐工作方興未艾,越來越多的大學生通過參與“三下鄉”實踐工作,走出校園,深入基層,體驗農村生活,服務農民,促進農村經濟社會發展,實現了理論與實踐…

算能科技,致力于成為全球領先的通用算力供應商

算能致力于成為全球領先的定制算力提供商,專注于RISC-V、TPU處理器等算力產品的研發和推廣應用。公司遵循全面開源開放的生態理念,攜手行業伙伴推動RISC-V高性能通用計算產業落地;打造覆蓋“云、邊、端”的全場景產品矩陣,為數據中…

【eNSP模擬實驗】三層交換機實現VLAN通信

實驗需求 讓PC1和PC2能夠互相通訊&#xff0c;其中PC1在vlan10中&#xff0c;PC2在vlan20中。 實驗操作 首先把PC1和PC2都配置好ip&#xff0c;配置好之后&#xff0c;點擊右下角的應用 然后&#xff0c;在S2交換機&#xff08;S3700&#xff09;上做如下配置 #進入系統 <…

mvvm模式

MVVM&#xff08;Model-View-ViewModel&#xff09;模式是一種軟件設計模式&#xff0c;特別適用于構建用戶界面&#xff08;UI&#xff09;應用程序&#xff0c;尤其是使用WPF&#xff08;Windows Presentation Foundation&#xff09;、Silverlight和其他XAML技術的應用程序。…

【Redis】Redis十大類型

文章目錄 前言一、string字符串類型二、List列表類型三、 Hash表四、 Set集合五、 ZSet有序集合六、 GEO地理空間七、 HyperLogLog基數統計八、Bitmap位圖九、bitfield位域十、 Stream流10.1 隊列指令10.2 消費組指令10.3 ACK機制 前言 redis是k-v鍵值對進行存儲&#xff0c;k…

Mac上pyenv的安裝及使用

Mac上pyenv的安裝及使用 安裝 brew update brew install pyenv 報錯 git -C /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core fetch --unshallowgit -C /usr/local/Homebrew/Library/Taps/homebrew/homebrew-cask fetch --unshallow那就執行這2句 還報錯 git -C /…

【最經典的79個】軟件測試面試題(內含答案)提前備戰“金九銀十”

001.軟件的生命周期(prdctrm) 計劃階段(planning)-〉需求分析(requirement)-〉設計階段(design)-〉編碼(coding)->測試(testing)->運行與維護(running maintrnacne) 測試用例 用例編號 測試項目 測試標題 重要級別 預置條件 輸入數據 執行步驟 預期結果 0002.問&…