INTEGER FUNCTION ILAZLR(M, N, A, LDA) IMPLICIT NONE ! ! -- LAPACK auxiliary routine (version 3.2) -- ! Univ. of Tennessee, Univ. of California Berkeley and NAG Ltd.. ! December 2007 ! ! .. Scalar Arguments .. INTEGER M, N, LDA ! .. ! .. Array Arguments .. COMPLEX*16 A( LDA, * ) ! .. ! ! Purpose ! ======= ! ! ILAZLR scans A for its last non-zero row. ! ! Arguments ! ========= ! ! M (input) INTEGER ! The number of rows of the matrix A. ! ! N (input) INTEGER ! The number of columns of the matrix A. ! ! A (input) COMPLEX*16 array, dimension (LDA,N) ! The m by n matrix A. ! ! LDA (input) INTEGER ! The leading dimension of the array A. LDA >= max(1,M). ! ! ===================================================================== ! ! .. Parameters .. COMPLEX*16 ZERO PARAMETER ( ZERO = (0.0D+0, 0.0D+0) ) ! .. ! .. Local Scalars .. INTEGER I, J ! .. ! .. Executable Statements .. ! ! Quick test for the common case where one corner is non-zero. IF( M.EQ.0 .OR. A(M, 1).NE.ZERO .OR. A(M, N).NE.ZERO ) THEN ILAZLR = M ELSE ! Scan up each column tracking the last zero row seen. ILAZLR = 0 DO J = 1, N DO I = M, 1, -1 IF( A(I, J).NE.ZERO ) EXIT END DO ILAZLR = MAX( ILAZLR, I ) END DO END IF RETURN END FUNCTION