function [C,D] = getFisher_CD(data_x,data_y)
% data_x: m x d
% data_y: m x 1

% inx1 = find( y == 1);
% inx2 = find( y == 2);
% n1 = length(inx1);
% n2 = length(inx2);
% X = X';
% m1 = mean(X(:,inx1),2);
% m2 = mean(X(:,inx2),2);
% 
% S1 = (X(:,inx1))*(X(:,inx1))';
% S2 = (X(:,inx2))*(X(:,inx2))';
% 
% A = (m1-m2)*(m1-m2)';
% B = S1 + S2;
% 
% 
% 
% 
% A = full(A);
% B = full(B);
% C = A + B;

[num_data,dim] = size(data_x);
for i=1:dim
    data_x(:,i) = data_x(:,i) / (max(norm(data_x(:,i)),1e-8));
end

% [num_data,dim] = size(data_x);
data_x = data_x';

inx1 = find( data_y == 1);
inx2 = find( data_y == -1);
n1 = length(inx1);
n2 = length(inx2);


m1 = mean(data_x(:,inx1),2);
m2 = mean(data_x(:,inx2),2);

S1 = (data_x(:,inx1)-m1*ones(1,n1))*(data_x(:,inx1)-m1*ones(1,n1))';
S2 = (data_x(:,inx2)-m2*ones(1,n2))*(data_x(:,inx2)-m2*ones(1,n2))';
C = (S1 + S2) / num_data;
D = (m1 - m2)*(m1 - m2)';
C = (C+C')/2;
D = (D+D')/2;
C = C ./ norm(C,'fro');
D = D ./ norm(D,'fro');



