-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlya_signal.slurm
executable file
·221 lines (177 loc) · 8.77 KB
/
lya_signal.slurm
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
#!/bin/csh
##################### DOCUMENTATION #####################
### Shell script for running the C++ encore NPCF-estimator function on a data and data-random catalog, then combining the outputs, including edge-correction (Oliver Philcox, 2021).
#
# This can be run either from the terminal or as a SLURM script (using the below parameters).
# The code should be compiled (with the relevant options, i.e. N-bins, ell-max and 4PCF/5PCF/6PCF) before this script is run. The isotropic 2PCF and 3PCF will always be computed.
# The script should be run from the code directory
# This is adapted from a similar script by Daniel Eisenstein.
# In the input directory, we expect compressed .gz files labelled {root}.data.gz, {ranroot}.ran.{IJ}.gz where {root} is a user-set name, and {IJ} indexes the random catalogs, from 0 - 31.
# We expect the summed weights to be the same for the data and each random catalog, but the random weights should be negative
# This script will compute the D^N counts, the (D-R)^N counts for 32 random subsets, and the R^N counts for one subset (should be sufficient).
# If the connected flag is set (and -DDISCONNECTED added to the makefile) we compute also the Gaussian contribution to the 4PCF.
# The output will be a set of .zeta_{N}pcf.txt files in the specified directory as well as a .tgz compressed directory of other intermediary outputs
# It is important to check the errlog file in the output directory to make sure all went well!
# Note that performing edge-correction is slow for the 5PCF and 6PCF since 9j symbols must be computed. Furthermore, the output multipoles are only accurate up to (ORDER-1), i.e. to compute an accurate edge-corrected spectrum with ell=5, we must compute (D-R) and R counts up to ell=6.
#
# NB: If needed, we could access a task ID by SLURM_ARRAY_TASK_ID, if we're running with SLURM
##########################################################
#SBATCH --ntasks-per-node=1
#SBATCH --nodes=8 # tasks
#SBATCH -p short-28core
#SBATCH -o /gpfs/home/padari/encore/logs/lya.%A.out # File to which STDOUT will be written (make sure the directory exists!)
#SBATCH -e /gpfs/home/padari/encore/logs/lya.%A.err # File to which STDERR will be written
#SBATCH --mail-type=END,FAIL # Type of email notification
#SBATCH [email protected] # Email to which notifications will be sent
#SBATCH --job-name=signal-encore
##################### INPUT PARAMETERS ###################
# Main inputs
set useAVX = 0 # whether we have AVX support
set periodic = 0 # whether to run with periodic boundary conditions (should also be set in Makefile)
set connected = 0 # if true, remove the disconnected (Gaussian) 4PCF contributions (need to set -DDISCONNECTED in the Makefile for this)
set rmin = 10 # minimum radius in Mpc/h
set rmax = 160 # maximum radius in Mpc/h
# Other inputs
set scale = 1 # rescaling for co-ordinates
set ngrid = 50 # grid-size for accelerating pair count
set boxsize = 1000 # only used if periodic=1
# File directories
set root = sig # root for data filenames
set ranroot = ran # root for random filenames
# set anzepath = /gpfs/home/padari/anze_encore/
set anzepath = /Users/pecom/Documents/Research/BNL/4pcf/data/anze_encore
set in = $anzepath/data/signal
set out = $anzepath/output/signal
set tmp = $anzepath/sig_scratch
# set tmp = /gpfs/scratch/padari/encoreout # temporary directory for intermediate file storage for this run (ideally somewhere with fast I/O)
# set tmp = /Users/pecom/Documents/Research/BNL/4pcf/data/anze_encore/tmpout
# module load anaconda/3
##########################################################
# Define output coupling file (to avoid recomputation of disconnected pieces if multiple aperiodic simulations are run)
set RRR_coupling = $out/$ranroot.RRR_coupling.npy
# Set number of threads (no SLURM)
set OMP_NUM_THREADS = 4
# Set number of threads (with SLURM)
# set OMP_NUM_THREADS = $SLURM_NPROCS
# Define command to run the C++ code
if ($useAVX) then
set code = ./encoreAVX
else
set code = ./encore
endif
if ($periodic) then
set command = "$code -rmax $rmax -rmin $rmin -ngrid $ngrid -scale $scale -boxsize $boxsize"
else
# set command = "$code -rmax $rmax -rmin $rmin -ngrid $ngrid -scale $scale"
set command = "$code -rmax $rmax -rmin $rmin"
endif
# Create a temporary directory for saving
/bin/rm -rf $tmp # Delete, just in case we have crud from a previous run.
mkdir $tmp
#cd /gpfs/home/padari/encore
cd $anzepath
# Copy this script in for posterity
# cp run_npcf.csh $tmp
# Create output directory
if (!(-e $out)) then
mkdir $out
endif
# Create an output file for errors
set errfile = errlog
set errlog = $out/$errfile
set tmpout = $tmp
rm -f $errlog
date > $errlog
echo Executing $0 >> $errlog
echo $command >> $errlog
echo "HERE ARE THE NUMBER OF THREADS" >> $errlog
echo $OMP_NUM_THREADS >> $errlog
# Filename for saved multipoles (a big file)
set multfile = $tmp/$root.mult
# Extra the data into our temporary ramdisk
gunzip -c $in/$root.data.gz > $tmp/$root.data
# Find number of galaxies (needed later for R^N periodic counts)
set Ngal = `cat $tmp/$root.data | wc -l`
set Ngal = `expr $Ngal + 1`
#### Compute D^N NPCF counts
# Note that we save the a_lm multipoles from the data here
echo Starting Computation
echo "Starting D^N" >> $errlog
date >> $errlog
($command -in $tmp/$root.data -save $multfile -outstr $root.data > $tmpout/$root.d.out) >> $errlog
echo "output dir" >> $errlog
ls ./output >> $errlog
# Remove the output - we don't use it
rm ./output/$root.data_?pc*.txt
echo "Done with D^N"
echo "Done with D^N" >> $errlog
### Compute R^N NPCF counts
# We just use one R catalog for this and invert it such that the galaxies are positively weighted
gunzip -c $in/$ranroot.ran.00.gz > $tmp/$root.ran.00
echo "Starting R^N" >> $errlog
date >> $errlog
($command -in $tmp/$root.ran.00 -outstr $root.r -invert > $tmpout/$root.r.out) >> $errlog
# Copy the output into the temporary directory
mv ./output/$root.r_?pc*.txt $tmpout/
echo "Done with R^N"
echo "Done with R^N" >> $errlog
# Now make D-R for each of 32 random catalogs, with loading
# foreach n ( 00 01 02 03 04 05 06 07 08 09 \
# 10 11 12 13 14 15 16 17 18 19 \
# 20 21 22 23 24 25 26 27 28 29 \
# 30 31 )
foreach n (00)
# First copy the randoms and add the data
/bin/cp -f $tmp/$root.data $tmp/$root.ran.$n
gunzip -c $in/$ranroot.ran.$n.gz >> $tmp/$root.ran.$n
### Compute the (D-R)^N counts
# This uses the loaded data multipoles from the D^N step
# Note that we balance the weights here to ensure that Sum(D-R) = 0 exactly
echo "Starting D-R $n" >> $errlog
date >> $errlog
# ($command -in $tmp/$root.ran.$n -load $multfile -outstr $root.n$n -balance > $tmpout/$root.n$n.out) >> $errlog
($command -in $tmp/$root.ran.$n -load $multfile -outstr $root.n$n > $tmpout/$root.n$n.out) >> $errlog
ls output/ >> $errlog
# Copy the output into the temporary directory
mv output/$root.n${n}_?pc*.txt $tmpout/
# Remove the random catalog
/bin/rm -f $tmp/$root.ran.$n
echo Done with D-R $n
end # foreach D-R loop
### Now need to combine the files to get the full NPCF estimate
# We do this in Python, and perform edge-correction unless the periodic flag is not set
if ($periodic) then
echo Combining files together without performing edge-corrections (using analytic R^N counts)
python3 python/combine_files_periodic.py $tmpout/$root $Ngal $boxsize $rmin $rmax >> $errlog
else
echo Combining files together and performing edge-corrections
python3 python/combine_files.py $tmpout/$root >> $errlog $OMP_NUM_THREADS
endif
### If the connected flag is set, also combine files to estimate the disconnected 4PCF
# We perform edge corrections unless the periodic flag is not set.
# If the file RRR_coupling exists we load the edge-correction matrix from file, else it is recomputed
if ($connected) then
if ($periodic) then
echo Combining files together to compute the disconnected 4PCF without performing edge corrections
python3 python/combine_disconnected_files_periodic.py $tmpout/$root 4 $Ngal $boxsize $rmin $rmax >> $errlog
else
echo Combining files together to compute the disconnected 4PCF including edge corrections
python3 python/combine_disconnected_files.py $tmpout/$root 4 $RRR_coupling >> $errlog
endif
endif
# Do some cleanup
rm $tmp/$root.data $multfile
# Now move the output files into the output directory.
# Compress all the auxilliary files and copy
echo Finished with computation. Placing results into $out/
echo Finished with computation. Placing results into $out/ >> $errlog
date >> $errlog
pushd $tmpout > /dev/null
echo >> $errlog
/bin/ls -l >> $errlog
/bin/cp $errlog .
tar cfz $root.tgz $root.*.out $root.*pc*.txt $errfile
popd > /dev/null
/bin/mv $tmpout/$root.tgz $tmpout/$root.zeta_*pcf.txt $out/
# Destroy ramdisk
# /bin/rm -rf $tmp