forked from paulskrzypczyk/steeringreview
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtargetStatePOVMLHS.m
54 lines (43 loc) · 2.03 KB
/
targetStatePOVMLHS.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
function is_POVM_LHS = targetStatePOVMLHS(rho,Max,gamma)
%TARGETSTATEPOVMLHS determine whether a qubit-qudit state has an LHS model
%for all POVM measurements
% This function has three required inputs:
% rho: a 2-D array containing a 2 x dB bipartite quantum state.
% Max: a 4-D array containing the POVM elements of a collection of qubit
% projective measurements. The first two dimensions contain the
% projectors, while the last two label (a,x).
% gamma: a dBxdB quantum state for Bob, which is used to pass from a PVM
% LHS model to a POVM LHS model.
%
% is_POVM_LHS = targetStatePOVMLHS(rho,Max,gamma) returns 1 if the set of
% measurements Max are able to demonstrate that the qubit-qudit state rho
% has an LHS model for all qubit POVM measurements. It returns 0 if this is
% not the case. Note that in the latter case one cannot draw any
% conclusions about whether or not rho has an LHS model.
%
% requires: CVX (http://cvxr.com/cvx/), QETLAB (http://www.qetlab.com),
% vert2lcon (http://www.mathworks.com/matlabcentral/fileexchange/30892)
% authors: Paul Skrzypczyk, Daniel Cavalcanti last updated: March 17,
% 2016
[dA,~,oa,ma] = size(Max);
% dA = dim. of Alice, oa = # outcomes for Alice, ma = # inputs for Alice
dB = length(rho)/dA;
% dB = dim. of Bob;
r = findRadiusPolytopeInBlochSphere(Max);
% r = radius of largest ball that fits inside the bloch sphere.
% it is the shrinking factor that we have to apply to the state.
cvx_begin sdp quiet
variable O(dA*dB,dA*dB) hermitian
% O is the quasi-state that we optimise over
subject to
rho == 1/2*(r*O + (1-r)*Tensor(eye(dA)/dA,PartialTrace(O,1,[dA dB]))) ...
+1/2*(Tensor(gamma,PartialTrace(O,1,[dA dB])))
% rho_AB = 1/2*(r*O_AB + (1-r) Id_A/dA otimes O_B) + 1/2*(gamma otimes
% O_B)
LHSAssemblage(genAssemblage(O,Max),1) == 1;
% O_AB should have an LHS model for the measurements Max
cvx_end
% CVX will return +inf if the problem is infeasible, and 0 if feasible
% this maps {+inf,0} to {0,1}
is_POVM_LHS = 1-min(cvx_optval,1);
end