function zetasketch
hold off
q=2;
N=1000000;
%N=1000;
%N=10;
mu = 1./(1:N).^q; mu=mu/sum(mu);
global XY
XY = [];

for n=10:10:1000
    %if n<k
    %    lb = 2*(1-1/k)^(2*n);
    %else
    %    lb = k/4/n*(1-1/k);
    %end
    ub = CKKW(n,mu);
    plot(log(n),log(ub),'.b');
    xy = [n,ub];
    XY = [XY;xy];
    hold on
    %ak = AK(n,d,D,p);
    %plot(n,ct,'.g');
    drawnow
    save ZETA XY
end
return


function ub = CKKW(n,mu)
ii = find(mu<1/n); jj = find(mu>=1/n);
Lambda = 2*sum(mu(ii)) + 1/sqrt(n)*sum(sqrt(mu(jj)));
%aa=linspace(1,d+D,100);
aa=linspace(1,50,500);
% choose the best alpha for this n
ub = 0;
for i=1:length(aa)
    a = aa(i);
    Ha = sum(mu.*log(1./mu).^a);
    b = (a^a*(2+exp(-1))+2*Ha)^(1/a)*Lambda^(1-1/a);
    ub = max(b,ub);
end
return

function tmp
load ZETA
nn = XY(:,1);
ub = XY(:,2);
plot(log(nn),log(ub),'.b');
%loglog(nn,ub,'.b');

title('Our bound for infinite alphabets (log-log)')
xlabel('log sample size','fontsize',14,'interpreter','latex')
ylabel('log bound value','fontsize',14,'interpreter','latex')

return