-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmetaqcd.jl
84 lines (67 loc) · 2.37 KB
/
metaqcd.jl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
using Pkg
Pkg.activate(@__DIR__(); io=devnull)
using MetaQCD.Utils
using MetaQCD: @level1, build_bias, run_sim
function parse_args(args)
parameterfile = args[end]
@assert length(args) >= 2 && isfile(parameterfile) """
An existing parameter file has to be given as the last input, e.g.:
julia metaqcd.jl -mode=sim parameters.toml
You either did not provide a file or the file you provided does not exist.
"""
@assert count(x -> occursin("-mode", x), args) == 1 """
The flag \"-mode\" has to be set before the parameter file.
Options are:
\"-mode=sim\" to run a simulation with or without Metadynamics or
\"-mode=build\" for building a bias potential with possibly multiple walkers
"""
mode = split(args[findfirst(x -> occursin("-mode", x), args)], "=")[2]
backend = try
split(args[findfirst(x -> occursin("-backend", x), args)], "=")[2]
catch _
"cpu"
end
return parameterfile, mode, backend
end
parameterfile, mode, backend = parse_args(ARGS)
@level1 "[ Mode: $(mode)\n"
if backend != "cpu"
@level1 """
If you get prompted to install a package here, make sure you do it in your \
GLOBAL julia environment, i.e., not under a project environment
"""
if backend == "cuda"
using CUDA
elseif backend ∈ ("rocm", "amd")
using AMDGPU
else
throw(ArgumentError(
"""
When a second input is given, it has to specify the backend to be used, \
so the package can be loaded.
Note, that the backend also has to be set in the parameter file.
Supported backends are:
- cpu
- cuda
- rocm
Your input was \"$(backend)\"
"""
))
end
end
mpi_parallel() && @level1("[ $(mpi_size()) MPI processes are being used")
if mode == "sim"
@assert mpi_size() < 10 "At max 9 MPI processes can be used in parallel tempering for now"
run_sim(parameterfile; backend=backend)
elseif mode == "build"
build_bias(parameterfile; backend=backend)
else
throw(ArgumentError(
"""
The supplied \"-mode\" is invalid. The two options are:
\"-mode=sim\" to run a simulation with or without Metadynamics or
\"-mode=build\" for building a bias potential with possibly multiple walkers
Your input was \"$(mode)\"
"""
))
end