📄 softdataassignmentweights.m
字号:
% SOFTDATAASSIGNMENTWEIGHTS soft-LOST soft data assignment%% dataWeights = softDataAssignmentWeights(M,N,B,signalSize,data,lineVectors)%% inputs;% M : Number of sources;% N : Number of mixtures;% B : Soft boundary value;% signalSize : Number of data points;% data : Mixture data;% lineVectors : Line orientation vectors%% outputs:% dataWeights : Partial Assignment of data points to line orientations%% % Code available at http://www-bcl.cs.may.ie/~pogrady/%% Function provided as part of Soft-LOST matlab functions%% Paul D. O'Grady - 14-11-2003% (paul.ogrady@may.ie) function dataWeights = softDataAssignmentWeights(M,N,B,signalSize,data,lineVectors)null_vector = zeros(N,1);zero_weights = zeros(1,M);% defining size in advance makes code run quickerZ(signalSize,M) = 0; for j = 1:signalSize dataPoint = data(:,j);%normalise(data(:,j)); if dataPoint ~= null_vector for count = 1:M %test the data with its oppsite signs R(count) = norm(dataPoint'-(lineVectors(count,:)*dataPoint)*lineVectors(count,:)); end R = -B*R; expR = exp(R); expRSum = sum(expR); Z(j,:) = expR/expRSum; else Z(j,:) = zero_weights; end;end;dataWeights = Z;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -