function [muhat,norms] = frechet_mean_Sphere(Y,epsilon,stepSize)
%- Created by Carlos J. Soto cjs7363@psu.edu

% This function does a gradient descent method to compute the
% mean of points on a sphere. 

%- Input:
%- Y                    		- matrix of points on a sphere(S^dim) size nxdim 
%- epsilon              		- precision
%- stepSize 					- step size for each gradient step

%- Output:
%- muhat 						- the frechet mean 
%- norms 						- the norm of the average moving direction at each step 
% (norms should go to zero as iterations increase)

%- tuning parameters
if nargin == 1
    stepSize = 0.5;                 %- can solve for this using a backtracking procedure
    epsilon = 0.00001;
end
Niter = 500;                        %- minimum number of iterations


muhat = Y(1,:);                         %- initialize the mean
n = size(Y,1);                          %- sample size
dimN = size(Y,2);                    %- dimension of P(dimN)
normd = 100000;
v = zeros(1,dimN,n);
iter = 1;
while (normd > epsilon && iter < Niter)
    
    for i = 1:n
        v(:,:,i) = inv_exp_map_Sphere(muhat,Y(i,:));
    end
    Delta = 1/(n) * sum(v,3);
    Delta = squeeze(Delta);
%     normd = norm_T_SPDM(muhat,Delta);
    normd = norm(Delta);
    norms(iter) = normd;
    if normd > epsilon        
        muhat = exp_map_Sphere(muhat, stepSize*Delta);
    end
    iter = iter + 1;
    
end



end

