File: mce2.f

package info (click to toggle)
nastran 0.1.95-2
  • links: PTS, VCS
  • area: non-free
  • in suites: bookworm, bullseye
  • size: 122,540 kB
  • sloc: fortran: 284,409; sh: 771; makefile: 324
file content (78 lines) | stat: -rw-r--r-- 2,338 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
      SUBROUTINE MCE2
C
C     MCE2 PARTITIONS KGG INTO KNNB, KMNB AND KMMB THEN COMPUTES
C
C     KNN = KNNB + GM(T)*KMNB + KMNB(T)*GM + GM(T)*KMMB*GM
C
C     SIMILAR OPERATIONS ARE PERFORMED ON MGG, BGG AND K4GG IF THE
C     MATRIX HAS NOT BEEN PURGED.
C
      INTEGER         SCR1  ,SCR2  ,SCR6  ,USET  ,MCB(7),GM    ,UG    ,
     1                UN    ,UM    ,BGG   ,BNNB  ,BMNB  ,BNN   ,BMMB
      COMMON /BITPOS/ UM    ,UO    ,UR    ,USG   ,USB   ,UL    ,UA    ,
     1                UF    ,US    ,UN    ,UG    ,UE    ,UP
C
C     INPUT AND OUTPUT FILES
C
      DATA    USET  , GM , KGG, MGG, BGG, K4GG,   KNN, MNN, BNN, K4NN /
     1        101   , 102, 103, 104, 105, 106 ,   201, 202, 203, 204  /
C
C     SCRATCH FILES
C
      DATA    SCR1  , SCR2, SCR6 / 301, 302, 306 /
      DATA    KNNB  , KMNB, KMMB / 303, 304, 305 /
      DATA    MNNB  , MMNB, MMMB / 303, 304, 305 /
      DATA    BNNB  , BMNB, BMMB / 303, 304, 305 /
      DATA    K4NNB , K4MNB,K4MMB/ 303, 304, 305 /
C
C     ARITHMETIC TYPES
C
C     PARTITION KGG INTO KNNB, KMNB, AND KMMB
C
      CALL UPART (USET,SCR1,UG,UN,UM)
      CALL MPART (KGG,KNNB,KMNB,0,KMMB)
C
C     COMPUTE KNN
C
      CALL ELIM (KNNB,KMNB,KMMB,GM,KNN,SCR1,SCR2,SCR6)
C
C     TEST TO SEE IF MGG IS PRESENT
C
      MCB(1) = MGG
      CALL RDTRL (MCB)
      IF (MCB(1) .LT. 0) GO TO 110
C
C     IF MGG PRESENT, PARTITION INTO MNNB, MMNB, AND MMMB
C     THEN COMPUTE MNN
C
      CALL UPART (USET,SCR1,UG,UN,UM)
      CALL MPART (MGG,MNNB,MMNB,0,MMMB)
      CALL ELIM  (MNNB,MMNB,MMMB,GM,MNN,SCR1,SCR2,SCR6)
C
C     TEST TO SEE IF BGG IS PRESENT
C
  110 MCB(1) = BGG
      CALL RDTRL (MCB)
      IF (MCB(1) .LT. 0) GO TO 130
C
C     IF BGG PRESENT, PARTITION INTO BNNB, BMNB, AND BMMB
C     THEN COMPUTE BNN
C
      CALL UPART (USET,SCR1,UG,UN,UM)
      CALL MPART (BGG,BNNB,BMNB,0,BMMB)
      CALL ELIM  (BNNB,BMNB,BMMB,GM,BNN,SCR1,SCR2,SCR6)
C
C     TEST TO SEE IF K4GG IS PRESENT
C
  130 MCB(1) = K4GG
      CALL RDTRL (MCB)
      IF (MCB(1) .LT. 0) RETURN
C
C     IF K4GG IS PRESENT, PARTITION INTO K4NNB, K4MNB, AND K4MMB
C     THEN COMPUTE K4NN
C
      CALL UPART (USET,SCR1,UG,UN,UM)
      CALL MPART (K4GG,K4NNB,K4MNB,0,K4MMB)
      CALL ELIM  (K4NNB,K4MNB,K4MMB,GM,K4NN,SCR1,SCR2,SCR6)
      RETURN
      END