splpce.f 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. *DECK SPLPCE
  2. SUBROUTINE SPLPCE (MRELAS, NVARS, LMX, LBM, ITLP, ITBRC, IBASIS,
  3. + IMAT, IBRC, IPR, IWR, IND, IBB, ERDNRM, EPS, TUNE, GG, AMAT,
  4. + BASMAT, CSC, WR, WW, PRIMAL, ERD, ERP, SINGLR, REDBAS)
  5. C***BEGIN PROLOGUE SPLPCE
  6. C***SUBSIDIARY
  7. C***PURPOSE Subsidiary to SPLP
  8. C***LIBRARY SLATEC
  9. C***TYPE SINGLE PRECISION (SPLPCE-S, DPLPCE-D)
  10. C***AUTHOR (UNKNOWN)
  11. C***DESCRIPTION
  12. C
  13. C THE EDITING REQUIRED TO CONVERT THIS SUBROUTINE FROM SINGLE TO
  14. C DOUBLE PRECISION INVOLVES THE FOLLOWING CHARACTER STRING CHANGES.
  15. C
  16. C USE AN EDITING COMMAND (CHANGE) /STRING-1/(TO)STRING-2/.
  17. C /REAL (12 BLANKS)/DOUBLE PRECISION/,
  18. C /SASUM/DASUM/,/SCOPY/,DCOPY/.
  19. C
  20. C REVISED 811219-1630
  21. C REVISED YYMMDD-HHMM
  22. C
  23. C THIS SUBPROGRAM IS FROM THE SPLP( ) PACKAGE. IT CALCULATES
  24. C THE APPROXIMATE ERROR IN THE PRIMAL AND DUAL SYSTEMS. IT IS
  25. C THE MAIN PART OF THE PROCEDURE (COMPUTE ERROR IN DUAL AND PRIMAL
  26. C SYSTEMS).
  27. C
  28. C***SEE ALSO SPLP
  29. C***ROUTINES CALLED IPLOC, LA05BS, PRWPGE, SASUM, SCOPY
  30. C***REVISION HISTORY (YYMMDD)
  31. C 811215 DATE WRITTEN
  32. C 890531 Changed all specific intrinsics to generic. (WRB)
  33. C 890605 Removed unreferenced labels. (WRB)
  34. C 891214 Prologue converted to Version 4.0 format. (BAB)
  35. C 900328 Added TYPE section. (WRB)
  36. C***END PROLOGUE SPLPCE
  37. INTEGER IBASIS(*),IMAT(*),IBRC(LBM,2),IPR(*),IWR(*),IND(*),IBB(*)
  38. REAL AMAT(*),BASMAT(*),CSC(*),WR(*),WW(*),PRIMAL(*),
  39. * ERD(*),ERP(*),EPS,ERDNRM,FACTOR,GG,ONE,ZERO,TEN,TUNE
  40. LOGICAL SINGLR,REDBAS,TRANS,PAGEPL
  41. C***FIRST EXECUTABLE STATEMENT SPLPCE
  42. ZERO=0.E0
  43. ONE=1.E0
  44. TEN=10.E0
  45. LPG=LMX-(NVARS+4)
  46. SINGLR=.FALSE.
  47. FACTOR=0.01
  48. C
  49. C COPY COLSUMS IN WW(*), AND SOLVE TRANSPOSED SYSTEM.
  50. I=1
  51. N20002=MRELAS
  52. GO TO 20003
  53. 20002 I=I+1
  54. 20003 IF ((N20002-I).LT.0) GO TO 20004
  55. J=IBASIS(I)
  56. IF (.NOT.(J.LE.NVARS)) GO TO 20006
  57. WW(I) = PRIMAL(J)
  58. GO TO 20007
  59. 20006 IF (.NOT.(IND(J).EQ.2)) GO TO 20009
  60. WW(I)=ONE
  61. GO TO 20010
  62. 20009 WW(I)=-ONE
  63. 20010 CONTINUE
  64. 20007 CONTINUE
  65. GO TO 20002
  66. C
  67. C PERTURB RIGHT-SIDE IN UNITS OF LAST BITS TO BETTER REFLECT
  68. C ERRORS IN THE CHECK SUM SOLNS.
  69. 20004 I=1
  70. N20012=MRELAS
  71. GO TO 20013
  72. 20012 I=I+1
  73. 20013 IF ((N20012-I).LT.0) GO TO 20014
  74. WW(I)=WW(I)+TEN*EPS*WW(I)
  75. GO TO 20012
  76. 20014 TRANS = .TRUE.
  77. CALL LA05BS(BASMAT,IBRC,LBM,MRELAS,IPR,IWR,WR,GG,WW,TRANS)
  78. I=1
  79. N20016=MRELAS
  80. GO TO 20017
  81. 20016 I=I+1
  82. 20017 IF ((N20016-I).LT.0) GO TO 20018
  83. ERD(I)=MAX(ABS(WW(I)-ONE),EPS)*TUNE
  84. C
  85. C SYSTEM BECOMES SINGULAR WHEN ACCURACY OF SOLUTION IS .GT. FACTOR.
  86. C THIS VALUE (FACTOR) MIGHT NEED TO BE CHANGED.
  87. SINGLR=SINGLR.OR.(ERD(I).GE.FACTOR)
  88. GO TO 20016
  89. 20018 ERDNRM=SASUM(MRELAS,ERD,1)
  90. C
  91. C RECALCULATE ROW CHECK SUMS EVERY ITBRC ITERATIONS OR WHEN
  92. C A REDECOMPOSITION HAS OCCURRED.
  93. IF (.NOT.(MOD(ITLP,ITBRC).EQ.0 .OR. REDBAS)) GO TO 20020
  94. C
  95. C COMPUTE ROW SUMS, STORE IN WW(*), SOLVE PRIMAL SYSTEM.
  96. WW(1)=ZERO
  97. CALL SCOPY(MRELAS,WW,0,WW,1)
  98. PAGEPL=.TRUE.
  99. J=1
  100. N20023=NVARS
  101. GO TO 20024
  102. 20023 J=J+1
  103. 20024 IF ((N20023-J).LT.0) GO TO 20025
  104. IF (.NOT.(IBB(J).GE.ZERO)) GO TO 20027
  105. C
  106. C THE VARIABLE IS NON-BASIC.
  107. PAGEPL=.TRUE.
  108. GO TO 20023
  109. 20027 IF (.NOT.(J.EQ.1)) GO TO 20030
  110. ILOW=NVARS+5
  111. GO TO 20031
  112. 20030 ILOW=IMAT(J+3)+1
  113. 20031 IF (.NOT.(PAGEPL)) GO TO 20033
  114. IL1=IPLOC(ILOW,AMAT,IMAT)
  115. IF (.NOT.(IL1.GE.LMX-1)) GO TO 20036
  116. ILOW=ILOW+2
  117. IL1=IPLOC(ILOW,AMAT,IMAT)
  118. 20036 CONTINUE
  119. IPAGE=ABS(IMAT(LMX-1))
  120. GO TO 20034
  121. 20033 IL1=IHI+1
  122. 20034 IHI=IMAT(J+4)-(ILOW-IL1)
  123. 20039 IU1=MIN(LMX-2,IHI)
  124. IF (.NOT.(IL1.GT.IU1)) GO TO 20041
  125. GO TO 20040
  126. 20041 CONTINUE
  127. DO 20 I=IL1,IU1
  128. WW(IMAT(I))=WW(IMAT(I))+AMAT(I)*CSC(J)
  129. 20 CONTINUE
  130. IF (.NOT.(IHI.LE.LMX-2)) GO TO 20044
  131. GO TO 20040
  132. 20044 CONTINUE
  133. IPAGE=IPAGE+1
  134. KEY=1
  135. CALL PRWPGE(KEY,IPAGE,LPG,AMAT,IMAT)
  136. IL1=NVARS+5
  137. IHI=IHI-LPG
  138. GO TO 20039
  139. 20040 PAGEPL=IHI.EQ.(LMX-2)
  140. GO TO 20023
  141. 20025 L=1
  142. N20047=MRELAS
  143. GO TO 20048
  144. 20047 L=L+1
  145. 20048 IF ((N20047-L).LT.0) GO TO 20049
  146. J=IBASIS(L)
  147. IF (.NOT.(J.GT.NVARS)) GO TO 20051
  148. I=J-NVARS
  149. IF (.NOT.(IND(J).EQ.2)) GO TO 20054
  150. WW(I)=WW(I)+ONE
  151. GO TO 20055
  152. 20054 WW(I)=WW(I)-ONE
  153. 20055 CONTINUE
  154. 20051 CONTINUE
  155. GO TO 20047
  156. C
  157. C PERTURB RIGHT-SIDE IN UNITS OF LAST BIT POSITIONS.
  158. 20049 I=1
  159. N20057=MRELAS
  160. GO TO 20058
  161. 20057 I=I+1
  162. 20058 IF ((N20057-I).LT.0) GO TO 20059
  163. WW(I)=WW(I)+TEN*EPS*WW(I)
  164. GO TO 20057
  165. 20059 TRANS = .FALSE.
  166. CALL LA05BS(BASMAT,IBRC,LBM,MRELAS,IPR,IWR,WR,GG,WW,TRANS)
  167. I=1
  168. N20061=MRELAS
  169. GO TO 20062
  170. 20061 I=I+1
  171. 20062 IF ((N20061-I).LT.0) GO TO 20063
  172. ERP(I)=MAX(ABS(WW(I)-ONE),EPS)*TUNE
  173. C
  174. C SYSTEM BECOMES SINGULAR WHEN ACCURACY OF SOLUTION IS .GT. FACTOR.
  175. C THIS VALUE (FACTOR) MIGHT NEED TO BE CHANGED.
  176. SINGLR=SINGLR.OR.(ERP(I).GE.FACTOR)
  177. GO TO 20061
  178. 20063 CONTINUE
  179. C
  180. 20020 RETURN
  181. END