Skip to content

Commit

Permalink
random_pauli had a method that disregards error probability and had w…
Browse files Browse the repository at this point in the history
…rong defaults (#257)
  • Loading branch information
Krastanov authored Apr 10, 2024
1 parent 6c184a7 commit 64f695c
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 4 deletions.
6 changes: 5 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,11 @@

# News

## v0.9.3 - 2024-04-08
## v0.9.3 - 2024-04-10

- **(fix)** One of `random_pauli`'s methods was disregarding the error probability and had incorrect kwarg defaults.

## v0.9.2 - 2024-04-08

- The ECC module now has access to an iterative bitflip decoder thanks to `LDPCDecoders.jl`.
- Provide more configuration options in the `PyBeliefProp` decoders.
Expand Down
2 changes: 1 addition & 1 deletion Project.toml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
name = "QuantumClifford"
uuid = "0525e862-1e90-11e9-3e4d-1b39d7109de1"
authors = ["Stefan Krastanov <stefan@krastanov.org> and QuantumSavory community members"]
version = "0.9.2"
version = "0.9.3"

[deps]
Combinatorics = "861a8166-3701-5b0c-9a16-15d98fcdc6aa"
Expand Down
4 changes: 2 additions & 2 deletions src/randoms.jl
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ function random_pauli!(rng::AbstractRNG, P::PauliOperator; nophase=true, realpha
P
end
random_pauli!(P::PauliOperator; kwargs...) = random_pauli!(GLOBAL_RNG,P; kwargs...)
function random_pauli!(rng::AbstractRNG,P::PauliOperator,p; nophase=false, realphase=false)
function random_pauli!(rng::AbstractRNG,P::PauliOperator,p; nophase=true, realphase=true)
n = nqubits(P)
p = p/3
for i in 1:n
Expand All @@ -44,7 +44,7 @@ random_pauli!(P::PauliOperator, p; kwargs...) = random_pauli!(GLOBAL_RNG,P,p; kw

random_pauli(rng::AbstractRNG,n::Int; kwargs...) = random_pauli!(rng, zero(PauliOperator, n); kwargs...)
random_pauli(n::Int; kwargs...) = random_pauli(GLOBAL_RNG, n; kwargs...)
random_pauli(rng::AbstractRNG,n::Int,p; kwargs...) = random_pauli!(rng, zero(PauliOperator, n); kwargs...)
random_pauli(rng::AbstractRNG,n::Int,p; kwargs...) = random_pauli!(rng, zero(PauliOperator, n),p; kwargs...)
random_pauli(n::Int, p; kwargs...) = random_pauli(GLOBAL_RNG,n,p; kwargs...)

##############################
Expand Down
25 changes: 25 additions & 0 deletions test/test_random.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
using QuantumClifford
using Test

using QuantumClifford: stab_looks_good, destab_looks_good, mixed_stab_looks_good, mixed_destab_looks_good

Expand Down Expand Up @@ -31,3 +32,27 @@ test_sizes = [1,2,10,63,64,65,127,128,129] # Including sizes that would test off
@test mixed_destab_looks_good(apply!(ms,sq,phases=false))
end
end

@testset "Random Paulis" begin
for n in [1, test_sizes..., 200,500]
@test all((random_pauli(n).phase[] == 0 for _ in 1:100))
@test all((random_pauli(n, 0.1).phase[] == 0 for _ in 1:100))
@test any((random_pauli(n; nophase=false, realphase=false).phase[] == 1 for _ in 1:100))
@test any((random_pauli(n, 0.1; nophase=false, realphase=false).phase[] == 1 for _ in 1:100))
@test any((random_pauli(n; nophase=false).phase[] [0,2] for _ in 1:100))
@test any((random_pauli(n, 0.1; nophase=false).phase[] [0,2] for _ in 1:100))
end
for i in 1:10
e = 0.2
n = 10000
expected = 2/3*e * 2 * n
bound = 1/sqrt(n)
@test expected * (1-10bound) <= sum(count_ones.(random_pauli(10000,0.2).xz)) <= expected * (1+10bound)
e = 0.75
n = 10000
expected = 2/3*e * 2 * n
bound = 1/sqrt(n)
@test expected * (1-10bound) <= sum(count_ones.(random_pauli(10000).xz)) <= expected * (1+10bound)

end
end

2 comments on commit 64f695c

@Krastanov
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@JuliaRegistrator
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Registration pull request created: JuliaRegistries/General/104635

Tip: Release Notes

Did you know you can add release notes too? Just add markdown formatted text underneath the comment after the text
"Release notes:" and it will be added to the registry PR, and if TagBot is installed it will also be added to the
release that TagBot creates. i.e.

@JuliaRegistrator register

Release notes:

## Breaking changes

- blah

To add them here just re-invoke and the PR will be updated.

Tagging

After the above pull request is merged, it is recommended that a tag is created on this repository for the registered package version.

This will be done automatically if the Julia TagBot GitHub Action is installed, or can be done manually through the github interface, or via:

git tag -a v0.9.3 -m "<description of version>" 64f695cb79dc99467ef8de53a1dc9f7488f8a047
git push origin v0.9.3

Please sign in to comment.