mirror of
https://gitlab.rlp.net/mobitar/ReCo.jl.git
synced 2025-01-01 15:39:20 +00:00
Used modules
This commit is contained in:
parent
7cb7f2d619
commit
a922ab9ab5
14 changed files with 69 additions and 52 deletions
|
@ -2,15 +2,15 @@ if splitdir(pwd())[2] == "analysis"
|
||||||
cd("..")
|
cd("..")
|
||||||
end
|
end
|
||||||
|
|
||||||
if splitdir(pwd())[2] != "ReCo"
|
if splitdir(pwd())[2] != "ReCo.jl"
|
||||||
error("You have to be in the main directeory ReCo!")
|
error("You have to be in the main directeory ReCo.jl!")
|
||||||
else
|
else
|
||||||
include("src/analysis/pair_correlation_function.jl")
|
include("src/analysis/pair_correlation_function.jl")
|
||||||
end
|
end
|
||||||
|
|
||||||
##
|
##
|
||||||
|
|
||||||
using JLD2
|
using JLD2: JLD2
|
||||||
|
|
||||||
using CairoMakie
|
using CairoMakie
|
||||||
CairoMakie.activate!()
|
CairoMakie.activate!()
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
module ReCoAnimation
|
module Animation
|
||||||
|
|
||||||
export animate
|
export animate
|
||||||
|
|
||||||
|
@ -9,7 +9,7 @@ using JSON3: JSON3
|
||||||
using JLD2: JLD2
|
using JLD2: JLD2
|
||||||
using ProgressMeter: @showprogress
|
using ProgressMeter: @showprogress
|
||||||
|
|
||||||
using ReCo: Bundle
|
using ..ReCo: Bundle
|
||||||
|
|
||||||
function animate_bundle!(args)
|
function animate_bundle!(args)
|
||||||
bundle_t = args.bundle.t
|
bundle_t = args.bundle.t
|
||||||
|
@ -90,7 +90,7 @@ function animate_bundle!(args)
|
||||||
return nothing
|
return nothing
|
||||||
end
|
end
|
||||||
|
|
||||||
function animate_after_loading(dir, animation_path, sim_consts, framerate, debug)
|
function animate_with_sim_consts(dir::String, sim_consts, framerate::Int64, debug::Bool)
|
||||||
set_theme!(theme_black())
|
set_theme!(theme_black())
|
||||||
|
|
||||||
fig = Figure(; resolution=(1080, 1080))
|
fig = Figure(; resolution=(1080, 1080))
|
||||||
|
@ -113,6 +113,8 @@ function animate_after_loading(dir, animation_path, sim_consts, framerate, debug
|
||||||
|
|
||||||
n_particles = sim_consts.n_particles
|
n_particles = sim_consts.n_particles
|
||||||
|
|
||||||
|
animation_path = "$dir/animation.mkv"
|
||||||
|
|
||||||
record(fig, animation_path; framerate=framerate) do io
|
record(fig, animation_path; framerate=framerate) do io
|
||||||
circles = Observable(Vector{Circle}(undef, n_particles))
|
circles = Observable(Vector{Circle}(undef, n_particles))
|
||||||
colors = Observable(Vector{RGBAf}(undef, n_particles))
|
colors = Observable(Vector{RGBAf}(undef, n_particles))
|
||||||
|
@ -185,11 +187,9 @@ function animate(dir::String; framerate::Int64=1, debug::Bool=false)
|
||||||
|
|
||||||
sim_consts = JSON3.read(read("$dir/sim_consts.json", String))
|
sim_consts = JSON3.read(read("$dir/sim_consts.json", String))
|
||||||
|
|
||||||
animation_path = "$dir/animation.mkv"
|
animate_with_sim_consts(dir, sim_consts, framerate, debug)
|
||||||
|
|
||||||
animate_after_loading(dir, animation_path, sim_consts, framerate, debug)
|
println("Animation done.")
|
||||||
|
|
||||||
println("Animation done and saved to $animation_path.")
|
|
||||||
|
|
||||||
return nothing
|
return nothing
|
||||||
end
|
end
|
|
@ -1,3 +1,5 @@
|
||||||
|
module Benchmark
|
||||||
|
|
||||||
using Statistics: mean
|
using Statistics: mean
|
||||||
using Dates: now
|
using Dates: now
|
||||||
using BenchmarkTools: @benchmark
|
using BenchmarkTools: @benchmark
|
||||||
|
@ -42,4 +44,6 @@ function run_benchmarks(
|
||||||
end
|
end
|
||||||
|
|
||||||
return dir
|
return dir
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end # module
|
|
@ -1,5 +1,3 @@
|
||||||
using StaticArrays: SVector
|
|
||||||
|
|
||||||
mutable struct Particle
|
mutable struct Particle
|
||||||
id::Int64
|
id::Int64
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,7 @@
|
||||||
|
module PreVectors
|
||||||
|
|
||||||
|
export PreVector, push!, reset!, iterate
|
||||||
|
|
||||||
import Base: push!, iterate
|
import Base: push!, iterate
|
||||||
|
|
||||||
mutable struct PreVector{T}
|
mutable struct PreVector{T}
|
||||||
|
@ -27,3 +31,5 @@ function iterate(pv::PreVector{T}, state=1) where {T}
|
||||||
return (pv.v[state], state + 1)
|
return (pv.v[state], state + 1)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end # module
|
|
@ -10,7 +10,7 @@ using LoopVectorization: @turbo
|
||||||
using Random: Random
|
using Random: Random
|
||||||
using ProgressMeter: @showprogress
|
using ProgressMeter: @showprogress
|
||||||
|
|
||||||
using ..ReCo
|
using ..ReCo: ReCo, Particle
|
||||||
|
|
||||||
const INITIAL_REWARD = 0.0
|
const INITIAL_REWARD = 0.0
|
||||||
|
|
||||||
|
@ -143,10 +143,10 @@ end
|
||||||
|
|
||||||
mutable struct Env <: AbstractEnv
|
mutable struct Env <: AbstractEnv
|
||||||
params::EnvParams
|
params::EnvParams
|
||||||
particle::ReCo.Particle
|
particle::Particle
|
||||||
state_ind::Int64
|
state_ind::Int64
|
||||||
|
|
||||||
function Env(params::EnvParams, particle::ReCo.Particle)
|
function Env(params::EnvParams, particle::Particle)
|
||||||
# initial_state = (nothing, nothing)
|
# initial_state = (nothing, nothing)
|
||||||
initial_state_ind = params.n_states
|
initial_state_ind = params.n_states
|
||||||
|
|
||||||
|
@ -154,7 +154,7 @@ mutable struct Env <: AbstractEnv
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function reset!(env::Env, particle::ReCo.Particle)
|
function reset!(env::Env, particle::Particle)
|
||||||
env.particle = particle
|
env.particle = particle
|
||||||
env.state_ind = env.params.n_states
|
env.state_ind = env.params.n_states
|
||||||
|
|
||||||
|
@ -274,7 +274,7 @@ function state_hook(
|
||||||
end
|
end
|
||||||
|
|
||||||
function integration_hook!(
|
function integration_hook!(
|
||||||
particle::ReCo.Particle, rl_params::Params, δt::Float64, si::Float64, co::Float64
|
particle::Particle, rl_params::Params, δt::Float64, si::Float64, co::Float64
|
||||||
)
|
)
|
||||||
# Apply action
|
# Apply action
|
||||||
action = rl_params.actions[particle.id]
|
action = rl_params.actions[particle.id]
|
||||||
|
@ -297,7 +297,7 @@ end
|
||||||
function post_integration_hook(
|
function post_integration_hook(
|
||||||
rl_params::Params,
|
rl_params::Params,
|
||||||
n_particles::Int64,
|
n_particles::Int64,
|
||||||
particles::Vector{ReCo.Particle},
|
particles::Vector{Particle},
|
||||||
half_box_len::Float64,
|
half_box_len::Float64,
|
||||||
)
|
)
|
||||||
# Update reward
|
# Update reward
|
31
src/ReCo.jl
31
src/ReCo.jl
|
@ -1,14 +1,37 @@
|
||||||
module ReCo
|
module ReCo
|
||||||
|
|
||||||
export init_sim, run_sim, RL
|
export init_sim, run_sim, run_rl, animate
|
||||||
|
|
||||||
|
using StaticArrays: SVector
|
||||||
|
using OrderedCollections: OrderedDict
|
||||||
|
using JLD2: JLD2
|
||||||
|
using JSON3: JSON3
|
||||||
|
using Distributions: Uniform, Normal
|
||||||
|
using ProgressMeter: @showprogress
|
||||||
|
using CellListMap: Box, CellList, map_pairwise!, UpdateCellList!
|
||||||
|
|
||||||
|
using Random: Random
|
||||||
|
using Dates: Dates, now
|
||||||
|
|
||||||
|
import Base: wait
|
||||||
|
|
||||||
|
include("PreVectors.jl")
|
||||||
|
using .PreVectors
|
||||||
|
|
||||||
include("PreVector.jl")
|
|
||||||
include("Particle.jl")
|
include("Particle.jl")
|
||||||
include("reinforcement_learning.jl")
|
|
||||||
|
include("Shape.jl")
|
||||||
|
using .Shape
|
||||||
|
|
||||||
|
include("RL.jl")
|
||||||
|
using .RL
|
||||||
|
|
||||||
include("data.jl")
|
include("data.jl")
|
||||||
include("setup.jl")
|
include("setup.jl")
|
||||||
include("simulation.jl")
|
include("simulation.jl")
|
||||||
include("shape.jl")
|
|
||||||
include("run.jl")
|
include("run.jl")
|
||||||
|
|
||||||
|
include("Animation.jl")
|
||||||
|
using .Animation
|
||||||
|
|
||||||
end # module
|
end # module
|
|
@ -1,6 +1,12 @@
|
||||||
|
module Shape
|
||||||
|
|
||||||
|
export center_of_mass, gyration_tensor_eigvals_ratio
|
||||||
|
|
||||||
using StaticArrays: SVector, SMatrix
|
using StaticArrays: SVector, SMatrix
|
||||||
using LinearAlgebra: eigvals, Hermitian
|
using LinearAlgebra: eigvals, Hermitian
|
||||||
|
|
||||||
|
using ..ReCo: Particle, restrict_coordinate, restrict_coordinates
|
||||||
|
|
||||||
function project_to_unit_circle(x::Float64, half_box_len::Float64)
|
function project_to_unit_circle(x::Float64, half_box_len::Float64)
|
||||||
φ = (x + half_box_len) * π / half_box_len
|
φ = (x + half_box_len) * π / half_box_len
|
||||||
si, co = sincos(φ)
|
si, co = sincos(φ)
|
||||||
|
@ -65,4 +71,6 @@ end
|
||||||
function gyration_tensor_eigvals_ratio(particles::Vector{Particle}, half_box_len::Float64)
|
function gyration_tensor_eigvals_ratio(particles::Vector{Particle}, half_box_len::Float64)
|
||||||
ev = eigvals(gyration_tensor(particles, half_box_len)) # Eigenvalues are sorted
|
ev = eigvals(gyration_tensor(particles, half_box_len)) # Eigenvalues are sorted
|
||||||
return ev[1] / ev[2]
|
return ev[1] / ev[2]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end # module
|
|
@ -1,5 +1,4 @@
|
||||||
using CairoMakie, LaTeXStrings
|
using CairoMakie, LaTeXStrings
|
||||||
using StaticArrays
|
|
||||||
using LoopVectorization: @turbo
|
using LoopVectorization: @turbo
|
||||||
|
|
||||||
using ReCo: minimum_image
|
using ReCo: minimum_image
|
||||||
|
|
|
@ -1,8 +1,3 @@
|
||||||
using StaticArrays: SVector
|
|
||||||
using JLD2: JLD2
|
|
||||||
using JSON3: JSON3
|
|
||||||
using OrderedCollections: OrderedDict
|
|
||||||
|
|
||||||
struct Bundle
|
struct Bundle
|
||||||
t::Vector{Float64}
|
t::Vector{Float64}
|
||||||
c::Matrix{SVector{2,Float64}}
|
c::Matrix{SVector{2,Float64}}
|
||||||
|
|
|
@ -1,8 +1,3 @@
|
||||||
using Random: Random
|
|
||||||
using JSON3: JSON3
|
|
||||||
using JLD2: JLD2
|
|
||||||
using StaticArrays: SVector
|
|
||||||
|
|
||||||
empty_hook(args...) = nothing
|
empty_hook(args...) = nothing
|
||||||
|
|
||||||
function run_sim(
|
function run_sim(
|
||||||
|
|
|
@ -1,6 +1,3 @@
|
||||||
using Distributions: Uniform
|
|
||||||
using Dates: now
|
|
||||||
|
|
||||||
const DEFAULT_PACKING_RATIO = 0.5
|
const DEFAULT_PACKING_RATIO = 0.5
|
||||||
const DEFAULT_δt = 1e-5
|
const DEFAULT_δt = 1e-5
|
||||||
const DEFAULT_SKIN_TO_INTERACTION_R_RATIO = 1.5
|
const DEFAULT_SKIN_TO_INTERACTION_R_RATIO = 1.5
|
||||||
|
|
|
@ -1,11 +1,3 @@
|
||||||
using Dates: Dates, now
|
|
||||||
using ProgressMeter: @showprogress
|
|
||||||
using Distributions: Normal
|
|
||||||
using CellListMap: Box, CellList, map_pairwise!, UpdateCellList!
|
|
||||||
using StaticArrays: SVector
|
|
||||||
|
|
||||||
import Base: wait
|
|
||||||
|
|
||||||
rand_normal01() = rand(Normal(0, 1))
|
rand_normal01() = rand(Normal(0, 1))
|
||||||
|
|
||||||
function push_to_verlet_list!(verlet_lists, i, j)
|
function push_to_verlet_list!(verlet_lists, i, j)
|
||||||
|
|
|
@ -38,7 +38,7 @@ using StaticArrays: SVector
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@testset "shape.jl" begin
|
@testset "Shape.jl" begin
|
||||||
n_particles = 10
|
n_particles = 10
|
||||||
v₀ = 0.0
|
v₀ = 0.0
|
||||||
sim_consts = ReCo.gen_sim_consts(n_particles, v₀)
|
sim_consts = ReCo.gen_sim_consts(n_particles, v₀)
|
||||||
|
@ -50,9 +50,9 @@ end
|
||||||
half_box_len = sim_consts.half_box_len
|
half_box_len = sim_consts.half_box_len
|
||||||
|
|
||||||
@testset "project_to_unit_circle" begin
|
@testset "project_to_unit_circle" begin
|
||||||
@test ReCo.project_to_unit_circle(0.0, half_box_len) ≈ SVector(-1.0, 0.0)
|
@test ReCo.Shape.project_to_unit_circle(0.0, half_box_len) ≈ SVector(-1.0, 0.0)
|
||||||
@test ReCo.project_to_unit_circle(half_box_len, half_box_len) ≈
|
@test ReCo.Shape.project_to_unit_circle(half_box_len, half_box_len) ≈
|
||||||
ReCo.project_to_unit_circle(-half_box_len, half_box_len) ≈
|
ReCo.Shape.project_to_unit_circle(-half_box_len, half_box_len) ≈
|
||||||
SVector(1.0, 0.0)
|
SVector(1.0, 0.0)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -61,10 +61,10 @@ end
|
||||||
)
|
)
|
||||||
|
|
||||||
@testset "center_of_mass" begin
|
@testset "center_of_mass" begin
|
||||||
@test ReCo.center_of_mass(particles, half_box_len) ≈ SVector(0.0, 0.0)
|
@test ReCo.Shape.center_of_mass(particles, half_box_len) ≈ SVector(0.0, 0.0)
|
||||||
end
|
end
|
||||||
|
|
||||||
@testset "gyration_tensor" begin
|
@testset "gyration_tensor" begin
|
||||||
@test ReCo.gyration_tensor_eigvals_ratio(particles, half_box_len) == 1.0
|
@test ReCo.Shape.gyration_tensor_eigvals_ratio(particles, half_box_len) == 1.0
|
||||||
end
|
end
|
||||||
end
|
end
|
Loading…
Reference in a new issue