| /* drotmg.f -- translated by f2c (version 20100827). |
| You must link the resulting object file with libf2c: |
| on Microsoft Windows system, link with libf2c.lib; |
| on Linux or Unix systems, link with .../path/to/libf2c.a -lm |
| or, if you install libf2c.a in a standard place, with -lf2c -lm |
| -- in that order, at the end of the command line, as in |
| cc *.o -lf2c -lm |
| Source for libf2c is in /netlib/f2c/libf2c.zip, e.g., |
| |
| http://www.netlib.org/f2c/libf2c.zip |
| */ |
| |
| #include "datatypes.h" |
| |
| /* Subroutine */ int drotmg_(doublereal *dd1, doublereal *dd2, doublereal * |
| dx1, doublereal *dy1, doublereal *dparam) |
| { |
| /* Initialized data */ |
| |
| static doublereal zero = 0.; |
| static doublereal one = 1.; |
| static doublereal two = 2.; |
| static doublereal gam = 4096.; |
| static doublereal gamsq = 16777216.; |
| static doublereal rgamsq = 5.9604645e-8; |
| |
| /* Format strings */ |
| static char fmt_120[] = ""; |
| static char fmt_150[] = ""; |
| static char fmt_180[] = ""; |
| static char fmt_210[] = ""; |
| |
| /* System generated locals */ |
| doublereal d__1; |
| |
| /* Local variables */ |
| doublereal du, dp1, dp2, dq1, dq2, dh11, dh12, dh21, dh22; |
| integer igo; |
| doublereal dflag, dtemp; |
| |
| /* Assigned format variables */ |
| static char *igo_fmt; |
| |
| /* .. Scalar Arguments .. */ |
| /* .. */ |
| /* .. Array Arguments .. */ |
| /* .. */ |
| |
| /* Purpose */ |
| /* ======= */ |
| |
| /* CONSTRUCT THE MODIFIED GIVENS TRANSFORMATION MATRIX H WHICH ZEROS */ |
| /* THE SECOND COMPONENT OF THE 2-VECTOR (DSQRT(DD1)*DX1,DSQRT(DD2)* */ |
| /* DY2)**T. */ |
| /* WITH DPARAM(1)=DFLAG, H HAS ONE OF THE FOLLOWING FORMS.. */ |
| |
| /* DFLAG=-1.D0 DFLAG=0.D0 DFLAG=1.D0 DFLAG=-2.D0 */ |
| |
| /* (DH11 DH12) (1.D0 DH12) (DH11 1.D0) (1.D0 0.D0) */ |
| /* H=( ) ( ) ( ) ( ) */ |
| /* (DH21 DH22), (DH21 1.D0), (-1.D0 DH22), (0.D0 1.D0). */ |
| /* LOCATIONS 2-4 OF DPARAM CONTAIN DH11, DH21, DH12, AND DH22 */ |
| /* RESPECTIVELY. (VALUES OF 1.D0, -1.D0, OR 0.D0 IMPLIED BY THE */ |
| /* VALUE OF DPARAM(1) ARE NOT STORED IN DPARAM.) */ |
| |
| /* THE VALUES OF GAMSQ AND RGAMSQ SET IN THE DATA STATEMENT MAY BE */ |
| /* INEXACT. THIS IS OK AS THEY ARE ONLY USED FOR TESTING THE SIZE */ |
| /* OF DD1 AND DD2. ALL ACTUAL SCALING OF DATA IS DONE USING GAM. */ |
| |
| |
| /* Arguments */ |
| /* ========= */ |
| |
| /* DD1 (input/output) DOUBLE PRECISION */ |
| |
| /* DD2 (input/output) DOUBLE PRECISION */ |
| |
| /* DX1 (input/output) DOUBLE PRECISION */ |
| |
| /* DY1 (input) DOUBLE PRECISION */ |
| |
| /* DPARAM (input/output) DOUBLE PRECISION array, dimension 5 */ |
| /* DPARAM(1)=DFLAG */ |
| /* DPARAM(2)=DH11 */ |
| /* DPARAM(3)=DH21 */ |
| /* DPARAM(4)=DH12 */ |
| /* DPARAM(5)=DH22 */ |
| |
| /* ===================================================================== */ |
| |
| /* .. Local Scalars .. */ |
| /* .. */ |
| /* .. Intrinsic Functions .. */ |
| /* .. */ |
| /* .. Data statements .. */ |
| |
| /* Parameter adjustments */ |
| --dparam; |
| |
| /* Function Body */ |
| /* .. */ |
| if (! (*dd1 < zero)) { |
| goto L10; |
| } |
| /* GO ZERO-H-D-AND-DX1.. */ |
| goto L60; |
| L10: |
| /* CASE-DD1-NONNEGATIVE */ |
| dp2 = *dd2 * *dy1; |
| if (! (dp2 == zero)) { |
| goto L20; |
| } |
| dflag = -two; |
| goto L260; |
| /* REGULAR-CASE.. */ |
| L20: |
| dp1 = *dd1 * *dx1; |
| dq2 = dp2 * *dy1; |
| dq1 = dp1 * *dx1; |
| |
| if (! (abs(dq1) > abs(dq2))) { |
| goto L40; |
| } |
| dh21 = -(*dy1) / *dx1; |
| dh12 = dp2 / dp1; |
| |
| du = one - dh12 * dh21; |
| |
| if (! (du <= zero)) { |
| goto L30; |
| } |
| /* GO ZERO-H-D-AND-DX1.. */ |
| goto L60; |
| L30: |
| dflag = zero; |
| *dd1 /= du; |
| *dd2 /= du; |
| *dx1 *= du; |
| /* GO SCALE-CHECK.. */ |
| goto L100; |
| L40: |
| if (! (dq2 < zero)) { |
| goto L50; |
| } |
| /* GO ZERO-H-D-AND-DX1.. */ |
| goto L60; |
| L50: |
| dflag = one; |
| dh11 = dp1 / dp2; |
| dh22 = *dx1 / *dy1; |
| du = one + dh11 * dh22; |
| dtemp = *dd2 / du; |
| *dd2 = *dd1 / du; |
| *dd1 = dtemp; |
| *dx1 = *dy1 * du; |
| /* GO SCALE-CHECK */ |
| goto L100; |
| /* PROCEDURE..ZERO-H-D-AND-DX1.. */ |
| L60: |
| dflag = -one; |
| dh11 = zero; |
| dh12 = zero; |
| dh21 = zero; |
| dh22 = zero; |
| |
| *dd1 = zero; |
| *dd2 = zero; |
| *dx1 = zero; |
| /* RETURN.. */ |
| goto L220; |
| /* PROCEDURE..FIX-H.. */ |
| L70: |
| if (! (dflag >= zero)) { |
| goto L90; |
| } |
| |
| if (! (dflag == zero)) { |
| goto L80; |
| } |
| dh11 = one; |
| dh22 = one; |
| dflag = -one; |
| goto L90; |
| L80: |
| dh21 = -one; |
| dh12 = one; |
| dflag = -one; |
| L90: |
| switch (igo) { |
| case 0: goto L120; |
| case 1: goto L150; |
| case 2: goto L180; |
| case 3: goto L210; |
| } |
| /* PROCEDURE..SCALE-CHECK */ |
| L100: |
| L110: |
| if (! (*dd1 <= rgamsq)) { |
| goto L130; |
| } |
| if (*dd1 == zero) { |
| goto L160; |
| } |
| igo = 0; |
| igo_fmt = fmt_120; |
| /* FIX-H.. */ |
| goto L70; |
| L120: |
| /* Computing 2nd power */ |
| d__1 = gam; |
| *dd1 *= d__1 * d__1; |
| *dx1 /= gam; |
| dh11 /= gam; |
| dh12 /= gam; |
| goto L110; |
| L130: |
| L140: |
| if (! (*dd1 >= gamsq)) { |
| goto L160; |
| } |
| igo = 1; |
| igo_fmt = fmt_150; |
| /* FIX-H.. */ |
| goto L70; |
| L150: |
| /* Computing 2nd power */ |
| d__1 = gam; |
| *dd1 /= d__1 * d__1; |
| *dx1 *= gam; |
| dh11 *= gam; |
| dh12 *= gam; |
| goto L140; |
| L160: |
| L170: |
| if (! (abs(*dd2) <= rgamsq)) { |
| goto L190; |
| } |
| if (*dd2 == zero) { |
| goto L220; |
| } |
| igo = 2; |
| igo_fmt = fmt_180; |
| /* FIX-H.. */ |
| goto L70; |
| L180: |
| /* Computing 2nd power */ |
| d__1 = gam; |
| *dd2 *= d__1 * d__1; |
| dh21 /= gam; |
| dh22 /= gam; |
| goto L170; |
| L190: |
| L200: |
| if (! (abs(*dd2) >= gamsq)) { |
| goto L220; |
| } |
| igo = 3; |
| igo_fmt = fmt_210; |
| /* FIX-H.. */ |
| goto L70; |
| L210: |
| /* Computing 2nd power */ |
| d__1 = gam; |
| *dd2 /= d__1 * d__1; |
| dh21 *= gam; |
| dh22 *= gam; |
| goto L200; |
| L220: |
| if (dflag < 0.) { |
| goto L250; |
| } else if (dflag == 0) { |
| goto L230; |
| } else { |
| goto L240; |
| } |
| L230: |
| dparam[3] = dh21; |
| dparam[4] = dh12; |
| goto L260; |
| L240: |
| dparam[2] = dh11; |
| dparam[5] = dh22; |
| goto L260; |
| L250: |
| dparam[2] = dh11; |
| dparam[3] = dh21; |
| dparam[4] = dh12; |
| dparam[5] = dh22; |
| L260: |
| dparam[1] = dflag; |
| return 0; |
| } /* drotmg_ */ |
| |