亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? qrj1d.m

?? 矩陣實驗室的內容
?? M
字號:
function [Y,B,varargout]=QRJ1D(X,varargin)
%QR based Jacbi-like JD; This function minimizes the cost
%J_{1}(B)=\sum{i=1}^{N} \|BC_{i}B^{T}-diag(BC_{i}B^{T})\|_{F}^{2}
%where \{C_{i}\}_{i=1}^{N} is a set of N, n\times n symmetric matrices
%and B the joint diagonalizer sought. A related measure that is used
%to measure the error is J_{2}=\sum{i=1}^{N} \|C_{i}-B^{-1}diag(BC_{i}B^{T})B^{-T}\|_{F}^{2}
%
%
%Standard usage: [Y,B]=QRJ1D(X),
%Here X is a large matrix of size n\times nN which contains the
%matrices to be jointly diagonalized such that X=[C1,C2,...,CN],
%Y contains the jointly diagonalized version of the input
%matrices, and B is the found diagonalizer.
%
%
%More controlled usage:[X,B,S,BB]=QRJ1D(X,'mode',ERR or ITER,RBALANCE):
%
%'mode'='B' or 'E' or 'N':  In the 'B' mode the stopping criteria at each
%                           step is max(max(abs(LU-I))) which measures
%                           how much the diagonalizer B has changed
%                           after a sweep. In the 'E' mode
%                           the stopping criterion is the difference between
%                           the values of the cost function J2 in two consequtive
%                           updates.In the 'N' mode the stopping criterion is
%                           the number of sweeps over L and U phases.
%
%ERR: In the 'B' mode it specifies the stopping value for the change in B max(max(abs(LU-I))).
%The default value for ERR in this mode and other modes including standard usage
%is ERR=10^-5. In implementation of the algorithm in order to account
%for dpendence of accuracy on the dimension n ERR is multiplied
%by n the size of matrices for JD. In the 'E' mode it ERR specifies the stopping value
%for the relative change of J_{2} in two consequetive sweeps.
%In the 'B' or 'E' mode or the standard mode
%if the change in B or relative change in J2 does not reach ERR after the default number of
%iterations (=200) then the program aborts and itreturns the current computed variables.
%
%ITER: Number of iterations in the 'N' mode
%
%%RBALANCE: if given it is the period for row balancing after each sweep.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%Outputs:
%Y= the diagonalized set of matrices
%B=the found joint diagonalizer
%S=a structure containing some information about the run program:
%          S.iterations: number of iterations
%          S.LUerror: the LU error after each sweep
%          S.J2error: the J2 error after each sweep
%          S.J2RelativeError:the relative J2 error after each sweep
%BB=a three dimensional array containing the joint diagonalizer after each sweep
%Note: S and BB are not required outputs in the function call
%
%This algorithm is based on a paper presented in ICA2006 conference and published in Springer LNCS
%Bijan Afsari, ''Simple LU and QR based Non-Orthogonal Matrix Joint Diagonalization''
%%Coded by Bijan Afsari. Please forward any questions and problem to bijan@glue.umd.edu
%v.1.1

%Acknowledgements: Some data structures and implementation ideas in this code are inspired from the code for JADE
%written by J.F. Cardoso and from the code FFDIAG written by Andreas Ziehe and Pavel Laskov
%Disclaimer: This code is to be used only for non-commercial research purposes and the author does not
%accept any reponsibility about its performance or fauilure
[n,m]=size(X);N=m/n;

BB=[];
%defaulat values
ERR=1*10^-5;RBALANCE=3;ITER=200;
%%%
MODE='B';
if nargin==0, display('you must enter the data'); B=eye(n); return; end;
if nargin==1, Err=ERR;Rbalance=RBALANCE;end;
if nargin> 1, MODE=upper(varargin{1});
    switch MODE
        case {'B'}
            ERR=varargin{2}; mflag='D'; if ERR >= 1, disp('Error value should be much smaller than unity');B=[];S=[]; return; end;
        case ('E')
            ERR=varargin{2};mflag='E'; if ERR >=1, disp('Error value should be much smaller than unity'); B=[];S=[];return;end;
        case ('N');mflag='N'; ITER=varargin{2}; ERR=0; if ITER <= 1, disp('Number of itternations should be higher than one');B=[];S=[];return;end;
    end
end;
if nargin==4, RBALANCE=varargin{3}; if ceil(RBALANCE)~=RBALANCE | RBALANCE<1, disp('RBALANCE should be a positive integer');B=[];S=[];return;end;end;
JJ=[];EERR=[]; EERRJ2=[];
X1=X;
B=eye(n,n);Binv=eye(n);
J=0;

for t=1:N
    J=J+norm(X1(:,(t-1)*n+1:t*n)-diag(diag(X(:,(t-1)*n+1:t*n))),'fro')^2;
end
JJ=[JJ,J];

%err=10^-3;
%the following part implements a sweep
%%%%%%%%%%%%%%%%%%%%%%%%%%
err=ERR*n+1;
if MODE=='B', ERR=ERR*n;end,
k=0;
while err>ERR & k<ITER
    k=k+1;

    L=eye(n);%Linv=eye(n);
    U=eye(n);%Uinv=eye(n);
    Dinv=eye(n);


    for i=2:n,
        for j=1:i-1,
            G=[-X(i,[i:n:m])+X(j,[j:n:m]);-2*X(i,[j:n:m])];
            [U1,D1,V1]=svd(G*G');
            v=U1(:,1);
            tetha=1/2*atan(v(2)/v(1));
            c=cos(tetha);
            s=sin(tetha);
            h1=c*X(:,[j:n:m])-s*X(:,[i:n:m]);
            h2=c*X(:,[i:n:m])+s*X(:,[j:n:m]);
            X(:,[j:n:m])=h1;
            X(:,[i:n:m])=h2;
            h1=c*X(j,:)-s*X(i,:);
            h2=s*X(j,:)+c*X(i,:);
            X(j,:)=h1;
            X(i,:)=h2;
            %h1=c*U(:,j)+s*U(:,i);
            %h2=-s*U(:,j)+c*U(:,i);
            h1=c*U(j,:)-s*U(i,:);
            h2=s*U(j,:)+c*U(i,:);
            U(j,:)=h1;
            U(i,:)=h2;

        end;%end for i
    end;%end for j
    for i=1:n
        %for j=i+1:n

        rindex=[];
        Xj=[];
        for j=i+1:n
            cindex=1:m;
            cindex(j:n:m)=[];
            a=-(X(i,cindex)*X(j,cindex)')/(X(i,cindex)*X(i,cindex)');
            %coorelation quefficient
            %a=-(X(i,cindex)*X(j,cindex)')/(norm(X(i,cindex))*norm(X(j,cindex)));
            %a=tanh(a);
            if abs(a)>1, a=sign(a)*1; end;
            X(j,:)=a*X(i,:)+X(j,:);
            I=i:n:m;
            J=j:n:m;
            X(:,J)=a*X(:,I)+X(:,J);
            L(j,:)=L(j,:)+a*L(i,:);
            %Linv(j,:)=Linv(j,:)-a*Linv(i,:);
        end%end loop over j
    end


    B=L*U*B;%Binv=Binv*Uinv*Linv;
    %err=norm(L*U-eye(n,n),'fro');
    err=max(max(abs(L*U-eye(n))));EERR=[EERR,err];
    if rem(k,RBALANCE)==0
        d=sum(abs(X'));
        D=diag(1./d*N); Dinv=diag(d*N);
        J=0;
        for t=1:N
            X(:,(t-1)*n+1:t*n)=D*X(:,(t-1)*n+1:t*n)*D;
        end;
        B=D*B; %Binv=Binv*Dinv;
    end
    J=0;
    BB(:,:,k)=B;
    Binv=inv(B);
    for t=1:N
        J=J+norm(X1(:,(t-1)*n+1:t*n)-Binv*diag(diag(X(:,(t-1)*n+1:t*n)))*Binv','fro')^2;
    end
    JJ=[JJ,J];
    if MODE=='E', err=abs(JJ(end-1)-JJ(end))/JJ(end-1);EERRJ2=[EERRJ2,err];end
end
Y=X;
S=struct('iterations',k,'LUerror',EERR,'J2error',JJ,'J2RelativeError',EERRJ2);varargout{1}=S;varargout{2}=BB;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久精品国产| 美女高潮久久久| 色天天综合色天天久久| 国产精品久久久久久久久免费丝袜| 国产精品一级黄| 中文字幕中文在线不卡住| 91年精品国产| 丝袜美腿亚洲一区二区图片| 欧美一级片在线看| 国产高清成人在线| 亚洲三级视频在线观看| 欧美日韩精品是欧美日韩精品| 日韩av在线播放中文字幕| www成人在线观看| 本田岬高潮一区二区三区| 一区二区三区不卡在线观看| 8v天堂国产在线一区二区| 国产一区二区成人久久免费影院| 日本一二三不卡| 欧美三级欧美一级| 极品少妇xxxx精品少妇| 亚洲国产精品99久久久久久久久| 色婷婷av一区二区| 国产一区二区福利视频| 亚洲综合色在线| 精品国产乱码久久久久久1区2区 | 精品一区二区久久| 中文字幕免费观看一区| 欧美日韩精品一区视频| 国产福利一区二区三区在线视频| 一区二区免费在线播放| 欧美精品一区二区久久婷婷| 97精品久久久午夜一区二区三区 | 精品视频免费在线| 国产在线不卡一卡二卡三卡四卡| 亚洲精品中文字幕在线观看| 欧美videossexotv100| 94-欧美-setu| 狠狠色伊人亚洲综合成人| 亚洲最新视频在线观看| 国产网站一区二区| 91精品国产综合久久福利软件| 成人免费视频一区二区| 美国十次综合导航| 亚洲永久免费av| 国产精品理论在线观看| 欧美不卡一区二区三区四区| 欧美日韩在线综合| 99久久婷婷国产| 国产成人在线免费观看| 奇米精品一区二区三区在线观看 | 91精品国产日韩91久久久久久| 成人av午夜电影| 精品一区二区在线免费观看| 五月天激情综合网| 午夜精品久久久| 亚洲一区二区三区自拍| 国产精品网站在线| 久久久久久亚洲综合| 日韩欧美成人激情| 在线综合视频播放| 欧美美女黄视频| 欧美日韩国产色站一区二区三区| 色综合久久综合中文综合网| av在线一区二区三区| 国产一区 二区 三区一级| 激情另类小说区图片区视频区| 日日骚欧美日韩| 天天色综合天天| 五月天亚洲婷婷| 婷婷成人激情在线网| 亚洲电影在线免费观看| 亚洲午夜影视影院在线观看| 亚洲伦理在线免费看| 成人欧美一区二区三区黑人麻豆| 日本一区二区成人| 日韩毛片视频在线看| 首页综合国产亚洲丝袜| 亚洲精品视频一区二区| 亚洲黄色录像片| 亚洲国产精品视频| 天天操天天干天天综合网| 日韩精品午夜视频| 美女精品一区二区| 国产一区二区免费在线| 成人听书哪个软件好| 99久久国产综合精品麻豆| 色噜噜夜夜夜综合网| 欧美伊人久久久久久久久影院 | 国产精品一区二区三区四区| 韩国av一区二区三区四区| 国产成人日日夜夜| 成人污污视频在线观看| 色综合天天综合在线视频| 91色婷婷久久久久合中文| 91福利在线免费观看| 6080yy午夜一二三区久久| 欧美sm美女调教| 国产精品另类一区| 亚洲午夜日本在线观看| 欧美96一区二区免费视频| 国产中文字幕精品| 一本色道久久综合狠狠躁的推荐| 91久久精品一区二区二区| 91精选在线观看| 亚洲国产精品成人综合色在线婷婷| 亚洲视频你懂的| 日韩精品成人一区二区三区 | 国产99久久久国产精品| 在线观看日韩国产| 精品美女在线播放| 综合av第一页| 日本va欧美va精品| 99re这里只有精品首页| 欧美日韩亚洲丝袜制服| 久久久久久久久久久久电影| 一区二区三区精品在线观看| 人人狠狠综合久久亚洲| a级高清视频欧美日韩| 欧美一区二区三区四区在线观看| 久久精品无码一区二区三区| 亚洲图片有声小说| 国产成人99久久亚洲综合精品| 欧美另类z0zxhd电影| 国产精品成人在线观看| 麻豆专区一区二区三区四区五区| 成人91在线观看| 精品免费一区二区三区| 亚洲小少妇裸体bbw| 不卡的av中国片| 久久久久久夜精品精品免费| 亚洲大片免费看| 色哟哟一区二区在线观看 | 国产人妖乱国产精品人妖| 亚洲一卡二卡三卡四卡五卡| 成人免费视频一区二区| 久久亚洲一级片| 奇米影视在线99精品| 一本色道久久综合狠狠躁的推荐 | 国产精品不卡在线观看| 极品少妇xxxx精品少妇偷拍| 欧美色综合久久| 亚洲天堂福利av| 成人免费观看视频| 久久久久久免费网| 久久激情综合网| 日韩欧美一级在线播放| 亚洲成人综合网站| 欧美日韩小视频| 亚洲一二三四在线观看| 91香蕉视频在线| 国产精品久久久久一区二区三区| 精品一区二区三区久久| 日韩欧美成人午夜| 久久精品国产成人一区二区三区 | 黑人巨大精品欧美一区| 欧美日韩一区二区不卡| 久久久久亚洲综合| 麻豆精品久久精品色综合| 91小宝寻花一区二区三区| 丰满岳乱妇一区二区三区| 国产精品一区二区不卡| 成人性色生活片免费看爆迷你毛片| 欧美一区二区日韩| 性做久久久久久久免费看| 日本乱码高清不卡字幕| 亚洲三级小视频| 91蝌蚪porny| 亚洲欧美日韩一区二区| 91久久免费观看| 亚洲午夜久久久久久久久电影院 | 99久免费精品视频在线观看| 国产精品免费丝袜| 成人免费看的视频| 亚洲少妇30p| 欧美午夜理伦三级在线观看| 亚洲第一久久影院| 91麻豆精品国产| 国产一区 二区| 中文字幕一区二区不卡| 91福利国产精品| 日韩avvvv在线播放| 日韩亚洲电影在线| 国产一区二区三区免费在线观看 | 亚洲日本免费电影| 91国产福利在线| 日韩电影在线免费看| 日韩欧美国产一区二区在线播放| 国产一区视频导航| 中文字幕欧美一| 欧美日韩成人综合天天影院| 欧美a一区二区| 国产欧美日本一区视频| 91在线观看视频| 日韩激情中文字幕| 欧美精彩视频一区二区三区| 色噜噜狠狠成人中文综合| 毛片av一区二区三区| 国产精品拍天天在线| 精品视频1区2区|