forked from paulskrzypczyk/steeringreview
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsteeringWeightState.m
58 lines (52 loc) · 2.35 KB
/
steeringWeightState.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
function [SWrho,optMax] = steeringWeightState(rho,Max,varargin)
%STEERINGWEIGHTSTATE estimate the steering weight of a quantum state
% This function has two required arguments:
% rho: a 2-D array containing a dA*dB x dA*dB bipartite quantum state rho.
% Max: a 4-D array containing an initial set of POVMs to start the
% algorithm with. The first two dimensions contain the dA x dA POVM
% elements. The last two dimensions label (a,x).
%
% This function has one optional argument:
% improv_tol: (default: 1E-6) a scalar which sets the threshold
% improvement in one round of the see-saw iteration before the algorithm
% terminates.
%
% SWrho = steeringWeightState(rho,Max) returns a lower bound on the
% Steering weight of the state rho, when measured with ma measurements of
% oa outcomes each, taking as an initial seed for the measurements Max. It
% employs a see-saw algorithm to try and find the optimal set of
% measurements for the state rho.
%
% [SWrho,optMax] = steeringWeightState(rho,Max) also returns the final set
% of measurements in optMax, that achieve the Steering weight SWrho. optMax
% is a 4-D array. The first two dimenions contain the dA x dA POVM
% elements. The last two dimensions contain (a,x).
%
% [SWrho,optMax] = steeringWeightState(rho,Max,improv_tol) uses the
% tolerance improv_tol in its stopping criteria for the algorithm: only
% if the improvement in one round of the see-saw algorithm drops below
% improv_tol will the algorithm terminate.
%
% requires: CVX (http://cvxr.com/cvx/), QETLAB (http://www.qetlab.com)
% authors: Paul Skrzypczyk, Daniel Cavalcanti
% last updated: March 17, 2016
[improv_tol] = opt_args({1E-6},varargin{:});
% improv_tol: tolerance in see-saw. default is 1e-6.
[SWi, F] = steeringWeight(genAssemblage(rho,Max));
% find the initial steering Weight SWi, and the initial steering inequality
% F which certifies SWi
improv = 1;
% initalise improv > improv_tol.
while improv >= improv_tol % as long as the improvement is big enough
[~, Max] = bestSteeringMeasurements(rho,F);
% find the best set of POVMs given the state rho, and functional F
[SWf, F] = steeringWeight(genAssemblage(rho,Max));
% find the new steering weight and function F given rho and Max
improv = SWf - SWi;
% calculate the improvement in the SW
SWi = SWf;
% set initial = final, and iterate.
end
SWrho = SWf;
optMax = Max;
end