博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
matlab练习程序(三阶张量T-QR分解)
阅读量:6472 次
发布时间:2019-06-23

本文共 1747 字,大约阅读时间需要 5 分钟。

  这里所谓的张量和黎曼那里的张量是不一样的,那个张量更多的用在物理上,这个张量就是矩阵的扩展。比如零阶张量就是数,一阶张量就是向量,二阶张量就是矩阵,三阶四阶就是更高维的数的集合。这个领域现在在数学上还都是很新的东西,矩阵的秩我们都知道怎么求,但是三维的张量或更高维的张量的秩现在在数学上也没有结果。至于张量的奇异值分解也只是也只是用很早的如用HOSVD来处理,我感觉这并不完全合适,新的分解算法就连老美也都没研究出来,从二维到多维的确有很多基础的理论都不适用了,像两个张量相乘这样基础的算法,现在虽然有,但我感觉也不是通用的,还要继续改进。

  下面就是我看的一篇论文的张量相乘和分解方法,她的理论也可能不正确,不过这种新领域,大家都是在探索。

  论文在这里:,他主要介绍的是T-svd,T-svd分解后合成的只是原张量的一个近似结果,而T-QR就能得到一个准确的结果,所以我这里用了T-QR。以Matlab角度来看T-SVD和T-QR的代码其实是很类似的。

main.m

clear all;close all;clc;n1=3;n2=3;n3=3;A(:,:,1)=[10 23 34;43 55 63;72 85 96];A(:,:,2)=[24 17 35;52 36 55;81 94 75];A(:,:,3)=[65 16 52;21 47 78;92 33 43];%A=imread('s.jpg');D=fft(A,[],3);for i=1:n3    [q r]=qr(D(:,:,i));    %[u s v]=svd(D(:,:,i));    Q(:,:,i)=q;    R(:,:,i)=r;    %S(:,:,i)=s;endQ=ifft(Q,[],3);R=ifft(R,[],3);%S=ifft(S,[],3);B(:,:,1)=eye(n1,n2);B(:,:,2)=zeros(n1,n2);B(:,:,3)=zeros(n1,n2);%c=mul(mul(U,S),transpos(V));c=mul(Q,R);

mul.m  张量相乘,论文第七页3.3的那个公式

function c=mul(a,b)    [a_n1 a_n2 a_n3]=size(a);    [b_n1 b_n2 b_n3]=size(b);    c=zeros(a_n1,b_n2,a_n3);    A=cell(a_n3,1);    B=cell(b_n3,1);        for i=1:a_n3        A{
i}=a(:,:,i); B{
i}=b(:,:,i); end index_up=zeros(1,a_n3); index_down=zeros(1,a_n3); for i=1:a_n3 index_up(i)=a_n3-i+1; index_down(i)=i; end s=cell(a_n3,a_n3); for i=1:a_n3 for j=1:a_n3 if i==j s{
i,j}=A{
1}; end if j>i s{
i,j}=A{
index_up(j-i)}; end if j

transpos.m  张量求转置,论文第十页example3.15的公式

function a=transpos(b)        [n1 n2 n3]=size(b);    a=zeros(n2,n1,n3);    for i=1:n3        a(:,:,i)=b(:,:,i)';    endend

转载于:https://www.cnblogs.com/tiandsp/archive/2012/10/31/2747971.html

你可能感兴趣的文章
linux操作系统加固软件,系统安全:教你Linux操作系统的安全加固
查看>>
linux中yum源安装dhcp,24.Linux系统下动态网络源部署方法(dhcpd)
查看>>
C#技术------垃圾回收机制(GC)
查看>>
HDOJ-1010 Tempter of the Bone
查看>>
JavaNIO基础02-缓存区基础
查看>>
日本开设无人机专业,打造无人机“人才市场”
查看>>
190行代码实现mvvm模式
查看>>
兼容几乎所有浏览器的透明背景效果
查看>>
jeesite 框架搭建与配置
查看>>
Adb移植(一)简单分析
查看>>
Linux VNC server的安装及简单配置使用
查看>>
阿里宣布开源Weex ,亿级应用匠心打造跨平台移动开发工具
查看>>
Android项目——实现时间线程源码
查看>>
招商银行信用卡重要通知:消费提醒服务调整,300元以下消费不再逐笔发送短信...
查看>>
python全栈_002_Python3基础语法
查看>>
C#_delegate - 调用列表
查看>>
[转]Windows的批处理脚本
查看>>
多维数组元素的地址
查看>>
数据库运维体系_SZMSD
查看>>
福大软工1816 · 第三次作业 - 结对项目1
查看>>