/* 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 */ void 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;
  (void)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;
} /* drotmg_ */