QUDA  v0.7.0
A library for QCD on GPUs
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
enum_quda_fortran.h
Go to the documentation of this file.
1 #/*
2 # enum_quda_fortran.h
3 #
4 # This is Fortran version of enum_quda.h. This is currently
5 # generated by hand, and so must be matched against an appropriate
6 # version of QUDA. It would be nice to auto-generate this from
7 # enum_quda.h and this should probably use Fortran enumerate types
8 # instead (this requires Fortran 2003, but this is covered by
9 # gfortran).
10 #*/
11 
12 #ifndef _ENUM_FORTRAN_QUDA_H
13 #define _ENUM_FORTRAN_QUDA_H
14 
15 #/* can't include limits.h in a Fortran program */
16 #define QUDA_INVALID_ENUM (-2147483647 - 1)
17 
18 #define QudaLinkType integer(4)
19 
20 #define QUDA_SU3_LINKS 0
21 #define QUDA_GENERAL_LINKS 1
22 #define QUDA_THREE_LINKS 2
23 #define QUDA_MOMENTUM 3
24 #define QUDA_WILSON_LINKS QUDA_SU3_LINKS
25 #define QUDA_ASQTAD_FAT_LINKS QUDA_GENERAL_LINKS
26 #define QUDA_ASQTAD_LONG_LINKS QUDA_THREE_LINKS
27 #define QUDA_ASQTAD_MOM_LINKS QUDA_MOMENTUM
28 #define QUDA_ASQTAD_GENERAL_LINKS QUDA_GENERAL_LINKS
29 #define QUDA_INVALID_LINKS QUDA_INVALID_ENUM
30 
31 #define QudaGaugeFieldOrder integer(4)
32 #define QUDA_FLOAT_GAUGE_ORDER 1
33 #define QUDA_FLOAT2_GAUGE_ORDER 2 //no reconstruct and double precision
34 #define QUDA_FLOAT4_GAUGE_ORDER 4 //8 and 12 reconstruct half and single
35 #define QUDA_QDP_GAUGE_ORDER 5 //expect *gauge[4] even-odd spacetime row-column color
36 #define QUDA_QDPJIT_GAUGE_ORDER 6 //expect *gauge[4] even-odd spacetime row-column color
37 #define QUDA_CPS_WILSON_GAUGE_ORDER 7 //expect *gauge even-odd spacetime column-row color
38 #define QUDA_MILC_GAUGE_ORDER 8 //expect *gauge even-odd mu spacetime row-column order
39 #define QUDA_BQCD_GAUGE_ORDER 9 //expect *gauge mu even-odd spacetime+halos row-column order
40 #define QUDA_TIFR_GAUGE_ORDER 10
41 #define QUDA_INVALID_GAUGE_ORDER QUDA_INVALID_ENUM
42 
43 #define QudaTboundary integer(4)
44 #define QUDA_ANTI_PERIODIC_T -1
45 #define QUDA_PERIODIC_T 1
46 #define QUDA_INVALID_T_BOUNDARY QUDA_INVALID_ENUM
47 
48 #define QudaPrecision integer(4)
49 #define QUDA_HALF_PRECISION 2
50 #define QUDA_SINGLE_PRECISION 4
51 #define QUDA_DOUBLE_PRECISION 8
52 #define QUDA_INVALID_PRECISION QUDA_INVALID_ENUM
53 
54 #define QudaReconstructType integer(4)
55 #define QUDA_RECONSTRUCT_NO 18
56 #define QUDA_RECONSTRUCT_12 12
57 #define QUDA_RECONSTRUCT_8 8
58 #define QUDA_RECONSTRUCT_13 13
59 #define QUDA_RECONSTRUCT_9 9
60 #define QUDA_RECONSTRUCT_10 10
61 #define QUDA_RECONSTRUCT_INVALID QUDA_INVALID_ENUM
62 
63 #define QudaGaugeFixed integer(4)
64 #define QUDA_GAUGE_FIXED_NO 0
65 #define QUDA_GAUGE_FIXED_YES 1 // gauge field stored in temporal gauge
66 #define QUDA_GAUGE_FIXED_INVALID QUDA_INVALID_ENUM
67 
68 ! Types used in QudaInvertParam
69 
70 #define QudaDslashType integer(4)
71 #define QUDA_WILSON_DSLASH 0
72 #define QUDA_CLOVER_WILSON_DSLASH 1
73 #define QUDA_DOMAIN_WALL_DSLASH 2
74 #define QUDA_DOMAIN_WALL_4D_DSLASH 3
75 #define QUDA_MOBIUS_DWF_DSLASH 4
76 #define QUDA_STAGGERED_DSLASH 5
77 #define QUDA_ASQTAD_DSLASH 7
78 #define QUDA_TWISTED_MASS_DSLASH 7
79 #define QUDA_TWISTED_CLOVER_DSLASH 8
80 #define QUDA_INVALID_DSLASH QUDA_INVALID_ENUM
81 
82 #define QudaDslashPolicy integer(4)
83 #define QUDA_DSLASH 0
84 #define QUDA_DSLASH2 1
85 #define QUDA_PTHREADS_DSLASH 2
86 #define QUDA_GPU_COMMS_DSLASH 3
87 #define QUDA_FUSED_DSLASH 4
88 #define QUDA_FUSED_GPU_COMMS_DSLASH 5
89 #define QUDA_DSLASH_NC 6
90 
91 #define QudaInverterType integer(4)
92 #define QUDA_CG_INVERTER 0
93 #define QUDA_BICGSTAB_INVERTER 1
94 #define QUDA_GCR_INVERTER 2
95 #define QUDA_MR_INVERTER 3
96 #define QUDA_MPBICGSTAB_INVERTER 4
97 #define QUDA_SD_INVERTER 5
98 #define QUDA_XSD_INVERTER 6
99 #define QUDA_PCG_INVERTER 7
100 #define QUDA_MPCG_INVERTER 8
101 #define QUDA_EIGCG_INVERTER 9
102 #define QUDA_INC_EIGCG_INVERTER 10
103 #define QUDA_INVALID_INVERTER QUDA_INVALID_ENUM
104 
105 #define QudaEigType integer(4)
106 #define QUDA_LANCZOS 0 //Normal Lanczos eigen solver
107 #define QUDA_IMP_RST_LANCZOS 1 //implicit restarted lanczos solver
108 #define QUDA_INVALID_TYPE QUDA_INVALID_ENUM
109 
110 #define QudaSolutionType integer(4)
111 #define QUDA_MAT_SOLUTION 0
112 #define QUDA_MATDAG_MAT_SOLUTION 1
113 #define QUDA_MATPC_SOLUTION 2
114 #define QUDA_MATPC_DAG_SOLUTION 3
115 #define QUDA_MATPCDAG_MATPC_SOLUTION 4
116 #define QUDA_MATPCDAG_MATPC_SHIFT_SOLUTION 5
117 #define QUDA_INVALID_SOLUTION QUDA_INVALID_ENUM
118 
119 #define QudaSolveType integer(4)
120 #define QUDA_DIRECT_SOLVE 0
121 #define QUDA_NORMOP_SOLVE 1
122 #define QUDA_DIRECT_PC_SOLVE 2
123 #define QUDA_NORMOP_PC_SOLVE 3
124 #define QUDA_NORMERR_SOLVE 4
125 #define QUDA_NORMERR_PC_SOLVE 5
126 #define QUDA_NORMEQ_SOLVE QUDA_NORMOP_SOLVE // deprecated
127 #define QUDA_NORMEQ_PC_SOLVE QUDA_NORMOP_PC_SOLVE // deprecated
128 #define QUDA_INVALID_SOLVE QUDA_INVALID_ENUM
129 
130 #define QudaSchwarzType integer(4)
131 #define QUDA_ADDITIVE_SCHWARZ 0
132 #define QUDA_MULTIPLICATIVE_SCHWARZ 1
133 #define QUDA_INVALID_SCHWARZ QUDA_INVALID_ENUM
134 
135 #define QudaResidualType integer(4)
136 #define QUDA_L2_RELATIVE_RESIDUAL 1
137 #define QUDA_L2_ABSOLUTE_RESIDUAL 2
138 #define QUDA_HEAVY_QUARK_RESIDUAL 4
139 #define QUDA_INVALID_RESIDUAL QUDA_INVALID_ENUM
140 
141 #/*
142  # Whether the preconditioned matrix is (1-k^2 Deo Doe) or (1-k^2 Doe Deo)
143  #
144  # For the clover-improved Wilson Dirac operator QUDA_MATPC_EVEN_EVEN
145  # defaults to the "symmetric" form (1 - k^2 A_ee^-1 D_eo A_oo^-1 D_oe)
146  # and likewise for QUDA_MATPC_ODD_ODD.
147  #
148  # For the "asymmetric" form (A_ee - k^2 D_eo A_oo^-1 D_oe) select
149  # QUDA_MATPC_EVEN_EVEN_ASYMMETRIC.
150  # */
151 
152 #define QudaMatPCType integer(4)
153 #define QUDA_MATPC_EVEN_EVEN 0
154 #define QUDA_MATPC_ODD_ODD 1
155 #define QUDA_MATPC_EVEN_EVEN_ASYMMETRIC 2
156 #define QUDA_MATPC_ODD_ODD_ASYMMETRIC 3
157 #define QUDA_MATPC_INVALID QUDA_INVALID_ENUM
158 
159 #define QudaDagType integer(4)
160 #define QUDA_DAG_NO 0
161 #define QUDA_DAG_YES 1
162 #define QUDA_DAG_INVALID QUDA_INVALID_ENUM
163 
164 #define QudaMassNormalization integer(4)
165 #define QUDA_KAPPA_NORMALIZATION 0
166 #define QUDA_MASS_NORMALIZATION 1
167 #define QUDA_ASYMMETRIC_MASS_NORMALIZATION 2
168 #define QUDA_INVALID_NORMALIZATION QUDA_INVALID_ENUM
169 
170 #define QudaSolverNormalization integer(4)
171 #define QUDA_DEFAULT_NORMALIZATION 0 // leave source and solution untouched
172 #define QUDA_SOURCE_NORMALIZATION 1 // normalize such that || src || = 1
173 
174 #define QudaPreserveSource integer(4)
175 #define QUDA_PRESERVE_SOURCE_NO 0 // use the source for the residual
176 #define QUDA_PRESERVE_SOURCE_YES 1
177 #define QUDA_PRESERVE_SOURCE_INVALID QUDA_INVALID_ENUM
178 
179 #define QudaDiracFieldOrder integer(4)
180 #define QUDA_INTERNAL_DIRAC_ORDER 0 // internal dirac order used by QUDA varies depending on precision and dslash type
181 #define QUDA_DIRAC_ORDER 1
182 #define QUDA_QDP_DIRAC_ORDER 2 // even-odd spin inside color
183 #define QUDA_QDPJIT_DIRAC_ORDER 3 // even-odd spin inside color
184 #define QUDA_CPS_WILSON_DIRAC_ORDER 4// odd-even color inside spin
185 #define QUDA_LEX_DIRAC_ORDER 5 // lexicographical order color inside spin
186 #define QUDA_INVALID_DIRAC_ORDER QUDA_INVALID_ENUM
187 
188 #define QudaCloverFieldOrder integer(4)
189 #define QUDA_FLOAT_CLOVER_ORDER 1 // even-odd float ordering
190 #define QUDA_FLOAT2_CLOVER_ORDER 2 // even-odd float2 ordering
191 #define QUDA_FLOAT4_CLOVER_ORDER 4 // even-odd float4 ordering
192 #define QUDA_PACKED_CLOVER_ORDER 5 // even-odd packed
193 #define QUDA_QDPJIT_CLOVER_ORDER 6 // lexicographical order packed
194 #define QUDA_BQCD_CLOVER_ORDER 7 // BQCD order which is a packed super-diagonal form
195 #define QUDA_INVALID_CLOVER_ORDER QUDA_INVALID_ENUM
196 
197 #define QudaVerbosity integer(4)
198 #define QUDA_SILENT 0
199 #define QUDA_SUMMARIZE 1
200 #define QUDA_VERBOSE 2
201 #define QUDA_DEBUG_VERBOSE 3
202 #define QUDA_INVALID_VERBOSITY QUDA_INVALID_ENUM
203 
204 #define QudaTune integer(4)
205 #define QUDA_TUNE_NO 0
206 #define QUDA_TUNE_YES 1
207 #define QUDA_TUNE_INVALID QUDA_INVALID_ENUM
208 
209 #define QudaPreserveDirac integer(4)
210 #define QUDA_PRESERVE_DIRAC_NO 0
211 #define QUDA_PRESERVE_DIRAC_YES 1
212 #define QUDA_PRESERVE_DIRAC_INVALID QUDA_INVALID_ENUM
213 
214 ! Type used for "parity" argument to dslashQuda()
215 
216 #define QudaParity integer(4)
217 #define QUDA_EVEN_PARITY 0
218 #define QUDA_ODD_PARITY 1
219 #define QUDA_INVALID_PARITY QUDA_INVALID_ENUM
220 
221 ! Types used only internally
222 
223 #define QudaDiracType integer(4)
224 #define QUDA_WILSON_DIRAC 0
225 #define QUDA_WILSONPC_DIRAC 1
226 #define QUDA_CLOVER_DIRAC 2
227 #define QUDA_CLOVERPC_DIRAC 3
228 #define QUDA_DOMAIN_WALL_DIRAC 4
229 #define QUDA_DOMAIN_WALLPC_DIRAC 5
230 #define QUDA_DOMAIN_WALL_4DPC_DIRAC 6
231 #define QUDA_MOBIUS_DOMAIN_WALLPC_DIRAC 7
232 #define QUDA_STAGGERED_DIRAC 8
233 #define QUDA_STAGGEREDPC_DIRAC 9
234 #define QUDA_ASQTAD_DIRAC 10
235 #define QUDA_ASQTADPC_DIRAC 11
236 #define QUDA_TWISTED_MASS_DIRAC 12
237 #define QUDA_TWISTED_MASSPC_DIRAC 13
238 #define QUDA_TWISTED_CLOVER_DIRAC 14
239 #define QUDA_TWISTED_CLOVERPC_DIRAC 15
240 #define QUDA_INVALID_DIRAC QUDA_INVALID_ENUM
241 
242 ! Where the field is stored
243 #define QudaFieldLocation integer(4)
244 #define QUDA_CPU_FIELD_LOCATION 1
245 #define QUDA_CUDA_FIELD_LOCATION 2
246 #define QUDA_INVALID_FIELD_LOCATION QUDA_INVALID_ENUM
247 
248 ! Which sites are included
249 #define QudaSiteSubset integer(4)
250 #define QUDA_FULL_SITE_SUBSET 0
251 #define QUDA_PARITY_SITE_SUBSET 1
252 #define QUDA_INVALID_SITE_SUBSET QUDA_INVALID_ENUM
253 
254 ! Site ordering (always t-z-y-x with rightmost varying fastest)
255 #define QudaSiteOrder integer(4)
256 #define QUDA_LEXICOGRAPHIC_SITE_ORDER 0 // lexicographic ordering
257 #define QUDA_EVEN_ODD_SITE_ORDER 1 // QUDA and QDP use this
258 #define QUDA_ODD_EVEN_SITE_ORDER 2 // CPS uses this
259 #define QUDA_INVALID_SITE_ORDER QUDA_INVALID_ENUM
260 
261 ! Degree of freedom ordering
262 #define QudaFieldOrder integer(4)
263 #define QUDA_FLOAT_FIELD_ORDER 1 // spin-color-complex-space
264 #define QUDA_FLOAT2_FIELD_ORDER 2 // (spin-color-complex)/2-space-(spin-color-complex)%2
265 #define QUDA_FLOAT4_FIELD_ORDER 4 // (spin-color-complex)/4-space-(spin-color-complex)%4
266 #define QUDA_SPACE_SPIN_COLOR_FIELD_ORDER 5 // CPS/QDP++ ordering
267 #define QUDA_SPACE_COLOR_SPIN_FIELD_ORDER 6 // QLA ordering (spin inside color)
268 #define QUDA_QDPJIT_FIELD_ORDER 7 // QDP field ordering (complex-color-spin-spacetime)
269 #define QUDA_QOP_DOMAIN_WALL_FIELD_ORDER 8 // QOP domain-wall ordering
270 #define QUDA_INVALID_FIELD_ORDER QUDA_INVALID_ENUM
271 
272 #define QudaFieldCreate integer(4)
273 #define QUDA_NULL_FIELD_CREATE 0 // create new field
274 #define QUDA_ZERO_FIELD_CREATE 1 // create new field and zero it
275 #define QUDA_COPY_FIELD_CREATE 2 // create copy to field
276 #define QUDA_REFERENCE_FIELD_CREATE 3 // create reference to field
277 #define QUDA_INVALID_FIELD_CREATE QUDA_INVALID_ENUM
278 
279 #define QudaGammaBasis integer(4)
280 #define QUDA_DEGRAND_ROSSI_GAMMA_BASIS 0
281 #define QUDA_UKQCD_GAMMA_BASIS 1
282 #define QUDA_CHIRAL_GAMMA_BASIS 2
283 #define QUDA_INVALID_GAMMA_BASIS QUDA_INVALID_ENUM
284 
285 #define QudaSourceType integer(4)
286 #define QUDA_POINT_SOURCE 0
287 #define QUDA_RANDOM_SOURCE 1
288 #define QUDA_INVALID_SOURCE QUDA_INVALID_ENUM
289 
290 #define QudaDWFPCType
291 #define QUDA_5D_PC 0
292 #define QUDA_4D_PC 1
293 #define QUDA_PC_INVALID QUDA_INVALID_ENUM
294 
295 #define QudaTwistFlavorType integer(4)
296 #define QUDA_TWIST_MINUS -1
297 #define QUDA_TWIST_PLUS +1
298 #define QUDA_TWIST_NONDEG_DOUBLET +2
299 #define QUDA_TWIST_DEG_DOUBLET -2
300 #define QUDA_TWIST_NO 0
301 #define QUDA_TWIST_INVALID QUDA_INVALID_ENUM
302 
303 #define QudaTwistDslashType integer(4)
304 #define QUDA_DEG_TWIST_INV_DSLASH 0
305 #define QUDA_DEG_DSLASH_TWIST_INV 1
306 #define QUDA_DEG_DSLASH_TWIST_XPAY 2
307 #define QUDA_NONDEG_DSLASH 3
308 #define QUDA_DSLASH_INVALID QUDA_INVALID_ENUM
309 
310 #define QudaTwistCloverDslashType
311 #define QUDA_DEG_CLOVER_TWIST_INV_DSLASH 0
312 #define QUDA_DEG_DSLASH_CLOVER_TWIST_INV 1
313 #define QUDA_DEG_DSLASH_CLOVER_TWIST_XPAY 2
314 #define QUDA_TC_DSLASH_INVALID QUDA_INVALID_ENUM
315 
316 #define QudaTwistGamma5Type integer(4)
317 #define QUDA_TWIST_GAMMA5_DIRECT 0
318 #define QUDA_TWIST_GAMMA5_INVERSE 1
319 #define QUDA_TWIST_GAMMA5_INVALID QUDA_INVALID_ENUM
320 
321 #define QudaUseInitGuess integer(4)
322 #define QUDA_USE_INIT_GUESS_NO 0
323 #define QUDA_USE_INIT_GUESS_YES 1
324 #define QUDA_USE_INIT_GUESS_INVALID QUDA_INVALID_ENUM
325 
326 #define QudaDirection integer(4)
327 #define QUDA_BACKWARDS -1
328 #define QUDA_FORWARDS +1
329 #define QUDA_BOTH_DIRS 2
330 
331 #define QudaComputeFatMethod integer(4)
332 #define QUDA_COMPUTE_FAT_STANDARD 0
333 #define QUDA_COMPUTE_FAT_EXTENDED_VOLUME 1
334 #define QUDA_COMPUTE_FAT_INVALID QUDA_INVALID_ENUM
335 
336 #define QudaFatLinkFlag integer(4)
337 #define QUDA_FAT_PRESERVE_CPU_GAUGE 1
338 #define QUDA_FAT_PRESERVE_GPU_GAUGE 2
339 #define QUDA_FAT_PRESERVE_COMM_MEM 4
340 
341 #define QudaFieldGeometry integer(4)
342 #define QUDA_SCALAR_GEOMETRY 1
343 #define QUDA_VECTOR_GEOMETRY 4
344 #define QUDA_TENSOR_GEOMETRY 6
345 #define QUDA_INVALID_GEOMETRY QUDA_INVALID_ENUM
346 
347 #define QudaGhostExchange integer(4)
348 #define QUDA_GHOST_EXCHANGE_NO 0
349 #define QUDA_GHOST_EXCHANGE_PAD 1
350 #define QUDA_GHOST_EXCHANGE_EXTENDED 2
351 #define QUDA_GHOST_EXCHANGE_INVALID QUDA_INVALID_ENUM
352 
353 #define QudaStaggeredPhase integer(4)
354 #define QUDA_MILC_STAGGERED_PHASE 0
355 #define QUDA_CPS_STAGGERED_PHASE 1
356 #define QUDA_TIFR_STAGGERED_PHASE 2
357 #define QUDA_INVALID_STAGGERED_PHASE QUDA_INVALID_ENUM
358 
359 #define QudaContractType integer(4)
360 #define QUDA_CONTRACT 0
361 #define QUDA_CONTRACT_PLUS 1
362 #define QUDA_CONTRACT_MINUS 2
363 #define QUDA_CONTRACT_GAMMA5 3
364 #define QUDA_CONTRACT_GAMMA5_PLUS 4
365 #define QUDA_CONTRACT_GAMMA5_MINUS 5
366 #define QUDA_CONTRACT_TSLICE 6
367 #define QUDA_CONTRACT_TSLICE_PLUS 7
368 #define QUDA_CONTRACT_TSLICE_MINUS 8
369 #define QUDA_CONTRACT_INVALID QUDA_INVALID_ENUM
370 
371 #endif
int y[4]
void dslashQuda(void *h_out, void *h_in, QudaInvertParam *inv_param, QudaParity parity)
cpuColorSpinorField * in
int x[4]