255 CHARACTER norm, transr, uplo
259 DOUBLE PRECISION work( 0: * )
266 DOUBLE PRECISION one, zero
267 parameter ( one = 1.0d+0, zero = 0.0d+0 )
270 INTEGER i, j, ifm, ilu, noe, n1, k, l, lda
271 DOUBLE PRECISION scale, s,
VALUE, aa, temp
281 INTRINSIC abs, dble, sqrt
288 ELSE IF( n.EQ.1 )
THEN
296 IF( mod( n, 2 ).EQ.0 )
302 IF(
lsame( transr,
'C' ) )
308 IF(
lsame( uplo,
'U' ) )
327 IF(
lsame( norm,
'M' ) )
THEN
341 temp = abs( dble( a( j+j*lda ) ) )
342 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
345 temp = abs( a( i+j*lda ) )
346 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
351 temp = abs( a( i+j*lda ) )
352 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
357 temp = abs( dble( a( i+j*lda ) ) )
358 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
362 temp = abs( dble( a( i+j*lda ) ) )
363 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
366 temp = abs( a( i+j*lda ) )
367 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
375 temp = abs( a( i+j*lda ) )
376 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
381 temp = abs( dble( a( i+j*lda ) ) )
382 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
386 temp = abs( dble( a( i+j*lda ) ) )
387 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
389 DO i = k + j + 1, n - 1
390 temp = abs( a( i+j*lda ) )
391 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
396 temp = abs( a( i+j*lda ) )
397 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
402 temp = abs( dble( a( i+j*lda ) ) )
403 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
412 temp = abs( a( i+j*lda ) )
413 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
418 temp = abs( dble( a( i+j*lda ) ) )
419 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
423 temp = abs( dble( a( i+j*lda ) ) )
424 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
427 temp = abs( a( i+j*lda ) )
428 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
434 temp = abs( a( i+j*lda ) )
435 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
440 temp = abs( dble( a( i+j*lda ) ) )
441 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
445 temp = abs( a( i+j*lda ) )
446 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
454 temp = abs( a( i+j*lda ) )
455 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
461 temp = abs( dble( a( 0+j*lda ) ) )
462 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
465 temp = abs( a( i+j*lda ) )
466 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
471 temp = abs( a( i+j*lda ) )
472 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
477 temp = abs( dble( a( i+j*lda ) ) )
478 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
482 temp = abs( dble( a( i+j*lda ) ) )
483 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
485 DO i = j - k + 2, k - 1
486 temp = abs( a( i+j*lda ) )
487 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
501 temp = abs( dble( a( j+j*lda ) ) )
502 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
504 temp = abs( dble( a( j+1+j*lda ) ) )
505 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
508 temp = abs( a( i+j*lda ) )
509 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
514 temp = abs( a( i+j*lda ) )
515 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
520 temp = abs( dble( a( i+j*lda ) ) )
521 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
525 temp = abs( dble( a( i+j*lda ) ) )
526 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
529 temp = abs( a( i+j*lda ) )
530 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
538 temp = abs( a( i+j*lda ) )
539 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
544 temp = abs( dble( a( i+j*lda ) ) )
545 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
549 temp = abs( dble( a( i+j*lda ) ) )
550 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
553 temp = abs( a( i+j*lda ) )
554 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
559 temp = abs( a( i+j*lda ) )
560 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
565 temp = abs( dble( a( i+j*lda ) ) )
566 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
570 temp = abs( dble( a( i+j*lda ) ) )
571 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
580 temp = abs( dble( a( j+j*lda ) ) )
581 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
584 temp = abs( a( i+j*lda ) )
585 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
590 temp = abs( a( i+j*lda ) )
591 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
596 temp = abs( dble( a( i+j*lda ) ) )
597 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
601 temp = abs( dble( a( i+j*lda ) ) )
602 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
605 temp = abs( a( i+j*lda ) )
606 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
612 temp = abs( a( i+j*lda ) )
613 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
618 temp = abs( dble( a( i+j*lda ) ) )
619 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
623 temp = abs( a( i+j*lda ) )
624 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
632 temp = abs( a( i+j*lda ) )
633 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
639 temp = abs( dble( a( 0+j*lda ) ) )
640 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
643 temp = abs( a( i+j*lda ) )
644 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
649 temp = abs( a( i+j*lda ) )
650 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
655 temp = abs( dble( a( i+j*lda ) ) )
656 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
660 temp = abs( dble( a( i+j*lda ) ) )
661 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
663 DO i = j - k + 1, k - 1
664 temp = abs( a( i+j*lda ) )
665 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
671 temp = abs( a( i+j*lda ) )
672 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
677 temp = abs( dble( a( i+j*lda ) ) )
678 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
683 ELSE IF( (
lsame( norm,
'I' ) ) .OR. (
lsame( norm,
'O' ) ) .OR.
684 $ ( norm.EQ.
'1' ) )
THEN
701 aa = abs( a( i+j*lda ) )
704 work( i ) = work( i ) + aa
706 aa = abs( dble( a( i+j*lda ) ) )
712 aa = abs( dble( a( i+j*lda ) ) )
714 work( j ) = work( j ) + aa
718 aa = abs( a( i+j*lda ) )
721 work( l ) = work( l ) + aa
723 work( j ) = work( j ) + s
729 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
742 aa = abs( a( i+j*lda ) )
745 work( i+k ) = work( i+k ) + aa
748 aa = abs( dble( a( i+j*lda ) ) )
751 work( i+k ) = work( i+k ) + s
755 aa = abs( dble( a( i+j*lda ) ) )
761 aa = abs( a( i+j*lda ) )
764 work( l ) = work( l ) + aa
766 work( j ) = work( j ) + s
771 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
785 aa = abs( a( i+j*lda ) )
788 work( i ) = work( i ) + aa
790 aa = abs( dble( a( i+j*lda ) ) )
794 aa = abs( dble( a( i+j*lda ) ) )
796 work( j ) = work( j ) + aa
800 aa = abs( a( i+j*lda ) )
803 work( l ) = work( l ) + aa
805 work( j ) = work( j ) + s
810 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
821 aa = abs( a( i+j*lda ) )
824 work( i+k ) = work( i+k ) + aa
826 aa = abs( dble( a( i+j*lda ) ) )
829 work( i+k ) = work( i+k ) + s
832 aa = abs( dble( a( i+j*lda ) ) )
838 aa = abs( a( i+j*lda ) )
841 work( l ) = work( l ) + aa
843 work( j ) = work( j ) + s
848 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
870 aa = abs( a( i+j*lda ) )
872 work( i+n1 ) = work( i+n1 ) + aa
878 s = abs( dble( a( 0+j*lda ) ) )
881 aa = abs( a( i+j*lda ) )
883 work( i+n1 ) = work( i+n1 ) + aa
886 work( j ) = work( j ) + s
890 aa = abs( a( i+j*lda ) )
892 work( i ) = work( i ) + aa
896 aa = abs( dble( a( i+j*lda ) ) )
899 work( j-k ) = work( j-k ) + s
901 s = abs( dble( a( i+j*lda ) ) )
905 aa = abs( a( i+j*lda ) )
907 work( l ) = work( l ) + aa
910 work( j ) = work( j ) + s
915 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
929 aa = abs( a( i+j*lda ) )
931 work( i ) = work( i ) + aa
934 aa = abs( dble( a( i+j*lda ) ) )
941 aa = abs( dble( a( i+j*lda ) ) )
943 DO l = k + j + 1, n - 1
945 aa = abs( a( i+j*lda ) )
948 work( l ) = work( l ) + aa
950 work( k+j ) = work( k+j ) + s
955 aa = abs( a( i+j*lda ) )
957 work( i ) = work( i ) + aa
961 aa = abs( dble( a( i+j*lda ) ) )
970 aa = abs( a( i+j*lda ) )
972 work( i ) = work( i ) + aa
975 work( j ) = work( j ) + s
980 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
994 aa = abs( a( i+j*lda ) )
996 work( i+k ) = work( i+k ) + aa
1002 aa = abs( dble( a( 0+j*lda ) ) )
1006 aa = abs( a( i+j*lda ) )
1008 work( i+k ) = work( i+k ) + aa
1011 work( j ) = work( j ) + s
1015 aa = abs( a( i+j*lda ) )
1017 work( i ) = work( i ) + aa
1021 aa = abs( dble( a( i+j*lda ) ) )
1024 work( j-k-1 ) = work( j-k-1 ) + s
1026 aa = abs( dble( a( i+j*lda ) ) )
1031 aa = abs( a( i+j*lda ) )
1033 work( l ) = work( l ) + aa
1036 work( j ) = work( j ) + s
1041 aa = abs( a( i+j*lda ) )
1043 work( i ) = work( i ) + aa
1047 aa = abs( dble( a( i+j*lda ) ) )
1050 work( i ) = work( i ) + s
1054 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
1063 s = abs( dble( a( 0 ) ) )
1068 work( i+k ) = work( i+k ) + aa
1071 work( k ) = work( k ) + s
1076 aa = abs( a( i+j*lda ) )
1078 work( i ) = work( i ) + aa
1081 aa = abs( dble( a( i+j*lda ) ) )
1088 aa = abs( dble( a( i+j*lda ) ) )
1090 DO l = k + j + 1, n - 1
1092 aa = abs( a( i+j*lda ) )
1095 work( l ) = work( l ) + aa
1097 work( k+j ) = work( k+j ) + s
1102 aa = abs( a( i+j*lda ) )
1104 work( i ) = work( i ) + aa
1109 aa = abs( dble( a( i+j*lda ) ) )
1119 aa = abs( a( i+j*lda ) )
1121 work( i ) = work( i ) + aa
1124 work( j-1 ) = work( j-1 ) + s
1129 IF(
VALUE .LT. temp .OR.
disnan( temp ) )
1135 ELSE IF( (
lsame( norm,
'F' ) ) .OR. (
lsame( norm,
'E' ) ) )
THEN
1149 CALL zlassq( k-j-2, a( k+j+1+j*lda ), 1, scale, s )
1153 CALL zlassq( k+j-1, a( 0+j*lda ), 1, scale, s )
1163 IF( aa.NE.zero )
THEN
1164 IF( scale.LT.aa )
THEN
1165 s = one + s*( scale / aa )**2
1168 s = s + ( aa / scale )**2
1171 aa = dble( a( l+1 ) )
1173 IF( aa.NE.zero )
THEN
1174 IF( scale.LT.aa )
THEN
1175 s = one + s*( scale / aa )**2
1178 s = s + ( aa / scale )**2
1185 IF( aa.NE.zero )
THEN
1186 IF( scale.LT.aa )
THEN
1187 s = one + s*( scale / aa )**2
1190 s = s + ( aa / scale )**2
1196 CALL zlassq( n-j-1, a( j+1+j*lda ), 1, scale, s )
1200 CALL zlassq( j, a( 0+( 1+j )*lda ), 1, scale, s )
1207 IF( aa.NE.zero )
THEN
1208 IF( scale.LT.aa )
THEN
1209 s = one + s*( scale / aa )**2
1212 s = s + ( aa / scale )**2
1220 IF( aa.NE.zero )
THEN
1221 IF( scale.LT.aa )
THEN
1222 s = one + s*( scale / aa )**2
1225 s = s + ( aa / scale )**2
1228 aa = dble( a( l+1 ) )
1230 IF( aa.NE.zero )
THEN
1231 IF( scale.LT.aa )
THEN
1232 s = one + s*( scale / aa )**2
1235 s = s + ( aa / scale )**2
1246 CALL zlassq( j, a( 0+( k+j )*lda ), 1, scale, s )
1250 CALL zlassq( k, a( 0+j*lda ), 1, scale, s )
1254 CALL zlassq( k-j-1, a( j+1+( j+k-1 )*lda ), 1,
1264 IF( aa.NE.zero )
THEN
1265 IF( scale.LT.aa )
THEN
1266 s = one + s*( scale / aa )**2
1269 s = s + ( aa / scale )**2
1277 IF( aa.NE.zero )
THEN
1278 IF( scale.LT.aa )
THEN
1279 s = one + s*( scale / aa )**2
1282 s = s + ( aa / scale )**2
1285 aa = dble( a( l+1 ) )
1287 IF( aa.NE.zero )
THEN
1288 IF( scale.LT.aa )
THEN
1289 s = one + s*( scale / aa )**2
1292 s = s + ( aa / scale )**2
1300 CALL zlassq( j, a( 0+j*lda ), 1, scale, s )
1304 CALL zlassq( k, a( 0+j*lda ), 1, scale, s )
1308 CALL zlassq( k-j-2, a( j+2+j*lda ), 1, scale, s )
1318 IF( aa.NE.zero )
THEN
1319 IF( scale.LT.aa )
THEN
1320 s = one + s*( scale / aa )**2
1323 s = s + ( aa / scale )**2
1326 aa = dble( a( l+1 ) )
1328 IF( aa.NE.zero )
THEN
1329 IF( scale.LT.aa )
THEN
1330 s = one + s*( scale / aa )**2
1333 s = s + ( aa / scale )**2
1341 IF( aa.NE.zero )
THEN
1342 IF( scale.LT.aa )
THEN
1343 s = one + s*( scale / aa )**2
1346 s = s + ( aa / scale )**2
1358 CALL zlassq( k-j-1, a( k+j+2+j*lda ), 1, scale, s )
1362 CALL zlassq( k+j, a( 0+j*lda ), 1, scale, s )
1372 IF( aa.NE.zero )
THEN
1373 IF( scale.LT.aa )
THEN
1374 s = one + s*( scale / aa )**2
1377 s = s + ( aa / scale )**2
1380 aa = dble( a( l+1 ) )
1382 IF( aa.NE.zero )
THEN
1383 IF( scale.LT.aa )
THEN
1384 s = one + s*( scale / aa )**2
1387 s = s + ( aa / scale )**2
1395 CALL zlassq( n-j-1, a( j+2+j*lda ), 1, scale, s )
1399 CALL zlassq( j, a( 0+j*lda ), 1, scale, s )
1409 IF( aa.NE.zero )
THEN
1410 IF( scale.LT.aa )
THEN
1411 s = one + s*( scale / aa )**2
1414 s = s + ( aa / scale )**2
1417 aa = dble( a( l+1 ) )
1419 IF( aa.NE.zero )
THEN
1420 IF( scale.LT.aa )
THEN
1421 s = one + s*( scale / aa )**2
1424 s = s + ( aa / scale )**2
1435 CALL zlassq( j, a( 0+( k+1+j )*lda ), 1, scale, s )
1439 CALL zlassq( k, a( 0+j*lda ), 1, scale, s )
1443 CALL zlassq( k-j-1, a( j+1+( j+k )*lda ), 1, scale,
1453 IF( aa.NE.zero )
THEN
1454 IF( scale.LT.aa )
THEN
1455 s = one + s*( scale / aa )**2
1458 s = s + ( aa / scale )**2
1466 IF( aa.NE.zero )
THEN
1467 IF( scale.LT.aa )
THEN
1468 s = one + s*( scale / aa )**2
1471 s = s + ( aa / scale )**2
1474 aa = dble( a( l+1 ) )
1476 IF( aa.NE.zero )
THEN
1477 IF( scale.LT.aa )
THEN
1478 s = one + s*( scale / aa )**2
1481 s = s + ( aa / scale )**2
1490 IF( aa.NE.zero )
THEN
1491 IF( scale.LT.aa )
THEN
1492 s = one + s*( scale / aa )**2
1495 s = s + ( aa / scale )**2
1501 CALL zlassq( j, a( 0+( j+1 )*lda ), 1, scale, s )
1505 CALL zlassq( k, a( 0+j*lda ), 1, scale, s )
1509 CALL zlassq( k-j-1, a( j+1+j*lda ), 1, scale, s )
1518 IF( aa.NE.zero )
THEN
1519 IF( scale.LT.aa )
THEN
1520 s = one + s*( scale / aa )**2
1523 s = s + ( aa / scale )**2
1531 IF( aa.NE.zero )
THEN
1532 IF( scale.LT.aa )
THEN
1533 s = one + s*( scale / aa )**2
1536 s = s + ( aa / scale )**2
1539 aa = dble( a( l+1 ) )
1541 IF( aa.NE.zero )
THEN
1542 IF( scale.LT.aa )
THEN
1543 s = one + s*( scale / aa )**2
1546 s = s + ( aa / scale )**2
1554 IF( aa.NE.zero )
THEN
1555 IF( scale.LT.aa )
THEN
1556 s = one + s*( scale / aa )**2
1559 s = s + ( aa / scale )**2
1565 VALUE = scale*sqrt( s )
logical function disnan(DIN)
DISNAN tests input for NaN.
double precision function zlanhf(NORM, TRANSR, UPLO, N, A, WORK)
ZLANHF returns the value of the 1-norm, or the Frobenius norm, or the infinity norm, or the element of largest absolute value of a Hermitian matrix in RFP format.
subroutine zlassq(N, X, INCX, SCALE, SUMSQ)
ZLASSQ updates a sum of squares represented in scaled form.
logical function lsame(CA, CB)
LSAME