Skip to content

Commit

Permalink
feat: phase difference options
Browse files Browse the repository at this point in the history
Allow user to choose the maximum phase difference and density threshold.
  • Loading branch information
musoke committed Jul 21, 2021
1 parent 91d32a8 commit 25ea5e7
Show file tree
Hide file tree
Showing 4 changed files with 42 additions and 14 deletions.
2 changes: 1 addition & 1 deletion Project.toml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
name = "UltraDark"
uuid = "1c8d022d-dfc0-4b41-80ab-3fc7e88cdfea"
authors = ["Nathan Musoke <[email protected]>"]
version = "0.1.2"
version = "0.1.3"

[deps]
AbstractFFTs = "621f4979-c628-5d54-868e-fcf4e3e8185c"
Expand Down
11 changes: 4 additions & 7 deletions src/UltraDark.jl
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,6 @@ export Grids, PencilGrids
export Config, SimulationConfig, constant_scale_factor
export OutputConfig

const PHASE_GRAD_LIMIT = π / 4

include("grids.jl")
include("pencil_grids.jl")
include("phase_diff.jl")
Expand Down Expand Up @@ -151,7 +149,7 @@ function evolve_to!(t_start, t_end, grids, output_config, config::Config.Simulat

while (t < t_end) && ~(t t_end)

if max_normed_phase_grad(grids) > PHASE_GRAD_LIMIT
if ~good_phase_diff(grids, config)
output_grids(grids, output_config, -1)
throw("Phase gradient is too large to continue")
end
Expand Down Expand Up @@ -184,9 +182,8 @@ function simulate(grids, options::Config.SimulationConfig, output_config::Output

# Output initial conditions
output_grids(grids, output_config, 1)

if max_normed_phase_grad(grids) > PHASE_GRAD_LIMIT
throw("Phase gradient is too large to start")
if ~good_phase_diff(grids, options)
throw("Initial phase gradient is already in untrusted regime")
end

for (index, t_end) in enumerate(output_config.output_times[2:end])
Expand All @@ -202,7 +199,7 @@ function simulate(grids, options::Config.SimulationConfig, output_config::Output
output_grids(grids, output_config, index + 1)
end

if max_normed_phase_grad(grids) > PHASE_GRAD_LIMIT
if ~good_phase_diff(grids, options)
throw("Phase gradient is too large to end")
end

Expand Down
18 changes: 17 additions & 1 deletion src/config.jl
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,30 @@ struct SimulationConfig
time_step_update_period::Int64
"function defining a(t)"
a
phase_grad_limit::Float64
density_threshold::Float64
end

function constant_scale_factor(t)
1.0
end

function SimulationConfig(time_step_update_period)
SimulationConfig(time_step_update_period, constant_scale_factor)
SimulationConfig(time_step_update_period, constant_scale_factor, π/4, 1e-6)
end

function SimulationConfig(time_step_update_period, a)
SimulationConfig(time_step_update_period, a, π/4, 1e-6)
end

function SimulationConfig(
;
time_step_update_period=10,
a=constant_scale_factor,
phase_grad_limit=π/4,
density_threshold=1e-6
)
SimulationConfig(time_step_update_period, constant_scale_factor, phase_grad_limit, density_threshold)
end

end # module
25 changes: 20 additions & 5 deletions src/phase_diff.jl
Original file line number Diff line number Diff line change
Expand Up @@ -40,9 +40,8 @@ Compute maximum phase gradient of a grid
Normalised to ignore large gradients in regions with low density. These tend
to be anomalous.
"""
function max_normed_phase_grad(grids)
DENSITY_THRESHOLD = 1e-6
tmp = similar(grids.ψx, Float64)
function max_normed_phase_diff(psi, rho, density_threshold)
tmp = similar(psi, Float64)
n = ndims(tmp)

max_grads = zeros(n)
Expand All @@ -52,11 +51,27 @@ function max_normed_phase_grad(grids)

for i in 1:n
dir = circshift(shift, i)
tmp .= abs.(phase_diff(grids.ψx, dir))
tmp[grids.ρx / maximum(grids.ρx) .< DENSITY_THRESHOLD] .= NaN
tmp .= abs.(phase_diff(psi, dir))
tmp[rho / maximum(rho) .< density_threshold] .= NaN
max_grads[i] = maximum(tmp)
end

maximum(max_grads)

end

"""
bad_phase_diff(grids, config)
Check if the phase of the ψ field is in a trustable regime.
Returns
"""
function good_phase_diff(grids, config)
density_threshold = config.density_threshold
if max_normed_phase_diff(grids.ψx, grids.ρx, density_threshold) > config.phase_grad_limit
false
else
true
end
end

2 comments on commit 25ea5e7

@musoke
Copy link
Owner Author

@musoke musoke commented on 25ea5e7 Jul 21, 2021

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/41298

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.1.3 -m "<description of version>" 25ea5e796954471e91c277bff6e75013b7a00c33
git push origin v0.1.3

Please sign in to comment.