-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathtemplate-config.sh
executable file
·82 lines (64 loc) · 3.26 KB
/
template-config.sh
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
#!/bin/bash
#*********************************************************************************#
# Simulation Configuration Script
#*********************************************************************************#
#
#--------------------------------------- PATH ---------------------------------------------
# absolute or relative paths of corresponding files or directories
template_directory="../run_template/"
exec_location="../1.exec/MF_LBM.cpu"
# if external geometry is used (external_geometry_read_cmd = 1)
geometry_file="placeholder"
# if pre-computed boundary info is used (geometry_preprocess_cmd = 2)
geometry_boundary_info_file="placeholder"
#------------------------ choose Linux or OSX system --------------------------------------
# sed command is slightly different between Linux and OSX.
# Uncomment OSX below if you are using a MAC
# OS="OSX"
# --- Linux
sed_option="-i"
# --- OSX sed -i.bak should be used. One can delete .bak files afterwards
if [[ "$OS" == "OSX" ]]
then
sed_option="-i.bak"
fi
# -------------------------------------- modify path --------------------------------------
# write above paths to path_info.txt
cp $template_directory/template-path_info.txt path_info.txt
sed $sed_option "s|exec_path_holder|$exec_location|" path_info.txt
sed $sed_option "s|geometry_file_path_holder|$geometry_file|" path_info.txt
sed $sed_option "s|geometry_boundary_file_path_holder|$geometry_boundary_info_file|" path_info.txt
cp $template_directory/clean.sh ./
#---------------------- copy and modify the control file template --------------------------
cp $template_directory/template-simulation_control.txt simulation_control.txt
# one can add sed commands here to modify the simulation control file using the script, i.e.,
# nx=240
# ny=240
# nz=260
# sed $sed_option "s|lattice_dimensions .*|lattice_dimensions $nx,$ny,$nz|g" ./simulation_control.txt
# -------------------------- modify interactive run script ----------------------------------
MPI_process_num=2 # MPI_process_num must be equal to mpi_npx * mpi_npy * mpi_npz
# Below is the run command for typical CPU computing node with two NUMAs
run_command="mpirun -n $MPI_process_num --map-by ppr:2:node --bind-to numa $exec_location"
# check out other run commands below for different platforms
################# sample run command #################
# ~~~~~ typical CPU computing nodes with two NUMAs per node
# mpirun -n $MPI_process_num --map-by ppr:2:node --bind-to numa $exec_location
# ~~~~~ consumer-grade desktop or laptop
# mpirun -n $MPI_process_num $exec_location
# ~~~~~ GPU nodes with 4 GPUs per node
# mpirun -n $MPI_process_num --map-by ppr:4:node --bind-to socket $exec_location
# ~~~~~ use srun
# srun -n $MPI_process_num $exec_location
# Intel Xeon Phi 'KNL' node
# export KMP_AFFINITY=noverbose,warnings,respect,granularity=fine,duplicates,scatter,0,0
# mpirun -n $MPI_process_num numactl --membind=1 $exec_location
################# sample run command #################
# Interactive run script. Slurm job scripts can be generated easily based on irun.sh
cp $template_directory/template-irun.sh irun.sh
sed $sed_option "s|run_command|$run_command|" irun.sh
# -------------------------- clean up ----------------------------------
if [[ "$OS" == "OSX" ]]
then
rm *.bak
fi