#include "blaswrap.h" /* -- translated by f2c (version 19990503). You must link the resulting object file with the libraries: -lf2c -lm (in that order) */ #include "f2c.h" /* Common Block Declarations */ struct { real ops, itcnt; } latime_; #define latime_1 latime_ /* Table of constant values */ static integer c__18 = 18; static integer c__1 = 1; static integer c__3 = 3; static logical c_true = TRUE_; static real c_b26 = 1.f; static integer c__2 = 2; static integer c__8 = 8; static logical c_false = FALSE_; static integer c__4 = 4; static integer c__0 = 0; static integer c__5 = 5; static real c_b419 = 0.f; /* Subroutine */ int ctim51_(char *line, integer *nsizes, integer *nn, integer *ntypes, logical *dotype, integer *nparms, integer *nnb, integer *nshfts, integer *neisps, integer *minnbs, integer *minbks, integer *ldas, real *timmin, integer *nout, integer *iseed, complex * a, real *ar, real *ai, complex *b, real *br, real *bi, complex *h__, real *hr, real *hi, complex *t, real *tr, real *ti, complex *q, real * qr, real *qi, complex *z__, real *zr, real *zi, complex *w, real *wr, complex *work, integer *lwork, real *rwork, logical *llwork, real * times, integer *ldt1, integer *ldt2, integer *ldt3, real *opcnts, integer *ldo1, integer *ldo2, integer *ldo3, integer *info, ftnlen line_len) { /* Initialized data */ static char subnam[11*18] = "CGGHRD(N) " "CGGHRD(Q) " "CGGHRD(Z) " "CGGHRD(Q,Z)" "CHGEQZ(E) " "CHGEQZ(S) " "CHGEQZ(Q) " "CHGEQZ(" "Z) " "CHGEQZ(Q,Z)" "CTGEVC(L,A)" "CTGEVC(L,B)" "CTGEVC(R,A)" "CTGEVC(R,B)" "CQZHES(F) " "CQZHES(T) " "CQZVAL(F) " "CQZVAL(" "T) " "CQZVEC "; static integer inparm[18] = { 2,2,2,2,1,1,1,1,1,1,1,1,1,1,1,1,1,1 }; static char pnames[6*6] = " LDA" " NB" " NS" " NEISP" " MINNB" "MINBLK"; static integer katype[4] = { 5,8,7,9 }; /* Format strings */ static char fmt_9999[] = "(1x,a,\002 timing run not attempted -- N > LD" "A\002,/)"; static char fmt_9998[] = "(1x,a,\002 timing run not attempted -- LWORK t" "oo small.\002,/)"; static char fmt_9997[] = "(\002 CTIM51: \002,a,\002 returned INFO=\002,i" "6,\002.\002,/9x,\002N=\002,i6,\002, ITYPE=\002,i6,\002, IPAR=" "\002,i6,\002, ISEED=(\002,3(i5,\002,\002),i5,\002)\002)"; /* System generated locals */ integer opcnts_dim1, opcnts_dim2, opcnts_dim3, opcnts_offset, times_dim1, times_dim2, times_dim3, times_offset, i__1, i__2, i__3, i__4, i__5, i__6, i__7, i__8; real r__1, r__2; complex q__1, q__2, q__3, q__4; /* Builtin functions */ integer s_wsfe(cilist *), do_fio(integer *, char *, ftnlen), e_wsfe(void); double r_sign(real *, real *), c_abs(complex *); void r_cnjg(complex *, complex *); double r_imag(complex *); /* Local variables */ static integer ipar; static real time; static integer isub, nmax, j, n, minnb, iinfo; static complex ctemp; static integer itemp, lastl, neisp; extern doublereal sopla_(char *, integer *, integer *, integer *, integer *, integer *); static logical runeq, runes; static integer itype, j1, j2, j3, j4, n1; static real s1, s2; static logical runqz; extern /* Subroutine */ int clatm4_(integer *, integer *, integer *, integer *, logical *, real *, real *, real *, integer *, integer * , complex *, integer *), cunm2r_(char *, char *, integer *, integer *, integer *, complex *, integer *, complex *, complex *, integer *, complex *, integer *); static integer ic, jc, nb, in, jr; extern /* Subroutine */ int clarfg_(integer *, complex *, complex *, integer *, complex *); static integer ldamin; extern doublereal slamch_(char *); extern /* Complex */ VOID clarnd_(complex *, integer *, integer *); extern doublereal second_(void); static integer minblk, ioldsd[4]; extern /* Subroutine */ int clacpy_(char *, integer *, integer *, complex *, integer *, complex *, integer *), ctgevc_(char *, char *, logical *, integer *, complex *, integer *, complex *, integer *, complex *, integer *, complex *, integer *, integer *, integer *, complex *, real *, integer *), atimin_(char *, char *, integer *, char *, logical *, integer *, integer *, ftnlen, ftnlen, ftnlen), chgeqz_(char *, char *, char *, integer * , integer *, integer *, complex *, integer *, complex *, integer * , complex *, complex *, complex *, integer *, complex *, integer * , complex *, integer *, real *, integer *) ; static integer nbsmax; extern /* Subroutine */ int claqzh_(logical *, logical *, integer *, integer *, integer *, complex *, integer *, complex *, integer *, complex *, integer *, complex *, integer *, complex *, integer *); static integer nshift; extern /* Subroutine */ int cqzvec_(integer *, integer *, real *, real *, real *, real *, real *, real *, real *, real *, real *), cqzhes_( integer *, integer *, real *, real *, real *, real *, logical *, real *, real *); static logical runhrd; static real untime; static logical runhes, timsub[18]; extern /* Subroutine */ int cqzval_(integer *, integer *, real *, real *, real *, real *, real *, real *, real *, real *, logical *, real *, real *, integer *), slacpy_(char *, integer *, integer *, real *, integer *, real *, integer *), slaset_(char *, integer *, integer *, real *, real *, real *, integer *), sprtbg_( char *, integer *, logical *, integer *, integer *, integer *, char *, integer *, integer *, integer *, integer *, integer *, integer *, integer *, real *, integer *, integer *, real *, integer *, integer *, real *, logical *, integer *, ftnlen, ftnlen), xlaenv_(integer *, integer *); static integer mtypes, lda, ldh, ldq, lds, ldw; static real ulp; /* Fortran I/O blocks */ static cilist io___10 = { 0, 0, 0, fmt_9999, 0 }; static cilist io___11 = { 0, 0, 0, fmt_9998, 0 }; static cilist io___38 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___43 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___44 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___45 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___46 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___47 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___50 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___51 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___52 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___53 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___58 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___59 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___61 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___62 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___63 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___64 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___65 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___67 = { 0, 0, 0, fmt_9997, 0 }; static cilist io___68 = { 0, 0, 0, fmt_9997, 0 }; #define times_ref(a_1,a_2,a_3,a_4) times[(((a_4)*times_dim3 + (a_3))*\ times_dim2 + (a_2))*times_dim1 + a_1] #define subnam_ref(a_0,a_1) &subnam[(a_1)*11 + a_0 - 11] #define opcnts_ref(a_1,a_2,a_3,a_4) opcnts[(((a_4)*opcnts_dim3 + (a_3))*\ opcnts_dim2 + (a_2))*opcnts_dim1 + a_1] /* -- LAPACK timing routine (version 3.0) -- Univ. of Tennessee, Univ. of California Berkeley, NAG Ltd., Courant Institute, Argonne National Lab, and Rice University September 30, 1994 Purpose ======= CTIM51 times the LAPACK routines for the COMPLEX non-symmetric generalized eigenvalue problem A x = w B x. For each N value in NN(1:NSIZES) and .TRUE. value in DOTYPE(1:NTYPES), a pair of matrices will be generated and used to test the selected routines. Thus, NSIZES*(number of .TRUE. values in DOTYPE) matrices will be generated. Arguments ========= LINE (input) CHARACTER*80 The input line which requested this routine. This line may contain a subroutine name, such as CGGHRD, indicating that only routine CGGHRD will be timed, or it may contain a generic name, such as CHG. In this case, the rest of the line is scanned for the first 18 non-blank characters, corresponding to the eighteen combinations of subroutine and options: LAPACK: Table Heading: 1: CGGHRD(no Q, no Z) (+CGEQRF, etc.) 'CGGHRD(N)' 2: CGGHRD(Q only) (+CGEQRF, etc.) 'CGGHRD(Q)' 3: CGGHRD(Z only) (+CGEQRF, etc.) 'CGGHRD(Z)' 4: CGGHRD(Q and Z) (+CGEQRF, etc.) 'CGGHRD(Q,Z)' 5: CHGEQZ(Eigenvalues only) 'CHGEQZ(E)' 6: CHGEQZ(Schur form only) 'CHGEQZ(S)' 7: CHGEQZ(Schur form and Q) 'CHGEQZ(Q)' 8: CHGEQZ(Schur form and Z) 'CHGEQZ(Z)' 9: CHGEQZ(Schur form, Q and Z) 'CHGEQZ(Q,Z)' 10: CTGEVC(SIDE='L', HOWMNY='A') 'CTGEVC(L,A)' 11: CTGEVC(SIDE='L', HOWMNY='B') 'CTGEVC(L,B)' 12: CTGEVC(SIDE='R', HOWMNY='A') 'CTGEVC(R,A)' 13: CTGEVC(SIDE='R', HOWMNY='B') 'CTGEVC(R,B)' EISPACK: Compare w/: Table Heading: 14: CQZHES w/ matz=.false. 1 'CQZHES(F)' 15: CQZHES w/ matz=.true. 3 'CQZHES(T)' 16: CQZVAL w/ matz=.false. 5 'CQZVAL(F)' 17: CQZVAL w/ matz=.true. 8 'CQZVAL(T)' 18: CQZVEC 13 'CQZVEC' If a character is 'T' or 't', the corresponding routine in this path is timed. If the entire line is blank, all the routines in the path are timed. Note that since QZHES does more than SGGHRD, the "SGGHRD" timing also includes the time for the calls to SGEQRF, SORMQR, and (if Q is computed) SORGQR which are necessary to get the same functionality as QZHES. NSIZES (input) INTEGER The number of values of N contained in the vector NN. NN (input) INTEGER array, dimension (NSIZES) The values of the matrix size N to be tested. For each N value in the array NN, and each .TRUE. value in DOTYPE, a matrix A will be generated and used to test the routines. NTYPES (input) INTEGER The number of types in DOTYPE. Only the first MAXTYP elements will be examined. Exception: if NSIZES=1 and NTYPES=MAXTYP+1, and DOTYPE=MAXTYP*f,t, then the input value of A will be used. DOTYPE (input) LOGICAL If DOTYPE(j) is .TRUE., then a pair of matrices (A,B) of type j will be generated. A and B have the form U T1 V and U T2 V , resp., where U and V are orthogonal, T1 and T2 are upper triangular. T2 has random O(1) entries in the strict upper triangle and ( 0, 1, 0, 1, 1, ..., 1, 0 ) on the diagonal, while T1 has random O(1) entries in the strict upper triangle, its diagonal will have the values: (j=1) 0, 0, 1, 1, ULP,..., ULP, 0. (j=2) 0, 0, 1, 1, 1-d, 1-2*d, ..., 1-(N-5)*d=ULP, 0. 2 N-5 (j=3) 0, 0, 1, 1, a, a , ..., a =ULP, 0. (j=4) 0, 0, 1, r1, r2, ..., r(N-4), 0, where r1, etc. are random numbers in (ULP,1). NPARMS (input) INTEGER The number of values in each of the arrays NNB, NSHFTS, NEISPS, and LDAS. For each pair of matrices A,B generated according to NN and DOTYPE, tests will be run with (NB,NSHIFT,NEISP,LDA)= (NNB(1), NSHFTS(1), NEISPS(1), LDAS(1)),..., (NNB(NPARMS), NSHFTS(NPARMS), NEISPS(NPARMS), LDAS(NPARMS)) NNB (input) INTEGER array, dimension (NPARMS) The values of the blocksize ("NB") to be tested. They must be at least 1. Currently, this is only used by CGEQRF, etc., in the timing of CGGHRD. NSHFTS (input) INTEGER array, dimension (NPARMS) The values of the number of shifts ("NSHIFT") to be tested. (Currently not used.) NEISPS (input) INTEGER array, dimension (NPARMS) The values of "NEISP", the size of largest submatrix to be processed by CLAEQZ (EISPACK method), to be tested. (Currently not used.) MINNBS (input) INTEGER array, dimension (NPARMS) The values of "MINNB", the minimum size of a product of transformations which may be applied as a blocked transformation, to be tested. (Currently not used.) MINBKS (input) INTEGER array, dimension (NPARMS) The values of "MINBK", the minimum number of rows/columns to be updated with a blocked transformation, to be tested. (Currently not used.) LDAS (input) INTEGER array, dimension (NPARMS) The values of LDA, the leading dimension of all matrices, to be tested. TIMMIN (input) REAL The minimum time a subroutine will be timed. NOUT (input) INTEGER If NOUT > 0 then NOUT specifies the unit number on which the output will be printed. If NOUT <= 0, no output is printed. ISEED (input/output) INTEGER array, dimension (4) The random seed used by the random number generator, used by the test matrix generator. It is used and updated on each call to CTIM51. A (workspace) COMPLEX array, dimension (max(NN)*max(LDAS)) (a) During the testing of CGGHRD, "A", the original left-hand-side matrix to be tested. (b) Later, "S", the Schur form of the original "A" matrix. AR, AI (workspace) REAL arrays, dimension (max(NN)*max(LDAS)) The real and imaginary parts of A, stored separately for the benefit of CQZHES, CQZVAL, and CQZVEC. These may be equivalenced with A by the calling routine. B (workspace) COMPLEX array, dimension (max(NN)*max(LDAS)) (a) During the testing of CGGHRD, "B", the original right-hand-side matrix to be tested. (b) Later, "P", the Schur form of the original "B" matrix. BR, BI (workspace) REAL arrays, dimension (max(NN)*max(LDAS)) The real and imaginary parts of B, stored separately for the benefit of CQZHES, CQZVAL, and CQZVEC. These may be equivalenced with B by the calling routine. H (workspace) COMPLEX array, dimension (max(NN)*max(LDAS)) (a) During the testing of CGGHRD and CHGEQZ, "H", the Hessenberg form of the original "A" matrix. (b) During the testing of CTGEVC, "L", the matrix of left eigenvectors. HR, HI (workspace) REAL arrays, dimension (max(NN)*max(LDAS)) The real and imaginary parts of H, stored separately for the benefit of CQZHES, CQZVAL, and CQZVEC. These may be equivalenced with H by the calling routine. T (workspace) COMPLEX array, dimension (max(NN)*max(LDAS)) (a) During the testing of CGGHRD and CHGEQZ, "T", the triangular form of the original "B" matrix. (b) During the testing of CTGEVC, "R", the matrix of right eigenvectors. TR, TI (workspace) REAL arrays, dimension (max(NN)*max(LDAS)) The real and imaginary parts of T, stored separately for the benefit of CQZHES, CQZVAL, and CQZVEC. These may be equivalenced with T by the calling routine. Q (workspace) COMPLEX array, dimension (max(NN)*max(LDAS)) The orthogonal matrix on the left generated by CGGHRD. If CHGEQZ computes only Q or Z, then that matrix is stored here. If both Q and Z are computed, the Q matrix goes here. QR, QI (workspace) REAL arrays, dimension (max(NN)*max(LDAS)) The real and imaginary parts of Q, stored separately for the benefit of CQZVAL. These may be equivalenced with Q by the calling routine. Z (workspace) COMPLEX array, dimension (max(NN)*max(LDAS)) The orthogonal matrix on the right generated by CGGHRD. If CHGEQZ computes both Q and Z, the Z matrix is stored here. Also used as scratch space for timing the CLACPY calls. ZR, ZI (workspace) REAL arrays, dimension (max(NN)*max(LDAS)) The real and imaginary parts of Z, stored separately for the benefit of CQZHES, CQZVAL, and CQZVEC. These may be equivalenced with Z by the calling routine. W (workspace) COMPLEX array, dimension (2*max(LDAS)) Treated as an LDA x 2 matrix whose 1st column holds ALPHA, the diagonal entries of "S", and whose 2nd column holds BETA, the diagonal entries of "P". WR (workspace) REAL array, dimension (3*max(LDAS)) Treated as an LDA x 3 matrix whose 1st and 2nd columns hold the real and imaginary parts of ALPHA (see the description of W), and whose 3rd column holds BETA (real part only.) This may be equivalenced to W by the calling routine. WORK (workspace) COMPLEX array, dimension (LWORK) LWORK (input) INTEGER [the following formulae are certainly wrong] Number of elements in WORK. LWORK >= 4*max(NN). RWORK (workspace) REAL array, dimension (max( 2*max(NN), NSIZES*NTYPES*NPARMS )) LLWORK (workspace) LOGICAL array, dimension (max( max(NN), NPARMS )) TIMES (output) REAL array, dimension (LDT1,LDT2,LDT3,NSUBS) TIMES(i,j,k,l) will be set to the run time (in seconds) for subroutine l, with N=NN(k), matrix type j, and LDA=LDAS(i), NEISP=NEISPS(i), NBLOCK=NNB(i), NSHIFT=NSHFTS(i), MINNB=MINNBS(i), and MINBLK=MINBKS(i). LDT1 (input) INTEGER The first dimension of TIMES. LDT1 >= min( 1, NPARMS ). LDT2 (input) INTEGER The second dimension of TIMES. LDT2 >= min( 1, NTYPES ). LDT3 (input) INTEGER The third dimension of TIMES. LDT3 >= min( 1, NSIZES ). OPCNTS (output) REAL array, dimension (LDO1,LDO2,LDO3,NSUBS) OPCNTS(i,j,k,l) will be set to the number of floating-point operations executed by subroutine l, with N=NN(k), matrix type j, and LDA=LDAS(i), NEISP=NEISPS(i), NBLOCK=NNB(i), NSHIFT=NSHFTS(i), MINNB=MINNBS(i), and MINBLK=MINBKS(i). LDO1 (input) INTEGER The first dimension of OPCNTS. LDO1 >= min( 1, NPARMS ). LDO2 (input) INTEGER The second dimension of OPCNTS. LDO2 >= min( 1, NTYPES ). LDO3 (input) INTEGER The third dimension of OPCNTS. LDO3 >= min( 1, NSIZES ). INFO (output) INTEGER Error flag. It will be set to zero if no error occurred. ===================================================================== Parameter adjustments */ --nn; --dotype; --nnb; --nshfts; --neisps; --minnbs; --minbks; --ldas; --iseed; --a; --ar; --ai; --b; --br; --bi; --h__; --hr; --hi; --t; --tr; --ti; --q; --qr; --qi; --z__; --zr; --zi; --w; --wr; --work; --rwork; --llwork; times_dim1 = *ldt1; times_dim2 = *ldt2; times_dim3 = *ldt3; times_offset = 1 + times_dim1 * (1 + times_dim2 * (1 + times_dim3 * 1)); times -= times_offset; opcnts_dim1 = *ldo1; opcnts_dim2 = *ldo2; opcnts_dim3 = *ldo3; opcnts_offset = 1 + opcnts_dim1 * (1 + opcnts_dim2 * (1 + opcnts_dim3 * 1) ); opcnts -= opcnts_offset; /* Function Body Quick Return */ *info = 0; if (*nsizes <= 0 || *ntypes <= 0 || *nparms <= 0) { return 0; } /* Extract the timing request from the input line. */ atimin_("CHG", line, &c__18, subnam, timsub, nout, info, (ftnlen)3, ( ftnlen)80, (ftnlen)11); if (*info != 0) { return 0; } /* Compute Maximum Values */ nmax = 0; i__1 = *nsizes; for (j1 = 1; j1 <= i__1; ++j1) { /* Computing MAX */ i__2 = nmax, i__3 = nn[j1]; nmax = max(i__2,i__3); /* L10: */ } ldamin = max(1,nmax) << 1; nbsmax = 0; i__1 = *nparms; for (j1 = 1; j1 <= i__1; ++j1) { /* Computing MIN */ i__2 = ldamin, i__3 = ldas[j1]; ldamin = min(i__2,i__3); /* Computing MAX */ i__2 = nbsmax, i__3 = nnb[j1] + nshfts[j1]; nbsmax = max(i__2,i__3); /* L20: */ } /* Check that N <= LDA for the input values. */ if (nmax > ldamin) { *info = -12; io___10.ciunit = *nout; s_wsfe(&io___10); do_fio(&c__1, line, (ftnlen)6); e_wsfe(); return 0; } /* Check LWORK */ if (*lwork < nmax << 2) { *info = -24; io___11.ciunit = *nout; s_wsfe(&io___11); do_fio(&c__1, line, (ftnlen)6); e_wsfe(); return 0; } /* Check to see whether CGGHRD or CHGEQZ must be run. RUNHRD -- if CGGHRD must be run. RUNES -- if CHGEQZ must be run to get Schur form. RUNEQ -- if CHGEQZ must be run to get Schur form and Q. */ runhrd = FALSE_; runes = FALSE_; runeq = FALSE_; if (timsub[9] || timsub[11]) { runes = TRUE_; } if (timsub[10] || timsub[12]) { runeq = TRUE_; } if (timsub[4] || timsub[5] || timsub[6] || timsub[7] || timsub[8] || runes || runeq) { runhrd = TRUE_; } if (timsub[5] || timsub[6] || timsub[7] || timsub[8] || runeq) { runes = FALSE_; } if (timsub[6] || timsub[7] || timsub[8]) { runeq = FALSE_; } if (timsub[0] || timsub[1] || timsub[2] || timsub[3]) { runhrd = FALSE_; } /* Check to see whether CQZHES or CQZVAL must be run. RUNHES -- if CQZHES must be run. RUNQZ -- if CQZVAL must be run (w/ MATZ=.TRUE.). */ runhes = FALSE_; runqz = FALSE_; if (timsub[17]) { runqz = TRUE_; } if (timsub[15] || timsub[16] || runqz) { runhes = TRUE_; } if (timsub[16]) { runqz = FALSE_; } if (timsub[13] || timsub[14]) { runhes = FALSE_; } /* Various Constants */ ulp = slamch_("Epsilon") * slamch_("Base"); /* Zero out OPCNTS, TIMES */ for (j4 = 1; j4 <= 18; ++j4) { i__1 = *nsizes; for (j3 = 1; j3 <= i__1; ++j3) { i__2 = *ntypes; for (j2 = 1; j2 <= i__2; ++j2) { i__3 = *nparms; for (j1 = 1; j1 <= i__3; ++j1) { opcnts_ref(j1, j2, j3, j4) = 0.f; times_ref(j1, j2, j3, j4) = 0.f; /* L30: */ } /* L40: */ } /* L50: */ } /* L60: */ } /* Do for each value of N: */ i__1 = *nsizes; for (in = 1; in <= i__1; ++in) { n = nn[in]; n1 = max(1,n); /* Do for each .TRUE. value in DOTYPE: */ mtypes = min(4,*ntypes); if (*ntypes == 5 && *nsizes == 1) { mtypes = *ntypes; } i__2 = mtypes; for (itype = 1; itype <= i__2; ++itype) { if (! dotype[itype]) { goto L930; } /* Save random number seed for error messages */ for (j = 1; j <= 4; ++j) { ioldsd[j - 1] = iseed[j]; /* L70: */ } /* Time the LAPACK Routines Generate A and B */ if (itype <= 4) { /* Generate A (w/o rotation) */ clatm4_(&katype[itype - 1], &n, &c__3, &c__1, &c_true, &c_b26, &ulp, &c_b26, &c__2, &iseed[1], &a[1], &n1); if (3 <= n) { i__3 = (n1 << 1) + 3; a[i__3].r = 1.f, a[i__3].i = 0.f; } /* Generate B (w/o rotation) */ clatm4_(&c__8, &n, &c__3, &c__1, &c_false, &c_b26, &c_b26, & c_b26, &c__2, &iseed[1], &b[1], &n1); if (2 <= n) { i__3 = n1 + 2; b[i__3].r = 1.f, b[i__3].i = 0.f; } if (n > 0) { /* Include rotations Generate U, V as Householder transformations times a diagonal matrix. (Note that CLARFG makes Q(jc+ic) and Z(jc+ic) real.) */ i__3 = n - 1; for (jc = 1; jc <= i__3; ++jc) { ic = (jc - 1) * n1; i__4 = n; for (jr = jc; jr <= i__4; ++jr) { i__5 = jr + ic; clarnd_(&q__1, &c__3, &iseed[1]); q[i__5].r = q__1.r, q[i__5].i = q__1.i; i__5 = jr + ic; clarnd_(&q__1, &c__3, &iseed[1]); z__[i__5].r = q__1.r, z__[i__5].i = q__1.i; /* L80: */ } i__4 = n + 1 - jc; clarfg_(&i__4, &q[jc + ic], &q[jc + 1 + ic], &c__1, & work[jc]); i__4 = (n << 1) + jc; i__5 = jc + ic; r__2 = q[i__5].r; r__1 = r_sign(&c_b26, &r__2); work[i__4].r = r__1, work[i__4].i = 0.f; i__4 = jc + ic; q[i__4].r = 1.f, q[i__4].i = 0.f; i__4 = n + 1 - jc; clarfg_(&i__4, &z__[jc + ic], &z__[jc + 1 + ic], & c__1, &work[n + jc]); i__4 = n * 3 + jc; i__5 = jc + ic; r__2 = z__[i__5].r; r__1 = r_sign(&c_b26, &r__2); work[i__4].r = r__1, work[i__4].i = 0.f; i__4 = jc + ic; z__[i__4].r = 1.f, z__[i__4].i = 0.f; /* L90: */ } ic = (n - 1) * n1; clarnd_(&q__1, &c__3, &iseed[1]); ctemp.r = q__1.r, ctemp.i = q__1.i; i__3 = n + ic; q[i__3].r = 1.f, q[i__3].i = 0.f; i__3 = n; work[i__3].r = 0.f, work[i__3].i = 0.f; i__3 = n * 3; r__1 = c_abs(&ctemp); q__1.r = ctemp.r / r__1, q__1.i = ctemp.i / r__1; work[i__3].r = q__1.r, work[i__3].i = q__1.i; clarnd_(&q__1, &c__3, &iseed[1]); ctemp.r = q__1.r, ctemp.i = q__1.i; i__3 = n + ic; z__[i__3].r = 1.f, z__[i__3].i = 0.f; i__3 = n << 1; work[i__3].r = 0.f, work[i__3].i = 0.f; i__3 = n << 2; r__1 = c_abs(&ctemp); q__1.r = ctemp.r / r__1, q__1.i = ctemp.i / r__1; work[i__3].r = q__1.r, work[i__3].i = q__1.i; /* Apply the diagonal matrices */ i__3 = n; for (jc = 1; jc <= i__3; ++jc) { i__4 = n; for (jr = 1; jr <= i__4; ++jr) { i__5 = jr + ic; i__6 = (n << 1) + jr; r_cnjg(&q__3, &work[n * 3 + jc]); q__2.r = work[i__6].r * q__3.r - work[i__6].i * q__3.i, q__2.i = work[i__6].r * q__3.i + work[i__6].i * q__3.r; i__7 = jr + ic; q__1.r = q__2.r * a[i__7].r - q__2.i * a[i__7].i, q__1.i = q__2.r * a[i__7].i + q__2.i * a[ i__7].r; a[i__5].r = q__1.r, a[i__5].i = q__1.i; i__5 = jr + ic; i__6 = (n << 1) + jr; r_cnjg(&q__3, &work[n * 3 + jc]); q__2.r = work[i__6].r * q__3.r - work[i__6].i * q__3.i, q__2.i = work[i__6].r * q__3.i + work[i__6].i * q__3.r; i__7 = jr + ic; q__1.r = q__2.r * b[i__7].r - q__2.i * b[i__7].i, q__1.i = q__2.r * b[i__7].i + q__2.i * b[ i__7].r; b[i__5].r = q__1.r, b[i__5].i = q__1.i; /* L100: */ } /* L110: */ } i__3 = n - 1; cunm2r_("L", "N", &n, &n, &i__3, &q[1], &n1, &work[1], &a[ 1], &n1, &work[(n << 1) + 1], &iinfo); if (iinfo != 0) { goto L120; } i__3 = n - 1; cunm2r_("R", "C", &n, &n, &i__3, &z__[1], &n1, &work[n + 1], &a[1], &n1, &work[(n << 1) + 1], &iinfo); if (iinfo != 0) { goto L120; } i__3 = n - 1; cunm2r_("L", "N", &n, &n, &i__3, &q[1], &n1, &work[1], &b[ 1], &n1, &work[(n << 1) + 1], &iinfo); if (iinfo != 0) { goto L120; } i__3 = n - 1; cunm2r_("R", "C", &n, &n, &i__3, &z__[1], &n1, &work[n + 1], &b[1], &n1, &work[(n << 1) + 1], &iinfo); if (iinfo != 0) { goto L120; } } L120: ; } /* . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Time CGGHRD Time CGEQRF+CGGHRD('N','N',...) for each pair (LDAS(j),NNB(j)) */ if (timsub[0]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; nb = nnb[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 1) = 0.f; opcnts_ref(ipar, itype, in, 1) = 0.f; goto L160; } /* If this value of (NB,LDA) has occurred before, just use that value. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j] && nb == nnb[j]) { lastl = j; } /* L130: */ } if (lastl == 0) { /* Time CGGHRD, computing neither Q nor Z (Actually, time CGEQRF + CUNMQR + CGGHRD.) */ xlaenv_(&c__1, &nb); ic = 0; latime_1.ops = 0.f; s1 = second_(); L140: clacpy_("Full", &n, &n, &a[1], &n1, &h__[1], &lda); clacpy_("Full", &n, &n, &b[1], &n1, &t[1], &lda); claqzh_(&c_false, &c_false, &n, &c__1, &n, &h__[1], & lda, &t[1], &lda, &q[1], &lda, &z__[1], &lda, &work[1], &iinfo); if (iinfo != 0) { io___38.ciunit = *nout; s_wsfe(&io___38); do_fio(&c__1, subnam_ref(0, 1), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L140; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &a[1], &n1, &z__[1], &lda); clacpy_("Full", &n, &n, &b[1], &n1, &z__[1], &lda); /* L150: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 1) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 1) = latime_1.ops / (real) ic + sopla_("CGEQRF", &n, &n, &c__0, &c__0, & nb) + sopla_("CUNMQR", &n, &n, & c__0, &c__0, &nb); ldh = lda; } else { opcnts_ref(ipar, itype, in, 1) = opcnts_ref(lastl, itype, in, 1); times_ref(ipar, itype, in, 1) = times_ref(lastl, itype, in, 1); } L160: ; } } else if (runhrd) { clacpy_("Full", &n, &n, &a[1], &n1, &h__[1], &n1); clacpy_("Full", &n, &n, &b[1], &n1, &t[1], &n1); claqzh_(&c_false, &c_false, &n, &c__1, &n, &h__[1], &n1, &t[1] , &n1, &q[1], &n1, &z__[1], &n1, &work[1], &iinfo); if (iinfo != 0) { io___43.ciunit = *nout; s_wsfe(&io___43); do_fio(&c__1, subnam_ref(0, 1), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&itype, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&c__0, (ftnlen)sizeof(integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof(integer)) ; e_wsfe(); *info = abs(iinfo); goto L930; } ldh = n; } /* Time CGGHRD('I','N',...) for each pair (LDAS(j),NNB(j)) */ if (timsub[1]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; nb = nnb[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 2) = 0.f; opcnts_ref(ipar, itype, in, 2) = 0.f; goto L200; } /* If this value of (NB,LDA) has occurred before, just use that value. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j] && nb == nnb[j]) { lastl = j; } /* L170: */ } if (lastl == 0) { /* Time CGGHRD, computing Q but not Z (Actually, CGEQRF + CUNMQR + CUNGQR + CGGHRD.) */ xlaenv_(&c__1, &nb); ic = 0; latime_1.ops = 0.f; s1 = second_(); L180: clacpy_("Full", &n, &n, &a[1], &n1, &h__[1], &lda); clacpy_("Full", &n, &n, &b[1], &n1, &t[1], &lda); claqzh_(&c_true, &c_false, &n, &c__1, &n, &h__[1], & lda, &t[1], &lda, &q[1], &lda, &z__[1], &lda, &work[1], &iinfo); if (iinfo != 0) { io___44.ciunit = *nout; s_wsfe(&io___44); do_fio(&c__1, subnam_ref(0, 2), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L180; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &a[1], &n1, &z__[1], &lda); clacpy_("Full", &n, &n, &b[1], &n1, &z__[1], &lda); /* L190: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 2) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 2) = latime_1.ops / (real) ic + sopla_("CGEQRF", &n, &n, &c__0, &c__0, & nb) + sopla_("CUNMQR", &n, &n, & c__0, &c__0, &nb) + sopla_("CUNGQR" , &n, &n, &c__0, &c__0, &nb); ldh = lda; } else { opcnts_ref(ipar, itype, in, 2) = opcnts_ref(lastl, itype, in, 2); times_ref(ipar, itype, in, 2) = times_ref(lastl, itype, in, 2); } L200: ; } } /* Time CGGHRD('N','I',...) for each pair (LDAS(j),NNB(j)) */ if (timsub[2]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; nb = nnb[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 3) = 0.f; opcnts_ref(ipar, itype, in, 3) = 0.f; goto L240; } /* If this value of (NB,LDA) has occurred before, just use that value. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j] && nb == nnb[j]) { lastl = j; } /* L210: */ } if (lastl == 0) { /* Time CGGHRD, computing Z but not Q (Actually, CGEQRF + CUNMQR + CGGHRD.) */ xlaenv_(&c__1, &nb); ic = 0; latime_1.ops = 0.f; s1 = second_(); L220: clacpy_("Full", &n, &n, &a[1], &n1, &h__[1], &lda); clacpy_("Full", &n, &n, &b[1], &n1, &t[1], &lda); claqzh_(&c_false, &c_true, &n, &c__1, &n, &h__[1], & lda, &t[1], &lda, &q[1], &lda, &z__[1], &lda, &work[1], &iinfo); if (iinfo != 0) { io___45.ciunit = *nout; s_wsfe(&io___45); do_fio(&c__1, subnam_ref(0, 3), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L220; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &a[1], &n1, &z__[1], &lda); clacpy_("Full", &n, &n, &b[1], &n1, &z__[1], &lda); /* L230: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 3) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 3) = latime_1.ops / (real) ic + sopla_("CGEQRF", &n, &n, &c__0, &c__0, & nb) + sopla_("CUNMQR", &n, &n, & c__0, &c__0, &nb); ldh = lda; } else { opcnts_ref(ipar, itype, in, 3) = opcnts_ref(lastl, itype, in, 3); times_ref(ipar, itype, in, 3) = times_ref(lastl, itype, in, 3); } L240: ; } } /* Time CGGHRD('I','I',...) for each pair (LDAS(j),NNB(j)) */ if (timsub[3]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; nb = nnb[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 4) = 0.f; opcnts_ref(ipar, itype, in, 4) = 0.f; goto L280; } /* If this value of (NB,LDA) has occurred before, just use that value. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j] && nb == nnb[j]) { lastl = j; } /* L250: */ } if (lastl == 0) { /* Time CGGHRD, computing Q and Z (Actually, CGEQRF + CUNMQR + CUNGQR + CGGHRD.) */ xlaenv_(&c__1, &nb); ic = 0; latime_1.ops = 0.f; s1 = second_(); L260: clacpy_("Full", &n, &n, &a[1], &n1, &h__[1], &lda); clacpy_("Full", &n, &n, &b[1], &n1, &t[1], &lda); claqzh_(&c_true, &c_true, &n, &c__1, &n, &h__[1], & lda, &t[1], &lda, &q[1], &lda, &z__[1], &lda, &work[1], &iinfo); if (iinfo != 0) { io___46.ciunit = *nout; s_wsfe(&io___46); do_fio(&c__1, subnam_ref(0, 4), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L260; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &a[1], &n1, &z__[1], &lda); clacpy_("Full", &n, &n, &b[1], &n1, &z__[1], &lda); /* L270: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 4) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 4) = latime_1.ops / (real) ic + sopla_("CGEQRF", &n, &n, &c__0, &c__0, & nb) + sopla_("CUNMQR", &n, &n, & c__0, &c__0, &nb) + sopla_("CUNGQR" , &n, &n, &c__0, &c__0, &nb); ldh = lda; } else { opcnts_ref(ipar, itype, in, 4) = opcnts_ref(lastl, itype, in, 4); times_ref(ipar, itype, in, 4) = times_ref(lastl, itype, in, 4); } L280: ; } } /* . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Time CHGEQZ Time CHGEQZ with JOB='E' for each value of LDAS(j) */ if (timsub[4]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 5) = 0.f; opcnts_ref(ipar, itype, in, 5) = 0.f; goto L320; } /* If this value of LDA has occurred before, just use that value. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L290: */ } if (lastl == 0) { /* Time CHGEQZ with JOB='E' */ ic = 0; latime_1.ops = 0.f; s1 = second_(); L300: clacpy_("Full", &n, &n, &h__[1], &ldh, &a[1], &lda); clacpy_("Full", &n, &n, &t[1], &ldh, &b[1], &lda); chgeqz_("E", "N", "N", &n, &c__1, &n, &a[1], &lda, &b[ 1], &lda, &w[1], &w[lda + 1], &q[1], &lda, & z__[1], &lda, &work[1], lwork, &rwork[1], & iinfo); if (iinfo != 0) { io___47.ciunit = *nout; s_wsfe(&io___47); do_fio(&c__1, subnam_ref(0, 5), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L300; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &h__[1], &ldh, &z__[1], & lda); clacpy_("Full", &n, &n, &t[1], &ldh, &z__[1], & lda); /* L310: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 5) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 5) = latime_1.ops / (real) ic; lds = 0; ldq = 0; } else { opcnts_ref(ipar, itype, in, 5) = opcnts_ref(lastl, itype, in, 5); times_ref(ipar, itype, in, 5) = times_ref(lastl, itype, in, 5); } L320: ; } } /* Time CHGEQZ with JOB='S', COMPQ=COMPZ='N' for each value of LDAS(j) */ if (timsub[5]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 6) = 0.f; opcnts_ref(ipar, itype, in, 6) = 0.f; goto L360; } /* If this value of LDA has occurred before, just use that value. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L330: */ } if (lastl == 0) { /* Time CHGEQZ with JOB='S', COMPQ=COMPZ='N' */ ic = 0; latime_1.ops = 0.f; s1 = second_(); L340: clacpy_("Full", &n, &n, &h__[1], &ldh, &a[1], &lda); clacpy_("Full", &n, &n, &t[1], &ldh, &b[1], &lda); chgeqz_("S", "N", "N", &n, &c__1, &n, &a[1], &lda, &b[ 1], &lda, &w[1], &w[lda + 1], &q[1], &lda, & z__[1], &lda, &work[1], lwork, &rwork[1], & iinfo); if (iinfo != 0) { io___50.ciunit = *nout; s_wsfe(&io___50); do_fio(&c__1, subnam_ref(0, 6), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L340; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &h__[1], &ldh, &z__[1], & lda); clacpy_("Full", &n, &n, &t[1], &ldh, &z__[1], & lda); /* L350: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 6) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 6) = latime_1.ops / (real) ic; lds = lda; ldq = 0; } else { opcnts_ref(ipar, itype, in, 6) = opcnts_ref(lastl, itype, in, 6); times_ref(ipar, itype, in, 6) = times_ref(lastl, itype, in, 6); } L360: ; } } else if (runes) { clacpy_("Full", &n, &n, &h__[1], &ldh, &a[1], &n1); clacpy_("Full", &n, &n, &t[1], &ldh, &b[1], &n1); chgeqz_("S", "N", "N", &n, &c__1, &n, &a[1], &n1, &b[1], &n1, &w[1], &w[n1 + 1], &q[1], &n1, &z__[1], &n1, &work[1], lwork, &rwork[1], &iinfo); if (iinfo != 0) { io___51.ciunit = *nout; s_wsfe(&io___51); do_fio(&c__1, subnam_ref(0, 6), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&itype, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&c__0, (ftnlen)sizeof(integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof(integer)) ; e_wsfe(); *info = abs(iinfo); goto L930; } lds = n1; ldq = 0; } /* Time CHGEQZ with JOB='S', COMPQ='I', COMPZ='N' for each value of LDAS(j) */ if (timsub[6]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 7) = 0.f; opcnts_ref(ipar, itype, in, 7) = 0.f; goto L400; } /* If this value of LDA has occurred before, just use that value. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L370: */ } if (lastl == 0) { /* Time CHGEQZ with JOB='S', COMPQ='I', COMPZ='N' */ ic = 0; latime_1.ops = 0.f; s1 = second_(); L380: clacpy_("Full", &n, &n, &h__[1], &ldh, &a[1], &lda); clacpy_("Full", &n, &n, &t[1], &ldh, &b[1], &lda); chgeqz_("S", "I", "N", &n, &c__1, &n, &a[1], &lda, &b[ 1], &lda, &w[1], &w[lda + 1], &q[1], &lda, & z__[1], &lda, &work[1], lwork, &rwork[1], & iinfo); if (iinfo != 0) { io___52.ciunit = *nout; s_wsfe(&io___52); do_fio(&c__1, subnam_ref(0, 7), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L380; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &h__[1], &ldh, &z__[1], & lda); clacpy_("Full", &n, &n, &t[1], &ldh, &z__[1], & lda); /* L390: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 7) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 7) = latime_1.ops / (real) ic; lds = lda; ldq = lda; } else { opcnts_ref(ipar, itype, in, 7) = opcnts_ref(lastl, itype, in, 7); times_ref(ipar, itype, in, 7) = times_ref(lastl, itype, in, 7); } L400: ; } } else if (runeq) { clacpy_("Full", &n, &n, &h__[1], &ldh, &a[1], &n1); clacpy_("Full", &n, &n, &t[1], &ldh, &b[1], &n1); chgeqz_("S", "I", "N", &n, &c__1, &n, &a[1], &n1, &b[1], &n1, &w[1], &w[n1 + 1], &q[1], &n1, &z__[1], &n1, &work[1], lwork, &rwork[1], &iinfo); if (iinfo != 0) { io___53.ciunit = *nout; s_wsfe(&io___53); do_fio(&c__1, subnam_ref(0, 7), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&itype, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&c__0, (ftnlen)sizeof(integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof(integer)) ; e_wsfe(); *info = abs(iinfo); goto L930; } lds = n1; ldq = n1; } /* Time CHGEQZ with JOB='S', COMPQ='N', COMPZ='I' for each value of LDAS(j) */ if (timsub[7]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 8) = 0.f; opcnts_ref(ipar, itype, in, 8) = 0.f; goto L440; } /* If this value of LDA has occurred before, just use that value. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L410: */ } if (lastl == 0) { /* Computing MIN */ i__4 = n, i__5 = nnb[ipar]; nb = min(i__4,i__5); nshift = nshfts[ipar]; neisp = neisps[ipar]; minnb = minnbs[ipar]; minblk = minbks[ipar]; xlaenv_(&c__1, &nb); xlaenv_(&c__2, &minnb); xlaenv_(&c__8, &neisp); xlaenv_(&c__4, &nshift); xlaenv_(&c__5, &minblk); /* Time CHGEQZ with JOB='S', COMPQ='N', COMPZ='I' (Note that the "Z" matrix is stored in the array Q) */ ic = 0; latime_1.ops = 0.f; s1 = second_(); L420: clacpy_("Full", &n, &n, &h__[1], &ldh, &a[1], &lda); clacpy_("Full", &n, &n, &t[1], &ldh, &b[1], &lda); chgeqz_("S", "N", "I", &n, &c__1, &n, &a[1], &lda, &b[ 1], &lda, &w[1], &w[lda + 1], &z__[1], &lda, & q[1], &lda, &work[1], lwork, &rwork[1], & iinfo); if (iinfo != 0) { io___58.ciunit = *nout; s_wsfe(&io___58); do_fio(&c__1, subnam_ref(0, 8), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L420; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &h__[1], &ldh, &z__[1], & lda); clacpy_("Full", &n, &n, &t[1], &ldh, &z__[1], & lda); /* L430: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 8) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 8) = latime_1.ops / (real) ic; lds = lda; ldq = lda; } else { opcnts_ref(ipar, itype, in, 8) = opcnts_ref(lastl, itype, in, 8); times_ref(ipar, itype, in, 8) = times_ref(lastl, itype, in, 8); } L440: ; } } /* Time CHGEQZ with JOB='S', COMPQ='I', COMPZ='I' for each value of LDAS(j) */ if (timsub[8]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 9) = 0.f; opcnts_ref(ipar, itype, in, 9) = 0.f; goto L480; } /* If this value of LDA has occurred before, just use that value. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L450: */ } if (lastl == 0) { /* Time CHGEQZ with JOB='S', COMPQ='I', COMPZ='I' */ ic = 0; latime_1.ops = 0.f; s1 = second_(); L460: clacpy_("Full", &n, &n, &h__[1], &ldh, &a[1], &lda); clacpy_("Full", &n, &n, &t[1], &ldh, &b[1], &lda); chgeqz_("S", "I", "I", &n, &c__1, &n, &a[1], &lda, &b[ 1], &lda, &w[1], &w[lda + 1], &q[1], &lda, & z__[1], &lda, &work[1], lwork, &rwork[1], & iinfo); if (iinfo != 0) { io___59.ciunit = *nout; s_wsfe(&io___59); do_fio(&c__1, subnam_ref(0, 9), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L460; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &h__[1], &ldh, &z__[1], & lda); clacpy_("Full", &n, &n, &t[1], &ldh, &z__[1], & lda); /* L470: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 9) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 9) = latime_1.ops / (real) ic; lds = lda; ldq = lda; } else { opcnts_ref(ipar, itype, in, 9) = opcnts_ref(lastl, itype, in, 9); times_ref(ipar, itype, in, 9) = times_ref(lastl, itype, in, 9); } L480: ; } } /* . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Time CTGEVC */ if (timsub[9] || timsub[10] || timsub[11] || timsub[12]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { for (j = 10; j <= 13; ++j) { if (timsub[j - 1]) { times_ref(ipar, itype, in, j) = 0.f; opcnts_ref(ipar, itype, in, j) = 0.f; } /* L490: */ } goto L610; } /* If this value of LDA has come up before, just use the value previously computed. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L500: */ } /* Time CTGEVC if this is a new value of LDA */ if (lastl == 0) { /* Copy S (which is in A) and P (which is in B) if necessary to get right LDA. */ if (lda > lds) { for (jc = n; jc >= 1; --jc) { for (jr = n; jr >= 1; --jr) { i__4 = jr + (jc - 1) * lda; i__5 = jr + (jc - 1) * lds; a[i__4].r = a[i__5].r, a[i__4].i = a[i__5] .i; i__4 = jr + (jc - 1) * lda; i__5 = jr + (jc - 1) * lds; b[i__4].r = b[i__5].r, b[i__4].i = b[i__5] .i; /* L510: */ } /* L520: */ } } else if (lda < lds) { i__4 = n; for (jc = 1; jc <= i__4; ++jc) { i__5 = n; for (jr = 1; jr <= i__5; ++jr) { i__6 = jr + (jc - 1) * lda; i__7 = jr + (jc - 1) * lds; a[i__6].r = a[i__7].r, a[i__6].i = a[i__7] .i; i__6 = jr + (jc - 1) * lda; i__7 = jr + (jc - 1) * lds; b[i__6].r = b[i__7].r, b[i__6].i = b[i__7] .i; /* L530: */ } /* L540: */ } } lds = lda; /* Time CTGEVC for Left Eigenvectors only, without back transforming */ if (timsub[9]) { ic = 0; latime_1.ops = 0.f; s1 = second_(); L550: ctgevc_("L", "A", &llwork[1], &n, &a[1], &lda, &b[ 1], &lda, &h__[1], &lda, &t[1], &lda, &n, &itemp, &work[1], &rwork[1], &iinfo); if (iinfo != 0) { io___61.ciunit = *nout; s_wsfe(&io___61); do_fio(&c__1, subnam_ref(0, 10), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen) sizeof(integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L550; } times_ref(ipar, itype, in, 10) = time / (real) ic; opcnts_ref(ipar, itype, in, 10) = latime_1.ops / ( real) ic; } /* Time CTGEVC for Left Eigenvectors only, with back transforming */ if (timsub[10]) { ic = 0; latime_1.ops = 0.f; s1 = second_(); L560: clacpy_("Full", &n, &n, &q[1], &ldq, &h__[1], & lda); ctgevc_("L", "B", &llwork[1], &n, &a[1], &lda, &b[ 1], &lda, &h__[1], &lda, &t[1], &lda, &n, &itemp, &work[1], &rwork[1], &iinfo); if (iinfo != 0) { io___62.ciunit = *nout; s_wsfe(&io___62); do_fio(&c__1, subnam_ref(0, 11), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen) sizeof(integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L560; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &q[1], &ldq, &h__[1], &lda); /* L570: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 11) = dmax(r__1,0.f) / (real) ic; opcnts_ref(ipar, itype, in, 11) = latime_1.ops / ( real) ic; } /* Time CTGEVC for Right Eigenvectors only, without back transforming */ if (timsub[11]) { ic = 0; latime_1.ops = 0.f; s1 = second_(); L580: ctgevc_("R", "A", &llwork[1], &n, &a[1], &lda, &b[ 1], &lda, &h__[1], &lda, &t[1], &lda, &n, &itemp, &work[1], &rwork[1], &iinfo); if (iinfo != 0) { io___63.ciunit = *nout; s_wsfe(&io___63); do_fio(&c__1, subnam_ref(0, 12), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen) sizeof(integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L580; } times_ref(ipar, itype, in, 12) = time / (real) ic; opcnts_ref(ipar, itype, in, 12) = latime_1.ops / ( real) ic; } /* Time CTGEVC for Right Eigenvectors only, with back transforming */ if (timsub[12]) { ic = 0; latime_1.ops = 0.f; s1 = second_(); L590: clacpy_("Full", &n, &n, &q[1], &ldq, &t[1], &lda); ctgevc_("R", "B", &llwork[1], &n, &a[1], &lda, &b[ 1], &lda, &h__[1], &lda, &t[1], &lda, &n, &itemp, &work[1], &rwork[1], &iinfo); if (iinfo != 0) { io___64.ciunit = *nout; s_wsfe(&io___64); do_fio(&c__1, subnam_ref(0, 13), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen) sizeof(integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L590; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { clacpy_("Full", &n, &n, &q[1], &ldq, &t[1], & lda); /* L600: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 13) = dmax(r__1,0.f) / (real) ic; opcnts_ref(ipar, itype, in, 13) = latime_1.ops / ( real) ic; } } else { /* If this LDA has previously appeared, use the previously computed value(s). */ if (timsub[9]) { opcnts_ref(ipar, itype, in, 10) = opcnts_ref( lastl, itype, in, 10); times_ref(ipar, itype, in, 10) = times_ref(lastl, itype, in, 10); } if (timsub[10]) { opcnts_ref(ipar, itype, in, 11) = opcnts_ref( lastl, itype, in, 11); times_ref(ipar, itype, in, 11) = times_ref(lastl, itype, in, 11); } if (timsub[11]) { opcnts_ref(ipar, itype, in, 12) = opcnts_ref( lastl, itype, in, 12); times_ref(ipar, itype, in, 12) = times_ref(lastl, itype, in, 12); } if (timsub[12]) { opcnts_ref(ipar, itype, in, 13) = opcnts_ref( lastl, itype, in, 13); times_ref(ipar, itype, in, 13) = times_ref(lastl, itype, in, 13); } } L610: ; } } /* Time the EISPACK Routines Restore random number seed */ for (j = 1; j <= 4; ++j) { iseed[j] = ioldsd[j - 1]; /* L620: */ } /* Re-generate A */ if (itype <= 4) { /* Generate A (w/o rotation) */ clatm4_(&katype[itype - 1], &n, &c__3, &c__1, &c_true, &c_b26, &ulp, &c_b26, &c__2, &iseed[1], &h__[1], &n1); if (n >= 3) { i__3 = (n1 << 1) + 3; h__[i__3].r = 1.f, h__[i__3].i = 0.f; } /* Generate B (w/o rotation) */ clatm4_(&c__8, &n, &c__3, &c__1, &c_false, &c_b26, &c_b26, & c_b26, &c__2, &iseed[1], &t[1], &n1); if (n >= 2) { i__3 = n1 + 2; t[i__3].r = 1.f, t[i__3].i = 0.f; } if (n > 0) { /* Include rotations Generate U, V as Householder transformations times a diagonal matrix. (Note that CLARFG makes Q(jc+ic) and Z(jc+ic) real.) */ i__3 = n - 1; for (jc = 1; jc <= i__3; ++jc) { ic = (jc - 1) * n1; i__4 = n; for (jr = jc; jr <= i__4; ++jr) { i__5 = jr + ic; clarnd_(&q__1, &c__3, &iseed[1]); q[i__5].r = q__1.r, q[i__5].i = q__1.i; i__5 = jr + ic; clarnd_(&q__1, &c__3, &iseed[1]); z__[i__5].r = q__1.r, z__[i__5].i = q__1.i; /* L630: */ } i__4 = n + 1 - jc; clarfg_(&i__4, &q[jc + ic], &q[jc + 1 + ic], &c__1, & work[jc]); i__4 = (n << 1) + jc; i__5 = jc + ic; r__2 = q[i__5].r; r__1 = r_sign(&c_b26, &r__2); work[i__4].r = r__1, work[i__4].i = 0.f; i__4 = jc + ic; q[i__4].r = 1.f, q[i__4].i = 0.f; i__4 = n + 1 - jc; clarfg_(&i__4, &z__[jc + ic], &z__[jc + 1 + ic], & c__1, &work[n + jc]); i__4 = n * 3 + jc; i__5 = jc + ic; r__2 = z__[i__5].r; r__1 = r_sign(&c_b26, &r__2); work[i__4].r = r__1, work[i__4].i = 0.f; i__4 = jc + ic; z__[i__4].r = 1.f, z__[i__4].i = 0.f; /* L640: */ } ic = (n - 1) * n1; clarnd_(&q__1, &c__3, &iseed[1]); ctemp.r = q__1.r, ctemp.i = q__1.i; i__3 = n + ic; q[i__3].r = 1.f, q[i__3].i = 0.f; i__3 = n; work[i__3].r = 0.f, work[i__3].i = 0.f; i__3 = n * 3; r__1 = c_abs(&ctemp); q__1.r = ctemp.r / r__1, q__1.i = ctemp.i / r__1; work[i__3].r = q__1.r, work[i__3].i = q__1.i; clarnd_(&q__1, &c__3, &iseed[1]); ctemp.r = q__1.r, ctemp.i = q__1.i; i__3 = n + ic; z__[i__3].r = 1.f, z__[i__3].i = 0.f; i__3 = n << 1; work[i__3].r = 0.f, work[i__3].i = 0.f; i__3 = n << 2; r__1 = c_abs(&ctemp); q__1.r = ctemp.r / r__1, q__1.i = ctemp.i / r__1; work[i__3].r = q__1.r, work[i__3].i = q__1.i; /* Apply the diagonal matrices */ i__3 = n; for (jc = 1; jc <= i__3; ++jc) { i__4 = n; for (jr = 1; jr <= i__4; ++jr) { i__5 = jr + ic; i__6 = (n << 1) + jr; r_cnjg(&q__3, &work[n * 3 + jc]); q__2.r = work[i__6].r * q__3.r - work[i__6].i * q__3.i, q__2.i = work[i__6].r * q__3.i + work[i__6].i * q__3.r; i__7 = jr + ic; q__1.r = q__2.r * h__[i__7].r - q__2.i * h__[i__7] .i, q__1.i = q__2.r * h__[i__7].i + q__2.i * h__[i__7].r; h__[i__5].r = q__1.r, h__[i__5].i = q__1.i; i__5 = jr + ic; i__6 = (n << 1) + jr; i__7 = n * 3 + jc; q__3.r = work[i__6].r * work[i__7].r - work[i__6] .i * work[i__7].i, q__3.i = work[i__6].r * work[i__7].i + work[i__6].i * work[i__7] .r; r_cnjg(&q__4, &work[n * 3 + jc]); q__2.r = q__3.r * q__4.r - q__3.i * q__4.i, q__2.i = q__3.r * q__4.i + q__3.i * q__4.r; i__8 = jr + ic; q__1.r = q__2.r * t[i__8].r - q__2.i * t[i__8].i, q__1.i = q__2.r * t[i__8].i + q__2.i * t[ i__8].r; t[i__5].r = q__1.r, t[i__5].i = q__1.i; /* L650: */ } /* L660: */ } i__3 = n - 1; cunm2r_("L", "N", &n, &n, &i__3, &q[1], &n1, &work[1], & h__[1], &n1, &work[(n << 1) + 1], &iinfo); if (iinfo != 0) { goto L670; } i__3 = n - 1; cunm2r_("R", "C", &n, &n, &i__3, &z__[1], &n1, &work[n + 1], &h__[1], &n1, &work[(n << 1) + 1], &iinfo); if (iinfo != 0) { goto L670; } i__3 = n - 1; cunm2r_("L", "N", &n, &n, &i__3, &q[1], &n1, &work[1], &t[ 1], &n1, &work[(n << 1) + 1], &iinfo); if (iinfo != 0) { goto L670; } i__3 = n - 1; cunm2r_("R", "C", &n, &n, &i__3, &z__[1], &n1, &work[n + 1], &t[1], &n1, &work[(n << 1) + 1], &iinfo); if (iinfo != 0) { goto L670; } } L670: /* Copy real and imaginary parts into separate arrays */ i__3 = n * n; for (j = 1; j <= i__3; ++j) { i__4 = j; ar[j] = h__[i__4].r; ai[j] = r_imag(&h__[j]); i__4 = j; br[j] = t[i__4].r; bi[j] = r_imag(&t[j]); /* L680: */ } } /* Time CQZHES w/ MATZ=.FALSE. for each LDAS(j) */ if (timsub[13]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 14) = 0.f; opcnts_ref(ipar, itype, in, 14) = 0.f; goto L720; } /* If this value of LDA has come up before, just use the value previously computed. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L690: */ } if (lastl == 0) { /* Time CQZHES( ...,.FALSE.,..) */ ic = 0; latime_1.ops = 0.f; s1 = second_(); L700: slacpy_("Full", &n, &n, &ar[1], &n1, &hr[1], &lda); slacpy_("Full", &n, &n, &ai[1], &n1, &hi[1], &lda); slacpy_("Full", &n, &n, &br[1], &n1, &tr[1], &lda); slacpy_("Full", &n, &n, &bi[1], &n1, &ti[1], &lda); cqzhes_(&lda, &n, &hr[1], &hi[1], &tr[1], &ti[1], & c_false, &qr[1], &qi[1]); s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L700; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { slacpy_("Full", &n, &n, &ar[1], &n1, &zr[1], &lda); slacpy_("Full", &n, &n, &ai[1], &n1, &zi[1], &lda); slacpy_("Full", &n, &n, &br[1], &n1, &zr[1], &lda); slacpy_("Full", &n, &n, &bi[1], &n1, &zi[1], &lda); /* L710: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 14) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 14) = latime_1.ops / ( real) ic; } else { opcnts_ref(ipar, itype, in, 14) = opcnts_ref(lastl, itype, in, 14); times_ref(ipar, itype, in, 14) = times_ref(lastl, itype, in, 14); } ldh = lda; L720: ; } } else if (runhes) { slacpy_("Full", &n, &n, &ar[1], &n1, &hr[1], &n1); slacpy_("Full", &n, &n, &ai[1], &n1, &hi[1], &n1); slacpy_("Full", &n, &n, &br[1], &n1, &tr[1], &n1); slacpy_("Full", &n, &n, &bi[1], &n1, &ti[1], &n1); cqzhes_(&n1, &n, &hr[1], &hi[1], &tr[1], &ti[1], &c_false, & qr[1], &qi[1]); ldh = n1; } /* Time CQZHES w/ MATZ=.TRUE. for each LDAS(j) */ if (timsub[14]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 15) = 0.f; opcnts_ref(ipar, itype, in, 15) = 0.f; goto L760; } /* If this value of LDA has come up before, just use the value previously computed. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L730: */ } if (lastl == 0) { /* Time CQZHES( ...,.TRUE.,..) */ ic = 0; latime_1.ops = 0.f; s1 = second_(); L740: slacpy_("Full", &n, &n, &ar[1], &n1, &hr[1], &lda); slacpy_("Full", &n, &n, &ai[1], &n1, &hi[1], &lda); slacpy_("Full", &n, &n, &br[1], &n1, &tr[1], &lda); slacpy_("Full", &n, &n, &bi[1], &n1, &ti[1], &lda); cqzhes_(&lda, &n, &hr[1], &hi[1], &tr[1], &ti[1], & c_true, &qr[1], &qi[1]); s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L740; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { slacpy_("Full", &n, &n, &ar[1], &n1, &zr[1], &lda); slacpy_("Full", &n, &n, &ai[1], &n1, &zi[1], &lda); slacpy_("Full", &n, &n, &br[1], &n1, &zr[1], &lda); slacpy_("Full", &n, &n, &bi[1], &n1, &zi[1], &lda); /* L750: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 15) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 15) = latime_1.ops / ( real) ic; } else { opcnts_ref(ipar, itype, in, 15) = opcnts_ref(lastl, itype, in, 15); times_ref(ipar, itype, in, 15) = times_ref(lastl, itype, in, 15); } ldh = lda; L760: ; } } /* Time CQZVAL w/ MATZ=.FALSE. for each LDAS(j) */ if (timsub[15]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 16) = 0.f; opcnts_ref(ipar, itype, in, 16) = 0.f; goto L800; } /* If this value of LDA has come up before, just use the value previously computed. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L770: */ } if (lastl == 0) { /* Time CQZVAL with MATZ=.FALSE. */ ic = 0; latime_1.ops = 0.f; s1 = second_(); L780: slacpy_("Full", &n, &n, &hr[1], &ldh, &ar[1], &lda); slacpy_("Full", &n, &n, &hi[1], &ldh, &ai[1], &lda); slacpy_("Full", &n, &n, &tr[1], &ldh, &br[1], &lda); slacpy_("Full", &n, &n, &ti[1], &ldh, &bi[1], &lda); cqzval_(&lda, &n, &ar[1], &ai[1], &br[1], &bi[1], & c_b419, &wr[1], &wr[lda + 1], &wr[(lda << 1) + 1], &c_false, &qr[1], &qi[1], &iinfo); if (iinfo != 0) { io___65.ciunit = *nout; s_wsfe(&io___65); do_fio(&c__1, subnam_ref(0, 16), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L780; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { slacpy_("Full", &n, &n, &hr[1], &ldh, &zr[1], & lda); slacpy_("Full", &n, &n, &hi[1], &ldh, &zi[1], & lda); slacpy_("Full", &n, &n, &tr[1], &ldh, &zr[1], & lda); slacpy_("Full", &n, &n, &ti[1], &ldh, &zi[1], & lda); /* L790: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 16) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 16) = latime_1.ops / ( real) ic; } else { opcnts_ref(ipar, itype, in, 16) = opcnts_ref(lastl, itype, in, 16); times_ref(ipar, itype, in, 16) = times_ref(lastl, itype, in, 16); } lds = 0; ldw = lda; L800: ; } } /* Time CQZVAL w/ MATZ=.TRUE. for each LDAS(j) */ if (timsub[16]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 17) = 0.f; opcnts_ref(ipar, itype, in, 17) = 0.f; goto L840; } /* If this value of LDA has come up before, just use the value previously computed. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L810: */ } if (lastl == 0) { /* Time CQZVAL with MATZ=.TRUE. */ ic = 0; latime_1.ops = 0.f; s1 = second_(); L820: slacpy_("Full", &n, &n, &hr[1], &ldh, &ar[1], &lda); slacpy_("Full", &n, &n, &hi[1], &ldh, &ai[1], &lda); slacpy_("Full", &n, &n, &tr[1], &ldh, &br[1], &lda); slacpy_("Full", &n, &n, &ti[1], &ldh, &bi[1], &lda); slaset_("Full", &n, &n, &c_b419, &c_b26, &qr[1], &lda); slaset_("Full", &n, &n, &c_b419, &c_b26, &qi[1], &lda); cqzval_(&lda, &n, &ar[1], &ai[1], &br[1], &bi[1], & c_b419, &wr[1], &wr[lda + 1], &wr[(lda << 1) + 1], &c_true, &qr[1], &qi[1], &iinfo); if (iinfo != 0) { io___67.ciunit = *nout; s_wsfe(&io___67); do_fio(&c__1, subnam_ref(0, 17), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)) ; do_fio(&c__1, (char *)&itype, (ftnlen)sizeof( integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof( integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof( integer)); e_wsfe(); *info = abs(iinfo); goto L930; } s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L820; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { slacpy_("Full", &n, &n, &hr[1], &ldh, &zr[1], & lda); slacpy_("Full", &n, &n, &hi[1], &ldh, &zi[1], & lda); slacpy_("Full", &n, &n, &tr[1], &ldh, &zr[1], & lda); slacpy_("Full", &n, &n, &ti[1], &ldh, &zi[1], & lda); slaset_("Full", &n, &n, &c_b419, &c_b26, &zr[1], & lda); slaset_("Full", &n, &n, &c_b419, &c_b26, &zi[1], & lda); /* L830: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 17) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 17) = latime_1.ops / ( real) ic; } else { opcnts_ref(ipar, itype, in, 17) = opcnts_ref(lastl, itype, in, 17); times_ref(ipar, itype, in, 17) = times_ref(lastl, itype, in, 17); } lds = lda; ldw = lda; L840: ; } } else if (runqz) { slacpy_("Full", &n, &n, &hr[1], &ldh, &ar[1], &n1); slacpy_("Full", &n, &n, &hi[1], &ldh, &ai[1], &n1); slacpy_("Full", &n, &n, &tr[1], &ldh, &br[1], &n1); slacpy_("Full", &n, &n, &ti[1], &ldh, &bi[1], &n1); slaset_("Full", &n, &n, &c_b419, &c_b26, &qr[1], &n1); slaset_("Full", &n, &n, &c_b419, &c_b26, &qi[1], &n1); cqzval_(&n1, &n, &ar[1], &ai[1], &br[1], &bi[1], &c_b419, &wr[ 1], &wr[n1 + 1], &wr[(n1 << 1) + 1], &c_true, &qr[1], &qi[1], &iinfo); if (iinfo != 0) { io___68.ciunit = *nout; s_wsfe(&io___68); do_fio(&c__1, subnam_ref(0, 17), (ftnlen)11); do_fio(&c__1, (char *)&iinfo, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&itype, (ftnlen)sizeof(integer)); do_fio(&c__1, (char *)&ipar, (ftnlen)sizeof(integer)); do_fio(&c__4, (char *)&ioldsd[0], (ftnlen)sizeof(integer)) ; e_wsfe(); *info = abs(iinfo); goto L930; } lds = n1; ldw = n1; } /* Time CQZVEC for each LDAS(j) */ if (timsub[17]) { i__3 = *nparms; for (ipar = 1; ipar <= i__3; ++ipar) { lda = ldas[ipar]; if (lda < n1) { times_ref(ipar, itype, in, 18) = 0.f; opcnts_ref(ipar, itype, in, 18) = 0.f; goto L920; } /* If this value of LDA has come up before, just use the value previously computed. */ lastl = 0; i__4 = ipar - 1; for (j = 1; j <= i__4; ++j) { if (lda == ldas[j]) { lastl = j; } /* L850: */ } if (lastl == 0) { /* Copy W if necessary to get right LDA. */ if (lda > ldw) { for (jc = 3; jc >= 1; --jc) { for (jr = n; jr >= 1; --jr) { wr[jr + (jc - 1) * lda] = wr[jr + (jc - 1) * ldw]; /* L860: */ } /* L870: */ } } else if (lda < ldw) { for (jc = 1; jc <= 3; ++jc) { i__4 = n; for (jr = 1; jr <= i__4; ++jr) { wr[jr + (jc - 1) * lda] = wr[jr + (jc - 1) * ldw]; /* L880: */ } /* L890: */ } } ldw = lda; /* Time CQZVEC */ ic = 0; latime_1.ops = 0.f; s1 = second_(); L900: slacpy_("Full", &n, &n, &ar[1], &lds, &hr[1], &lda); slacpy_("Full", &n, &n, &ai[1], &lds, &hi[1], &lda); slacpy_("Full", &n, &n, &br[1], &lds, &tr[1], &lda); slacpy_("Full", &n, &n, &bi[1], &lds, &ti[1], &lda); slacpy_("Full", &n, &n, &qr[1], &lds, &zr[1], &lda); slacpy_("Full", &n, &n, &qi[1], &lds, &zi[1], &lda); cqzvec_(&lda, &n, &hr[1], &hi[1], &tr[1], &ti[1], &wr[ 1], &wr[lda + 1], &wr[(lda << 1) + 1], &zr[1], &zi[1]); s2 = second_(); time = s2 - s1; ++ic; if (time < *timmin) { goto L900; } /* Subtract the time used in CLACPY. */ s1 = second_(); i__4 = ic; for (j = 1; j <= i__4; ++j) { slacpy_("Full", &n, &n, &ar[1], &lds, &zr[1], & lda); slacpy_("Full", &n, &n, &ai[1], &lds, &zi[1], & lda); slacpy_("Full", &n, &n, &br[1], &lds, &zr[1], & lda); slacpy_("Full", &n, &n, &bi[1], &lds, &zi[1], & lda); slacpy_("Full", &n, &n, &qr[1], &lds, &zr[1], & lda); slacpy_("Full", &n, &n, &qi[1], &lds, &zi[1], & lda); /* L910: */ } s2 = second_(); untime = s2 - s1; /* Computing MAX */ r__1 = time - untime; times_ref(ipar, itype, in, 18) = dmax(r__1,0.f) / ( real) ic; opcnts_ref(ipar, itype, in, 18) = latime_1.ops / ( real) ic; } else { opcnts_ref(ipar, itype, in, 18) = opcnts_ref(lastl, itype, in, 18); times_ref(ipar, itype, in, 18) = times_ref(lastl, itype, in, 18); } L920: ; } } L930: ; } /* L940: */ } /* Print a table of results for each timed routine. */ for (isub = 1; isub <= 18; ++isub) { if (timsub[isub - 1]) { sprtbg_(subnam_ref(0, isub), &mtypes, &dotype[1], nsizes, &nn[1], &inparm[isub - 1], pnames, nparms, &ldas[1], &nnb[1], & nshfts[1], &neisps[1], &minnbs[1], &minbks[1], & opcnts_ref(1, 1, 1, isub), ldo1, ldo2, ×_ref(1, 1, 1, isub), ldt1, ldt2, &rwork[1], &llwork[1], nout, (ftnlen) 11, (ftnlen)6); } /* L950: */ } return 0; /* End of CTIM51 */ } /* ctim51_ */ #undef opcnts_ref #undef subnam_ref #undef times_ref