mirror of
https://git.planet-casio.com/Lephenixnoir/OpenLibm.git
synced 2025-01-04 07:53:38 +01:00
86 lines
2.4 KiB
FortranFixed
86 lines
2.4 KiB
FortranFixed
|
*DECK FULMAT
|
||
|
SUBROUTINE FULMAT (I, J, AIJ, INDCAT, PRGOPT, DATTRV, IFLAG)
|
||
|
C***BEGIN PROLOGUE FULMAT
|
||
|
C***SUBSIDIARY
|
||
|
C***PURPOSE Subsidiary to SPLP
|
||
|
C***LIBRARY SLATEC
|
||
|
C***TYPE SINGLE PRECISION (FULMAT-S, DFULMT-D)
|
||
|
C***AUTHOR (UNKNOWN)
|
||
|
C***DESCRIPTION
|
||
|
C
|
||
|
C DECODES A STANDARD TWO-DIMENSIONAL FORTRAN ARRAY PASSED
|
||
|
C IN THE ARRAY DATTRV(IA,*). THE ROW DIMENSION IA AND THE
|
||
|
C MATRIX DIMENSIONS MRELAS AND NVARS MUST SIMULTANEOUSLY BE
|
||
|
C PASSED USING THE OPTION ARRAY, PRGOPT(*). IT IS AN ERROR
|
||
|
C IF THIS DATA IS NOT PASSED TO FULMAT( ).
|
||
|
C EXAMPLE-- (FOR USE TOGETHER WITH SPLP().)
|
||
|
C EXTERNAL USRMAT
|
||
|
C DIMENSION DATTRV(IA,*)
|
||
|
C PRGOPT(01)=7
|
||
|
C PRGOPT(02)=68
|
||
|
C PRGOPT(03)=1
|
||
|
C PRGOPT(04)=IA
|
||
|
C PRGOPT(05)=MRELAS
|
||
|
C PRGOPT(06)=NVARS
|
||
|
C PRGOPT(07)=1
|
||
|
C CALL SPLP( ... FULMAT INSTEAD OF USRMAT...)
|
||
|
C
|
||
|
C***SEE ALSO SPLP
|
||
|
C***ROUTINES CALLED XERMSG
|
||
|
C***REVISION HISTORY (YYMMDD)
|
||
|
C 811215 DATE WRITTEN
|
||
|
C 891214 Prologue converted to Version 4.0 format. (BAB)
|
||
|
C 900315 CALLs to XERROR changed to CALLs to XERMSG. (THJ)
|
||
|
C 900328 Added TYPE section. (WRB)
|
||
|
C***END PROLOGUE FULMAT
|
||
|
REAL AIJ,ZERO,DATTRV(*),PRGOPT(*)
|
||
|
INTEGER IFLAG(10)
|
||
|
SAVE ZERO
|
||
|
C***FIRST EXECUTABLE STATEMENT FULMAT
|
||
|
IF (.NOT.(IFLAG(1).EQ.1)) GO TO 50
|
||
|
C INITIALIZE POINTERS TO PROCESS FULL TWO-DIMENSIONAL FORTRAN
|
||
|
C ARRAYS.
|
||
|
ZERO = 0.
|
||
|
LP = 1
|
||
|
10 NEXT = PRGOPT(LP)
|
||
|
IF (.NOT.(NEXT.LE.1)) GO TO 20
|
||
|
NERR = 29
|
||
|
LEVEL = 1
|
||
|
CALL XERMSG ('SLATEC', 'FULMAT',
|
||
|
+ 'IN SPLP PACKAGE, ROW DIM., MRELAS, NVARS ARE MISSING FROM ' //
|
||
|
+ 'PRGOPT.', NERR, LEVEL)
|
||
|
IFLAG(1) = 3
|
||
|
GO TO 110
|
||
|
20 KEY = PRGOPT(LP+1)
|
||
|
IF (.NOT.(KEY.NE.68)) GO TO 30
|
||
|
LP = NEXT
|
||
|
GO TO 10
|
||
|
30 IF (.NOT.(PRGOPT(LP+2).EQ.ZERO)) GO TO 40
|
||
|
LP = NEXT
|
||
|
GO TO 10
|
||
|
40 IFLAG(2) = 1
|
||
|
IFLAG(3) = 1
|
||
|
IFLAG(4) = PRGOPT(LP+3)
|
||
|
IFLAG(5) = PRGOPT(LP+4)
|
||
|
IFLAG(6) = PRGOPT(LP+5)
|
||
|
GO TO 110
|
||
|
50 IF (.NOT.(IFLAG(1).EQ.2)) GO TO 100
|
||
|
60 I = IFLAG(2)
|
||
|
J = IFLAG(3)
|
||
|
IF (.NOT.(J.GT.IFLAG(6))) GO TO 70
|
||
|
IFLAG(1) = 3
|
||
|
GO TO 110
|
||
|
70 IF (.NOT.(I.GT.IFLAG(5))) GO TO 80
|
||
|
IFLAG(2) = 1
|
||
|
IFLAG(3) = J + 1
|
||
|
GO TO 60
|
||
|
80 AIJ = DATTRV(IFLAG(4)*(J-1)+I)
|
||
|
IFLAG(2) = I + 1
|
||
|
IF (.NOT.(AIJ.EQ.ZERO)) GO TO 90
|
||
|
GO TO 60
|
||
|
90 INDCAT = 0
|
||
|
GO TO 110
|
||
|
100 CONTINUE
|
||
|
110 RETURN
|
||
|
END
|