⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 nn_bp.m

📁 该代码用c++语言实现了KSVD算法,运行环境为vc6.0
💻 M
字号:
function coefMatrix = NN_BP(Data,D,maxCoef,coefMatrix)
MulFactor = 5;
numIterations = 15;
lambda = 1e-9;

numberOfIncreasedElems = ceil(maxCoef);
maxValues = max(coefMatrix) - min(coefMatrix)/2;
% we increase 'numberOfIncreasedElems' values only from the initial coefficient values.
for col = 1:size(coefMatrix,2)
    I = find(coefMatrix(:,col)==0);
    if (length(I) > numberOfIncreasedElems)
        permutation = randperm(size(coefMatrix,1)-maxCoef);
        coefMatrix(I(permutation(1:numberOfIncreasedElems)),col) = maxValues(col);
    else
        permutation = randperm(size(coefMatrix,1));
        coefMatrix(permutation(1:numberOfIncreasedElems),col) = maxValues(col);
    end
end
for iter = 1:numIterations
    coefMatrix = coefMatrix.*(D'*Data)./(D'*D*coefMatrix+lambda);
end

for s = 1:size(Data,2)
    [v,i] = sort(coefMatrix(:,s)); 
    FirstNonZeroIdx = size(coefMatrix,1)-maxCoef+1;
    coefMatrix(i(1:FirstNonZeroIdx-1),s) = 0;
    coefMatrix(i(FirstNonZeroIdx:end),s) = lsqnonneg(D(:,i(FirstNonZeroIdx:end)),Data(:,s),coefMatrix(i(FirstNonZeroIdx:end),s));
end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -