-
Notifications
You must be signed in to change notification settings - Fork 6
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Collecting interface definition #1
Comments
In terms of naming, may we remove the "Optics" part of the name? Many of these functions would be useful for If you give me push privilidges I can push a version that already works with experimental branches of QSymbolics, QuantumClifford, and QuantumOpticsBase. No need for any changes to QuantumOptics. |
For the moment I have not needed any changes to |
Type-piracy issues can be detected with static analysis like |
Here is the draft package I have been toying with. Basically exactly what you described. Happy to transfer it to qojulia if it seems like a reasonable basis. https://github.com/Krastanov/QuantumCore.jl Here is the branch of QuantumOpticsBase that works with it: qojulia/QuantumOpticsBase.jl#73 Here is the branch of QuantumClifford that works with it: https://github.com/Krastanov/QuantumClifford.jl/compare/quantumcore Here is the newly factored out QSymbolics that shows how this enables some interesting conversions between different formalisms: https://github.com/Krastanov/QSymbolics.jl Documentation of what is possible with QSymbolics: https://krastanov.github.io/QuantumSavory.jl/dev/symbolics/ A lot of this type of mixing of formalisms is done in the kernel of QuantumSavory: https://krastanov.github.io/QuantumSavory.jl/dev/ The overall relationship I am imagining is Some observations on which feedback would be helpful:
Would it make sense to move this package to qojulia soon and publishing it, even in such draft form, so that we can start running the CI on pull requests like the one here: qojulia/QuantumOpticsBase.jl#73 Would it make sense to reach out to https://github.com/JuliaQuantum which seems to be a long dead organization and checking whether they would give us the organization name so we can host all these packages in a single location? I am also happy to host everything under qojulia, it is just the name would be a bit misleading when the other packages are added. |
@Krastanov I've invited you to work on this repository. Alternatively you can also transfer the one you already have (will add you as repository owner afterwards of course), whichever way you prefer is fine by me, thanks. I was actually browsing through your repos before creating this one, I must have missed it, sorry about that.
Sure.
I agree on all of those. Specifically, I think it makes a lot of sense to factor out bases.
They look like some short-hand convenience functions, so I don't see a problem in moving them upstream.
Yes, we'll definitely need some iteration and testing before depending on this package with all the libraries. Let's just take it step by step. Still, as you say, that shouldn't keep us from publishing it IMHO. |
No, it was my bad. The repository was not published until a day ago. I made the pull request #2 which copies over that package. |
@david-pl , it seems How about we change the name yet again to Or we can ask for a manual merge in the registry? |
@Krastanov |
Yes, I will proceed with the cleanup and a new attempt at registration |
The general plan for this package is to be a lightweight dependency that defines the interface for a number of different packages such that they can all work together without clashing. The list of packages includes (at least) the following:
In this issue I want to collect what actually should be part of the interface package. So far I've only added very few basic function definitions. @Krastanov what functionality do we need for QuantumSavory? @amilsted do you have any input here?
Off the top of my head I'm thinking of the following things:
Functions
tensor / ⊗
destroy / create
and other operator constructors (used in QuantumCumulants)?embed
tr
,ptrace
,expect
,dagger
, ...)LinearAlgebra
I thinkTypes
I'm not sure about types as it could easily lead to type-piracy. It might make sense to move out
Basis
types entirely, however. @amilsted do you see any problems with precompilation / method invalidations?Do
Basis
types need more abstraction (e.g. adding a label, removing information on dimensions)?Also pinging @bastikr, @ChristophHotter , @j-moser here.
The text was updated successfully, but these errors were encountered: