summaryrefslogtreecommitdiff
path: root/Dragon/src/LIBTER.f
blob: 8fe3641e2c8043659072df912c41a075d27cde73 (plain)
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
*DECK LIBTER
      SUBROUTINE LIBTER (NGRO,NSUBM,TMIX,SMIX,TN,SN,TERP)
*
*-----------------------------------------------------------------------
*
*Purpose:
* Compute the Lagrange interpolation factors (TERP) for temperature and
* dilution interpolation of cross sections. TRANSX CTR algorithm.
*
*Copyright:
* Copyright (C) 2002 Ecole Polytechnique de Montreal
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version
*
*Author(s): A. Hebert
*
*Parameters: input
* NGRO    number of energy groups.
* NSUBM   number of submaterials (number of temperature/dilution
*         collocation points).
* TMIX    temperature of each submaterial in the library.
* SMIX    dilution of each submaterial in the library.
*         The submaterials are ordered by decreasing dilution and
*         then by increasing temperature.
* TN      temperature of the isotope.
* SN      dilution cross section in each energy group of the isotope.
*         A value of 1.0E10 is used for infinite dilution.
*
*Parameters: output
* TERP    Lagrange interpolation factors.
*
*-----------------------------------------------------------------------
*
*----
*  SUBROUTINE ARGUMENTS
*----
      INTEGER NGRO,NSUBM
      REAL TMIX(NSUBM),SMIX(NSUBM),TN,SN(NGRO),TERP(NGRO,NSUBM)
*----
*  LOCAL VARIABLES
*----
      PARAMETER (IOUT=6)
      DOUBLE PRECISION CHECK
*----
*  TEMPERATURE AND BACKGROUND LOOP
*----
      IF (NSUBM.EQ.1) THEN
         DO 10 I=1,NGRO
         TERP(I,1)=1.0
   10    CONTINUE
         RETURN
      ENDIF
      BREAK=0.0
      SMIN=1.0E10
      DO 20 ISUBM=1,NSUBM
      ST=SMIX(ISUBM)
      IF ((ST.LT.1.0E8).AND.(ST.GT.BREAK)) BREAK=ST
      IF (ST.LT.SMIN) SMIN=ST
   20 CONTINUE
      DO 70 ISUBM=1,NSUBM
      DO 30 JJ=1,NGRO
      TERP(JJ,ISUBM)=0.0
   30 CONTINUE
      TMAT=TMIX(ISUBM)
      SMAT=SMIX(ISUBM)
*----
*  COMPUTE TERP FACTORS
*----
      TERPT=1.0
      DO 40 ISM=1,NSUBM
      TT=TMIX(ISM)
      ST=SMIX(ISM)
      IF (ST.LE.0.99E10) GO TO 40
      IF (ABS(TMAT-TT).LT.1.0E-5*TMAT+1.0E-5) GO TO 40
      TERPT=TERPT*(TN-TT)/(TMAT-TT)
      IF (ABS(TERPT).LT.1.0E-5) GO TO 70
   40 CONTINUE
      DO 60 JJ=1,NGRO
      TERPS=TERPT
      IF ((SN(JJ).LT.SMIN).AND.(SMAT.GT.1.01*SMIN)) GO TO 60
      IF ((SN(JJ).LT.BREAK).AND.(SMAT.GT.1.01*BREAK)) GO TO 60
      IF ((SN(JJ).GE.BREAK).AND.(SMAT.LT.0.99*BREAK)) GO TO 60
      TLAST=-1.0
      DO 50 ISM=1,NSUBM
      TT=TMIX(ISM)
      ST=SMIX(ISM)
      IF (TLAST.LT.0.) TLAST=TT
      IF (TT.NE.TLAST) GO TO 50
      IF (ABS(SMAT-ST).LT.1.0E-5*SMAT) GO TO 50
      IF ((SN(JJ).GE.SMIN).AND.(SN(JJ).LT.BREAK)) THEN
         IF (ST.GT.1.01*BREAK) GO TO 50
         TERPS=TERPS*LOG(SN(JJ)/ST)/LOG(SMAT/ST)
      ELSE IF ((SN(JJ).GE.SMIN).AND.(SN(JJ).GE.BREAK)) THEN
         IF (ST.LT.0.99*BREAK) GO TO 50
         TERPS=TERPS*((ST/SN(JJ))-1.)/((ST/SMAT)-1.)
      ELSE
         IF (ST.GT.1.01*SMIN) GO TO 50
         TERPS=TERPS*(SN(JJ)**2-ST**2)/(SMAT**2-ST**2)
      ENDIF
      IF (ABS(TERPS).LE.1.0E-5) GO TO 60
   50 CONTINUE
      TERP(JJ,ISUBM)=TERPS
   60 CONTINUE
   70 CONTINUE
*----
*  CHECK FOR CONSISTENCY OF THE TERP FACTORS.
*----
      DO 90 JJ=1,NGRO
      CHECK=0.0D0
      DO 80 ISUBM=1,NSUBM
      CHECK=CHECK+TERP(JJ,ISUBM)
   80 CONTINUE
      IF (ABS(CHECK-1.0D0).GT.5.0D-3) THEN
         WRITE (IOUT,100) JJ,CHECK,(TERP(JJ,ISUBM),ISUBM=1,NSUBM)
         CALL XABORT('LIBTER: INTERPOLATION FAILURE.')
      ENDIF
   90 CONTINUE
      RETURN
  100 FORMAT (/51H LIBTER: INCONSISTENT LAGRANGE INTERPOLATION FACTOR,
     1 9H IN GROUP,I4,8H. CHECK=,1P,E13.3/9H FACTORS=,1P,9E13.3/
     2 (9X,1P,9E13.3))
      END