From 0d967d8f9e1d30e22593657369d9b8e11d4909ed Mon Sep 17 00:00:00 2001 From: lxvm Date: Thu, 14 Nov 2024 19:08:40 -0500 Subject: [PATCH] change default frequency point for prototypes to Fermi level --- src/ElectronDensitySolver.jl | 8 ++++---- src/KineticCoefficientSolver.jl | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/ElectronDensitySolver.jl b/src/ElectronDensitySolver.jl index e629c0c..01309fb 100644 --- a/src/ElectronDensitySolver.jl +++ b/src/ElectronDensitySolver.jl @@ -3,9 +3,9 @@ function _DynamicalOccupiedGreensSolver(fun::F, Σ::AbstractSelfEnergy, fdom, fa bandwidth = oneunit(μ) V = abs(det(bz.B)) inner_kws = _rescale_abstol(something(scale_inner, inv(bandwidth)); kws...) - dos_prob = _GreensProblem(fun, Σ, h, bz, linalg; ω=(fdom[1]+fdom[2])/2, μ, inner_kws...) + dos_prob = _GreensProblem(fun, Σ, h, bz, linalg; ω=zero(fdom[1]+fdom[2])/2, μ, inner_kws...) p = (; β, μ) - proto = dos_prob.f.prototype * V * fermi(β, (fdom[1]+fdom[2])/2) + proto = dos_prob.f.prototype * V * fermi(β, zero(fdom[1]+fdom[2])/2) # WARN: Σ evaluation in update_greens! may not be threadsafe so need another prob type up = (solver, ω, (_, (; β, μ))) -> (update_greens!(solver; ω, μ); return) post = (sol, ω, (_, (; β, μ))) -> sol.value*fermi(β, ω) @@ -34,7 +34,7 @@ function _DynamicalOccupiedGreensSolver(fun::F, h::AbstractHamiltonianInterp, bz k = period(h) hk = h(k) g = gauge(h) - M = evalM(; Σ, ω=(fdom[1]+fdom[2])/2, μ) + M = evalM(; Σ, ω=zero(fdom[1]+fdom[2])/2, μ) A = g isa Hamiltonian ? M - Diagonal(hk.values) : M - hk linprob, rep = linalg isa LinearSystemAlgorithm ? (LinearSystemProblem(A), UnknownRep()) : linalg isa TraceInverseAlgorithm ? (TraceInverseProblem(A), TrivialRep()) : @@ -59,7 +59,7 @@ function _DynamicalOccupiedGreensSolver(fun::F, h::AbstractHamiltonianInterp, bz error("$sol is neither a LinearSystemSolution nor TraceInverseSolution") end |> fun |> x -> x*fermi(β, ω) inner_kws = _rescale_abstol(something(scale_inner, inv(V*nsyms(bz))); kws...) - proto = post_k(solve(linprob, linalg), (fdom[1]+fdom[2])/2, p_k) + proto = post_k(solve(linprob, linalg), zero(fdom[1]+fdom[2])/2, p_k) f_k = CommonSolveIntegralFunction(linprob, linalg, up_k, post_k, proto) fprob = IntegralProblem(f_k, get_safe_fermi_function_limits(β, fdom...), p_k; inner_kws...) linprob, rep = linalg isa LinearSystemAlgorithm ? (LinearSystemProblem(A), UnknownRep()) : diff --git a/src/KineticCoefficientSolver.jl b/src/KineticCoefficientSolver.jl index d2f79f0..b6ad9eb 100644 --- a/src/KineticCoefficientSolver.jl +++ b/src/KineticCoefficientSolver.jl @@ -51,7 +51,7 @@ function _DynamicalTransportDistributionSolver(fun::F, hv::AbstractVelocityInter return end post_k = (sol, ω, (_, Σ, hvk, (; β, μ, Ω, n))) -> (ω*β)^n * fermi_window(β, ω, Ω) * fun(transport_distribution_integrand(hvk[2], sol.G1, sol.G2, sol.isdistinct), hvk..., sol) - proto = post_k(solve(prob_k, alg), (fdom[1]+fdom[2])/2, p_k) + proto = post_k(solve(prob_k, alg), zero(fdom[1]+fdom[2])/2, p_k) f_k = CommonSolveIntegralFunction(prob_k, alg, up_k, post_k, proto) V = abs(det(bz.B)) inner_kws = _rescale_abstol(something(scale_inner, inv(V*nsyms(bz))); kws...)