generate_automake_test_programs.py 2.76 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
#!/usr/bin/env python
from __future__ import print_function
from itertools import product

domain_flag = {
        "real"   : "-DTEST_REAL",
        "complex": "-DTEST_COMPLEX",
}
prec_flag = {
        "double" : "-DTEST_DOUBLE",
        "single" : "-DTEST_SINGLE",
}
solver_flag = {
        "1stage" : "-DTEST_SOLVER_1STAGE",
        "2stage" : "-DTEST_SOLVER_2STAGE",
}
gpu_flag = {
        0 : "-DTEST_GPU=0",
        1 : "-DTEST_GPU=1",
}
Pavel Kus's avatar
Pavel Kus committed
21 22 23 24
matrix_flag = {
        "random" : "-DTEST_MATRIX_RANDOM",
        "analytic" : "-DTEST_MATRIX_ANALYTIC",
}
25

26 27 28 29 30 31
test_type_flag = {
        "eigenvectors" : "-D__EIGENVECTORS",
        "eigenvalues"  : "-D__EIGENVALUES",
        "solve_tridiagonal"  : "-D__SOLVE_TRIDIAGONAL",
}

Pavel Kus's avatar
Pavel Kus committed
32 33
for m, g, t, p, d, s in product(sorted(matrix_flag.keys()),
                             sorted(gpu_flag.keys()),
34 35 36 37
                             sorted(test_type_flag.keys()),
                             sorted(prec_flag.keys()),
                             sorted(domain_flag.keys()),
                             sorted(solver_flag.keys())):
38

Pavel Kus's avatar
Pavel Kus committed
39 40 41 42
    #todo: decide what tests we actually want
    if(m == "analytic" and (g == 1 or t != "eigenvectors" or p == "single" or d == "complex")):
        continue

43 44 45
    if (t == "solve_tridiagonal" and (s == "2stage" and d == "complex")):
        continue

46 47 48
    for kernel in ["all_kernels", "default_kernel"] if s == "2stage" else ["nokernel"]:
        endifs = 0
        extra_flags = []
49 50 51 52

        if (t == "eigenvalues" and kernel == "all_kernels"):
           continue

53 54 55
        if (g == 1):
            print("if WITH_GPU_VERSION")
            endifs += 1
56

57 58 59 60
        if kernel == "default_kernel":
            extra_flags.append("-DTEST_KERNEL=ELPA_2STAGE_{0}_DEFAULT".format(d.upper()))
        elif kernel == "all_kernels":
            extra_flags.append("-DTEST_ALL_KERNELS")
61

62 63 64 65 66 67 68 69 70
        if (p == "single"):
            if (d == "real"):
                print("if WANT_SINGLE_PRECISION_REAL")
            elif (d == "complex"):
                print("if WANT_SINGLE_PRECISION_COMPLEX")
            else:
                raise Exception("Oh no!")
            endifs += 1

Pavel Kus's avatar
Pavel Kus committed
71
        name = "test_{0}_{1}_{2}_{3}{4}{5}{6}".format(d, p, t, s, "" if kernel == "nokernel" else "_" + kernel, "_gpu" if g else "", "_analytic" if m == "analytic" else "")
72 73 74
        print("noinst_PROGRAMS += " + name)
        print("check_SCRIPTS += " + name + ".sh")
        print(name + "_SOURCES = test/Fortran/test.F90")
75 76
        print(name + "_LDADD = $(test_program_ldadd)")
        print(name + "_FCFLAGS = $(test_program_fcflags) \\")
77 78 79
        print("  " + " \\\n  ".join([
            domain_flag[d],
            prec_flag[p],
80
            test_type_flag[t],
81
            solver_flag[s],
Pavel Kus's avatar
Pavel Kus committed
82 83
            gpu_flag[g],
            matrix_flag[m]] + extra_flags))
84 85

        print("endif\n" * endifs)