1 INTEGER FUNCTION pilaenvx( ICTXT, ISPEC, NAME, OPTS, N1, N2, N3,
15 CHARACTER*( * ) name, opts
16 INTEGER ictxt, ispec, n1, n2, n3, n4
135 INTEGER i, ic, iz, nb, nbmin, nx, nprow, npcol, myrow,
138 CHARACTER c1*1, c2*2, c4*2, c3*3, subnam*6
141 INTRINSIC char, ichar, int,
min, real
149 IF( ispec.GT.23 )
GO TO 990
150 GO TO ( 10, 10, 10, 80, 90, 100, 110, 120,
151 $ 130, 140, 150, 160, 160, 160, 160, 160,
152 $ 170, 180, 190, 200, 210, 220, 230, 160)ispec
165 ic = ichar( subnam( 1: 1 ) )
167 IF( iz.EQ.90 .OR. iz.EQ.122 )
THEN
171 IF( ic.GE.97 .AND. ic.LE.122 )
THEN
172 subnam( 1: 1 ) = char( ic-32 )
174 ic = ichar( subnam( i: i ) )
175 IF( ic.GE.97 .AND. ic.LE.122 )
176 $ subnam( i: i ) = char( ic-32 )
180 ELSE IF( iz.EQ.233 .OR. iz.EQ.169 )
THEN
184 IF( ( ic.GE.129 .AND. ic.LE.137 ) .OR.
185 $ ( ic.GE.145 .AND. ic.LE.153 ) .OR.
186 $ ( ic.GE.162 .AND. ic.LE.169 ) )
THEN
187 subnam( 1: 1 ) = char( ic+64 )
189 ic = ichar( subnam( i: i ) )
190 IF( ( ic.GE.129 .AND. ic.LE.137 ) .OR.
191 $ ( ic.GE.145 .AND. ic.LE.153 ) .OR.
192 $ ( ic.GE.162 .AND. ic.LE.169 ) )subnam( i:
193 $ i ) = char( ic+64 )
197 ELSE IF( iz.EQ.218 .OR. iz.EQ.250 )
THEN
201 IF( ic.GE.225 .AND. ic.LE.250 )
THEN
202 subnam( 1: 1 ) = char( ic-32 )
204 ic = ichar( subnam( i: i ) )
205 IF( ic.GE.225 .AND. ic.LE.250 )
206 $ subnam( i: i ) = char( ic-32 )
212 sname = c1.EQ.
'S' .OR. c1.EQ.
'D'
213 cname = c1.EQ.
'C' .OR. c1.EQ.
'Z'
214 IF( .NOT.( cname .OR. sname ) )
220 GO TO ( 50, 60, 70 )ispec
232 IF( c2.EQ.
'GE' )
THEN
233 IF( c3.EQ.
'TRF' )
THEN
239 ELSE IF( c3.EQ.'qrf.OR..EQ.
' C3'rqf.OR..EQ.
' C3'lqf.OR.
'
246.EQ.
ELSE IF( C3'hrd' )
THEN
252 ELSE IF( c3.EQ.
'BRD' )
THEN
258 ELSE IF( c3.EQ.
'TRI' )
THEN
265 ELSE IF( c2.EQ.
'PO' )
THEN
266 IF( c3.EQ.
'TRF' )
THEN
273 ELSE IF( c2.EQ.
'SY' )
THEN
274 IF( c3.EQ.
'TRF' )
THEN
280 ELSE IF( sname .AND. c3.EQ.
'TRD' )
THEN
282 ELSE IF( sname .AND. c3.EQ.
'GST' )
THEN
285 ELSE IF( cname .AND. c2.EQ.
'HE' )
THEN
286 IF( c3.EQ.
'TRF' )
THEN
288 ELSE IF( c3.EQ.
'TRD' )
THEN
290 ELSE IF( c3.EQ.
'GST' )
THEN
293 ELSE IF( sname .AND. c2.EQ.
'OR' )
THEN
294 IF( c3( 1: 1 ).EQ.
'G' )
THEN
295 IF( c4.EQ.
'QR' .OR. c4.EQ.
'RQ' .OR. c4.EQ.
'LQ' .OR. c4.EQ.
296 $
'QL' .OR. c4.EQ.
'HR' .OR. c4.EQ.
'TR' .OR. c4.EQ.
'BR' )
300 ELSE IF( c3( 1: 1 ).EQ.
'M' )
THEN
301 IF( c4.EQ.
'QR' .OR. c4.EQ.
'RQ' .OR. c4.EQ.
'LQ' .OR. c4.EQ.
302 $
'QL' .OR. c4.EQ.
'HR' .OR. c4.EQ.
'TR' .OR. c4.EQ.
'BR' )
307 ELSE IF( cname .AND. c2.EQ.
'UN' )
THEN
308 IF( c3( 1: 1 ).EQ.
'G' )
THEN
309 IF( c4.EQ.
'QR' .OR. c4.EQ.
'RQ' .OR. c4.EQ.
'LQ' .OR. c4.EQ.
310 $
'QL' .OR. c4.EQ.
'HR' .OR. c4.EQ.
'TR' .OR. c4.EQ.
'BR' )
314 ELSE IF( c3( 1: 1 ).EQ.
'M' )
THEN
315 IF( c4.EQ.
'QR' .OR. c4.EQ.
'RQ' .OR. c4.EQ.
'LQ' .OR. c4.EQ.
316 $
'QL' .OR. c4.EQ.
'HR' .OR. c4.EQ.
'TR' .OR. c4.EQ.
'BR' )
321 ELSE IF( c2.EQ.
'GB' )
THEN
322 IF( c3.EQ.
'TRF' )
THEN
337 ELSE IF( c2.EQ.
'PB' )
THEN
338 IF( c3.EQ.
'TRF' )
THEN
353 ELSE IF( c2.EQ.
'TR' )
THEN
354 IF( c3.EQ.
'TRI' )
THEN
361 ELSE IF( c2.EQ.
'LA' )
THEN
362 IF( c3.EQ.
'UUM' )
THEN
369 ELSE IF( sname .AND. c2.EQ.
'ST' )
THEN
370 IF( c3.EQ.
'EBZ' )
THEN
382 IF( c2.EQ.
'GE' )
THEN
383 IF( c3.EQ.
'QRF' .OR. c3.EQ.
'RQF' .OR. c3.EQ.
'LQF' .OR. c3.EQ.
390 ELSE IF( c3.EQ.
'HRD' )
THEN
396 ELSE IF( c3.EQ.
'BRD' )
THEN
402 ELSE IF( c3.EQ.
'TRI' )
THEN
409 ELSE IF( c2.EQ.
'SY' )
THEN
410 IF( c3.EQ.
'TRF' )
THEN
416 ELSE IF( sname .AND. c3.EQ.
'TRD' )
THEN
419 ELSE IF( cname .AND. c2.EQ.
'HE' )
THEN
420 IF( c3.EQ.
'TRD' )
THEN
423 ELSE IF( sname
'OR' )
THEN
424 IF( c3( 1: 1 ).EQ.
'G' )
THEN
425 IF( c4.EQ.'qr.OR..EQ.
' C4'rq.OR..EQ.
' C4'lq.OR..EQ.
' C4
426 $ 'ql.OR..EQ.
' C4'hr.OR..EQ.
' C4'tr.OR..EQ.
' C4'br
' )
430.EQ.
ELSE IF( C3( 1: 1 )'m
' ) THEN
431.EQ.
IF( C4'qr.OR..EQ.
' C4'rq.OR..EQ.
' C4'lq.OR..EQ.
' C4
432 $ 'ql.OR..EQ.
' C4'hr.OR..EQ.
' C4'tr.OR..EQ.
' C4'br
' )
437.AND..EQ.
ELSE IF( CNAME C2'un
' ) THEN
438.EQ.
IF( C3( 1: 1 )'g
' ) THEN
439.EQ.
IF( C4'qr.OR..EQ.
' C4'rq' .OR. c4.EQ.
'LQ' .OR. c4.EQ.
440 $
'QL' .OR. c4.EQ.
'HR' .OR. c4.EQ.'tr.OR..EQ.
' C4'br
' )
444.EQ.
ELSE IF( C3( 1: 1 )'m
' ) THEN
445.EQ.
IF( C4'qr.OR..EQ.
' C4'rq.OR..EQ.
' C4'lq.OR..EQ.
' C4
446 $ 'ql.OR..EQ.
' C4'hr.OR..EQ.
' C4'tr.OR..EQ.
' C4'br
' )
460.EQ.
IF( C2'ge
' ) THEN
461.EQ.
IF( C3'qrf.OR..EQ.
' C3'rqf.OR..EQ.
' C3'lqf.OR..EQ.
' C3
468.EQ.
ELSE IF( C3'hrd
' ) THEN
474.EQ.
ELSE IF( C3'brd
' ) THEN
481.EQ.
ELSE IF( C2'sy
' ) THEN
482.AND..EQ.
IF( SNAME C3'trd
' ) THEN
485.AND..EQ.
ELSE IF( CNAME C2'he
' ) THEN
486.EQ.
IF( C3'trd
' ) THEN
489.AND..EQ.
ELSE IF( SNAME C2'or
' ) THEN
490.EQ.
IF( C3( 1: 1 )'g
' ) THEN
491.EQ.
IF( C4'qr.OR..EQ.
' C4'rq.OR..EQ.
' C4'lq.OR..EQ.
' C4
492 $ 'ql.OR..EQ.
' C4'hr.OR..EQ.
' C4'tr.OR..EQ.
' C4'br
' )
497.AND..EQ.
ELSE IF( CNAME C2'un
' ) THEN
498.EQ.
IF( C3( 1: 1 )'g
' ) THEN
499.EQ.
IF( C4'qr.OR..EQ.
' C4'rq.OR..EQ.
' C4'lq.OR..EQ.
' C4
500 $ 'ql.OR..EQ.
' C4'hr.OR..EQ.
' C4'tr.OR..EQ.
' C4'br' )