1
0
Fork 0
mirror of https://gitlab.rlp.net/mobitar/ReCo.jl.git synced 2025-01-22 17:11:32 +00:00
ReCo.jl/src/run.jl

154 lines
5.5 KiB
Julia
Raw Normal View History

2022-09-25 15:54:46 +02:00
using CellListMap: CellListMap
using Dates: Dates
using JLD2: JLD2
using Random: Random
using StaticArrays: SVector
const DEFAULT_SNAPSHOT_AT = 0.1
const DEFAULT_SEED = 42
const DEFAULT_N_BUNDLE_SNAPSHOTS = 100
const DEFAULT_SHOW_PROGRESS = true
2022-01-18 02:17:52 +01:00
function empty_hook(args...)
return nothing
end
2021-12-12 15:29:08 +01:00
2022-01-29 14:32:04 +01:00
function gen_cell_list_box(half_box_len::Float64, skin_radius::Float64)
return CellListMap.Box(SVector(2 * half_box_len, 2 * half_box_len), skin_radius)
2022-01-23 03:04:10 +01:00
end
"""
run_sim(sim_dir::String; <keyword arguments>)
Run the initialized simulation in its directory `sim_dir`.
This function starts or resumes a simulation. For long simulations, the simulation can be stopped by pressing `Ctrl` + `c`. This stopped simulation can be resumed later by running this function again with the same simulation directory.
Some of the last snapshots might be lost if the simulations is stopped (see the argument `n_bundle_snapshots`).
Return `nothing`.
# Arguments
- `sim_dir::String`: Relative path of the initialized simulation directory.
- `duration::Float64`: Duration of the simulation.
- `snapshot_at::Float64=$DEFAULT_SNAPSHOT_AT`: Snapshot time interval.
- `seed::Int64=$DEFAULT_SEED`: Random number generator seed.
2022-03-19 23:11:03 +01:00
- `n_bundle_snapshots::Int64=$DEFAULT_N_BUNDLE_SNAPSHOTS`: Number of snapshots in a bundle. This number is relevant for long simulations that can be stopped while running. A simulation can be continued from the last bundle of snapshots. If the number of snapshots in a bundle is too high and the simulation is stopped, many of the last snapshots can be lost. A low number results in high IO since snapshots are then bundled and stored more often. For example, setting this number to 1 results in saving every snapshot immediately without bundling it with other snapshots which would be more efficient. Setting the number to 1000 could mean loosing 999 snapshots in the worst case if the simulation is stopped before having 1000 snapshots to bundle and save.
- `env_helper::Union{RL.EnvHelper,Nothing}=nothing`: Environment helper. It should be left as the default `nothing` unless this function is used internally for reinforcement learning.
- `show_progress::Bool=$DEFAULT_SHOW_PROGRESS`: Show simulation progress bar.
"""
2021-11-26 06:55:27 +01:00
function run_sim(
sim_dir::String;
2021-11-26 06:55:27 +01:00
duration::Float64,
snapshot_at::Float64=DEFAULT_SNAPSHOT_AT,
seed::Int64=DEFAULT_SEED,
n_bundle_snapshots::Int64=DEFAULT_N_BUNDLE_SNAPSHOTS,
env_helper::Union{RL.EnvHelper,Nothing}=nothing,
show_progress::Bool=DEFAULT_SHOW_PROGRESS,
2021-11-16 22:26:08 +01:00
)
@assert length(sim_dir) > 0
2021-11-26 06:55:27 +01:00
@assert duration > 0
2021-12-11 19:21:56 +01:00
@assert snapshot_at in 0.001:0.001:duration
2021-11-23 01:35:36 +01:00
@assert seed > 0
2021-11-26 06:55:27 +01:00
@assert n_bundle_snapshots >= 0
2021-11-23 01:35:36 +01:00
Random.seed!(seed)
2021-11-10 15:41:04 +01:00
sim_consts = load_sim_consts(sim_dir)
2021-11-10 15:41:04 +01:00
2021-11-26 06:55:27 +01:00
integration_steps = floor(Int64, duration / sim_consts.δt) + 1
2021-11-10 15:41:04 +01:00
2021-12-12 15:29:08 +01:00
n_steps_before_snapshot = round(Int64, snapshot_at / sim_consts.δt)
2021-11-26 06:55:27 +01:00
n_snapshots = floor(Int64, integration_steps / n_steps_before_snapshot) + 1
2021-11-10 15:41:04 +01:00
2021-12-13 00:19:18 +01:00
@assert (n_snapshots - 1) * snapshot_at == duration
2021-11-26 06:55:27 +01:00
n_bundle_snapshots = min(n_snapshots, n_bundle_snapshots)
2021-11-18 19:42:11 +01:00
sim_state::SimState = JLD2.load_object("$sim_dir/sim_state.jld2")
2021-12-10 03:16:18 +01:00
n_bundles = sim_state.n_bundles
2021-12-03 00:37:43 +01:00
2021-12-12 15:29:08 +01:00
T0::Float64 = sim_state.T
T = T0 + duration
if n_bundle_snapshots > 0
save_data = true
else
save_data = false
end
@async begin
start_datetime = Dates.now()
2021-12-12 15:29:08 +01:00
run_params = RunParams(
2021-12-12 15:29:08 +01:00
# Input
duration,
snapshot_at,
seed,
n_bundle_snapshots,
2022-01-17 22:00:59 +01:00
# Internal
2021-12-12 15:29:08 +01:00
integration_steps,
n_steps_before_snapshot,
n_snapshots,
T,
T0,
start_datetime,
)
next_bundle = n_bundles + 1
runs_dir = "$sim_dir/runs"
2021-12-12 15:29:08 +01:00
if save_data
JLD2.save_object("$runs_dir/run_params_$next_bundle.jld2", run_params)
2021-12-12 15:29:08 +01:00
end
end
bundles_dir = "$sim_dir/bundles"
2022-01-24 21:27:43 +01:00
bundle::Bundle = JLD2.load_object("$bundles_dir/$n_bundles.jld2")
2021-12-03 00:37:43 +01:00
2021-12-12 15:29:08 +01:00
particles = gen_particles(bundle, sim_consts.n_particles)
2021-12-07 04:19:35 +01:00
2021-11-10 15:41:04 +01:00
args = (
2021-12-12 15:29:08 +01:00
v₀=sim_consts.v₀,
2021-12-12 18:27:56 +01:00
δt=sim_consts.δt,
2022-01-29 14:32:04 +01:00
skin_radius=sim_consts.skin_radius,
skin_radius²=sim_consts.skin_radius^2,
2021-11-26 06:55:27 +01:00
n_snapshots=n_snapshots,
2022-01-26 14:39:42 +01:00
ϵσ⁶δtμₜ24=24 * sim_consts.ϵ * sim_consts.σ^6 * sim_consts.δt * sim_consts.μₜ,
σ⁶2=2 * sim_consts.σ^6,
sqrt_Dₜδt2=sqrt(2 * sim_consts.Dₜ * sim_consts.δt),
sqrt_Dᵣδt2=sqrt(2 * sim_consts.Dᵣ * sim_consts.δt),
2021-12-12 15:29:08 +01:00
v₀δt=sim_consts.v₀ * sim_consts.δt,
2022-01-23 16:14:37 +01:00
μₜ=sim_consts.μₜ,
2022-01-29 14:32:04 +01:00
interaction_radius=sim_consts.interaction_radius,
interaction_radius²=sim_consts.interaction_radius^2,
2021-12-10 03:16:18 +01:00
n_particles=sim_consts.n_particles,
half_box_len=sim_consts.half_box_len,
2021-12-07 04:19:35 +01:00
particles=particles,
2021-12-10 03:16:18 +01:00
particles_c=[particles[i].c for i in 1:(sim_consts.n_particles)],
verlet_lists=[
PreVector{Int64}(sim_consts.n_particles - i) for
i in 1:(sim_consts.n_particles - 1)
],
2021-11-26 06:55:27 +01:00
n_bundle_snapshots=n_bundle_snapshots,
2021-12-10 03:16:18 +01:00
bundle=Bundle(sim_consts.n_particles, n_bundle_snapshots),
2022-01-29 14:32:04 +01:00
box=gen_cell_list_box(sim_consts.half_box_len, sim_consts.skin_radius),
2022-01-23 04:21:06 +01:00
show_progress=show_progress,
2021-11-17 20:43:20 +01:00
)
2022-01-18 02:17:52 +01:00
simulate!(
2021-11-26 06:55:27 +01:00
args,
T0,
T,
2021-12-13 00:19:18 +01:00
sim_consts.n_steps_before_verlet_list_update,
2021-11-26 06:55:27 +01:00
n_steps_before_snapshot,
n_bundles,
sim_dir,
2021-11-26 06:55:27 +01:00
save_data,
env_helper,
2021-11-26 06:55:27 +01:00
)
2021-11-10 15:41:04 +01:00
2021-12-12 15:29:08 +01:00
return nothing
2022-03-19 23:11:03 +01:00
end