clear;
clc;
lib_path = fullfile(pwd, '.',  filesep, "lib", filesep);
addpath(lib_path);
code_path = fullfile(pwd, '.',  filesep, "FMKKM", filesep);
addpath(code_path);


data_name = 'jaffe_expression_213n_676d_10c_7g_uni_12k_';


clear Ks y g;
load(data_name);
nCluster = length(unique(y));
nSmp = length(y);
K = Ks(:,:,7); 


% **************************************************************************
% Parameter Configuration
% **************************************************************************
nMeasure = 4;
lambda_pre = 0;
mnce_pre = 0;
increase_rate = 1;



%**************************************************************************
% Initialization Y0
%**************************************************************************
opt.disp = 0;
[H, ~] = eigs(K, nCluster,'LA',opt);
H_normalized = H ./ repmat(sqrt(sum(H.^2, 2)), 1,nCluster);
label0 = kmeans(H_normalized, nCluster, 'MaxIter', 50, 'Replicates', 10);
Y0 = full(ind2vec(label0'))';


%**************************************************************************
% FKKM
%**************************************************************************
G = full(ind2vec(g'))';
F = G*G';
sigmm_max = max(sum(G,1));

tic
while increase_rate > 0.005
    lambda_cur = lambda_pre + 1;
    beta = sigmm_max .* lambda_cur;
    K_fair = zeros(nSmp,nSmp);    
    K_fair = K+ beta.*eye(nSmp) -lambda_cur.*F;
    [pre_y,~] = FKKM(K_fair, Y0);
    result = my_fair_eval_y(pre_y,y,g);
    mnce_cur = result(4);
    increase_rate = mnce_cur - mnce_pre;
    mnce_pre = mnce_cur;
    lambda_pre = lambda_cur;
end

result


