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
|
import os, btlbase, shlex, subprocess as sp
numproc = 4
class Module(btlbase.BTLBase):
def _initialize(self):
self.libname = "scalapack"
self.avail = ['axpy', 'matrix_vector', 'lu_decomp', 'cholesky',
'qr_decomp', 'svd_decomp', 'symm_ev']
def _parse_args(self, args):
# Parse arguments
tests = []
skip = 0
for i, a in enumerate(args):
if skip != 0:
skip -= 1
continue
if a == '-n':
skip += 1
numproc = args[i+1]
continue
if a in self.avail:
tests.append(a)
continue
raise Exception("Argument not recognized: " + a)
# Sort tests
self.tests = [i for i in self.avail if i in tests]
# If no test is specified, then choose four standard tests
if len(self.tests) == 0:
self.tests = self.avail
btlbase.BTLBase._parse_args(self, args)
@staticmethod
def _testClass():
return ScaLAPACKTest
class ScaLAPACKTest(btlbase.BTLTest):
# def __init__(self, *args, **kwargs):
# os.environ['CXX'] = 'mpic++'
# btlbase.BTLTest.__init__(self, *args, **kwargs)
def _get_flags(self):
proc = sp.Popen(['mpic++', '-showme'], stdout=sp.PIPE)
out = proc.communicate()[0]
if proc.returncode != 0:
raise Exception("An MPI implementation is needed in order to" \
+ " run the scalapack tests.")
return shlex.split(out)[1:] + btlbase.BTLTest._get_flags(self)
def _executeTest(self, exe, logfile):
btlbase.BTLTest._executeTest(self, exe, logfile, \
['mpirun', '-n', str(numproc)])
@staticmethod
def _btl_source():
return "libs/PBLAS/main.cpp"
@staticmethod
def _btl_includes():
return ["libs/"+i for i in ("BLAS", "LAPACK", "BLACS", "PBLAS", "STL")]
def _btl_defines(self):
return ["PBLASNAME="+self.libname]
|