11QR分解

1.定义

矩阵A可以化为正交(酉)矩阵Q和上三角矩阵R的乘积,即 A = Q R A=QR A=QR,则称上式为矩阵的 Q R QR QR分解

2.定理

A A A是一个 n n n阶非奇异矩阵,则存在正交(酉)矩阵 Q Q Q和上三角矩阵 R R R使得 A = Q R A=QR A=QR,且除去相差一个对角元素绝对值全为1的对角因子外,上述分解唯一。
回顾一下施密特正交化的过程
在这里插入图片描述
可以得到施密特正交化的矩阵为
在这里插入图片描述
证明:
A = [ a 1 , a 2 . . . a n ] A=[a_1,a_2...a_n] A=[a1,a2...an],且 a 1 , a 2 , . . . a n a_1,a_2,...a_n a1,a2,...an线性无关。应用施密特正交化的办法可以得到 [ a 1 a 2 ⋯ a n ] = [ b 1 b 2 ⋯ b n ] [ 1 b ⋯ k n 1 1 ⋯ k n 2 ⋱ ⋮ k n n − 1 ] \left[ \begin{matrix} a_1 & a_2 & \cdots & a_n \end{matrix} \right]=\left[ \begin{matrix} b_1 & b_2 & \cdots & b_n \end{matrix} \right]\left[ \begin{matrix} 1 & b & \cdots & k_{n1} \\ & 1 & \cdots & k_{n2} \\ & & \ddots & \vdots \\ & & & k_{nn-1} \end{matrix} \right] [a1a2an]=[b1b2bn]1b1kn1kn2knn1对其单位化可得 [ a 1 a 2 ⋯ a n ] = [ q 1 q 2 ⋯ q n ] [ ∣ b 1 ∣ ∣ b 2 ∣ ⋱ ∣ b n ∣ ] [ 1 b ⋯ k n 1 1 ⋯ k n 2 ⋱ ⋮ k n n − 1 ] = Q R \left[ \begin{matrix} a_1 & a_2 & \cdots & a_n \end{matrix} \right]=\left[ \begin{matrix} q_1 & q_2 & \cdots & q_n \end{matrix} \right]\left[ \begin{matrix} |b_1| & & & \\ & |b_2| & & \\ & & \ddots & \\ & & & |b_n| \end{matrix} \right]\left[ \begin{matrix} 1 & b & \cdots & k_{n1} \\ & 1 & \cdots & k_{n2} \\ & & \ddots & \vdots \\ & & & k_{nn-1} \end{matrix} \right]=QR [a1a2an]=[q1q2qn]b1b2bn1b1kn1kn2knn1=QR接下来我们证明其唯一性:
假设有两个QR分解 A = Q R = Q 1 R 1 A=QR=Q_1R_1 A=QR=Q1R1 Q = Q 1 R 1 R − 1 = Q 1 D Q=Q_1R_1R^{-1}=Q_1D Q=Q1R1R1=Q1D因为 R 1 , R R_1,R R1,R都为上三角矩阵,而上三角矩阵的逆为上三角矩阵,上三角矩阵成上三角矩阵还是上三角矩阵因此 D D D是上三角矩阵。又 I = Q H Q = D H Q 1 H Q 1 D = D H D I=Q^HQ=D^HQ_1^HQ_1D=D^HD I=QHQ=DHQ1HQ1D=DHD所以 D D D是酉矩阵。所以, D D D只能是对角元素绝对值全为1的对角阵

3.求QR分解的办法

3.1Gives变换(利用Gives变换的 T x = ∣ x ∣ e 1 Tx=|x|e_1 Tx=xe1

例题:利用 G i v e n s 变 换 Givens变换 Givens A = [ 2 2 1 0 2 2 2 1 2 ] A=\left[ \begin{matrix} 2 & 2& 1 \\ 0 & 2& 2\\ 2 & 1 & 2 \end{matrix} \right] A=202221122 Q R 分 解 QR分解 QR正交矩阵的转置就是其逆
解:首先对第一列进行Givens变换,有 T 13 = [ c 0 s 0 1 0 − s 0 c ] , c = a 11 a 11 2 + a 31 2 = 2 2 2 = 1 2 , s = a 31 a 11 2 + a 31 2 = 1 2 T_{13}=\left[ \begin{matrix} c & 0& s \\ 0 & 1& 0\\ -s & 0 & c \end{matrix} \right] ,c=\frac{a_{11}}{\sqrt{a_{11}^2+a_{31}^2}}=\frac{2}{2\sqrt{2}}=\frac{1}{\sqrt{2}},s=\frac{a_{31}}{\sqrt{a_{11}^2+a_{31}^2}}=\frac{1}{\sqrt{2}} T13=c0s010s0c,c=a112+a312 a11=22 2=2 1,s=a112+a312 a31=2 1所以可得 T 1 = [ 1 2 0 1 2 0 1 0 − 1 2 0 1 2 ] , T 1 A = [ 2 2 3 2 3 2 0 2 2 0 − 1 2 1 2 ] , A ( 1 ) = [ 2 2 − 1 2 1 2 ] T_1=\left[ \begin{matrix} \frac{1}{\sqrt{2}} & 0& \frac{1}{\sqrt{2}} \\ 0 & 1& 0\\ -\frac{1}{\sqrt{2}} & 0& \frac{1}{\sqrt{2}} \end{matrix} \right] ,T_1A=\left[ \begin{matrix} 2\sqrt{2} & \frac{3}{\sqrt{2}}&\frac{3}{\sqrt{2}} \\ 0 & 2& 2\\ 0 & -\frac{1}{\sqrt{2}} &\frac{1}{\sqrt{2}} \end{matrix} \right],A^{(1)}=\left[ \begin{matrix} 2& 2\\ -\frac{1}{\sqrt{2}} &\frac{1}{\sqrt{2}} \end{matrix} \right] T1=2 102 10102 102 1,T1A=22 002 322 12 322 1,A(1)=[22 122 1] A ( 1 ) A^{(1)} A(1)再进行Givens变换,可以得到 T 12 = [ c s − s c ] , c = 2 2 3 , s = − 1 3 T_{12}=\left[ \begin{matrix} c & s \\ -s & c \end{matrix} \right],c=\frac{2\sqrt{2}}{3},s=-\frac{1}{3} T12=[cssc],c=322 ,s=31所以可得 T 2 = [ 2 2 3 − 1 3 1 3 2 2 3 ] , T 2 A ( 1 ) = [ 2 2 3 7 2 6 0 4 3 ] , T2=\left[ \begin{matrix} \frac{2\sqrt{2}}{3} & -\frac{1}{3} \\ \frac{1}{3} & \frac{2\sqrt{2}}{3} \end{matrix} \right],T_2A^{(1)}=\left[ \begin{matrix} \frac{2\sqrt{2}}{3} & \frac{7\sqrt{2}}{6} \\ 0 & \frac{4}{3} \end{matrix} \right], T2=[322 3131322 ],T2A(1)=[322 0672 34],综上可得, R = [ 2 2 3 2 3 2 0 2 2 3 7 2 6 0 0 4 3 ] , Q = [ [ 1 0 0 T 2 ] T 1 ] T = [ 1 2 1 3 2 − 2 3 0 2 2 3 7 2 6 1 2 − 1 3 2 2 3 ] R=\left[ \begin{matrix} 2\sqrt{2} & \frac{3}{\sqrt{2}}&\frac{3}{\sqrt{2}} \\ 0 & \frac{2\sqrt{2}}{3} & \frac{7\sqrt{2}}{6}\\ 0 & 0 & \frac{4}{3} \end{matrix} \right],Q=\left[\left[ \begin{matrix} 1 & 0 \\ 0& T2 \end{matrix} \right]T_1\right]^T=\left[ \begin{matrix} \frac{1}{\sqrt{2}} & \frac{1}{3\sqrt{2}}&-\frac{2}{3} \\ 0 & \frac{2\sqrt{2}}{3} & \frac{7\sqrt{2}}{6}\\ \frac{1}{\sqrt{2}} & -\frac{1}{3\sqrt{2}}& \frac{2}{3} \end{matrix} \right] R=22 002 3322 02 3672 34,Q=[[100T2]T1]T=2 102 132 1322 32 132672 32

3.2Householder变换(利用 H x = ∣ x ∣ z Hx=|x|z Hx=xz

z z z矩阵设为e矩阵,u= x − ∣ x ∣ z ∣ x − ∣ x ∣ z ∣ \frac{x-|x|z}{|x-|x|z|} xxzxxz
利用Householder求 A = [ 0 4 1 1 1 1 0 3 2 ] A=\left[ \begin{matrix} 0 & 4& 1 \\ 1 & 1& 1\\ 0 & 3 & 2 \end{matrix} \right] A=010413112 Q R QR QR分解
解:首先对第一列使用Householder变换,可以得到 H = I − 2 u u T , ∣ x − ∣ x ∣ e 1 ∣ = 2 , x − ∣ x ∣ e 1 = [ − 1 1 0 ] , u = 1 2 [ − 1 1 0 ] H=I-2uu^T,|x-|x|e_1|=\sqrt{2},x-|x|e_1=\left[ \begin{matrix} -1\\ 1 \\ 0 \end{matrix} \right],u=\frac{1}{\sqrt{2}}\left[ \begin{matrix} -1\\ 1 \\ 0 \end{matrix} \right] H=I2uuT,xxe1=2 ,xxe1=110,u=2 1110 2 u u T = 1 2 [ − 1 1 0 ] 1 2 [ − 1 1 0 ] = 1 2 [ 1 − 1 0 − 1 1 0 0 0 0 ] 2uu^T=\frac{1}{\sqrt{2}}\left[ \begin{matrix} -1\\ 1 \\ 0 \end{matrix} \right]\frac{1}{\sqrt{2}}\left[ \begin{matrix} -1 &1 & 0 \end{matrix} \right]=\frac{1}{2}\left[ \begin{matrix} 1&-1&0\\ -1&1&0 \\ 0&0&0 \end{matrix} \right] 2uuT=2 11102 1[110]=21110110000 I − 2 u u T = [ 0 1 0 1 0 0 0 0 1 ] = H , H A = [ 1 1 1 0 4 1 0 3 2 ] I-2uu^T=\left[ \begin{matrix} 0&1&0\\ 1&0&0 \\ 0&0&1 \end{matrix} \right]=H,HA=\left[ \begin{matrix} 1&1&1\\ 0&4&1 \\ 0&3&2 \end{matrix} \right] I2uuT=010100001=H,HA=100143112继续做下去,可以得到
在这里插入图片描述
在这里插入图片描述

  • 6
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
要批量生成二维码并打包,你可以使用以下步骤: 1. 安装 vue-qr 插件:在命令行中运行 `npm install vue-qr --save`,或者在项目目录下运行 `yarn add vue-qr`。 2. 创建一个二维码生成器组件:在 Vue 应用中创建一个新的组件,用于批量生成二维码。在组件中使用 vue-qr 插件来生成二维码。 3. 创建一个数据源:在组件中创建一个数据源,用于存储所有要生成二维码的数据。可以使用数组或对象存储数据。 4. 使用 v-for 指令循环生成二维码:在组件中使用 v-for 指令循环遍历数据源,使用 vue-qr 插件生成二维码,并将生成的二维码添加到页面中。 5. 打包生成的二维码:在组件中添加一个按钮,当用户点击按钮时,使用 jszip 插件将所有二维码打包成一个压缩文件,并将文件下载到本地。 以下是一个简单的示例代码: ```html <template> <div> <div v-for="(data, index) in dataSource" :key="index"> <p>{{ data.name }}</p> <qrcode :value="data.code"></qrcode> </div> <button @click="handleDownload">Download</button> </div> </template> <script> import VueQr from 'vue-qr' import JSZip from 'jszip' import FileSaver from 'file-saver' export default { components: { VueQr }, data() { return { dataSource: [ { name: 'Qrcode 1', code: 'https://www.example.com/1' }, { name: 'Qrcode 2', code: 'https://www.example.com/2' }, { name: 'Qrcode 3', code: 'https://www.example.com/3' } ] } }, methods: { handleDownload() { const zip = new JSZip() this.dataSource.forEach((data, index) => { const imgData = this.$refs[`qrcode${index}`][0].$el.toDataURL() zip.file(`${data.name}.png`, imgData.substr(imgData.indexOf(',') + 1), { base64: true }) }) zip.generateAsync({ type: 'blob' }).then((content) => { FileSaver.saveAs(content, 'qrcodes.zip') }) } } } </script> ``` 在上述示例代码中,我们使用了 vue-qr 插件来生成二维码,使用 jszip 插件将所有二维码打包成一个压缩文件,并使用 file-saver 插件将文件下载到本地。注意,我们使用了 $refs 来获取每个二维码组件的实例,并将实例转换为图片数据进行打包。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值