-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplot_data_eta.m
121 lines (98 loc) · 3.84 KB
/
plot_data_eta.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
% Plot the data
% dataCliff array is indexed as follows: dataCliff(samples,idx,numQ,etaPower)
% This stores the Frobenius norm of the error of the reconstructed Choi
% matrix
% samples = # of measurement settings (also called m)
% idx = points to a specific run of the numerical simulation
% numQ = number of qubits
% etaPower = -log_{10}(noise strength)
clear
% load('run1x')
load('./Cliff_eta01/dataBerlin.mat');
% load('./Haar_eta01/dataBerlin.mat');
% reps = jobs(j,2)-1;
dataCliff = squeeze( data.frob_norm(:,1:reps,:,:) );
optval = squeeze( data.cvx_optval(:,1:reps,:,:) );
cvxReps = squeeze( data.cvxReps(:,1:reps,:,:) );
%check precision decreas and failures
n_fails = squeeze(sum(isnan(optval),2));
display([ num2str(sum(n_fails(:))), ' fails out of ', num2str(length(optval(:))) ]);
n_runs = length( cvxReps(:));
n_reps = sum(cvxReps(:));
display([num2str( n_reps ) ' runs to solve ' num2str( n_runs ) ' SDPs, i.e., '...
'machine precision ' num2str(n_reps-n_runs) ' times increased']);
% Truncate error values that are > 2
% dims: m, reps, numQ, eta
dataCliffTrunc = min(dataCliff, 2);
numQ=3;
% For j = 1:length(samples), the j'th data point will correspond to the
% simulation where the number of samples was samples(j)
% Exclude those simulation runs that have fewer than 201 samples
samples = m_list;
% Calculate the averages and standard deviations of the errors
% Call these Delta and Sigma
% Along the way, we calculate the 2nd moments of the errors -- call this Tmp2
% They are indexed like this: Delta(j, numQ, etaPower)
num_trials = size( dataCliffTrunc, 2);
% AVERAGE
Delta = squeeze( mean( dataCliffTrunc, 2, 'omitnan') );
% STANDARD DEVIATION
Sigma = squeeze( std(dataCliffTrunc, 0, 2, 'omitnan') );
n_fails = squeeze(sum(isnan(optval),2));
display([ num2str(sum(n_fails(:))), ' fails out of ', num2str(length(optval(:))) ]);
% Calculate upper and lower bounds on Delta, for the error bars
Upper = Delta + Sigma;
Lower = max(Delta - Sigma, 10^-15);
% % THIRD SET OF PLOTS:
% %
% % Fix the number of qubits
% % For each choice of the number of measurement settings m, draw one line:
% % How does the reconstruction error \Delta depend on the noise strength \eta?
n_eta = size(Delta,2);
n_m = size(Delta,1);
numQ = 3;
fig1 = figure(1);
% Draw one line for each j = 1:length(samples)
% errorbar() draws one line for each column of the data matrix,
EBX = kron(ones([1,n_m]), log10(eta_list)'); % X coordinates
EBY = log10(Delta'); % Y coordinates
EBL = EBY - log10(Lower'); % Deviation below EBY: length of error bar
EBU = log10(Upper') - EBY; % Deviation above EBY
errorbar(EBX, EBY, EBL, EBU)
xlim([-4.2 0]);
ylim([-4.2,.2]);
FigTitle = ['\Delta(\eta) averaged over ', num2str(reps), ' realizations: '...
, num2str(numQ), ', qubits'];
title(FigTitle);
xlabel(texlabel('log_10(eta)'))
ylabel(texlabel('log_10(Delta)'))
legend([texlabel('m = '), num2str(m_list(1))], ...
[texlabel('m = '), num2str(m_list(2))], ...
[texlabel('m = '), num2str(m_list(3))], ...
[texlabel('m = '), num2str(m_list(4))], ...
[texlabel('m = '), num2str(m_list(5))], ...
'Location', 'Best')
name1 = 'Delta(eta)_3qubits_SDPT3';
saveas(fig1, [name1, '.png']);
savefig(fig1, name1);
fig2 = figure(2);
ebx = kron(ones([1,n_m]), eta_list');
eby = Delta';
eb = Sigma';
errorbar(ebx,eby,eb)
xlim([-.05 1.05]);
ylim([-.05,1.1]);
title(FigTitle)
xlabel(texlabel('eta'))
ylabel(texlabel('Delta'))
legend([texlabel('m = '), num2str(m_list(1))], ...
[texlabel('m = '), num2str(m_list(2))], ...
[texlabel('m = '), num2str(m_list(3))], ...
[texlabel('m = '), num2str(m_list(4))], ...
[texlabel('m = '), num2str(m_list(5))], ...
'Location', 'Best')
name2 = 'Delta(eta)_3qubits_SDPT3_non-log';
saveas(fig2, [name2, '.png']);
savefig(fig2, name2);
figure(3);
errorbar(EBX(5:end-1,4), EBY(5:end-1,4), EBL(5:end-1,4), EBU(5:end-1,4))