forked from etmc/tmLQCD
-
Notifications
You must be signed in to change notification settings - Fork 0
/
README
371 lines (323 loc) · 15.1 KB
/
README
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
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
Here are some remarks collected in order to configure, compile and
install the tmLQCD programme suit. For more information, also about running
the code please read the documentation in the doc sub-directory.
CONFIGURE and COMPILE
It is recommended to build the code not in the source directory but in
a separate directory.
The lime library (tested with version 1.2.3) is needed to compile the
program. Please download it at
http://usqcd.jlab.org/usqcd-software/c-lime/
Configure and compile lime (for documentation see
http://usqcd.jlab.org/usqcd-docs/c-lime/) first.
Then you should use the configure option --with-lime=dir for the
tmLQCD to set the correct directory where to find lime (see below).
For more documentation please change into the doc directory and type
latex main.tex
and see the sections for configuring, installing and testing the code.
Here we have gathered some examples for some standard architectures.
Building the tmLQCD executables is a three step procedure:
****************************************************************************
1) configure:
In your build directory type
path-to-the-sources/configure --help
to get an overview of the available options and switches. In
particular check out the prefix option for your installation path.
What follows now are some examples for a few standard architectures.
- a scalar build on a P4 machine would look like:
path-to-the-sources/configure --disable-mpi --enable-sse2 --enable-p4 \
--enable-gaugecopy --disable-newdiracop --with-limedir=<path-to-lime> \
--with-lapack="<linker options needed for lapack>" \
CC=<cc>
- Opteron with SSE2:
path-to-the-sources/configure --disable-mpi --enable-sse2 --enable-opteron \
--enable-gaugecopy --disable-newdiracop --with-limedir=<path-to-lime> \
--with-lapack="<linker options needed for lapack>" \
CC=<cc>
- A MPI parallel (4dims) build on a P4 cluster:
path-to-the-sources/configure --enable-mpi --enable-sse2 --enable-p4 \
--with-mpidimension=4 --enable-gaugecopy --disable-newdiracop \
--with-limedir=<path-to-lime> --with-lapack="<linker options needed for lapack>" \
CC=<mpicc>
- on the Munich Altix machine:
path-to-the-sources/configure --enable-mpi --with-mpidimension=4 \
--with-limedir=<path-to-lime> --enable-newdiracop \
--disable-shmem --with-lapack="<linker options needed for lapack>" \
CC=mpicc CFLAGS="-mcpu=itanium2 -O3 -g -c99 -mtune=itanium2"
for lapack on this machine please type
module load mkl
- on the HLRB ice installation use
path-to-the-sources/configure --enable-mpi --with-mpidimension=4 \
--disable-sse2 --disable-p4 --with-limedir=<path-to-lime> \
--enable-newdiracop --with-lapack="<linker options needed for lapack>" \
CC="mpicc -std=c99" CFLAGS="-g" \
where it is again important to use the Intel C compiler!
for lapack first load the module mkl and then use
--with-lapack="-L$LIBRARY_PATH -llapack -lblas"
- on Blue Gene installations
For the Blue Gene L and P see the README.bg? files
For BG/Q you can enable QPX intrinsics with --enable-qpx, which will have
effect only with the XLC compiler.
You may enable or disable other configure options as needed. See the
documentation for more details.
****************************************************************************
2) make
type `make` in your build directory.
If there appears no error message during compilation you should end up
with a few executable in the build directory, namely `hmc_tm`,
`invert` and `invert_doublet`.
****************************************************************************
3) make install
type `make install`
to get the executables installed.
****************************************************************************
****************************************************************************
in the following we provide a "codemap", giving a short explanation
for the contents of each c-file:
****************************************************************************
top directory: apart from the main routines all routines are compiled into
the run-time library libhmc.
DML_crc32.c: invert, invert_doublet, hmc_tm
some helper functions to compute the SCIDAC
checksum
D_psi.c: invert, invert_doublet, hmc_tm
Wilson twisted mass Dirac operator, not even/odd
preconditioned
Hopping_Matrix.c: invert, invert_doublet, hmc_tm
Hopping matrix for the even/odd preconditioned
Dirac operator
Hopping_Matrix_nocom.c: benchmark
Hopping matrix for the even/odd preconditioned
Dirac operator, communication switched off
Nondegenerate_Matrix.c: invert_doublet, hmc_tm
operators needed for even/odd preconditioning
the non-degenerate flavour doublet Dirac operator
Ptilde_nd.c: hmc_tm
the more precise polynomial $\tilde P$ needed for
the PHMC for the non-degenerate flavour doublet
benchmark.c: main routine
benchmark code for D_psi and Hopping_Matrix
block.c: experimental
boundary.c: invert, invert_doublet, hmc_tm
implements the twisted boundary conditions for the
spinor fields
chebyshev_polynomial.c: experimental
chebyshev_polynomial_nd.c: hmc_tm
implements the generation of coefficients for the
chebyshev polynomial using the clenshaw recursion
relation
deriv_Sb.c: hmc_tm
the variation of Q=gamma_5 D with respect to the
gauge fields in the even/odd case
deriv_Sb_D_psi.c: hmc_tm
the variation of Q=gamma_5 D with respect to the
gauge fields in the non even/odd case
det_monomial.c: hmc_tm
implements the functions needed for a det monomial
detratio_monomial.c: hmc_tm
implements the functions needed for a detratio monomial
poly_monomial.c: hmc_tm
implements function needed for a POLY monomial
(PHMC for light degenerate quarks)
dml.c: invert, invert_doublet, hmc_tm
some helper functions to compute the SCIDAC
checksum
double2single.c: main routine
can convert a gauge field from double to single precision
single2double.c: main routine
can convert a gauge field from single to double precision
eigenvalues_bi.c: hmc_tm
computes eigenvalues of the mass non-degenerate two flavour
Dirac operatoe
expo.c: hmc_tm
implements the exponetial function of an su(3) element
gamma.c: invert, invert_doublet, hmc_tm
implements multiplication of gamma matrices and some useful
combination of those with a spinor field
gauge_io.c: invert, invert_doublet, hmc_tm
IO routines for gauge fields
gauge_monomial.c: hmc_tm
implements the functions needed for a gauge monomial
gen_sources.c: invert, invert_doublet, hmc_tm
implements the generation of source spinor fields
geometry_eo.c: invert, invert_doublet, hmc_tm
anything related to gauge and spinor field geometry
get_rectangle_staples.c: hmc_tm
computes rectangular staples of gauge links as needed for
e.g. the Iwasaki gauge action and its derivative
get_staples.c: hmc_tm
computes plaquette staples of gauge links as needed for
for all gauge actions and their derivatives
getopt.c: invert, invert_doublet, hmc_tm
needed for command line options
hmc_tm.c: main routine
hmc_tm executable
hybrid_update.c: hmc_tm
implements the functions for the gauge field update and
the momenta update
init_bispinor_field.c
init_chi_copy.c
init_chi_spinor_field.c
init_dirac_halfspinor.c
init_gauge_field.c
init_gauge_tmp.c
init_geometry_indices.c
init_moment_field.c
init_spinor_field.c
init_stout_smear_vars.c: invert, invert_doublet, hmc_tm
provide routines to allocate memory for the corresponding
objects
integrator.c: hmc_tm
implements the routines needed for the integrator in the
MD udpate
invert.c: main routine
invert executable
invert_doublet.c: main routine
invert_doublet executable
invert_doublet_eo.c: invert_doublet
performs an inversion of the flavour doublet operator using
even/odd preconditioning and the CG solver
invert_eo.c: invert
performs an inversion of the Wilson twisted mass Dirac operator
using a solver as specified in the input file. Depending on the
input file even/odd preconditioning is used or not
io.c: invert, invert_doublet, hmc_tm
helper routines: some deprecated IO routines for gauge and spinor
spinor fields, and the routine writing the initial stdout message
of the executables
io_utils.c: invert, invert_doublet, hmc_tm
IO helper routines related to swap endian and checksums
linsolve.c: hmc_tm
CG and bicgstab solvers as used only in the HMC
little_D.c: experimental
measure_rectangles.c: hmc_tm
computes the gauge action related to the rectangular part
monomial.c: hmc_tm
provides the definition for monomials and initialisation functions
mpi_init.c: invert, invert_doublet, hmc_tm, benchmark
MPI initialisation routine
ndpoly_monomial.c: hmc_tm
implements the functions needed for a ndpoly monomial
observables.c: hmc_tm, invert, invert_doublet
computes the gauge action related to the Wilson plaquette part
online_measurement.c: hmc_tm
anything related to online measurements
phmc.c hmc_tm
functions and variables as needed for the PHC
polyakov_loop.c: hmc_tm
measures the polyakov loop
propagator_io.c: invert, invert_doublet, hmc_tm
functions related to spinor field IO
ranlxd.c: invert, invert_doublet, hmc_tm
RANLUX random number generator (64 Bit)
ranlxs.c: invert, invert_doublet, hmc_tm
RANLUX random number generator (32 Bit)
read_input.l: invert, invert_doublet, hmc_tm
definition of the input file parser (flex)
reweighting_factor.c: experimental
reweighting_factor_nd.c: experimental
sighandler.c: invert, invert_doublet, hmc_tm
handles signal related to illegal instructions
start.c: invert, invert_doublet, hmc_tm
functions needed to give initial values to gauge and spinor fields
stout_smear.c: invert, invert_doublet
functions to stout smear a given gauge configuration
stout_smear_force.c: experimental
tm_operators.c: invert, invert_doublet, hmc_tm
operators needed for even/odd preconditioning the Wilson
twisted mass Dirac operator
update_backward_gauge.c: invert, invert_doublet, hmc_tm
functions to update the gauge copy
update_momenta.c: hmc_tm
function to update the momenta in the HMC MD part
update_tm.c: hmc_tm
the HMC MD part
xchange_2fields.c: invert, invert_doublet, hmc_tm
implements the MPI communication of two even/odd spinor fields
at once
xchange_deri.c: hmc_tm
implements the MPI communication of derivatives
xchange_field.c: invert, invert_doublet, hmc_tm
implements the MPI communication of a single even/odd spinor
field
xchange_gauge.c: invert, invert_doublet, hmc_tm
implements the MPI communication of the gauge field
xchange_halffield.c: invert, invert_doublet, hmc_tm
implements the MPI communication of a half spinor field
xchange_lexicfield.c: invert, invert_doublet, hmc_tm
implements the MPI communication of a single (full) spinor
field
****************************************************************************
the linalg directory: all routines here are compiled into the liblinalg
runtime library
capital letters are spinor fields, others scalars
add.c: Q = R + S
assign.c: R = S
assign_add_mul.c: P = P + c Q with c complex
assign_add_mul_r.c: P = P + c Q with c real
assign_add_mul_add_mul.c: R = R + c1*S + c2*U with c1 and c2 complex variables
assign_add_mul_add_mul_r.c: R = R + c1*S + c2*U with c1 and c2 real variables
assign_diff_mul.c: S=S-c*Q
assign_mul_add_mul_add_mul_add_mul_r.c: R = c1*R + c2*S + c3*U + c4*V
with c1, c2, c3, c4 real variables
assign_mul_add_mul_add_mul_r.c: R = c1*R + c2*S + c3*U
with c1, c2 and c3 real variables
assign_mul_add_mul_r.c: R = c1*R + c2*S , c1 and c2 are real constants
assign_mul_add_r.c: R = c*R + S c is a real constant
assign_mul_bra_add_mul_ket_add.c: R = c2*(R + c1*S) + (*U)
with c1 and c2 complex variables
assign_mul_bra_add_mul_ket_add_r.c: R = c2*(R + c1*S) + (*U)
with c1 and c2 complex variables
assign_mul_bra_add_mul_r.c: R = c1*(R + c2*S)
with c1 and c2 complex variables
comp_decomp.c: Splits the Bi-spinor R in the spinors S and T
convert_eo_to_lexic.c: convert to even odd spinors to one full spinor
diff.c: Q = R - S
diff_and_square_norm.c: Q = R - S and ||Q||^2
mattimesvec.c: w = M*v for complex vectors w,v and and complex square matrix M
mul.c: R = c*S, for complex c
mul_r.c: R = c*S, for real c
mul_add_mul.c: R = c1*S + c2*U , c1 and c2 are complex constants
mul_add_mul_r.c R = c1*S + c2*U , c1 and c2 are real constants
mul_diff_mul.c: R = c1*S - c2*U , c1 and c2 are complex constants
mul_diff_mul_r.c R = c1*S - c2*U , c1 and c2 are real constants
mul_diff_r.c R = c1*S - U , c1 is a real constant
scalar_prod.c: c = (R, S)
scalar_prod_i.c: c = Im(R, S)
scalar_prod_r.c: c = Re(R, S)
square_and_prod_r.c: Returns Re(R,S) and the square norm of S
square_norm.c: c = ||Q||^2
****************************************************************************
solver directory: all routines here are compiled into the libsolver
runtime library
the solvers are for spinor fields, if not indicated
otherwise.
Msap.c: experimental SAP preconditioner
bicgstab_complex.c: BiCGstab for complex fields
bicgstabell.c: experimental
cg_her.c : CG solver for hermitian operators
cg_her_nd.c: CG solver for hermitian heavy doublet operators
cgs_real.c: CGS solver
chrono_guess.c: routines for the chronological solver
dfl_projector.c: experimental
diagonalise_general_matrix.c: subroutine to diagonalise a complex n times n
matrix. Input is a complex matrix in _C_ like
order. Output is again _C_ like. Uses lapack
eigenvalues.c compute the nr_of_eigenvalues lowest eigenvalues
of (gamma5*D)^2
fgmres.c: FGMRES (flexible GMRES) solver
gcr.c: GCR solver
gcr4complex.c: GCR solver for complex fields
generate_dfl_subspace.c: experimental
gmres.c: GMRES solver
gmres_dr.c: GMRES-DR solver
gmres_precon.c: GMRES usable for preconditioning other solvers (experimental)
gram-schmidt.c: Gram-Schmidt orthonormalisation routines
jdher.c: Jacobi Davidson for hermitian matrices (to compute EVs)
lu_solve.c: compute the inverse of a matrix with LU decomposition
mr.c: MR solver
pcg_her.c: PCG solver
poly_precon.c: polynomial preconditioner using Chebysheff polynomials
with complex argument
quicksort.c: a quicksort routine
sub_low_ev.c: routines to subtract exactly computed eigenvectors from
a given spinor field