This paper describes an approach for the automatic generation and optimization of numerical software for processors with deep memory hierarchies and pipelined functional units. The production of such software for machines ranging from desktop workstations to embedded processors can be a tedious and time consuming process. The work described here can help in automating much of this process. We will concentrate our efforts on the widely used linear algebra kernels called the Basic Linear Algebra Subroutines (BLAS). In particular, the work presented here is for general matrix multiply, DGEMM. However much of the technology and approach developed here can be applied to the other Level 3 BLAS and the general strategy can have an impact on basic linear algebra operations in general and may be extended to other important kernel operations.
[1]
Jack Dongarra,et al.
ScaLAPACK Users' Guide
,
1987
.
[2]
Jack J. Dongarra,et al.
An extended set of FORTRAN basic linear algebra subprograms
,
1988,
TOMS.
[3]
Jack J. Dongarra,et al.
LAPPACK Working Note No. 28: The IBM RISC System/6000 and Linear Algebra Operations
,
1990
.
[4]
Jack J. Dongarra,et al.
A set of level 3 basic linear algebra subprograms
,
1990,
TOMS.
[5]
Bo Kågström,et al.
Portable High Performance GEMM-Based Level 3 BLAS
,
1993,
PPSC.
[6]
James Demmel,et al.
Optimizing matrix multiply using PHiPAC: a portable, high-performance, ANSI C coding methodology
,
1997,
ICS '97.