標題: Matlab盲源分離的一個小程序 [打印本頁]

作者: 壁虎歸來    時間: 2018-3-13 16:06
標題: Matlab盲源分離的一個小程序
matlab盲源分離的一個小程序。。。

源程序如下:
  1. %以下程序調用ICA,輸入觀察信號,輸出為解混合信號
  2. function Z=ICA(X)
  3. %-------------去均值------------
  4. [M,T] = size(X); %獲取輸入矩陣的行/列數,行數為觀測數據的個數,列數為采樣點點數
  5. average= mean(X')';  %按行取均值
  6. for i=1:M
  7.     X(i,:)=X(i,:)-average(i)*ones(1,T);
  8. end
  9. %------------白化--------------
  10. Cx = cov(X',1);    %計算協方差矩陣Cx
  11. [eigvector,eigvalue] = eig(Cx); %計算Cx的特征值和特征向量
  12. W=eigvalue^(-1/2)*eigvector';   %白化矩陣
  13. Z=W*X;   %正交矩陣

  14. %-------------迭代-------------
  15. Maxcount=10000;        %最大迭代次數
  16. Critical=0.00001;   %判斷是否收斂
  17. m=M;                %需要估計的分量的個數
  18. W=rand(m);
  19. for n=1:m  
  20.     WP=W(:,n);  %初始權矢量(任意)
  21. %     Y=WP'*Z;
  22. %     G=Y.^3;%G為非線性函數,可取y^3等
  23. %     GG=3*Y.^2;  %G的導數
  24.     count=0;
  25.     LastWP=zeros(m,1);
  26.     W(:,n)=W(:,n)/norm(W(:,n));%單位化一列向量
  27.     while abs(WP-LastWP)&abs(WP+LastWP)>Critical %兩個絕對值同時大于收斂條件
  28.         count=count+1;   %迭代次數
  29.         LastWP=WP;       %上次迭代的值
  30.        % WP=1/T*Z*((LastWP'*Z).^3)'-3*LastWP;
  31.         for i=1:m     
  32. WP(i)=mean(Z(i,:).*(tanh((LastWP)'*Z)))-(mean(1-(tanh((LastWP))'*Z).^2)).*LastWP(i);%更新
  33.         end
  34.         WPP=zeros(m,1);%施密特正交化
  35.         for j=1:n-1
  36.             WPP=WPP+(WP'*W(:,j))*W(:,j);
  37.         end
  38.         WP=WP-WPP;
  39.         WP=WP/(norm(WP));

  40.         if count==Maxcount
  41.             fprintf('未找到相應的信號');
  42.             return;
  43.         end
  44.     end
  45.     W(:,n)=WP;
  46. end
  47. Z=W'*Z;
復制代碼

所有資料51hei提供下載:
mangyuanfenli.rar (972 Bytes, 下載次數: 16)







歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1