- 
                Notifications
    You must be signed in to change notification settings 
- Fork 19
Description
This is one of 3 independent bounties which share the type of work that needs to be done:
- Conversion from symbolic object to numeric objects from the QuantumToolbox.jl library (by implementing a backend for the expressAPI) #116 on interfacing with QuantumToolbox.jl
- Conversion of symbolic objects to "lazy" QuantumOptics.jl numerical objects #117 on improving the interface that already exists for QuantumOptics.jl
- Conversion of symbolic objects to base linear algebra objects (vectors, matrices, sparse matrices, etc) #118 on using the already existing QuantumOptics.jl interface to provide an interface for unstructured "naked" state vectors and operators
One of the main value-adds of QuantumSymbolics.jl is to enable converting symbolic expressions into the appropriate numerical representation for use with a variety of simulators. We have such capabilities with respect to a few simulators now, e.g. converting the symbolic Z1 into either a Ket (from QuantumOptics.jl) or a Stabilizer tableau (from QuantumClifford.jl). Here is an example:
julia> using QuantumSavory, QuantumOpticsBase, QuantumClifford
julia> express(X1, QuantumOpticsRepr())
Ket(dim=2)
  basis: Spin(1/2)
 0.7071067811865475 + 0.0im
 0.7071067811865475 + 0.0im
julia> express(X1, CliffordRepr())
𝒟ℯ𝓈𝓉𝒶𝒷
+ Z
𝒮𝓉𝒶𝒷
+ X
This bounty is on improving the conversion to QuantumOptics.jl objects to support "lazy" numerical computation
QuantumOptics.jl is a library providing the standard exponentially-expensive "state vector" modeling tools for quantum mechanics. In has kets, bras, operators, etc. Importantly, it also provides "lazy" operators for delayed computation. These semi-symbolic semi-numeric objects are particularly convenient for avoiding redundant computation or the creation of particularly large objects. Currently, conversion to these operators is not supported by QuantumSymbolics.jl.
This bounty requires the addition of a new configuration option to QuantumOpticsRepr, namely QuantumOpticsRepr(lazy=true). When that option is selected, the conversion (as done by the express API) should preferentially create LazyTensor, LazySum, and LazyProduct objects.
The most useful references would be:
- the "lazy" objects of QuantumOptics.jl
- what is the expressAPI that is used for conversion from symbolics to numerics
- how expressis implemented forQuantumOptics
- the overall documentation of QuantumSymbolics
For this bounty to be completed, one would need:
- enabling expresswithQuantumOpticsRepr(lazy=true)to return "lazy" numerical objects
- adding tests for correctness, potentially comparing lazy and non-lazy representations
- a brief mention of the new capability in the documentation, e.g. in the docstring of QuantumOpticsRepr
If you are new to julia, make sure to:
- install julia using juliaupfor version management
- look through the julia manual and modern workflows
- try out VSCode with the Julia plugin for good IDE support