aboutsummaryrefslogtreecommitdiff
path: root/SRC/cla_hercond_x.f
diff options
context:
space:
mode:
authordeaglanhalligan <deaglanhalligan@8a072113-8704-0410-8d35-dd094bca7971>2009-02-13 23:58:46 +0000
committerdeaglanhalligan <deaglanhalligan@8a072113-8704-0410-8d35-dd094bca7971>2009-02-13 23:58:46 +0000
commit46e09e3c99a1c6aeedcde4281d7625a76f48d315 (patch)
tree942c090e0a2c3b96035d4a7187459c460cb35a5d /SRC/cla_hercond_x.f
parent165a76fe3b8aaf2e928c1a2ebdf0d9444d98a22f (diff)
Restructured loops in {c,z}la_yyrcond_{x,c} and {s,c,d,z}la_yyamv to do less comparisons.
Diffstat (limited to 'SRC/cla_hercond_x.f')
-rw-r--r--SRC/cla_hercond_x.f28
1 files changed, 13 insertions, 15 deletions
diff --git a/SRC/cla_hercond_x.f b/SRC/cla_hercond_x.f
index ce305ccd..1610e8ea 100644
--- a/SRC/cla_hercond_x.f
+++ b/SRC/cla_hercond_x.f
@@ -30,11 +30,11 @@
* Arguments
* =========
*
-* X COMPLEX vector.
+* X COMPLEX vector.
*
-* WORK COMPLEX workspace of size 2*N.
+* WORK COMPLEX workspace of size 2*N.
*
-* RWORK REAL workspace of size 3*N.
+* RWORK REAL workspace of size N.
*
* =====================================================================
*
@@ -84,12 +84,11 @@
IF ( UP ) THEN
DO I = 1, N
TMP = 0.0E+0
- DO J = 1, N
- IF ( I.GT.J ) THEN
- TMP = TMP + CABS1( A( J, I ) * X( J ) )
- ELSE
- TMP = TMP + CABS1( A( I, J ) * X( J ) )
- END IF
+ DO J = 1, I
+ TMP = TMP + CABS1( A( J, I ) * X( J ) )
+ END DO
+ DO J = I+1, N
+ TMP = TMP + CABS1( A( I, J ) * X( J ) )
END DO
RWORK( I ) = TMP
ANORM = MAX( ANORM, TMP )
@@ -97,12 +96,11 @@
ELSE
DO I = 1, N
TMP = 0.0E+0
- DO J = 1, N
- IF ( I.LT.J ) THEN
- TMP = TMP + CABS1( A( J, I ) * X( J ) )
- ELSE
- TMP = TMP + CABS1( A( I, J ) * X( J ) )
- END IF
+ DO J = 1, I
+ TMP = TMP + CABS1( A( I, J ) * X( J ) )
+ END DO
+ DO J = I+1, N
+ TMP = TMP + CABS1( A( J, I ) * X( J ) )
END DO
RWORK( I ) = TMP
ANORM = MAX( ANORM, TMP )