📄 drotmg.f
字号:
SUBROUTINE DROTMG(DD1,DD2,DX1,DY1,DPARAM)* .. Scalar Arguments .. DOUBLE PRECISION DD1,DD2,DX1,DY1* ..* .. Array Arguments .. DOUBLE PRECISION DPARAM(5)* ..** 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 .. DOUBLE PRECISION DFLAG,DH11,DH12,DH21,DH22,DP1,DP2,DQ1,DQ2,DTEMP, + DU,GAM,GAMSQ,ONE,RGAMSQ,TWO,ZERO INTEGER IGO* ..* .. Intrinsic Functions .. INTRINSIC DABS* ..* .. Data statements ..* DATA ZERO,ONE,TWO/0.D0,1.D0,2.D0/ DATA GAM,GAMSQ,RGAMSQ/4096.D0,16777216.D0,5.9604645D-8/* .. IF (.NOT.DD1.LT.ZERO) GO TO 10* GO ZERO-H-D-AND-DX1.. GO TO 60 10 CONTINUE* CASE-DD1-NONNEGATIVE DP2 = DD2*DY1 IF (.NOT.DP2.EQ.ZERO) GO TO 20 DFLAG = -TWO GO TO 260* REGULAR-CASE.. 20 CONTINUE DP1 = DD1*DX1 DQ2 = DP2*DY1 DQ1 = DP1*DX1* IF (.NOT.DABS(DQ1).GT.DABS(DQ2)) GO TO 40 DH21 = -DY1/DX1 DH12 = DP2/DP1* DU = ONE - DH12*DH21* IF (.NOT.DU.LE.ZERO) GO TO 30* GO ZERO-H-D-AND-DX1.. GO TO 60 30 CONTINUE DFLAG = ZERO DD1 = DD1/DU DD2 = DD2/DU DX1 = DX1*DU* GO SCALE-CHECK.. GO TO 100 40 CONTINUE IF (.NOT.DQ2.LT.ZERO) GO TO 50* GO ZERO-H-D-AND-DX1.. GO TO 60 50 CONTINUE 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 GO TO 100* PROCEDURE..ZERO-H-D-AND-DX1.. 60 CONTINUE DFLAG = -ONE DH11 = ZERO DH12 = ZERO DH21 = ZERO DH22 = ZERO* DD1 = ZERO DD2 = ZERO DX1 = ZERO* RETURN.. GO TO 220* PROCEDURE..FIX-H.. 70 CONTINUE IF (.NOT.DFLAG.GE.ZERO) GO TO 90* IF (.NOT.DFLAG.EQ.ZERO) GO TO 80 DH11 = ONE DH22 = ONE DFLAG = -ONE GO TO 90 80 CONTINUE DH21 = -ONE DH12 = ONE DFLAG = -ONE 90 CONTINUE GO TO IGO(120,150,180,210)* PROCEDURE..SCALE-CHECK 100 CONTINUE 110 CONTINUE IF (.NOT.DD1.LE.RGAMSQ) GO TO 130 IF (DD1.EQ.ZERO) GO TO 160 ASSIGN 120 TO IGO* FIX-H.. GO TO 70 120 CONTINUE DD1 = DD1*GAM**2 DX1 = DX1/GAM DH11 = DH11/GAM DH12 = DH12/GAM GO TO 110 130 CONTINUE 140 CONTINUE IF (.NOT.DD1.GE.GAMSQ) GO TO 160 ASSIGN 150 TO IGO* FIX-H.. GO TO 70 150 CONTINUE DD1 = DD1/GAM**2 DX1 = DX1*GAM DH11 = DH11*GAM DH12 = DH12*GAM GO TO 140 160 CONTINUE 170 CONTINUE IF (.NOT.DABS(DD2).LE.RGAMSQ) GO TO 190 IF (DD2.EQ.ZERO) GO TO 220 ASSIGN 180 TO IGO* FIX-H.. GO TO 70 180 CONTINUE DD2 = DD2*GAM**2 DH21 = DH21/GAM DH22 = DH22/GAM GO TO 170 190 CONTINUE 200 CONTINUE IF (.NOT.DABS(DD2).GE.GAMSQ) GO TO 220 ASSIGN 210 TO IGO* FIX-H.. GO TO 70 210 CONTINUE DD2 = DD2/GAM**2 DH21 = DH21*GAM DH22 = DH22*GAM GO TO 200 220 CONTINUE IF (DFLAG) 250,230,240 230 CONTINUE DPARAM(3) = DH21 DPARAM(4) = DH12 GO TO 260 240 CONTINUE DPARAM(2) = DH11 DPARAM(5) = DH22 GO TO 260 250 CONTINUE DPARAM(2) = DH11 DPARAM(3) = DH21 DPARAM(4) = DH12 DPARAM(5) = DH22 260 CONTINUE DPARAM(1) = DFLAG RETURN END
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -