view toolboxes/distance_learning/mlr/regularize/regularizeMKLDOD.m @ 0:cc4b1211e677 tip

initial commit to HG from Changeset: 646 (e263d8a21543) added further path and more save "camirversion.m"
author Daniel Wolff
date Fri, 19 Aug 2016 13:07:06 +0200
parents
children
line wrap: on
line source
function r = regularizeMKLDOD(W, X, gradient)
%
% r = regularizeMKLDOD(W, X, gradient)
%
%

    [d,n,m] = size(X);

    if gradient
        r = zeros(m,m,d);
        for i = 1:m
            r(i,i,:) = diag(X(:,:,i));
            for j = (i+1):m
                r(i,j,:) = diag(X(:,:,i)) + diag(X(:,:,j));
            end
        end
    else
        r = 0;
        for i = 1:m
            r = r + squeeze(W(i,i,:))' * diag(X(:,:,i));
            for j = (i+1):m
                r = r + squeeze(W(i,j,:))' * (diag(X(:,:,i)) + diag(X(:,:,j)));
            end
        end
    end
end