Skip to content

Commit

Permalink
Add ChoiState superoperator representation
Browse files Browse the repository at this point in the history
  • Loading branch information
akirakyle committed Jul 24, 2024
1 parent b7edca6 commit 45e5850
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 2 deletions.
5 changes: 3 additions & 2 deletions src/QuantumOpticsBase.jl
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,9 @@ export Basis, GenericBasis, CompositeBasis, basis,
current_time, time_shift, time_stretch, time_restrict, static_operator,
#superoperators
SuperOperator, DenseSuperOperator, DenseSuperOpType,
SparseSuperOperator, SparseSuperOpType, spre, spost, sprepost, liouvillian,
identitysuperoperator,
SparseSuperOperator, SparseSuperOpType,
ChoiState,
spre, spost, sprepost, liouvillian, identitysuperoperator,
#fock
FockBasis, number, destroy, create,
fockstate, coherentstate, coherentstate!,
Expand Down
48 changes: 48 additions & 0 deletions src/superoperators.jl
Original file line number Diff line number Diff line change
Expand Up @@ -316,3 +316,51 @@ end
}
throw(IncompatibleBases())
end

"""
Base class for the Choi representation of superoperators.
"""

mutable struct ChoiState{B1,B2,T} <: AbstractSuperOperator{B1,B2}
basis_l::B1
basis_r::B2
data::T
function ChoiState{BL,BR,T}(basis_l::BL, basis_r::BR, data::T) where {BL,BR,T}
if (length(basis_l) != 2 || length(basis_r) != 2 ||

Check warning on line 329 in src/superoperators.jl

View check run for this annotation

Codecov / codecov/patch

src/superoperators.jl#L328-L329

Added lines #L328 - L329 were not covered by tests
length(basis_l[1])*length(basis_l[2]) != size(data, 1) ||
length(basis_r[1])*length(basis_r[2]) != size(data, 2))
throw(DimensionMismatch("Tried to assign data of size $(size(data)) to Hilbert spaces of sizes $(length.(basis_l)), $(length.(basis_r))"))

Check warning on line 332 in src/superoperators.jl

View check run for this annotation

Codecov / codecov/patch

src/superoperators.jl#L332

Added line #L332 was not covered by tests
end
new(basis_l, basis_r, data)

Check warning on line 334 in src/superoperators.jl

View check run for this annotation

Codecov / codecov/patch

src/superoperators.jl#L334

Added line #L334 was not covered by tests
end
end
ChoiState{BL,BR}(b1::BL,b2::BR,data::T) where {BL,BR,T} = ChoiState{BL,BR,T}(b1,b2,data)
ChoiState(b1::BL,b2::BR,data::T) where {BL,BR,T} = ChoiState{BL,BR,T}(b1,b2,data)
ChoiState(b,data) = SuperOperator(b,b,data)

Check warning on line 339 in src/superoperators.jl

View check run for this annotation

Codecov / codecov/patch

src/superoperators.jl#L337-L339

Added lines #L337 - L339 were not covered by tests

# reshape swaps within systems due to colum major ordering
# https://docs.qojulia.org/quantumobjects/operators/#tensor_order
function _super_choi((l1, l2), (r1, r2), data::Matrix)
data = reshape(data, map(length, (l2, l1, r2, r1)))
(l1, l2), (r1, r2) = (r2, l2), (r1, l1)
data = permutedims(data, (1, 3, 2, 4))
data = reshape(data, map(length, (l1l2, r1r2)))
return (l1, l2), (r1, r2), data

Check warning on line 348 in src/superoperators.jl

View check run for this annotation

Codecov / codecov/patch

src/superoperators.jl#L343-L348

Added lines #L343 - L348 were not covered by tests
end

function _super_choi((r2, l2), (r1, l1), data::SparseMatrixCSC)
data = _permutedims(data, map(length, (l2, r2, l1, r1)), (1, 3, 2, 4))
data = reshape(data, map(length, (l1l2, r1r2)))

Check warning on line 353 in src/superoperators.jl

View check run for this annotation

Codecov / codecov/patch

src/superoperators.jl#L351-L353

Added lines #L351 - L353 were not covered by tests
# sparse(data) is necessary since reshape of a sparse array returns a
# ReshapedSparseArray which is not a subtype of AbstractArray and so
# _permutedims fails to acces the ".m" field
# https://github.com/qojulia/QuantumOpticsBase.jl/pull/83
# https://github.com/JuliaSparse/SparseArrays.jl/issues/24
# permutedims in SparseArrays.jl only implements perm (2,1) and so
# _permutedims should be upstreamed
# https://github.com/JuliaLang/julia/issues/26534
return (l1, l2), (r1, r2), sparse(data)

Check warning on line 362 in src/superoperators.jl

View check run for this annotation

Codecov / codecov/patch

src/superoperators.jl#L362

Added line #L362 was not covered by tests
end

ChoiState(op::SuperOperator) = ChoiState(_super_choi(op.basis_l, op.basis_r, op.data)...)
SuperOperator(op::ChoiState) = SuperOperator(_super_choi(op.basis_l, op.basis_r, op.data)...)

Check warning on line 366 in src/superoperators.jl

View check run for this annotation

Codecov / codecov/patch

src/superoperators.jl#L365-L366

Added lines #L365 - L366 were not covered by tests

0 comments on commit 45e5850

Please sign in to comment.