Skip to content

Commit

Permalink
Add more benchmarks
Browse files Browse the repository at this point in the history
  • Loading branch information
albertomercurio committed May 5, 2024
1 parent bb7fb7c commit f86f15e
Show file tree
Hide file tree
Showing 7 changed files with 159 additions and 23 deletions.
30 changes: 30 additions & 0 deletions benchmarks/correlations_and_spectrum.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
function benchmark_correlations_and_spectrum()
ωc = 1
ωq = 1
g = 0.05
ωd = 0.95
F = 0.1
nth = 7
γ = 0.1

Δc = ωc - ωd
Δq = ωq - ωd

# Operators definition
N = 50 # cutoff for the cavity Hilbert space
a = tensor(destroy(N), qeye(2))
σm = tensor(qeye(N), sigmam())
σz = tensor(qeye(N), sigmaz())

# Hamiltonian
H = Δc * a' * a + Δq * σz / 2 + g * (a' * σm + a * σm') + F * (a + a')
c_ops = [sqrt* (nth + 1)) * a, sqrt* nth) * a', sqrt(γ) * σm]

ω_l = range(0, 3, length=1000)

SUITE["Correlations and Spectrum"]["FFT Correlation"] = @benchmarkable spectrum($H, $ω_l, $(a'), $a, $c_ops, solver=FFTCorrelation(), progress_bar=false)

SUITE["Correlations and Spectrum"]["Exponential Series"] = @benchmarkable spectrum($H, $ω_l, $(a'), $a, $c_ops)
end

benchmark_correlations_and_spectrum()
33 changes: 33 additions & 0 deletions benchmarks/dynamical_fock_dimension.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
function H_dfd2(dims, p)
Δ = p.Δ
F = p.F
J = p.J
a = tensor(destroy(dims[1]), qeye(dims[2]))
b = tensor(qeye(dims[1]), destroy(dims[2]))
Δ * a' * a + F * (a + a') + Δ * b' * b + J * (a' * b + a * b')
end
function c_ops_dfd2(dims, p)
κ = p.κ
a = tensor(destroy(dims[1]), qeye(dims[2]))
b = tensor(qeye(dims[1]), destroy(dims[2]))
[κ * a, κ * b]
end
function e_ops_dfd2(dims, p)
a = tensor(destroy(dims[1]), qeye(dims[2]))
b = tensor(qeye(dims[1]), destroy(dims[2]))
[a' * a, b' * b]
end

function benchmark_dfd()
F, Δ, κ, J = 1.5, 0.25, 1, 0.05
maxdims = [50, 50]

ψ0 = tensor(fock(3, 0), fock(20, 15))
dfd_params ==Δ, F=F, κ=κ, J=J)

tlist = range(0, 15 / κ, 100)

SUITE["Time Evolution"]["Dynamical Fock Dymension"] = @benchmarkable dfd_mesolve(H_dfd2, $ψ0, $tlist, c_ops_dfd2, $maxdims, $dfd_params, e_ops=e_ops_dfd2, progress_bar=false)
end

benchmark_dfd()
22 changes: 22 additions & 0 deletions benchmarks/eigenvalues.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
function benchmark_eigenvalues()
N = 5
a = tensor(destroy(N), qeye(N))
a_d = a'
b = tensor(qeye(N), destroy(N))
b_d = b'

ωc = 1
ωb = 1
g = 0.2
κ = 0.01
n_thermal = 0.1

H = ωc * a_d * a + ωb * b_d * b + g * (a + a_d) * (b + b_d)
c_ops = [((1+n_thermal)*κ) * a, κ * b, (n_thermal*κ) * a_d]
L = liouvillian(H, c_ops)

SUITE["Eigenvalues"]["eigenstates"]["dense"] = @benchmarkable eigenstates($L)
SUITE["Eigenvalues"]["eigenstates"]["sparse"] = @benchmarkable eigenstates($L, sparse=true, sigma=0.01, k=5)
end

benchmark_eigenvalues()
30 changes: 9 additions & 21 deletions benchmarks/runbenchmarks.jl
Original file line number Diff line number Diff line change
@@ -1,28 +1,16 @@
using BenchmarkTools
using QuantumToolbox

suite = BenchmarkGroup()
const SUITE = BenchmarkGroup()

suite["steadystate"] = BenchmarkGroup(["steadystate"])
include("correlations_and_spectrum.jl")
include("dynamical_fock_dimension.jl")
include("eigenvalues.jl")
include("steadystate.jl")
include("timeevolution.jl")


## steadystate ##

N = 50
Δ = 0.1
F = 2
γ = 1
a = destroy(N)
H = Δ * a' * a + F * (a + a')
c_ops = [sqrt(γ) * a]

suite["steadystate"]["driven-dissipative harmonic oscillator"] = @benchmarkable steadystate($H, $c_ops)

## end ##


BenchmarkTools.tune!(suite)
results = run(suite, verbose = true)
BenchmarkTools.tune!(SUITE)
results = BenchmarkTools.run(SUITE, verbose = true)
display(median(results))

BenchmarkTools.save(joinpath(@__DIR__, "benchmarks_output.json"), median(results))
BenchmarkTools.save("benchmarks_output.json", median(results))
15 changes: 15 additions & 0 deletions benchmarks/steadystate.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
function benchmark_steadystate()
N = 50
Δ = 0.1
F = 2
γ = 1
nth = 5

a = destroy(N)
H = Δ * a' * a + F * (a + a')
c_ops = [sqrt* (nth + 1)) * a, sqrt* nth) * a']

SUITE["Steadystate"]["Direct"] = @benchmarkable steadystate($H, $c_ops)
end

benchmark_steadystate()
48 changes: 48 additions & 0 deletions benchmarks/timeevolution.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
function benchmark_timeevolution()
ωc = 1
ωq = 1
g = 0.05
ωd = 0.95
F = 0.1

Δc = ωc - ωd
Δq = ωq - ωd

# Operators definition
N = 50 # cutoff for the cavity Hilbert space
a = tensor(destroy(N), qeye(2))
σm = tensor(qeye(N), sigmam())
σz = tensor(qeye(N), sigmaz())

# Hamiltonian
H = Δc * a' * a + Δq * σz / 2 + g * (a' * σm + a * σm') + F * (a + a')

e_ops = [a'*a, σz]

# Initial state
ψ0 = tensor(coherent(N, 0), fock(2, 1))

## sesolve ##

tlist = range(0, 2π * 10 / g, 1000)

SUITE["Time Evolution"]["time-independent"]["sesolve"] = @benchmarkable sesolve($H, $ψ0, $tlist, e_ops=$e_ops, progress_bar=false)

## mesolve ##

nth = 7
γ = 0.1
c_ops = [sqrt* (nth + 1)) * a, sqrt* nth) * a', sqrt(γ) * σm]

tlist = range(0, 10/γ, 100)

SUITE["Time Evolution"]["time-independent"]["mesolve"] = @benchmarkable mesolve($H, $ψ0, $tlist, $c_ops, e_ops=$e_ops, progress_bar=false)

## mcsolve ##

ntraj = 100

SUITE["Time Evolution"]["time-independent"]["mcsolve"] = @benchmarkable mcsolve($H, $ψ0, $tlist, $c_ops, n_traj=ntraj, e_ops=$e_ops)
end

benchmark_timeevolution()
4 changes: 2 additions & 2 deletions docs/make.jl
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ DocMeta.setdocmeta!(QuantumToolbox, :DocTestSetup, :(using QuantumToolbox); recu
makedocs(;
modules=[QuantumToolbox],
authors="Alberto Mercurio",
# repo="https://github.com/albertomercurio/QuantumToolbox.jl/blob/{commit}{path}#{line}",
repo = Remotes.GitHub("albertomercurio", "QuantumToolbox.jl"),
sitename="QuantumToolbox.jl",
format=Documenter.HTML(;
Expand All @@ -30,7 +29,8 @@ makedocs(;
"api.md",
"Users Guide" => [
"Low Rank Master Equation" => "lowrank.md",
]
],
"Benchmarks" => "benchmarks/index.html"
],
)

Expand Down

0 comments on commit f86f15e

Please sign in to comment.