summaryrefslogtreecommitdiff
path: root/Donjon/src/DETPLAT.f
blob: cca47646edbeffbc5732a751881609b04d6b2747 (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
*DECK DETPLAT
      SUBROUTINE DETPLAT(DT,RESPON,REF,KC,PDD,REGUL,PDF,PDT,NDDG,
     +                   AP,BP)
*
*-----------------------------------------------------------------------
*
*Purpose:
* Computes platinum detector reading with delay time consideration
* and normalized to a reference value.
*
*Copyright:
* Copyright (C) 2010 Ecole Polytechnique de Montreal.
*
*Author(s): 
* E. Varin
*
*Parameters: 
* DT       
* RESPON   
* REF      
* KC       
* PDD      
* REGUL    
* PDF      
* PDT      
* NDDG     
* AP       
* BP       
*
*-----------------------------------------------------------------------
*
      INTEGER  NDDG,I
      REAL RESPON,REF,DT
      REAL AEP,AP(NDDG),BP(NDDG),PDT(NDDG),PDF(NDDG+1),PDD(NDDG),PDO
      LOGICAL  REGUL
*
*     FLUX AT DETECTOR SITE
*     ---------------------
      IF ( KC.EQ.0) THEN
*     REFERENCE CALCULATION
*
          PDO = RESPON
          IF (REGUL) THEN
             CALL DETFIL(PDO,RESPON,RESPON,25.,DT,1)
          ENDIF
          IF (PDO.EQ.0.0) THEN
            PDO = 1.
            WRITE(6,*)'===> DETECTOR HAS AN INITIAL ZERO VALUE <==='
          ENDIF
          REF = PDO
      ENDIF
*
*     NORMALIZATION TO REFERENCE VALUE
*
      RESPON = RESPON/REF
*
      DO 10 I = 1 , NDDG
*
        AEP   = DT*PDT(I)
        AP(I) = 1.0
*
        IF (AEP.GT.20.0) THEN
           AEP = 20.0
        ENDIF
        IF (AEP.GT.1.0E-6) THEN
           AP(I) = EXP ( -AEP )
        ENDIF
        BP(I) = 1.0 - AP(I)
*
10    CONTINUE
*
      IF (KC.EQ.0) THEN
*
*     INITIALISATION AT REFERENCE CALCULATION
*     ---------------------------------------
*
         DO 20 I = 1 , NDDG
           PDD(I) = PDF(I+1) * RESPON
20       CONTINUE
      ENDIF
*
*     CALCULATION OF DETECTOR RESPONSE
*     --------------------------------
*
      PDO = 0.0
      PDO = PDF(1)*RESPON
      DO 30 I = 1 , NDDG
           PDD(I) = AP(I)*PDD(I) + BP(I)*PDF(I+1)*RESPON
           PDO    = PDO + PDD(I)
 30   CONTINUE
*
      RESPON = PDO
*
      RETURN
      END