sdpst.f 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286
  1. *DECK SDPST
  2. SUBROUTINE SDPST (EL, F, FA, H, IMPL, JACOBN, MATDIM, MITER, ML,
  3. 8 MU, N, NDE, NQ, SAVE2, T, USERS, Y, YH, YWT, UROUND, NFE, NJE,
  4. 8 A, DFDY, FAC, IER, IPVT, SAVE1, ISWFLG, BND, JSTATE)
  5. C***BEGIN PROLOGUE SDPST
  6. C***SUBSIDIARY
  7. C***PURPOSE Subroutine SDPST evaluates the Jacobian matrix of the right
  8. C hand side of the differential equations.
  9. C***LIBRARY SLATEC (SDRIVE)
  10. C***TYPE SINGLE PRECISION (SDPST-S, DDPST-D, CDPST-C)
  11. C***AUTHOR Kahaner, D. K., (NIST)
  12. C National Institute of Standards and Technology
  13. C Gaithersburg, MD 20899
  14. C Sutherland, C. D., (LANL)
  15. C Mail Stop D466
  16. C Los Alamos National Laboratory
  17. C Los Alamos, NM 87545
  18. C***DESCRIPTION
  19. C
  20. C If MITER is 1, 2, 4, or 5, the matrix
  21. C P = I - L(0)*H*Jacobian is stored in DFDY and subjected to LU
  22. C decomposition, with the results also stored in DFDY.
  23. C***ROUTINES CALLED SGBFA, SGEFA, SNRM2
  24. C***REVISION HISTORY (YYMMDD)
  25. C 790601 DATE WRITTEN
  26. C 900329 Initial submission to SLATEC.
  27. C***END PROLOGUE SDPST
  28. INTEGER I, IFLAG, IMAX, IMPL, INFO, ISWFLG, J, J2, JSTATE, K,
  29. 8 MATDIM, MITER, ML, MU, MW, N, NDE, NFE, NJE, NQ
  30. REAL A(MATDIM,*), BL, BND, BP, BR, BU, DFDY(MATDIM,*),
  31. 8 DFDYMX, DIFF, DY, EL(13,12), FAC(*), FACMAX, FACMIN, FACTOR,
  32. 8 H, SAVE1(*), SAVE2(*), SCALE, SNRM2, T, UROUND, Y(*),
  33. 8 YH(N,*), YJ, YS, YWT(*)
  34. INTEGER IPVT(*)
  35. LOGICAL IER
  36. PARAMETER(FACMAX = .5E0, BU = 0.5E0)
  37. C***FIRST EXECUTABLE STATEMENT SDPST
  38. NJE = NJE + 1
  39. IER = .FALSE.
  40. IF (MITER .EQ. 1 .OR. MITER .EQ. 2) THEN
  41. IF (MITER .EQ. 1) THEN
  42. CALL JACOBN (N, T, Y, DFDY, MATDIM, ML, MU)
  43. IF (N .EQ. 0) THEN
  44. JSTATE = 8
  45. RETURN
  46. END IF
  47. IF (ISWFLG .EQ. 3) BND = SNRM2(N*N, DFDY, 1)
  48. FACTOR = -EL(1,NQ)*H
  49. DO 110 J = 1,N
  50. DO 110 I = 1,N
  51. 110 DFDY(I,J) = FACTOR*DFDY(I,J)
  52. ELSE IF (MITER .EQ. 2) THEN
  53. BR = UROUND**(.875E0)
  54. BL = UROUND**(.75E0)
  55. BP = UROUND**(-.15E0)
  56. FACMIN = UROUND**(.78E0)
  57. DO 170 J = 1,N
  58. YS = MAX(ABS(YWT(J)), ABS(Y(J)))
  59. 120 DY = FAC(J)*YS
  60. IF (DY .EQ. 0.E0) THEN
  61. IF (FAC(J) .LT. FACMAX) THEN
  62. FAC(J) = MIN(100.E0*FAC(J), FACMAX)
  63. GO TO 120
  64. ELSE
  65. DY = YS
  66. END IF
  67. END IF
  68. IF (NQ .EQ. 1) THEN
  69. DY = SIGN(DY, SAVE2(J))
  70. ELSE
  71. DY = SIGN(DY, YH(J,3))
  72. END IF
  73. DY = (Y(J) + DY) - Y(J)
  74. YJ = Y(J)
  75. Y(J) = Y(J) + DY
  76. CALL F (N, T, Y, SAVE1)
  77. IF (N .EQ. 0) THEN
  78. JSTATE = 6
  79. RETURN
  80. END IF
  81. Y(J) = YJ
  82. FACTOR = -EL(1,NQ)*H/DY
  83. DO 140 I = 1,N
  84. 140 DFDY(I,J) = (SAVE1(I) - SAVE2(I))*FACTOR
  85. C Step 1
  86. DIFF = ABS(SAVE2(1) - SAVE1(1))
  87. IMAX = 1
  88. DO 150 I = 2,N
  89. IF (ABS(SAVE2(I) - SAVE1(I)) .GT. DIFF) THEN
  90. IMAX = I
  91. DIFF = ABS(SAVE2(I) - SAVE1(I))
  92. END IF
  93. 150 CONTINUE
  94. C Step 2
  95. IF (MIN(ABS(SAVE2(IMAX)), ABS(SAVE1(IMAX))) .GT. 0.E0) THEN
  96. SCALE = MAX(ABS(SAVE2(IMAX)), ABS(SAVE1(IMAX)))
  97. C Step 3
  98. IF (DIFF .GT. BU*SCALE) THEN
  99. FAC(J) = MAX(FACMIN, FAC(J)*.5E0)
  100. ELSE IF (BR*SCALE .LE. DIFF .AND. DIFF .LE. BL*SCALE) THEN
  101. FAC(J) = MIN(FAC(J)*2.E0, FACMAX)
  102. C Step 4
  103. ELSE IF (DIFF .LT. BR*SCALE) THEN
  104. FAC(J) = MIN(BP*FAC(J), FACMAX)
  105. END IF
  106. END IF
  107. 170 CONTINUE
  108. IF (ISWFLG .EQ. 3) BND = SNRM2(N*N, DFDY, 1)/(-EL(1,NQ)*H)
  109. NFE = NFE + N
  110. END IF
  111. IF (IMPL .EQ. 0) THEN
  112. DO 190 I = 1,N
  113. 190 DFDY(I,I) = DFDY(I,I) + 1.E0
  114. ELSE IF (IMPL .EQ. 1) THEN
  115. CALL FA (N, T, Y, A, MATDIM, ML, MU, NDE)
  116. IF (N .EQ. 0) THEN
  117. JSTATE = 9
  118. RETURN
  119. END IF
  120. DO 210 J = 1,N
  121. DO 210 I = 1,N
  122. 210 DFDY(I,J) = DFDY(I,J) + A(I,J)
  123. ELSE IF (IMPL .EQ. 2) THEN
  124. CALL FA (N, T, Y, A, MATDIM, ML, MU, NDE)
  125. IF (N .EQ. 0) THEN
  126. JSTATE = 9
  127. RETURN
  128. END IF
  129. DO 230 I = 1,NDE
  130. 230 DFDY(I,I) = DFDY(I,I) + A(I,1)
  131. ELSE IF (IMPL .EQ. 3) THEN
  132. CALL FA (N, T, Y, A, MATDIM, ML, MU, NDE)
  133. IF (N .EQ. 0) THEN
  134. JSTATE = 9
  135. RETURN
  136. END IF
  137. DO 220 J = 1,NDE
  138. DO 220 I = 1,NDE
  139. 220 DFDY(I,J) = DFDY(I,J) + A(I,J)
  140. END IF
  141. CALL SGEFA (DFDY, MATDIM, N, IPVT, INFO)
  142. IF (INFO .NE. 0) IER = .TRUE.
  143. ELSE IF (MITER .EQ. 4 .OR. MITER .EQ. 5) THEN
  144. IF (MITER .EQ. 4) THEN
  145. CALL JACOBN (N, T, Y, DFDY(ML+1,1), MATDIM, ML, MU)
  146. IF (N .EQ. 0) THEN
  147. JSTATE = 8
  148. RETURN
  149. END IF
  150. FACTOR = -EL(1,NQ)*H
  151. MW = ML + MU + 1
  152. DO 260 J = 1,N
  153. DO 260 I = MAX(ML+1, MW+1-J), MIN(MW+N-J, MW+ML)
  154. 260 DFDY(I,J) = FACTOR*DFDY(I,J)
  155. ELSE IF (MITER .EQ. 5) THEN
  156. BR = UROUND**(.875E0)
  157. BL = UROUND**(.75E0)
  158. BP = UROUND**(-.15E0)
  159. FACMIN = UROUND**(.78E0)
  160. MW = ML + MU + 1
  161. J2 = MIN(MW, N)
  162. DO 340 J = 1,J2
  163. DO 290 K = J,N,MW
  164. YS = MAX(ABS(YWT(K)), ABS(Y(K)))
  165. 280 DY = FAC(K)*YS
  166. IF (DY .EQ. 0.E0) THEN
  167. IF (FAC(K) .LT. FACMAX) THEN
  168. FAC(K) = MIN(100.E0*FAC(K), FACMAX)
  169. GO TO 280
  170. ELSE
  171. DY = YS
  172. END IF
  173. END IF
  174. IF (NQ .EQ. 1) THEN
  175. DY = SIGN(DY, SAVE2(K))
  176. ELSE
  177. DY = SIGN(DY, YH(K,3))
  178. END IF
  179. DY = (Y(K) + DY) - Y(K)
  180. DFDY(MW,K) = Y(K)
  181. 290 Y(K) = Y(K) + DY
  182. CALL F (N, T, Y, SAVE1)
  183. IF (N .EQ. 0) THEN
  184. JSTATE = 6
  185. RETURN
  186. END IF
  187. DO 330 K = J,N,MW
  188. Y(K) = DFDY(MW,K)
  189. YS = MAX(ABS(YWT(K)), ABS(Y(K)))
  190. DY = FAC(K)*YS
  191. IF (DY .EQ. 0.E0) DY = YS
  192. IF (NQ .EQ. 1) THEN
  193. DY = SIGN(DY, SAVE2(K))
  194. ELSE
  195. DY = SIGN(DY, YH(K,3))
  196. END IF
  197. DY = (Y(K) + DY) - Y(K)
  198. FACTOR = -EL(1,NQ)*H/DY
  199. DO 300 I = MAX(ML+1, MW+1-K), MIN(MW+N-K, MW+ML)
  200. 300 DFDY(I,K) = FACTOR*(SAVE1(I+K-MW) - SAVE2(I+K-MW))
  201. C Step 1
  202. IMAX = MAX(1, K - MU)
  203. DIFF = ABS(SAVE2(IMAX) - SAVE1(IMAX))
  204. DO 310 I = MAX(1, K - MU)+1, MIN(K + ML, N)
  205. IF (ABS(SAVE2(I) - SAVE1(I)) .GT. DIFF) THEN
  206. IMAX = I
  207. DIFF = ABS(SAVE2(I) - SAVE1(I))
  208. END IF
  209. 310 CONTINUE
  210. C Step 2
  211. IF (MIN(ABS(SAVE2(IMAX)), ABS(SAVE1(IMAX))) .GT.0.E0) THEN
  212. SCALE = MAX(ABS(SAVE2(IMAX)), ABS(SAVE1(IMAX)))
  213. C Step 3
  214. IF (DIFF .GT. BU*SCALE) THEN
  215. FAC(J) = MAX(FACMIN, FAC(J)*.5E0)
  216. ELSE IF (BR*SCALE .LE.DIFF .AND. DIFF .LE.BL*SCALE) THEN
  217. FAC(J) = MIN(FAC(J)*2.E0, FACMAX)
  218. C Step 4
  219. ELSE IF (DIFF .LT. BR*SCALE) THEN
  220. FAC(K) = MIN(BP*FAC(K), FACMAX)
  221. END IF
  222. END IF
  223. 330 CONTINUE
  224. 340 CONTINUE
  225. NFE = NFE + J2
  226. END IF
  227. IF (ISWFLG .EQ. 3) THEN
  228. DFDYMX = 0.E0
  229. DO 345 J = 1,N
  230. DO 345 I = MAX(ML+1, MW+1-J), MIN(MW+N-J, MW+ML)
  231. 345 DFDYMX = MAX(DFDYMX, ABS(DFDY(I,J)))
  232. BND = 0.E0
  233. IF (DFDYMX .NE. 0.E0) THEN
  234. DO 350 J = 1,N
  235. DO 350 I = MAX(ML+1, MW+1-J), MIN(MW+N-J, MW+ML)
  236. 350 BND = BND + (DFDY(I,J)/DFDYMX)**2
  237. BND = DFDYMX*SQRT(BND)/(-EL(1,NQ)*H)
  238. END IF
  239. END IF
  240. IF (IMPL .EQ. 0) THEN
  241. DO 360 J = 1,N
  242. 360 DFDY(MW,J) = DFDY(MW,J) + 1.E0
  243. ELSE IF (IMPL .EQ. 1) THEN
  244. CALL FA (N, T, Y, A(ML+1,1), MATDIM, ML, MU, NDE)
  245. IF (N .EQ. 0) THEN
  246. JSTATE = 9
  247. RETURN
  248. END IF
  249. DO 380 J = 1,N
  250. DO 380 I = MAX(ML+1, MW+1-J), MIN(MW+N-J, MW+ML)
  251. 380 DFDY(I,J) = DFDY(I,J) + A(I,J)
  252. ELSE IF (IMPL .EQ. 2) THEN
  253. CALL FA (N, T, Y, A, MATDIM, ML, MU, NDE)
  254. IF (N .EQ. 0) THEN
  255. JSTATE = 9
  256. RETURN
  257. END IF
  258. DO 400 J = 1,NDE
  259. 400 DFDY(MW,J) = DFDY(MW,J) + A(J,1)
  260. ELSE IF (IMPL .EQ. 3) THEN
  261. CALL FA (N, T, Y, A(ML+1,1), MATDIM, ML, MU, NDE)
  262. IF (N .EQ. 0) THEN
  263. JSTATE = 9
  264. RETURN
  265. END IF
  266. DO 390 J = 1,NDE
  267. DO 390 I = MAX(ML+1, MW+1-J), MIN(MW+NDE-J, MW+ML)
  268. 390 DFDY(I,J) = DFDY(I,J) + A(I,J)
  269. END IF
  270. CALL SGBFA (DFDY, MATDIM, N, ML, MU, IPVT, INFO)
  271. IF (INFO .NE. 0) IER = .TRUE.
  272. ELSE IF (MITER .EQ. 3) THEN
  273. IFLAG = 1
  274. CALL USERS (Y, YH(1,2), YWT, SAVE1, SAVE2, T, H, EL(1,NQ), IMPL,
  275. 8 N, NDE, IFLAG)
  276. IF (IFLAG .EQ. -1) THEN
  277. IER = .TRUE.
  278. RETURN
  279. END IF
  280. IF (N .EQ. 0) THEN
  281. JSTATE = 10
  282. RETURN
  283. END IF
  284. END IF
  285. RETURN
  286. END