*DECK SPINCW SUBROUTINE SPINCW (MRELAS, NVARS, LMX, LBM, NPP, JSTRT, IBASIS, + IMAT, IBRC, IPR, IWR, IND, IBB, COSTSC, GG, ERDNRM, DULNRM, + AMAT, BASMAT, CSC, WR, WW, RZ, RG, COSTS, COLNRM, DUALS, + STPEDG) C***BEGIN PROLOGUE SPINCW C***SUBSIDIARY C***PURPOSE Subsidiary to SPLP C***LIBRARY SLATEC C***TYPE SINGLE PRECISION (SPINCW-S, DPINCW-D) C***AUTHOR (UNKNOWN) C***DESCRIPTION C C THE EDITING REQUIRED TO CONVERT THIS SUBROUTINE FROM SINGLE TO C DOUBLE PRECISION INVOLVES THE FOLLOWING CHARACTER STRING CHANGES. C C USE AN EDITING COMMAND (CHANGE) /STRING-1/(TO)STRING-2/, C REAL (12 BLANKS)/DOUBLE PRECISION/,/SCOPY/DCOPY/,/SDOT/DDOT/. C C THIS SUBPROGRAM IS PART OF THE SPLP( ) PACKAGE. C IT IMPLEMENTS THE PROCEDURE (INITIALIZE REDUCED COSTS AND C STEEPEST EDGE WEIGHTS). C C***SEE ALSO SPLP C***ROUTINES CALLED IPLOC, LA05BS, PRWPGE, SCOPY, SDOT C***REVISION HISTORY (YYMMDD) C 811215 DATE WRITTEN C 890531 Changed all specific intrinsics to generic. (WRB) C 890605 Removed unreferenced labels. (WRB) C 891214 Prologue converted to Version 4.0 format. (BAB) C 900328 Added TYPE section. (WRB) C***END PROLOGUE SPINCW INTEGER IBASIS(*),IMAT(*),IBRC(LBM,2),IPR(*),IWR(*),IND(*),IBB(*) REAL AMAT(*),BASMAT(*),CSC(*),WR(*),WW(*),RZ(*),RG(*), * COSTS(*),COLNRM(*),DUALS(*),COSTSC,ERDNRM,DULNRM,GG,ONE,RZJ, * SCALR,ZERO,RCOST LOGICAL STPEDG,PAGEPL,TRANS C***FIRST EXECUTABLE STATEMENT SPINCW LPG=LMX-(NVARS+4) ZERO=0. ONE=1. C C FORM REDUCED COSTS, RZ(*), AND STEEPEST EDGE WEIGHTS, RG(*). PAGEPL=.TRUE. RZ(1)=ZERO CALL SCOPY(NVARS+MRELAS,RZ,0,RZ,1) RG(1)=ONE CALL SCOPY(NVARS+MRELAS,RG,0,RG,1) NNEGRC=0 J=JSTRT 20002 IF (.NOT.(IBB(J).LE.0)) GO TO 20004 PAGEPL=.TRUE. GO TO 20005 C C THESE ARE NONBASIC INDEPENDENT VARIABLES. THE COLS. ARE IN SPARSE C MATRIX FORMAT. 20004 IF (.NOT.(J.LE.NVARS)) GO TO 20007 RZJ=COSTSC*COSTS(J) WW(1)=ZERO CALL SCOPY(MRELAS,WW,0,WW,1) IF (.NOT.(J.EQ.1)) GO TO 20010 ILOW=NVARS+5 GO TO 20011 20010 ILOW=IMAT(J+3)+1 20011 CONTINUE IF (.NOT.(PAGEPL)) GO TO 20013 IL1=IPLOC(ILOW,AMAT,IMAT) IF (.NOT.(IL1.GE.LMX-1)) GO TO 20016 ILOW=ILOW+2 IL1=IPLOC(ILOW,AMAT,IMAT) 20016 CONTINUE IPAGE=ABS(IMAT(LMX-1)) GO TO 20014 20013 IL1=IHI+1 20014 CONTINUE IHI=IMAT(J+4)-(ILOW-IL1) 20019 IU1=MIN(LMX-2,IHI) IF (.NOT.(IL1.GT.IU1)) GO TO 20021 GO TO 20020 20021 CONTINUE DO 60 I=IL1,IU1 RZJ=RZJ-AMAT(I)*DUALS(IMAT(I)) WW(IMAT(I))=AMAT(I)*CSC(J) 60 CONTINUE IF (.NOT.(IHI.LE.LMX-2)) GO TO 20024 GO TO 20020 20024 CONTINUE IPAGE=IPAGE+1 KEY=1 CALL PRWPGE(KEY,IPAGE,LPG,AMAT,IMAT) IL1=NVARS+5 IHI=IHI-LPG GO TO 20019 20020 PAGEPL=IHI.EQ.(LMX-2) RZ(J)=RZJ*CSC(J) IF (.NOT.(STPEDG)) GO TO 20027 TRANS=.FALSE. CALL LA05BS(BASMAT,IBRC,LBM,MRELAS,IPR,IWR,WR,GG,WW,TRANS) RG(J)=SDOT(MRELAS,WW,1,WW,1)+ONE 20027 CONTINUE C C THESE ARE NONBASIC DEPENDENT VARIABLES. THE COLS. ARE IMPLICITLY C DEFINED. GO TO 20008 20007 PAGEPL=.TRUE. WW(1)=ZERO CALL SCOPY(MRELAS,WW,0,WW,1) SCALR=-ONE IF (IND(J).EQ.2) SCALR=ONE I=J-NVARS RZ(J)=-SCALR*DUALS(I) WW(I)=SCALR IF (.NOT.(STPEDG)) GO TO 20030 TRANS=.FALSE. CALL LA05BS(BASMAT,IBRC,LBM,MRELAS,IPR,IWR,WR,GG,WW,TRANS) RG(J)=SDOT(MRELAS,WW,1,WW,1)+ONE 20030 CONTINUE CONTINUE 20008 CONTINUE C 20005 RCOST=RZ(J) IF (MOD(IBB(J),2).EQ.0) RCOST=-RCOST IF (IND(J).EQ.4) RCOST=-ABS(RCOST) CNORM=ONE IF (J.LE.NVARS) CNORM=COLNRM(J) IF (RCOST+ERDNRM*DULNRM*CNORM.LT.ZERO) NNEGRC=NNEGRC+1 J=MOD(J,MRELAS+NVARS)+1 IF (.NOT.(NNEGRC.GE.NPP .OR. J.EQ.JSTRT)) GO TO 20033 GO TO 20003 20033 GO TO 20002 20003 JSTRT=J RETURN END