1 | C=======================================================================
|
---|
2 |
|
---|
3 | SUBROUTINE CERENE( STEPCR )
|
---|
4 |
|
---|
5 | C-----------------------------------------------------------------------
|
---|
6 | C CEREN(KOV RADIATION FROM) E(LECTRONS)
|
---|
7 | C
|
---|
8 | C CREATION OF CERENKOV PHOTONS ALONG A TRACK OF ELECTRONS
|
---|
9 | C CERENKOV RADIATION IS ONLY CALCULATED FOR LOWEST OBSERVATION LEVEL
|
---|
10 | C THE COORDINATES ON EGS-STACK ARE AT THE END OF STEP EXCEPT E(NP),
|
---|
11 | C WHICH IS AT THE BEGINNING OF STEP
|
---|
12 | C THIS SUBROUTINE IS CALLED FROM ELECTR
|
---|
13 | C ARGUMENT:
|
---|
14 | C STEPCR = STEP LENGTH FOR ELECTRON OR POSITRON (REAL*4)
|
---|
15 | C
|
---|
16 | C AUTHOR : M. ROZANSKA UNIVERSITY OF KRAKOW
|
---|
17 | C S. MARTINEZ UNIVERSITY OF MADRID
|
---|
18 | C F. ARQUEROS UNIVERSITY OF MADRID
|
---|
19 | C CHANGES : D. HECK IK3 FZK KARLSRUHE
|
---|
20 | C R. ATTALLAH UNIVERSITY OF PERPIGNAN
|
---|
21 | C-----------------------------------------------------------------------
|
---|
22 |
|
---|
23 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
24 | parameter (xct=1)
|
---|
25 | parameter (yct=2)
|
---|
26 | parameter (zct=3)
|
---|
27 | parameter (ctthet=4)
|
---|
28 | parameter (ctphi=5)
|
---|
29 | parameter (ctdiam=6)
|
---|
30 | parameter (ctfoc=7)
|
---|
31 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
32 |
|
---|
33 | c IMPLICIT NONE
|
---|
34 | *KEEP,BUFFS.
|
---|
35 | COMMON /BUFFS/ RUNH,RUNE,EVTH,EVTE,DATAB,LH
|
---|
36 | INTEGER MAXBUF,MAXLEN
|
---|
37 | PARAMETER (MAXBUF=39*7)
|
---|
38 | PARAMETER (MAXLEN=12)
|
---|
39 | REAL RUNH(MAXBUF),EVTH(MAXBUF),EVTE(MAXBUF),
|
---|
40 | * RUNE(MAXBUF),DATAB(MAXBUF)
|
---|
41 | INTEGER LH
|
---|
42 | CHARACTER*4 CRUNH,CRUNE,CEVTH,CEVTE
|
---|
43 | EQUIVALENCE (RUNH(1),CRUNH), (RUNE(1),CRUNE)
|
---|
44 | EQUIVALENCE (EVTH(1),CEVTH), (EVTE(1),CEVTE)
|
---|
45 | *KEEP,CONST.
|
---|
46 | COMMON /CONST/ PI,PI2,OB3,TB3,ENEPER
|
---|
47 | DOUBLE PRECISION PI,PI2,OB3,TB3,ENEPER
|
---|
48 | *KEEP,EPCONT.
|
---|
49 | COMMON/EPCONT/ EDEP,RATIO,TSTEP,TUSTEP,USTEP,TVSTEP,VSTEP,IDISC,
|
---|
50 | * IROLD,IRNEW,RHOFAC, EOLD,ENEW,EKE,ELKE,BETA2,GLE,
|
---|
51 | * TSCAT,IAUSFL
|
---|
52 | DOUBLE PRECISION EDEP,RATIO
|
---|
53 | REAL TSTEP,TUSTEP,USTEP,TVSTEP,VSTEP,RHOFAC,EOLD,ENEW,
|
---|
54 | * EKE,ELKE,BETA2,GLE,TSCAT
|
---|
55 | INTEGER IDISC,IROLD,IRNEW,IAUSFL(29)
|
---|
56 | *KEEP,LONGI.
|
---|
57 | COMMON /LONGI/ APLONG,HLONG,PLONG,SPLONG,THSTEP,THSTPI,
|
---|
58 | * NSTEP,LLONGI,FLGFIT
|
---|
59 | DOUBLE PRECISION APLONG(0:1040,9),HLONG(0:1024),PLONG(0:1040,9),
|
---|
60 | * SPLONG(0:1040,9),THSTEP,THSTPI
|
---|
61 | INTEGER NSTEP
|
---|
62 | LOGICAL LLONGI,FLGFIT
|
---|
63 | *KEEP,MAGANG.
|
---|
64 | COMMON /MAGANG/ ARRANG,ARRANR,COSANG,SINANG
|
---|
65 | DOUBLE PRECISION ARRANG,ARRANR,COSANG,SINANG
|
---|
66 | *KEEP,OBSPAR.
|
---|
67 | COMMON /OBSPAR/ OBSLEV,THCKOB,XOFF,YOFF,THETAP,PHIP,
|
---|
68 | * THETPR,PHIPR,NOBSLV
|
---|
69 | DOUBLE PRECISION OBSLEV(10),THCKOB(10),XOFF(10),YOFF(10),
|
---|
70 | * THETAP,THETPR(2),PHIP,PHIPR(2)
|
---|
71 | INTEGER NOBSLV
|
---|
72 | *KEEP,PAM.
|
---|
73 | COMMON /PAM/ PAMA,SIGNUM
|
---|
74 | DOUBLE PRECISION PAMA(6000),SIGNUM(6000)
|
---|
75 | *KEEP,PARPAR.
|
---|
76 | COMMON /PARPAR/ CURPAR,SECPAR,PRMPAR,OUTPAR,C,
|
---|
77 | * E00,E00PN,PTOT0,PTOT0N,THICKH,ITYPE,LEVL
|
---|
78 | DOUBLE PRECISION CURPAR(14),SECPAR(14),PRMPAR(14),OUTPAR(14),
|
---|
79 | * C(50),E00,E00PN,PTOT0,PTOT0N,THICKH
|
---|
80 | INTEGER ITYPE,LEVL
|
---|
81 | *KEEP,RANDPA.
|
---|
82 | COMMON /RANDPA/ FAC,U1,U2,RD,NSEQ,ISEED,KNOR
|
---|
83 | DOUBLE PRECISION FAC,U1,U2
|
---|
84 | REAL RD(3000)
|
---|
85 | INTEGER ISEED(103,10),NSEQ
|
---|
86 | LOGICAL KNOR
|
---|
87 | *KEEP,RUNPAR.
|
---|
88 | COMMON /RUNPAR/ FIXHEI,THICK0,HILOECM,HILOELB,
|
---|
89 | * STEPFC,NRRUN,NSHOW,PATAPE,MONIIN,
|
---|
90 | * MONIOU,MDEBUG,NUCNUC,
|
---|
91 | * CETAPE,
|
---|
92 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
93 | * N1STTR,MDBASE,
|
---|
94 | * DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
95 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
96 | * ,GHEISH,GHESIG
|
---|
97 | COMMON /RUNPAC/ DSN,HOST,USER
|
---|
98 | DOUBLE PRECISION FIXHEI,THICK0,HILOECM,HILOELB
|
---|
99 | REAL STEPFC
|
---|
100 | INTEGER NRRUN,NSHOW,PATAPE,MONIIN,MONIOU,MDEBUG,NUCNUC,
|
---|
101 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
102 | * N1STTR,MDBASE
|
---|
103 | INTEGER CETAPE
|
---|
104 | CHARACTER*79 DSN
|
---|
105 | CHARACTER*20 HOST,USER
|
---|
106 |
|
---|
107 | LOGICAL DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
108 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
109 | * ,GHEISH,GHESIG
|
---|
110 | *KEEP,STACKE.
|
---|
111 | COMMON/STACKE/ E,TIME,X,Y,Z,U,V,W,DNEAR,IQ,IGEN,IR,IOBS,LPCTE,NP
|
---|
112 | DOUBLE PRECISION E(60),TIME(60)
|
---|
113 | REAL X(60),Y(60),Z(60),U(60),V(60),W(60),DNEAR(60)
|
---|
114 | INTEGER IQ(60),IGEN(60),IR(60),IOBS(60),LPCTE(60),NP
|
---|
115 | *KEEP,CEREN1.
|
---|
116 | COMMON /CEREN1/ CERELE,CERHAD,ETADSN,WAVLGL,WAVLGU,CYIELD,
|
---|
117 | * CERSIZ,LCERFI
|
---|
118 | DOUBLE PRECISION CERELE,CERHAD,ETADSN,WAVLGL,WAVLGU,CYIELD
|
---|
119 | REAL CERSIZ
|
---|
120 | LOGICAL LCERFI
|
---|
121 | *KEEP,CEREN2.
|
---|
122 | COMMON /CEREN2/ PHOTCM,XCER,YCER,UEMIS,VEMIS,CARTIM,ZEMIS,
|
---|
123 | * DCERX,DCERY,ACERX,ACERY,
|
---|
124 | * XCMAX,YCMAX,EPSX,EPSY,
|
---|
125 | * DCERXI,DCERYI,FCERX,FCERY,
|
---|
126 | * XSCATT,YSCATT,CERXOS,CERYOS,
|
---|
127 | * NCERX,NCERY,ICERML
|
---|
128 | REAL PHOTCM,XCER,YCER,UEMIS,VEMIS,CARTIM,ZEMIS,
|
---|
129 | * DCERX,DCERY,ACERX,ACERY,
|
---|
130 | * XCMAX,YCMAX,EPSX,EPSY,
|
---|
131 | * DCERXI,DCERYI,FCERX,FCERY,
|
---|
132 | * XSCATT,YSCATT,CERXOS(20),CERYOS(20)
|
---|
133 | INTEGER NCERX,NCERY,ICERML
|
---|
134 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
135 | *keep,certel.
|
---|
136 | common /certel/ cormxd,cord,coralp,ctpars,omega,
|
---|
137 | + photn,photnp,phpt,pht,vphot,
|
---|
138 | + vchi,veta,vzeta,vchim,vetam,vzetam,
|
---|
139 | + lambda,mu,nu,nctels,ncph
|
---|
140 | double precision cormxd,cord,coralp,ctpars(20,7),omega(20,3,3),
|
---|
141 | + photn(3),photnp(3),phpt(3),pht,vphot(3),
|
---|
142 | + vchi(3),veta(3),vzeta(3),vchim,vetam,vzetam,
|
---|
143 | + lambda,mu,nu
|
---|
144 | integer nctels,ncph(5)
|
---|
145 | double precision xg,yg,zg,xgp,ygp,zgp,up,vp,wp,xpcut,ypcut,zpcut
|
---|
146 | equivalence (photn(1) ,xg) ,(photn(2) ,yg) ,(photn(3) ,zg) ,
|
---|
147 | + (photnp(1),xgp) ,(photnp(2),ygp) ,(photnp(3),zgp),
|
---|
148 | + (phpt(1) ,xpcut),(phpt(2) ,ypcut),(phpt(3) ,zpcut),
|
---|
149 | + (vphot(1) ,up) ,(vphot(2) ,vp) ,(vphot(3) ,wp)
|
---|
150 | character *72 ctfile
|
---|
151 | *keep,graal1.
|
---|
152 | common /graal1/ wavelength ! (nm)
|
---|
153 | real wavelength
|
---|
154 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
155 | *KEND.
|
---|
156 |
|
---|
157 | COMMON /ACLOCK/ NCLOCK,JCLOCK
|
---|
158 | DOUBLE PRECISION BETAE,BETAF,BETAI,CTHETA,DBETA,ECR,
|
---|
159 | * ETA1,E1,STHETA,STHETF,STHETI
|
---|
160 | DOUBLE PRECISION RHOF,THICK
|
---|
161 | REAL A,B,CC,COSCR,COSDEL,DVCOR,DXXX,DYYY,FSTEPI,
|
---|
162 | * HTOP,H2,PATHCR,PHICER,PHOTCT,RADINV,
|
---|
163 | * SINCR,SINDEL,SINPSI,SINPS2,STEPCR,UEMIS2,US,VCOR,
|
---|
164 | * VEMIS2,VS,WEMIS,XCER1,XCER2,XEMIS,XXX,
|
---|
165 | * YCER1,YCER2,YEMIS,YYY
|
---|
166 | INTEGER I,ISTC,I1,JCLOCK,LPCT1,NCLOCK,NSTEPC
|
---|
167 | EXTERNAL RHOF,THICK
|
---|
168 | C-----------------------------------------------------------------------
|
---|
169 | C_____IF (NCLOCK.GT.JCLOCK) THEN
|
---|
170 | C______WRITE(MDEBUG,*)'CERENE: NP=',NP,' IR=',IR(NP),' IOBS=',IOBS(NP)
|
---|
171 | C______CALL AUSGB2
|
---|
172 | C_____ENDIF
|
---|
173 |
|
---|
174 | C-----------------------------------------------------------------------
|
---|
175 |
|
---|
176 | C SKIP PARTICLES OUT OF ZENITH ANGULAR CUT
|
---|
177 | IF ( W(NP) .LT. C(29) ) RETURN
|
---|
178 | C E(NP) IS ENERGY AT BEGIN OF STEP
|
---|
179 | E1 = E(NP)
|
---|
180 |
|
---|
181 | C LOOK WETHER CERENKOV CONDITION IS FULFILLED AT BEGIN OF STEP
|
---|
182 | BETAI = SQRT( 1.D0 - (PAMA(2)*1.D3/E1)**2 )
|
---|
183 | C REFRACTIVE INDEX PARAMETRISATION: N=1+ETA = ETA1
|
---|
184 | H2 = -Z(NP)
|
---|
185 | HTOP = H2 + VSTEP * W(NP)
|
---|
186 | ETA1 = 1.D0 + ETADSN * RHOF(DBLE(HTOP))
|
---|
187 | CTHETA = 1.D0 /( ETA1 * BETAI)
|
---|
188 | STHETI = 1.D0 - CTHETA**2
|
---|
189 | IF ( STHETI .GT. 0.D0 ) THEN
|
---|
190 | C PARTICLE IS ABOVE ENERGY THRESHOLD IF EMISSION ANGLE IS >0
|
---|
191 | PHOTCT = CYIELD * STEPCR * STHETI
|
---|
192 | NSTEPC = PHOTCT / CERSIZ + 1
|
---|
193 | IF ( NSTEPC .LT. 1 ) RETURN
|
---|
194 | FSTEPI = 1. / REAL(NSTEPC)
|
---|
195 | C CALCULATE INCREMENTS AND START VALUES FOR POSITION AND VELOCITY
|
---|
196 | DVCOR = -VSTEP * FSTEPI
|
---|
197 | VCOR = VSTEP - 0.5 * DVCOR
|
---|
198 | DBETA = -2.D0*FSTEPI*EDEP*(PAMA(2)*1.D3)**2 / (E1**3*BETAI)
|
---|
199 | BETAE = BETAI - 0.5D0 * DBETA
|
---|
200 | ELSE
|
---|
201 |
|
---|
202 | C LOOK WETHER CERENKOV CONDITION IS FULFILLED AT END OF STEP, BUT NOT
|
---|
203 | C AT THE BEGINNING. THIS MAY HAPPEN ONLY ABOVE ABOUT 22 KM
|
---|
204 | IF ( HTOP .LT. 22.E5 ) RETURN
|
---|
205 | C ENERGY AT END OF STEP IS ENEW (FROM COMMON EPCONT)
|
---|
206 | BETAF = SQRT( 1.D0 - (PAMA(2)*1.D3/ENEW)**2 )
|
---|
207 | C REFRACTIVE INDEX PARAMETRISATION: N=1+ETA = ETA1
|
---|
208 | ETA1 = 1.D0 + ETADSN * RHOF( DBLE(H2) )
|
---|
209 | CTHETA = 1.D0 /( ETA1 * BETAF)
|
---|
210 | STHETF = 1.D0 - CTHETA**2
|
---|
211 | C PARTICLE IS BELOW ENERGY THRESHOLD IF EMISSION ANGLE IS 0
|
---|
212 | IF ( STHETF .LE. 0.D0 ) RETURN
|
---|
213 | PHOTCT = CYIELD * STEPCR * STHETF
|
---|
214 | NSTEPC = PHOTCT / CERSIZ + 1
|
---|
215 | IF ( NSTEPC .LT. 1 ) RETURN
|
---|
216 | FSTEPI = 1. / REAL(NSTEPC)
|
---|
217 | C CALCULATE INCREMENTS AND START VALUES FOR POSITION AND VELOCITY
|
---|
218 | C LOOP 1000 RUNS FROM BOTTOM TO TOP OF STEP
|
---|
219 | DVCOR = VSTEP * FSTEPI
|
---|
220 | VCOR = -0.5 * DVCOR
|
---|
221 | DBETA = 2.D0*FSTEPI*EDEP*(PAMA(2)*1.D3)**2 / (ENEW**3*BETAF)
|
---|
222 | BETAE = BETAF - 0.5D0 * DBETA
|
---|
223 | ENDIF
|
---|
224 |
|
---|
225 | C LOOP OVER SUBSTEPS
|
---|
226 | DO 1000 ISTC = 1,NSTEPC
|
---|
227 | VCOR = VCOR + DVCOR
|
---|
228 | ZEMIS = H2 + VCOR * W(NP)
|
---|
229 | ETA1 = 1.D0 + ETADSN * RHOF(DBLE(ZEMIS))
|
---|
230 | C VELOCITY IN THE MIDDLE OF SUBSTEP
|
---|
231 | BETAE = BETAE + DBETA
|
---|
232 | CTHETA = 1.D0 / (ETA1*BETAE)
|
---|
233 | STHETA = 1.D0 - CTHETA**2
|
---|
234 | C PARTICLE IS AT ENERGY THRESHOLD IF EMISSION ANGLE BECOMES 0
|
---|
235 | IF ( STHETA .LE. 0.D0 ) RETURN
|
---|
236 | C NUMBER OF EMITTED PHOTONS ON DISTANCE DVCOR
|
---|
237 | PHOTCM = CYIELD * STHETA * STEPCR * FSTEPI
|
---|
238 | STHETA = SQRT(STHETA)
|
---|
239 | C ASSUME EMISSION POINT OF ALL PHOTONS IN THE MIDDLE OF THE STEP
|
---|
240 | XEMIS = X(NP) - VCOR * U(NP)
|
---|
241 | YEMIS = -Y(NP) + VCOR * V(NP)
|
---|
242 | C>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
243 | C GENERATE RANDOM WAVELENGTH FOR SINGLE C-PHOTON.
|
---|
244 | CALL RMMAR( RD,1,3 )
|
---|
245 | WAVELENGTH = 1. / (1/WAVLGL -
|
---|
246 | + RD(1)/(WAVLGL*WAVLGU/(WAVLGU-WAVLGL)))
|
---|
247 | C>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
248 | C CALCULATE PHOTON DIRECTION IN THE CORSIKA COORDINATE FRAME
|
---|
249 | CALL RMMAR( RD,1,3 )
|
---|
250 | PHICER = RD(1) * PI2
|
---|
251 | SINCR = SIN(PHICER)
|
---|
252 | COSCR = COS(PHICER)
|
---|
253 | A = U(NP)
|
---|
254 | B = -V(NP)
|
---|
255 | CC = W(NP)
|
---|
256 | SINPS2 = A**2 + B**2
|
---|
257 | IF ( SINPS2 .LT. 1.E-10 ) THEN
|
---|
258 | UEMIS = STHETA * COSCR
|
---|
259 | VEMIS = STHETA * SINCR
|
---|
260 | WEMIS = CTHETA * CC
|
---|
261 | ELSE
|
---|
262 | SINPSI = SQRT(SINPS2)
|
---|
263 | US = STHETA * COSCR
|
---|
264 | VS = STHETA * SINCR
|
---|
265 | SINDEL = B * (1./SINPSI)
|
---|
266 | COSDEL = A * (1./SINPSI)
|
---|
267 | UEMIS = CC * COSDEL * US - SINDEL * VS + A * CTHETA
|
---|
268 | VEMIS = CC * SINDEL * US + COSDEL * VS + B * CTHETA
|
---|
269 | WEMIS = -SINPSI * US + CC * CTHETA
|
---|
270 | ENDIF
|
---|
271 | C EMISSION ANGLE WITHIN ZENITH ANGULAR CUT?
|
---|
272 | IF ( WEMIS .LT. C(29) ) GOTO 1000
|
---|
273 | RADINV = 1.5 - 0.5 * ( UEMIS**2 + VEMIS**2 + WEMIS**2 )
|
---|
274 | UEMIS2 = UEMIS * RADINV
|
---|
275 | VEMIS2 = VEMIS * RADINV
|
---|
276 | WEMIS = WEMIS * RADINV
|
---|
277 |
|
---|
278 | C CALCULATE DISTANCE FROM SHOWER AXIS AT THE DETECTOR LEVEL
|
---|
279 | PATHCR = ( ZEMIS - OBSLEV(NOBSLV) ) / WEMIS
|
---|
280 | XCER2 = XEMIS + PATHCR * UEMIS2 - XOFF(NOBSLV)
|
---|
281 | YCER2 = YEMIS + PATHCR * VEMIS2 - YOFF(NOBSLV)
|
---|
282 |
|
---|
283 | C ADD THE CERENKOV PHOTONS TO THE LONGITUDINAL DEVELOPMENT
|
---|
284 | IF ( LLONGI ) THEN
|
---|
285 | C IF STARTING POINT BELOW LOWEST LEVEL THEN DON'T CHECK
|
---|
286 | IF ( HLONG(NSTEP) .LE. ZEMIS ) THEN
|
---|
287 | C FIND FIRST THE EQUIVALENT LEVELS
|
---|
288 | LPCT1 = LPCTE(NP)
|
---|
289 | C ZEMIS IS ONLY LITTLE BELOW Z OLD, THEREFORE INCREMENTAL SEARCH
|
---|
290 | C (REMEBER: LPCTE IS AT START OF ELECTRON STEP)
|
---|
291 | DO 6002 I1 = LPCT1,NSTEP
|
---|
292 | IF ( HLONG(I1) .LT. ZEMIS ) GOTO 6003
|
---|
293 | 6002 CONTINUE
|
---|
294 | I1 = NSTEP + 1
|
---|
295 | 6003 CONTINUE
|
---|
296 | DO 4862 I=I1,NSTEP
|
---|
297 | PLONG(I,9) = PLONG(I,9) + PHOTCM
|
---|
298 | 4862 CONTINUE
|
---|
299 | ENDIF
|
---|
300 | ENDIF
|
---|
301 |
|
---|
302 | C TAKE INTO ACCOUNT A ROTATION OF ARRAY RELATIVE TO MAGNETIC NORD
|
---|
303 | XCER = XCER2 * COSANG + YCER2 * SINANG
|
---|
304 | YCER = YCER2 * COSANG - XCER2 * SINANG
|
---|
305 | UEMIS = UEMIS2 * COSANG + VEMIS2 * SINANG
|
---|
306 | VEMIS = VEMIS2 * COSANG - UEMIS2 * SINANG
|
---|
307 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
308 | CERELE = CERELE + PHOTCM
|
---|
309 | DO 7001 I=1,ICERML
|
---|
310 | DO 101 NCT=1,NCTELS
|
---|
311 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
312 | c>> Modification to implement sphere algorithm >>>>>>>>>>>>>>>>>>>>>>>>
|
---|
313 | c>> JCG Wed Sep 21 10:49:14 MET DST 1998 >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
314 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
315 | c>>>>> this is the last (simple) check <<<<<
|
---|
316 | C changes to ct frame
|
---|
317 | c XG = XCER - CERXOS(I) - CTPARS(NCT,XCT)
|
---|
318 | c YG = YCER - CERYOS(I) - CTPARS(NCT,YCT)
|
---|
319 | c ZG = 0.0 - CTPARS(NCT,ZCT)
|
---|
320 | c DIST2 = SQRT( XG**2 + YG**2 )
|
---|
321 | c IF ( DIST2 .LT. (CTPARS(NCT,CTDIAM)/2.) ) GOTO 102
|
---|
322 | c>> New check >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
323 | XG = XCER - CERXOS(I)
|
---|
324 | YG = YCER - CERYOS(I)
|
---|
325 | ZG = 0.0
|
---|
326 | DIST2 =
|
---|
327 | > SQRT((VEMIS*(-CTPARS(NCT,XCT) + XG) -
|
---|
328 | > UEMIS*(-CTPARS(NCT,YCT) + YG))**2 +
|
---|
329 | > (-(SQRT(1 - UEMIS**2 - VEMIS**2)*
|
---|
330 | > (-CTPARS(NCT,XCT) + XG)) +
|
---|
331 | > UEMIS*(-CTPARS(NCT,ZCT) + ZG))**2 +
|
---|
332 | > (SQRT(1 - UEMIS**2 - VEMIS**2)*
|
---|
333 | > (-CTPARS(NCT,YCT) + YG) -
|
---|
334 | > VEMIS*(-CTPARS(NCT,ZCT) + ZG))**2)
|
---|
335 | IF ( DIST2 .LT. (CTPARS(NCT,CTDIAM)/2.) ) GOTO 102
|
---|
336 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
337 |
|
---|
338 | 101 CONTINUE
|
---|
339 |
|
---|
340 | GOTO 7001
|
---|
341 |
|
---|
342 | C BUNCH FALLS ON A DETECTOR, CALCULATE ARRIVAL TIME (NSEC)
|
---|
343 |
|
---|
344 | 102 CARTIM = ((ETADSN*(THCKOB(NOBSLV)-THICK(DBLE(ZEMIS)))
|
---|
345 | * /WEMIS+PATHCR-VCOR/BETAE)/C(25)+TIME(NP))* 1.E9
|
---|
346 |
|
---|
347 | c CALL OUTPT2(IQ(NP),I)
|
---|
348 | CALL OUTPT2(NCT,I)
|
---|
349 | C
|
---|
350 | CBC++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
---|
351 | C
|
---|
352 | C Modified by C. Bigongiari 2001 Jan 16
|
---|
353 | C
|
---|
354 | C
|
---|
355 | Cc>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
356 | C call jctime(cartim)
|
---|
357 | Cc>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
358 | C
|
---|
359 | C
|
---|
360 | CBC++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
---|
361 | C
|
---|
362 |
|
---|
363 | GOTO 1000
|
---|
364 |
|
---|
365 | 7001 CONTINUE
|
---|
366 | 1000 CONTINUE
|
---|
367 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
368 | RETURN
|
---|
369 | END
|
---|
370 |
|
---|
371 | C=======================================================================
|
---|
372 |
|
---|
373 | SUBROUTINE CERENH( STEPCR,BETACR )
|
---|
374 |
|
---|
375 | C-----------------------------------------------------------------------
|
---|
376 | C CEREN(KOV RADIATION FROM) H(ADRONS)
|
---|
377 | C
|
---|
378 | C CERENKOV RADIATION FROM HADRONS
|
---|
379 | C CERENKOV RADIATION IS ONLY CALCULATED FOR LOWEST OBSERVATION LEVEL
|
---|
380 | C THIS SUBROUTINE IS CALLED FROM UPDATE
|
---|
381 | C ARGUMENTS:
|
---|
382 | C STEPCR = STEP LENGTH FOR ELECTRON OR POSITRON
|
---|
383 | C BETACR = VELOCITY OF PARTICLE IN UNITS OF SPEED OF LIGHT
|
---|
384 | C
|
---|
385 | C AUTHOR : M. ROZANSKA UNIVERSITY OF KRAKOW
|
---|
386 | C S. MARTINEZ UNIVERSITY OF MADRID
|
---|
387 | C F. ARQUEROS UNIVERSITY OF MADRID
|
---|
388 | C CHANGES : D. HECK IK3 FZK KARLSRUHE
|
---|
389 | C-----------------------------------------------------------------------
|
---|
390 |
|
---|
391 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
392 | parameter (xct=1)
|
---|
393 | parameter (yct=2)
|
---|
394 | parameter (zct=3)
|
---|
395 | parameter (ctthet=4)
|
---|
396 | parameter (ctphi=5)
|
---|
397 | parameter (ctdiam=6)
|
---|
398 | parameter (ctfoc=7)
|
---|
399 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
400 |
|
---|
401 | c IMPLICIT NONE
|
---|
402 | *KEEP,BUFFS.
|
---|
403 | COMMON /BUFFS/ RUNH,RUNE,EVTH,EVTE,DATAB,LH
|
---|
404 | INTEGER MAXBUF,MAXLEN
|
---|
405 | PARAMETER (MAXBUF=39*7)
|
---|
406 | PARAMETER (MAXLEN=12)
|
---|
407 | REAL RUNH(MAXBUF),EVTH(MAXBUF),EVTE(MAXBUF),
|
---|
408 | * RUNE(MAXBUF),DATAB(MAXBUF)
|
---|
409 | INTEGER LH
|
---|
410 | CHARACTER*4 CRUNH,CRUNE,CEVTH,CEVTE
|
---|
411 | EQUIVALENCE (RUNH(1),CRUNH), (RUNE(1),CRUNE)
|
---|
412 | EQUIVALENCE (EVTH(1),CEVTH), (EVTE(1),CEVTE)
|
---|
413 | *KEEP,CONST.
|
---|
414 | COMMON /CONST/ PI,PI2,OB3,TB3,ENEPER
|
---|
415 | DOUBLE PRECISION PI,PI2,OB3,TB3,ENEPER
|
---|
416 | *KEEP,EPCONT.
|
---|
417 | COMMON/EPCONT/ EDEP,RATIO,TSTEP,TUSTEP,USTEP,TVSTEP,VSTEP,IDISC,
|
---|
418 | * IROLD,IRNEW,RHOFAC, EOLD,ENEW,EKE,ELKE,BETA2,GLE,
|
---|
419 | * TSCAT,IAUSFL
|
---|
420 | DOUBLE PRECISION EDEP,RATIO
|
---|
421 | REAL TSTEP,TUSTEP,USTEP,TVSTEP,VSTEP,RHOFAC,EOLD,ENEW,
|
---|
422 | * EKE,ELKE,BETA2,GLE,TSCAT
|
---|
423 | INTEGER IDISC,IROLD,IRNEW,IAUSFL(29)
|
---|
424 | *KEEP,LONGI.
|
---|
425 | COMMON /LONGI/ APLONG,HLONG,PLONG,SPLONG,THSTEP,THSTPI,
|
---|
426 | * NSTEP,LLONGI,FLGFIT
|
---|
427 | DOUBLE PRECISION APLONG(0:1040,9),HLONG(0:1024),PLONG(0:1040,9),
|
---|
428 | * SPLONG(0:1040,9),THSTEP,THSTPI
|
---|
429 | INTEGER NSTEP
|
---|
430 | LOGICAL LLONGI,FLGFIT
|
---|
431 | *KEEP,MAGANG.
|
---|
432 | COMMON /MAGANG/ ARRANG,ARRANR,COSANG,SINANG
|
---|
433 | DOUBLE PRECISION ARRANG,ARRANR,COSANG,SINANG
|
---|
434 | *KEEP,OBSPAR.
|
---|
435 | COMMON /OBSPAR/ OBSLEV,THCKOB,XOFF,YOFF,THETAP,PHIP,
|
---|
436 | * THETPR,PHIPR,NOBSLV
|
---|
437 | DOUBLE PRECISION OBSLEV(10),THCKOB(10),XOFF(10),YOFF(10),
|
---|
438 | * THETAP,THETPR(2),PHIP,PHIPR(2)
|
---|
439 | INTEGER NOBSLV
|
---|
440 | *KEEP,PAM.
|
---|
441 | COMMON /PAM/ PAMA,SIGNUM
|
---|
442 | DOUBLE PRECISION PAMA(6000),SIGNUM(6000)
|
---|
443 | *KEEP,PARPAR.
|
---|
444 | COMMON /PARPAR/ CURPAR,SECPAR,PRMPAR,OUTPAR,C,
|
---|
445 | * E00,E00PN,PTOT0,PTOT0N,THICKH,ITYPE,LEVL
|
---|
446 | DOUBLE PRECISION CURPAR(14),SECPAR(14),PRMPAR(14),OUTPAR(14),
|
---|
447 | * C(50),E00,E00PN,PTOT0,PTOT0N,THICKH
|
---|
448 | INTEGER ITYPE,LEVL
|
---|
449 | *KEEP,PARPAE.
|
---|
450 | DOUBLE PRECISION GAMMA,COSTHE,PHI,H,T,X,Y,CHI,BETA,GCM,ECM
|
---|
451 | EQUIVALENCE (CURPAR(2),GAMMA), (CURPAR(3),COSTHE),
|
---|
452 | * (CURPAR(4), PHI ), (CURPAR(5), H ),
|
---|
453 | * (CURPAR(6), T ), (CURPAR(7), X ),
|
---|
454 | * (CURPAR(8), Y ), (CURPAR(9), CHI ),
|
---|
455 | * (CURPAR(10),BETA), (CURPAR(11),GCM ),
|
---|
456 | * (CURPAR(12),ECM )
|
---|
457 | *KEEP,RANDPA.
|
---|
458 | COMMON /RANDPA/ FAC,U1,U2,RD,NSEQ,ISEED,KNOR
|
---|
459 | DOUBLE PRECISION FAC,U1,U2
|
---|
460 | REAL RD(3000)
|
---|
461 | INTEGER ISEED(103,10),NSEQ
|
---|
462 | LOGICAL KNOR
|
---|
463 | *KEEP,RUNPAR.
|
---|
464 | COMMON /RUNPAR/ FIXHEI,THICK0,HILOECM,HILOELB,
|
---|
465 | * STEPFC,NRRUN,NSHOW,PATAPE,MONIIN,
|
---|
466 | * MONIOU,MDEBUG,NUCNUC,
|
---|
467 | * CETAPE,
|
---|
468 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
469 | * N1STTR,MDBASE,
|
---|
470 | * DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
471 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
472 | * ,GHEISH,GHESIG
|
---|
473 | COMMON /RUNPAC/ DSN,HOST,USER
|
---|
474 | DOUBLE PRECISION FIXHEI,THICK0,HILOECM,HILOELB
|
---|
475 | REAL STEPFC
|
---|
476 | INTEGER NRRUN,NSHOW,PATAPE,MONIIN,MONIOU,MDEBUG,NUCNUC,
|
---|
477 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
478 | * N1STTR,MDBASE
|
---|
479 | INTEGER CETAPE
|
---|
480 | CHARACTER*79 DSN
|
---|
481 | CHARACTER*20 HOST,USER
|
---|
482 |
|
---|
483 | LOGICAL DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
484 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
485 | * ,GHEISH,GHESIG
|
---|
486 | *KEEP,CEREN1.
|
---|
487 | COMMON /CEREN1/ CERELE,CERHAD,ETADSN,WAVLGL,WAVLGU,CYIELD,
|
---|
488 | * CERSIZ,LCERFI
|
---|
489 | DOUBLE PRECISION CERELE,CERHAD,ETADSN,WAVLGL,WAVLGU,CYIELD
|
---|
490 | REAL CERSIZ
|
---|
491 | LOGICAL LCERFI
|
---|
492 | *KEEP,CEREN2.
|
---|
493 | COMMON /CEREN2/ PHOTCM,XCER,YCER,UEMIS,VEMIS,CARTIM,ZEMIS,
|
---|
494 | * DCERX,DCERY,ACERX,ACERY,
|
---|
495 | * XCMAX,YCMAX,EPSX,EPSY,
|
---|
496 | * DCERXI,DCERYI,FCERX,FCERY,
|
---|
497 | * XSCATT,YSCATT,CERXOS,CERYOS,
|
---|
498 | * NCERX,NCERY,ICERML
|
---|
499 | REAL PHOTCM,XCER,YCER,UEMIS,VEMIS,CARTIM,ZEMIS,
|
---|
500 | * DCERX,DCERY,ACERX,ACERY,
|
---|
501 | * XCMAX,YCMAX,EPSX,EPSY,
|
---|
502 | * DCERXI,DCERYI,FCERX,FCERY,
|
---|
503 | * XSCATT,YSCATT,CERXOS(20),CERYOS(20)
|
---|
504 | INTEGER NCERX,NCERY,ICERML
|
---|
505 | *KEEP,CERHDR.
|
---|
506 | COMMON/CERHDR/ TPART,UPART,VPART,WPART,XPART,YPART,ZPART
|
---|
507 | DOUBLE PRECISION TPART,UPART,VPART,WPART,XPART,YPART,ZPART
|
---|
508 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
509 | *keep,certel.
|
---|
510 | common /certel/ cormxd,cord,coralp,ctpars,omega,
|
---|
511 | + photn,photnp,phpt,pht,vphot,
|
---|
512 | + vchi,veta,vzeta,vchim,vetam,vzetam,
|
---|
513 | + lambda,mu,nu,nctels,ncph
|
---|
514 | double precision cormxd,cord,coralp,ctpars(20,7),omega(20,3,3),
|
---|
515 | + photn(3),photnp(3),phpt(3),pht,vphot(3),
|
---|
516 | + vchi(3),veta(3),vzeta(3),vchim,vetam,vzetam,
|
---|
517 | + lambda,mu,nu
|
---|
518 | integer nctels,ncph(5)
|
---|
519 | double precision xg,yg,zg,xgp,ygp,zgp,up,vp,wp,xpcut,ypcut,zpcut
|
---|
520 | equivalence (photn(1) ,xg) ,(photn(2) ,yg) ,(photn(3) ,zg) ,
|
---|
521 | + (photnp(1),xgp) ,(photnp(2),ygp) ,(photnp(3),zgp),
|
---|
522 | + (phpt(1) ,xpcut),(phpt(2) ,ypcut),(phpt(3) ,zpcut),
|
---|
523 | + (vphot(1) ,up) ,(vphot(2) ,vp) ,(vphot(3) ,wp)
|
---|
524 | character *72 ctfile
|
---|
525 | *keep,graal1.
|
---|
526 | common /graal1/ wavelength ! (nm)
|
---|
527 | real wavelength
|
---|
528 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
529 | *KEND.
|
---|
530 |
|
---|
531 | DOUBLE PRECISION BETACR,CINTEN,CTHETA,ETA,ETA1,HMID,PHOTCT,
|
---|
532 | * RHOF,STEPCR,STHETA,THICK
|
---|
533 | REAL A,B,CC,COSCR,COSDEL,DVCOR,DXXX,DYYY,FSTEPI,
|
---|
534 | * PATHCR,PHICER,RADINV,SINCR,SINDEL,SINPSI,SINPS2,
|
---|
535 | * UEMIS2,US,VEMIS2,VCOR,VS,WEMIS,XCER1,XCER2,XEMIS,
|
---|
536 | * XXX,YCER1,YCER2,YEMIS,YYY
|
---|
537 | INTEGER I,II,ISTC,I1,I2,NSTEPC
|
---|
538 | EXTERNAL RHOF,THICK
|
---|
539 | C-----------------------------------------------------------------------
|
---|
540 |
|
---|
541 | c IF ( DEBUG ) WRITE(MDEBUG,*) 'CERENH: ZPART=',SNGL(ZPART),
|
---|
542 | c * ' STEPCR=',SNGL(STEPCR),' BETACR=',SNGL(BETACR)
|
---|
543 |
|
---|
544 | C SKIP PARTICLE OUT OF ANGULAR ACCEPTANCE RANGE
|
---|
545 | IF ( WPART .LT. C(29) ) RETURN
|
---|
546 | C CERENKOV INTENSITY FACTOR DEPENDS ON CHARGE STATE OF HEAVY IONS
|
---|
547 | CINTEN = CYIELD * ABS(SIGNUM(INT(CURPAR(1))))
|
---|
548 |
|
---|
549 | C REFRACTIVE INDEX PARAMETRISATION: N=1+ETA
|
---|
550 | HMID = ZPART + 0.5D0 * STEPCR * WPART
|
---|
551 | ETA1 = 1.D0 + ETADSN * RHOF(DBLE(HMID))
|
---|
552 | CTHETA = 1.D0 / ( ETA1 * BETACR )
|
---|
553 | STHETA = 1.D0 - CTHETA**2
|
---|
554 | IF ( STHETA .LE. 0.D0 ) RETURN
|
---|
555 |
|
---|
556 | PHOTCT = CINTEN * STHETA * STEPCR
|
---|
557 | NSTEPC = PHOTCT / CERSIZ + 1
|
---|
558 | IF ( NSTEPC .LT. 1 ) RETURN
|
---|
559 | FSTEPI = 1. / REAL(NSTEPC)
|
---|
560 | VCOR = -0.5 * STEPCR * FSTEPI
|
---|
561 | DVCOR = -2. * VCOR
|
---|
562 | C CERENKOV RADIATION IS ONLY CALCULATED FOR LOWEST OBSERVATION LEVEL
|
---|
563 | DO 1000 ISTC = 1,NSTEPC
|
---|
564 | VCOR = VCOR + DVCOR
|
---|
565 | ZEMIS = ZPART + VCOR * WPART
|
---|
566 | ETA = ETADSN * RHOF(DBLE(ZEMIS))
|
---|
567 | ETA1 = 1.D0 + ETA
|
---|
568 | CTHETA = 1.D0 / ( ETA1 * BETACR )
|
---|
569 | STHETA = 1.D0 - CTHETA**2
|
---|
570 | IF ( STHETA .LE. 0.D0 ) RETURN
|
---|
571 |
|
---|
572 | C NUMBER OF EMITTED PHOTONS ON DISTANCE STEPCR
|
---|
573 | PHOTCM = CINTEN * STHETA * STEPCR * FSTEPI
|
---|
574 | STHETA = SQRT(STHETA)
|
---|
575 |
|
---|
576 | C ASSUME EMISSION POINT OF ALL PHOTONS IN THE MIDDLE OF THE STEP
|
---|
577 | C HAS TO BE CHECKED IF STEPS ARE NOT TOO LONG
|
---|
578 | XEMIS = XPART - VCOR * UPART
|
---|
579 | YEMIS = YPART - VCOR * VPART
|
---|
580 |
|
---|
581 | C>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
582 | C GENERATE RANDOM WAVELENGTH FOR SINGLE C-PHOTON.
|
---|
583 | CALL RMMAR( RD,1,3 )
|
---|
584 | WAVELENGTH = 1. / (1/WAVLGL -
|
---|
585 | + RD(1)/(WAVLGL*WAVLGU/(WAVLGU-WAVLGL)))
|
---|
586 | C>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
587 |
|
---|
588 | C CALCULATE PHOTON DIRECTION IN THE OVERALL COORDINATE FRAME
|
---|
589 | CALL RMMAR( RD,1,3 )
|
---|
590 | PHICER = RD(1) * PI2
|
---|
591 | SINCR = SIN(PHICER)
|
---|
592 | COSCR = COS(PHICER)
|
---|
593 | A = UPART
|
---|
594 | B = VPART
|
---|
595 | CC = WPART
|
---|
596 | SINPS2 = A**2 + B**2
|
---|
597 | IF ( SINPS2 .LT. 1.E-10 ) THEN
|
---|
598 | UEMIS = STHETA * COSCR
|
---|
599 | VEMIS = STHETA * SINCR
|
---|
600 | WEMIS = CTHETA * CC
|
---|
601 | ELSE
|
---|
602 | SINPSI = SQRT(SINPS2)
|
---|
603 | US = STHETA * COSCR
|
---|
604 | VS = STHETA * SINCR
|
---|
605 | SINDEL = B * (1./SINPSI)
|
---|
606 | COSDEL = A * (1./SINPSI)
|
---|
607 | UEMIS = CC * COSDEL * US - SINDEL * VS + A * CTHETA
|
---|
608 | VEMIS = CC * SINDEL * US + COSDEL * VS + B * CTHETA
|
---|
609 | WEMIS = -SINPSI * US + CC * CTHETA
|
---|
610 | ENDIF
|
---|
611 | C EMISSION ANGLE WITHIN ZENITH ANGULAR CUT?
|
---|
612 | IF ( WEMIS .LT. C(29) ) GOTO 1000
|
---|
613 | RADINV = 1.5 - 0.5 * ( UEMIS**2 + VEMIS**2 + WEMIS**2 )
|
---|
614 | UEMIS2 = UEMIS * RADINV
|
---|
615 | VEMIS2 = VEMIS * RADINV
|
---|
616 | WEMIS = WEMIS * RADINV
|
---|
617 |
|
---|
618 | C CALCULATE DISTANCE FROM SHOWER AXIS AT THE DETECTOR LEVEL
|
---|
619 | PATHCR = ( ZEMIS - OBSLEV(NOBSLV) ) / WEMIS
|
---|
620 | XCER2 = XEMIS + PATHCR * UEMIS2 - XOFF(NOBSLV)
|
---|
621 | YCER2 = YEMIS + PATHCR * VEMIS2 - YOFF(NOBSLV)
|
---|
622 |
|
---|
623 | C ADD THE CERENKOV PHOTONS TO THE LONGITUDINAL DEVELOPMENT
|
---|
624 | IF ( LLONGI ) THEN
|
---|
625 | C IF STARTING POINT BELOW LOWEST LEVEL THEN DON'T CHECK
|
---|
626 | IF ( HLONG(NSTEP) .LE. ZEMIS ) THEN
|
---|
627 | C FIND FIRST THE EQUIVALENT LEVELS
|
---|
628 | I1 = 0
|
---|
629 | I2 = NSTEP
|
---|
630 | 6001 CONTINUE
|
---|
631 | II = (I1+I2)/2
|
---|
632 | IF ( HLONG(II) .LT. ZEMIS ) THEN
|
---|
633 | I2 = II
|
---|
634 | ELSE
|
---|
635 | I1 = II
|
---|
636 | ENDIF
|
---|
637 | IF ( I2-I1 .GT. 1 ) GOTO 6001
|
---|
638 | DO 4862 I=I2,NSTEP
|
---|
639 | PLONG(I,9) = PLONG(I,9) + PHOTCM
|
---|
640 | 4862 CONTINUE
|
---|
641 | ENDIF
|
---|
642 | ENDIF
|
---|
643 |
|
---|
644 | C TAKE INTO ACCOUNT A ROTATION OF ARRAY RELATIVE TO MAGNETIC NORD
|
---|
645 | XCER = XCER2 * COSANG + YCER2 * SINANG
|
---|
646 | YCER = YCER2 * COSANG - XCER2 * SINANG
|
---|
647 | UEMIS = UEMIS2 * COSANG + VEMIS2 * SINANG
|
---|
648 | VEMIS = VEMIS2 * COSANG - UEMIS2 * SINANG
|
---|
649 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
650 | CERHAD = CERHAD + PHOTCM
|
---|
651 | DO 7001 I=1,ICERML
|
---|
652 | DO 101 NCT=1,NCTELS
|
---|
653 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
654 | c>> Modification to implement sphere algorithm >>>>>>>>>>>>>>>>>>>>>>>>
|
---|
655 | c>> JCG Wed Sep 21 10:49:14 MET DST 1998 >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
656 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
657 | c>>>>> this is the last (simple) check <<<<<
|
---|
658 | C changes to ct frame
|
---|
659 | c XG = XCER - CERXOS(I) - CTPARS(NCT,XCT)
|
---|
660 | c YG = YCER - CERYOS(I) - CTPARS(NCT,YCT)
|
---|
661 | c ZG = 0.0 - CTPARS(NCT,ZCT)
|
---|
662 | c DIST2 = SQRT( XG**2 + YG**2 )
|
---|
663 | c IF ( DIST2 .LT. (CTPARS(NCT,CTDIAM)/2.) ) GOTO 102
|
---|
664 | c>> New check >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
665 | XG = XCER - CERXOS(I)
|
---|
666 | YG = YCER - CERYOS(I)
|
---|
667 | ZG = 0.0
|
---|
668 | DIST2 =
|
---|
669 | > SQRT((VEMIS*(-CTPARS(NCT,XCT) + XG) -
|
---|
670 | > UEMIS*(-CTPARS(NCT,YCT) + YG))**2 +
|
---|
671 | > (-(SQRT(1 - UEMIS**2 - VEMIS**2)*
|
---|
672 | > (-CTPARS(NCT,XCT) + XG)) +
|
---|
673 | > UEMIS*(-CTPARS(NCT,ZCT) + ZG))**2 +
|
---|
674 | > (SQRT(1 - UEMIS**2 - VEMIS**2)*
|
---|
675 | > (-CTPARS(NCT,YCT) + YG) -
|
---|
676 | > VEMIS*(-CTPARS(NCT,ZCT) + ZG))**2)
|
---|
677 | IF ( DIST2 .LT. (CTPARS(NCT,CTDIAM)/2.) ) GOTO 102
|
---|
678 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
679 | 101 CONTINUE
|
---|
680 |
|
---|
681 | GOTO 7001
|
---|
682 |
|
---|
683 | C BUNCH FALLS ON A DETECTOR, CALCULATE ARRIVAL TIME (NSEC)
|
---|
684 |
|
---|
685 | 102 CARTIM = ((ETADSN*(THCKOB(NOBSLV)-THICK(DBLE(ZEMIS)))
|
---|
686 | * /WEMIS+PATHCR-VCOR/BETACR)/C(25)+TPART)*1.E9
|
---|
687 |
|
---|
688 | c CALL OUTPT2(INT(CURPAR(1)),I)
|
---|
689 | CALL OUTPT2(NCT,I)
|
---|
690 |
|
---|
691 | C
|
---|
692 | CBC++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
---|
693 | C
|
---|
694 | C Modified by C. Bigongiari 2001 Jan 16
|
---|
695 | C
|
---|
696 | C
|
---|
697 | Cc>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
698 | C call jctime(cartim)
|
---|
699 | Cc>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
700 | C
|
---|
701 | C
|
---|
702 | CBC++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
---|
703 | C
|
---|
704 |
|
---|
705 | GOTO 1000
|
---|
706 |
|
---|
707 | 7001 CONTINUE
|
---|
708 | 1000 CONTINUE
|
---|
709 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
710 | RETURN
|
---|
711 | END
|
---|
712 |
|
---|
713 | C=======================================================================
|
---|
714 |
|
---|
715 | SUBROUTINE GETBUS( IPARTI,ENERGY,THETA,CERSZE )
|
---|
716 |
|
---|
717 | C-----------------------------------------------------------------------
|
---|
718 | C GET BU(NCH) S(IZE)
|
---|
719 | C
|
---|
720 | C CALCULATES OPTIMAL BUNCH SIZE FOR CERENKOV PHOTONS. CERENKOV PHOTONS
|
---|
721 | C ARE GROUPED IN BUNCHES IN ORDER TO ACCELERATE COMPUTING TIME.
|
---|
722 | C HOWEVER, WE SET A MAXIMAL VALUE FOR THE GROUPING OF CERENKOV PHOTONS
|
---|
723 | C SO THAT WE GET AT LEAST 100 BUNCHES/M**2 AT A CERENKOV FLUX OF 3000
|
---|
724 | C PHOTONS/M**2. THIS IS THE MINIMUM CERENKOV FLUX WHICH CAN BE
|
---|
725 | C DISTINGUISHED FROM THE NIGHT SKY LIGHT BACKGROUND IN THE HEGRA
|
---|
726 | C EXPERIMENT AT THE ISLAND LA PALMA. SO THE PARAMETRIZATION OF THE
|
---|
727 | C CERENKOV BUNCH AS CALCULATED IN THIS SUBROUTINE IS VALID FOR
|
---|
728 | C OBSERVATION LEVELS SIMILAR TO THAT OF THE HEGRA EXPERIMENT.
|
---|
729 | C FOR A GIVEN PRIMARY PARTICLE, INCIDENT ENERGY AND ANGLE, AN
|
---|
730 | C OPTIMAL BUNCH SIZE IS CALCULATED BY INTERPOLATION IN A TABLE,
|
---|
731 | C WHERE WE HAVE CHOSEN AN ENERGY RANGE UP TO 1000 TEV, INCIDENT
|
---|
732 | C ANGLES 0 AND 40 DEGREES, AND 4 TYPES OF PRIMARIS: GAMMAS,
|
---|
733 | C PROTONS, NITROGEN, AND IRON.
|
---|
734 | C THIS SUBROUTINE IS CALLED FROM MAIN
|
---|
735 | C ARGUMENTS:
|
---|
736 | C IPARTI = TYPE OF PRIMARY PARTICLE
|
---|
737 | C ENERGY (R4) = PARTICLES ENERGY IN GEV
|
---|
738 | C THETA (R4) = ANGLE IN RAD
|
---|
739 | C CERSZE (R4) = SIZE OF CERENKOV BUNCH
|
---|
740 | C
|
---|
741 | C AUTHORS : S. MARTINEZ UNIVERSITY OF MADRID
|
---|
742 | C F. ARQUEROS UNIVERSITY OF MADRID
|
---|
743 | C-----------------------------------------------------------------------
|
---|
744 |
|
---|
745 | IMPLICIT NONE
|
---|
746 | *KEEP,CONST.
|
---|
747 | COMMON /CONST/ PI,PI2,OB3,TB3,ENEPER
|
---|
748 | DOUBLE PRECISION PI,PI2,OB3,TB3,ENEPER
|
---|
749 | *KEEP,RUNPAR.
|
---|
750 | COMMON /RUNPAR/ FIXHEI,THICK0,HILOECM,HILOELB,
|
---|
751 | * STEPFC,NRRUN,NSHOW,PATAPE,MONIIN,
|
---|
752 | * MONIOU,MDEBUG,NUCNUC,
|
---|
753 | * CETAPE,
|
---|
754 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
755 | * N1STTR,MDBASE,
|
---|
756 | * DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
757 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
758 | * ,GHEISH,GHESIG
|
---|
759 | COMMON /RUNPAC/ DSN,HOST,USER
|
---|
760 | DOUBLE PRECISION FIXHEI,THICK0,HILOECM,HILOELB
|
---|
761 | REAL STEPFC
|
---|
762 | INTEGER NRRUN,NSHOW,PATAPE,MONIIN,MONIOU,MDEBUG,NUCNUC,
|
---|
763 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
764 | * N1STTR,MDBASE
|
---|
765 | INTEGER CETAPE
|
---|
766 | CHARACTER*79 DSN
|
---|
767 | CHARACTER*20 HOST,USER
|
---|
768 |
|
---|
769 | LOGICAL DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
770 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
771 | * ,GHEISH,GHESIG
|
---|
772 | *KEND.
|
---|
773 |
|
---|
774 | REAL ANGLE(2),ENGAM(3),ENHAD(3),ENNIT(2),
|
---|
775 | * SIFE(3,2),SIGAM(3,2),SINIT(2),SIPRO(3,2)
|
---|
776 | REAL CERS1F,CERS1P,ENERGY,CERSZE,S1,S2,THETA
|
---|
777 | INTEGER I,IANFE,IANP,IATNUM,IPARTI,I1,I2
|
---|
778 |
|
---|
779 | DATA ANGLE / 0., 40. /
|
---|
780 | DATA ENGAM / 100., 200., 500. /
|
---|
781 | DATA ENHAD / 100., 200., 1000. /
|
---|
782 | DATA ENNIT / 200., 1000. /
|
---|
783 | DATA ( SIFE (I,1),I=1,3 ) / 30., 30., 140. /
|
---|
784 | DATA ( SIFE (I,2),I=1,3 ) / 30., 30., 110. /
|
---|
785 | DATA ( SIGAM(I,1),I=1,3 ) / 30., 45., 100. /
|
---|
786 | DATA ( SIGAM(I,2),I=1,3 ) / 30., 40., 100. /
|
---|
787 | DATA SINIT / 30., 150. /
|
---|
788 | DATA ( SIPRO(I,1),I=1,3 ) / 30., 30., 120. /
|
---|
789 | DATA ( SIPRO(I,2),I=1,3 ) / 30., 30., 160. /
|
---|
790 | DATA IANP / 1 /, IANFE / 26 /
|
---|
791 | C-----------------------------------------------------------------------
|
---|
792 |
|
---|
793 | c IF ( DEBUG ) WRITE(MDEBUG,100) IPARTI,SNGL(ENERGY),SNGL(THETA)
|
---|
794 | c 100 FORMAT(' GETBUS: INPUT PARTICLE = ',I5,1P,2E10.3)
|
---|
795 |
|
---|
796 | C DEFAULT VALUE
|
---|
797 | CERSZE = 100.
|
---|
798 |
|
---|
799 | ENERGY = ENERGY / 1000.
|
---|
800 | IF ( ENERGY .LE. 100. ) THEN
|
---|
801 | CERSZE = 30.
|
---|
802 | IF ( DEBUG ) WRITE(MDEBUG,101) CERSZE
|
---|
803 | RETURN
|
---|
804 | ENDIF
|
---|
805 |
|
---|
806 | THETA = THETA / PI * 180.
|
---|
807 |
|
---|
808 | C-----------------------------------------------------------------------
|
---|
809 | C PHOTON, ELECTRON OR POSITRON AS PRIMARY PARTICLE
|
---|
810 | IF ( IPARTI .LE. 3 ) THEN
|
---|
811 | C FIND ENERGY BIN FOR INTERPOLATION
|
---|
812 | IF ( ENERGY .LE. ENGAM(2) ) THEN
|
---|
813 | I1 = 1
|
---|
814 | I2 = 2
|
---|
815 | ELSE
|
---|
816 | I1 = 2
|
---|
817 | I2 = 3
|
---|
818 | ENDIF
|
---|
819 | S1 = SIGAM(I1,1) + (ENERGY - ENGAM(I1))
|
---|
820 | * / (ENGAM(I2) - ENGAM(I1))
|
---|
821 | * * (SIGAM(I2,1) - SIGAM(I1,1))
|
---|
822 | S2 = SIGAM(I1,2) + (ENERGY - ENGAM(I1))
|
---|
823 | * / (ENGAM(I2) - ENGAM(I1))
|
---|
824 | * * (SIGAM(I2,2) - SIGAM(I1,2))
|
---|
825 | CERSZE = S1 + (THETA-ANGLE(1))/(ANGLE(2)-ANGLE(1)) * (S2-S1)
|
---|
826 | IF ( DEBUG ) WRITE(MDEBUG,101) CERSZE
|
---|
827 | RETURN
|
---|
828 | ENDIF
|
---|
829 |
|
---|
830 | C-----------------------------------------------------------------------
|
---|
831 | C NITROGEN AS PRIMARY PARTICLE AND VERTICAL INCIDENCE
|
---|
832 | CJOK WHY SPECIAL TREATMENT FOR NITROGEN ????
|
---|
833 | CJOK WHY ONLY VERTICAL INCIDENCE ????
|
---|
834 | IF ( IPARTI .EQ. 1407 .AND. ABS(THETA) .LT. 1.E-1 ) THEN
|
---|
835 | IF ( ENERGY .LT. 200. ) THEN
|
---|
836 | CERSZE = 30.
|
---|
837 | ELSE
|
---|
838 | CERSZE = SINIT(1) + (ENERGY-ENNIT(1))
|
---|
839 | * / (ENNIT(2)-ENNIT(1)) * (SINIT(2)-SINIT(1))
|
---|
840 | ENDIF
|
---|
841 | IF ( DEBUG ) WRITE(MDEBUG,101) CERSZE
|
---|
842 | RETURN
|
---|
843 | ENDIF
|
---|
844 |
|
---|
845 | C-----------------------------------------------------------------------
|
---|
846 | C GET THE ATOMIC NUMBER OF THE NUCLEUS
|
---|
847 | C Z IS 1, IF PROTON
|
---|
848 | IF ( IPARTI .EQ. 14 ) THEN
|
---|
849 | IATNUM = 1
|
---|
850 | C REST OF POSSIBLE NUCLEI
|
---|
851 | ELSEIF ( IPARTI .GT. 100 ) THEN
|
---|
852 | IATNUM = MOD(IPARTI,100)
|
---|
853 | IF ( IATNUM .GT. 26 ) THEN
|
---|
854 | WRITE(MONIOU,*) 'GETBUS: UNEXPECTED PARTICLE CODE'
|
---|
855 | RETURN
|
---|
856 | ENDIF
|
---|
857 | ELSE
|
---|
858 | WRITE(MONIOU,*) 'GETBUS: UNEXPECTED PARTICLE CODE'
|
---|
859 | RETURN
|
---|
860 | ENDIF
|
---|
861 |
|
---|
862 | C FIND ENERGY BIN FOR INTERPOLATION IN CASE OF HADRONIC PRIMARY
|
---|
863 | IF ( ENERGY .LE. ENHAD(2) ) THEN
|
---|
864 | I1 = 1
|
---|
865 | I2 = 2
|
---|
866 | ELSE
|
---|
867 | I1 = 2
|
---|
868 | I2 = 3
|
---|
869 | ENDIF
|
---|
870 |
|
---|
871 | C INTERPOLATION FOR HADRONS
|
---|
872 | S1 = SIPRO(I1,1) + (ENERGY-ENHAD(I1))
|
---|
873 | * / (ENHAD(I2)-ENHAD(I1)) * (SIPRO(I2,1)-SIPRO(I1,1))
|
---|
874 | S2 = SIPRO(I1,2) + (ENERGY-ENHAD(I1))
|
---|
875 | * / (ENHAD(I2)-ENHAD(I1)) * (SIPRO(I2,2)-SIPRO(I1,2))
|
---|
876 | CERS1P = S1 + (THETA-ANGLE(1)) / (ANGLE(2)-ANGLE(1)) * (S2-S1)
|
---|
877 |
|
---|
878 | S1 = SIFE(I1,1) + (ENERGY-ENHAD(I1)) / (ENHAD(I2)-ENHAD(I1))
|
---|
879 | * * (SIFE(I2,1)-SIFE(I1,1))
|
---|
880 | S2 = SIFE(I1,2) + (ENERGY-ENHAD(I1)) / (ENHAD(I2)-ENHAD(I1))
|
---|
881 | * * (SIFE(I2,2)-SIFE(I1,2))
|
---|
882 | CERS1F = S1 + (THETA-ANGLE(1)) / (ANGLE(2)-ANGLE(1)) * (S2-S1)
|
---|
883 |
|
---|
884 | CERSZE = CERS1P + (IATNUM-IANP) * (CERS1F-CERS1P) / (IANFE-IANP)
|
---|
885 |
|
---|
886 | IF ( DEBUG ) WRITE(MDEBUG,101) CERSZE
|
---|
887 | 101 FORMAT(' GETBUS: BUNCH SIZE = ',1P,1E10.3)
|
---|
888 |
|
---|
889 | RETURN
|
---|
890 | END
|
---|
891 |
|
---|
892 | C=======================================================================
|
---|
893 |
|
---|
894 | SUBROUTINE OUTND2
|
---|
895 |
|
---|
896 | C-----------------------------------------------------------------------
|
---|
897 | C OUT(PUT AT E)ND (OF SHOWER)
|
---|
898 | C
|
---|
899 | C WRITE REST OF PARTICLES TO OUTPUT BUFFER
|
---|
900 | C OUTND2 IS CALLED FROM MAIN
|
---|
901 | C
|
---|
902 | C AUTHORS : S. MARTINEZ, UNIVERSITY OF MADRID
|
---|
903 | C F. ARQUEROS, UNIVERSITY OF MADRID
|
---|
904 | C-----------------------------------------------------------------------
|
---|
905 |
|
---|
906 | IMPLICIT NONE
|
---|
907 | *KEEP,RUNPAR.
|
---|
908 | COMMON /RUNPAR/ FIXHEI,THICK0,HILOECM,HILOELB,
|
---|
909 | * STEPFC,NRRUN,NSHOW,PATAPE,MONIIN,
|
---|
910 | * MONIOU,MDEBUG,NUCNUC,
|
---|
911 | * CETAPE,
|
---|
912 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
913 | * N1STTR,MDBASE,
|
---|
914 | * DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
915 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
916 | * ,GHEISH,GHESIG
|
---|
917 | COMMON /RUNPAC/ DSN,HOST,USER
|
---|
918 | DOUBLE PRECISION FIXHEI,THICK0,HILOECM,HILOELB
|
---|
919 | REAL STEPFC
|
---|
920 | INTEGER NRRUN,NSHOW,PATAPE,MONIIN,MONIOU,MDEBUG,NUCNUC,
|
---|
921 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
922 | * N1STTR,MDBASE
|
---|
923 | INTEGER CETAPE
|
---|
924 | CHARACTER*79 DSN
|
---|
925 | CHARACTER*20 HOST,USER
|
---|
926 |
|
---|
927 | LOGICAL DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
928 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
929 | * ,GHEISH,GHESIG
|
---|
930 | *KEEP,CEREN2.
|
---|
931 | COMMON /CEREN2/ PHOTCM,XCER,YCER,UEMIS,VEMIS,CARTIM,ZEMIS,
|
---|
932 | * DCERX,DCERY,ACERX,ACERY,
|
---|
933 | * XCMAX,YCMAX,EPSX,EPSY,
|
---|
934 | * DCERXI,DCERYI,FCERX,FCERY,
|
---|
935 | * XSCATT,YSCATT,CERXOS,CERYOS,
|
---|
936 | * NCERX,NCERY,ICERML
|
---|
937 | REAL PHOTCM,XCER,YCER,UEMIS,VEMIS,CARTIM,ZEMIS,
|
---|
938 | * DCERX,DCERY,ACERX,ACERY,
|
---|
939 | * XCMAX,YCMAX,EPSX,EPSY,
|
---|
940 | * DCERXI,DCERYI,FCERX,FCERY,
|
---|
941 | * XSCATT,YSCATT,CERXOS(20),CERYOS(20)
|
---|
942 | INTEGER NCERX,NCERY,ICERML
|
---|
943 | *KEEP,CEREN3.
|
---|
944 | COMMON /CEREN3/ CERCNT,DATAB2,LHCER
|
---|
945 | INTEGER MAXBF2
|
---|
946 | PARAMETER (MAXBF2 = 39 * 7)
|
---|
947 | DOUBLE PRECISION CERCNT
|
---|
948 | REAL DATAB2(MAXBF2)
|
---|
949 | INTEGER LHCER
|
---|
950 | *KEND.
|
---|
951 |
|
---|
952 | INTEGER I
|
---|
953 | C-----------------------------------------------------------------------
|
---|
954 |
|
---|
955 | IF ( LHCER .GT. 0 ) THEN
|
---|
956 | CALL TOBUFC( DATAB2,1 )
|
---|
957 | DO 2 I = 1,MAXBF2
|
---|
958 | DATAB2(I) = 0.
|
---|
959 | 2 CONTINUE
|
---|
960 | ELSE
|
---|
961 | CALL TOBUFC( DATAB2,2 )
|
---|
962 | ENDIF
|
---|
963 |
|
---|
964 | WRITE(MONIOU,*) 'CERCNT = ',SNGL( CERCNT )
|
---|
965 | CERCNT = 0.D0
|
---|
966 | LHCER = 0
|
---|
967 |
|
---|
968 | RETURN
|
---|
969 | END
|
---|
970 |
|
---|
971 | C=======================================================================
|
---|
972 |
|
---|
973 | SUBROUTINE OUTPT2(J,IMOV)
|
---|
974 |
|
---|
975 | C-----------------------------------------------------------------------
|
---|
976 | C (WRITE CERENKOV RADIATION) OUTP(U)T
|
---|
977 | C
|
---|
978 | C OUTPUT ROUTINE FOR CERENKOV PHOTONS
|
---|
979 | C THIS SUBROUTINE IS CALLED FROM CERENE AND CERENH
|
---|
980 | C
|
---|
981 | C AUTHORS : S. MARTINEZ, UNIVERSITY OF MADRID
|
---|
982 | C F. ARQUEROS, UNIVERSITY OF MADRID
|
---|
983 | C-----------------------------------------------------------------------
|
---|
984 |
|
---|
985 | IMPLICIT NONE
|
---|
986 | *KEEP,BUFFS.
|
---|
987 | COMMON /BUFFS/ RUNH,RUNE,EVTH,EVTE,DATAB,LH
|
---|
988 | INTEGER MAXBUF,MAXLEN
|
---|
989 | PARAMETER (MAXBUF=39*7)
|
---|
990 | PARAMETER (MAXLEN=12)
|
---|
991 | REAL RUNH(MAXBUF),EVTH(MAXBUF),EVTE(MAXBUF),
|
---|
992 | * RUNE(MAXBUF),DATAB(MAXBUF)
|
---|
993 | INTEGER LH
|
---|
994 | CHARACTER*4 CRUNH,CRUNE,CEVTH,CEVTE
|
---|
995 | EQUIVALENCE (RUNH(1),CRUNH), (RUNE(1),CRUNE)
|
---|
996 | EQUIVALENCE (EVTH(1),CEVTH), (EVTE(1),CEVTE)
|
---|
997 | *KEEP,RUNPAR.
|
---|
998 | COMMON /RUNPAR/ FIXHEI,THICK0,HILOECM,HILOELB,
|
---|
999 | * STEPFC,NRRUN,NSHOW,PATAPE,MONIIN,
|
---|
1000 | * MONIOU,MDEBUG,NUCNUC,
|
---|
1001 | * CETAPE,
|
---|
1002 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
1003 | * N1STTR,MDBASE,
|
---|
1004 | * DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
1005 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
1006 | * ,GHEISH,GHESIG
|
---|
1007 | COMMON /RUNPAC/ DSN,HOST,USER
|
---|
1008 | DOUBLE PRECISION FIXHEI,THICK0,HILOECM,HILOELB
|
---|
1009 | REAL STEPFC
|
---|
1010 | INTEGER NRRUN,NSHOW,PATAPE,MONIIN,MONIOU,MDEBUG,NUCNUC,
|
---|
1011 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
1012 | * N1STTR,MDBASE
|
---|
1013 | INTEGER CETAPE
|
---|
1014 | CHARACTER*79 DSN
|
---|
1015 | CHARACTER*20 HOST,USER
|
---|
1016 |
|
---|
1017 | LOGICAL DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
1018 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
1019 | * ,GHEISH,GHESIG
|
---|
1020 | *KEEP,CEREN1.
|
---|
1021 | COMMON /CEREN1/ CERELE,CERHAD,ETADSN,WAVLGL,WAVLGU,CYIELD,
|
---|
1022 | * CERSIZ,LCERFI
|
---|
1023 | DOUBLE PRECISION CERELE,CERHAD,ETADSN,WAVLGL,WAVLGU,CYIELD
|
---|
1024 | REAL CERSIZ
|
---|
1025 | LOGICAL LCERFI
|
---|
1026 | *KEEP,CEREN2.
|
---|
1027 | COMMON /CEREN2/ PHOTCM,XCER,YCER,UEMIS,VEMIS,CARTIM,ZEMIS,
|
---|
1028 | * DCERX,DCERY,ACERX,ACERY,
|
---|
1029 | * XCMAX,YCMAX,EPSX,EPSY,
|
---|
1030 | * DCERXI,DCERYI,FCERX,FCERY,
|
---|
1031 | * XSCATT,YSCATT,CERXOS,CERYOS,
|
---|
1032 | * NCERX,NCERY,ICERML
|
---|
1033 | REAL PHOTCM,XCER,YCER,UEMIS,VEMIS,CARTIM,ZEMIS,
|
---|
1034 | * DCERX,DCERY,ACERX,ACERY,
|
---|
1035 | * XCMAX,YCMAX,EPSX,EPSY,
|
---|
1036 | * DCERXI,DCERYI,FCERX,FCERY,
|
---|
1037 | * XSCATT,YSCATT,CERXOS(20),CERYOS(20)
|
---|
1038 | INTEGER NCERX,NCERY,ICERML
|
---|
1039 | *KEEP,CEREN3.
|
---|
1040 | COMMON /CEREN3/ CERCNT,DATAB2,LHCER
|
---|
1041 | INTEGER MAXBF2
|
---|
1042 | PARAMETER (MAXBF2 = 39 * 7)
|
---|
1043 | DOUBLE PRECISION CERCNT
|
---|
1044 | REAL DATAB2(MAXBF2)
|
---|
1045 | INTEGER LHCER
|
---|
1046 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
1047 | COMMON /GRAAL1/ WAVELENGTH ! (NM)
|
---|
1048 | REAL WAVELENGTH
|
---|
1049 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
1050 | *KEND.
|
---|
1051 |
|
---|
1052 | INTEGER I,J,IMOV
|
---|
1053 | C-----------------------------------------------------------------------
|
---|
1054 |
|
---|
1055 | IF(DEBUG)WRITE(MDEBUG,3)PHOTCM,XCER,YCER,UEMIS,VEMIS,CARTIM,ZEMIS
|
---|
1056 | 3 FORMAT(' OUTPT2: ',1P,8E10.3)
|
---|
1057 | C WRITE A BLOCK OF 39 PARTICLES TO THE CERENKOV OUTPUT BUFFER AND
|
---|
1058 | C CLEAR FIELD
|
---|
1059 | IF ( LCERFI ) THEN
|
---|
1060 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
1061 | c DATAB2(LHCER+1) = PHOTCM
|
---|
1062 | cc DATAB2(LHCER+1) = WAVELENGTH + J*1000.
|
---|
1063 | DATAB2(LHCER+1) = J*100000. + IMOV*1000. + WAVELENGTH
|
---|
1064 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
1065 | DATAB2(LHCER+2) = XCER
|
---|
1066 | DATAB2(LHCER+3) = YCER
|
---|
1067 | DATAB2(LHCER+4) = UEMIS
|
---|
1068 | DATAB2(LHCER+5) = VEMIS
|
---|
1069 | DATAB2(LHCER+6) = CARTIM
|
---|
1070 | DATAB2(LHCER+7) = ZEMIS
|
---|
1071 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
1072 | c CERCNT = CERCNT + DBLE( PHOTCM )
|
---|
1073 | CERCNT = CERCNT + 1
|
---|
1074 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
1075 | LHCER = LHCER + 7
|
---|
1076 | IF ( LHCER .GE. MAXBF2 ) THEN
|
---|
1077 | CALL TOBUFC( DATAB2,0 )
|
---|
1078 | DO 1 I = 1,MAXBF2
|
---|
1079 | DATAB2(I) = 0.
|
---|
1080 | 1 CONTINUE
|
---|
1081 | LHCER = 0
|
---|
1082 | ENDIF
|
---|
1083 | ELSE
|
---|
1084 | C WRITE A BLOCK OF 39 PARTICLES TO THE PARTICLE OUTPUT BUFFER AND
|
---|
1085 | C CLEAR FIELD
|
---|
1086 | DATAB(LH+1) = 99.E5 + NINT(PHOTCM)*10. + 1.
|
---|
1087 | DATAB(LH+2) = XCER
|
---|
1088 | DATAB(LH+3) = YCER
|
---|
1089 | DATAB(LH+4) = UEMIS
|
---|
1090 | DATAB(LH+5) = VEMIS
|
---|
1091 | DATAB(LH+6) = CARTIM
|
---|
1092 | DATAB(LH+7) = ZEMIS
|
---|
1093 | LH = LH + 7
|
---|
1094 | NOPART = NOPART + 1
|
---|
1095 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
1096 | c CERCNT = CERCNT + DBLE( PHOTCM )
|
---|
1097 | CERCNT = CERCNT + 1
|
---|
1098 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
1099 | IF ( LH .GE. MAXBUF ) THEN
|
---|
1100 | CALL TOBUF( DATAB,0 )
|
---|
1101 | DO 2 I = 1,MAXBUF
|
---|
1102 | DATAB(I) = 0.
|
---|
1103 | 2 CONTINUE
|
---|
1104 | LH = 0
|
---|
1105 | ENDIF
|
---|
1106 | ENDIF
|
---|
1107 |
|
---|
1108 | RETURN
|
---|
1109 | END
|
---|
1110 |
|
---|
1111 | C=======================================================================
|
---|
1112 |
|
---|
1113 | SUBROUTINE TOBUFC( A,IFL )
|
---|
1114 |
|
---|
1115 | C-----------------------------------------------------------------------
|
---|
1116 | C (WRITE) TO BUF(FER) C(ERENKOV DATA)
|
---|
1117 | C
|
---|
1118 | C COPY TO BUFFER CERENKOV DATA
|
---|
1119 | C THIS SUBROUTINE IS CALLED FROM MAIN, INPRM, ELECTR, PHOTON, OUTND2,
|
---|
1120 | C AND OUTPT2
|
---|
1121 | C ARGUMENTS:
|
---|
1122 | C A = ARRAY TO BE WRITTEN TO TAPE
|
---|
1123 | C IFL = STARTING OF FINAL OUTPUT
|
---|
1124 | C = 0 NORMAL BLOCK
|
---|
1125 | C = 1 NORMAL BLOCK WITH END OF OUTPUT
|
---|
1126 | C = 2 ONLY END OF OUTPUT
|
---|
1127 | C-----------------------------------------------------------------------
|
---|
1128 |
|
---|
1129 | IMPLICIT NONE
|
---|
1130 | *KEEP,BUFFS.
|
---|
1131 | COMMON /BUFFS/ RUNH,RUNE,EVTH,EVTE,DATAB,LH
|
---|
1132 | INTEGER MAXBUF,MAXLEN
|
---|
1133 | PARAMETER (MAXBUF=39*7)
|
---|
1134 | PARAMETER (MAXLEN=12)
|
---|
1135 | REAL RUNH(MAXBUF),EVTH(MAXBUF),EVTE(MAXBUF),
|
---|
1136 | * RUNE(MAXBUF),DATAB(MAXBUF)
|
---|
1137 | INTEGER LH
|
---|
1138 | CHARACTER*4 CRUNH,CRUNE,CEVTH,CEVTE
|
---|
1139 | EQUIVALENCE (RUNH(1),CRUNH), (RUNE(1),CRUNE)
|
---|
1140 | EQUIVALENCE (EVTH(1),CEVTH), (EVTE(1),CEVTE)
|
---|
1141 | *KEEP,RECORD.
|
---|
1142 | COMMON /RECORD/ IRECOR
|
---|
1143 | INTEGER IRECOR
|
---|
1144 | *KEEP,RUNPAR.
|
---|
1145 | COMMON /RUNPAR/ FIXHEI,THICK0,HILOECM,HILOELB,
|
---|
1146 | * STEPFC,NRRUN,NSHOW,PATAPE,MONIIN,
|
---|
1147 | * MONIOU,MDEBUG,NUCNUC,
|
---|
1148 | * CETAPE,
|
---|
1149 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
1150 | * N1STTR,MDBASE,
|
---|
1151 | * DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
1152 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
1153 | * ,GHEISH,GHESIG
|
---|
1154 | COMMON /RUNPAC/ DSN,HOST,USER
|
---|
1155 | DOUBLE PRECISION FIXHEI,THICK0,HILOECM,HILOELB
|
---|
1156 | REAL STEPFC
|
---|
1157 | INTEGER NRRUN,NSHOW,PATAPE,MONIIN,MONIOU,MDEBUG,NUCNUC,
|
---|
1158 | * SHOWNO,ISHW,NOPART,NRECS,NBLKS,MAXPRT,NDEBDL,
|
---|
1159 | * N1STTR,MDBASE
|
---|
1160 | INTEGER CETAPE
|
---|
1161 | CHARACTER*79 DSN
|
---|
1162 | CHARACTER*20 HOST,USER
|
---|
1163 |
|
---|
1164 | LOGICAL DEBDEL,DEBUG,FDECAY,FEGS,FIRSTI,FIXINC,FIXTAR,
|
---|
1165 | * FIX1I,FMUADD,FNKG,FPRINT,FDBASE
|
---|
1166 | * ,GHEISH,GHESIG
|
---|
1167 | *KEEP,CEREN3.
|
---|
1168 | COMMON /CEREN3/ CERCNT,DATAB2,LHCER
|
---|
1169 | INTEGER MAXBF2
|
---|
1170 | PARAMETER (MAXBF2 = 39 * 7)
|
---|
1171 | DOUBLE PRECISION CERCNT
|
---|
1172 | REAL DATAB2(MAXBF2)
|
---|
1173 | INTEGER LHCER
|
---|
1174 | *KEEP,CEREN4.
|
---|
1175 | COMMON /CEREN4/ NRECER
|
---|
1176 | INTEGER NRECER
|
---|
1177 | *KEND.
|
---|
1178 |
|
---|
1179 | INTEGER NSUBBL
|
---|
1180 | PARAMETER (NSUBBL=21)
|
---|
1181 | REAL A(*)
|
---|
1182 | C NSUBBL IS NUMBER OF SUBBLOCKS IN ONE OUTPUT RECORD
|
---|
1183 | C (OUTPUT RECORD LENGTH = NSUBBL * 39 * 7 * 4 BYTES <= 22932 )
|
---|
1184 | C IBLK2 IS COUNTER FOR SUBBLOCKS OF CERENKOV OUTPUT
|
---|
1185 | C OUTPUT BUFFER FOR CERENKOV OUTPUT
|
---|
1186 | REAL OUTBF2(MAXBF2,NSUBBL)
|
---|
1187 | SAVE OUTBF2
|
---|
1188 | INTEGER I,IBLK2,IFL,K
|
---|
1189 | DATA IBLK2 / 0 /
|
---|
1190 | C-----------------------------------------------------------------------
|
---|
1191 |
|
---|
1192 | IF ( IFL .LE. 1 ) THEN
|
---|
1193 | IBLK2 = IBLK2 + 1
|
---|
1194 | DO 3 I = 1,MAXBF2
|
---|
1195 | OUTBF2(I,IBLK2) = A(I)
|
---|
1196 | 3 CONTINUE
|
---|
1197 | ENDIF
|
---|
1198 |
|
---|
1199 | C WRITE TO TAPE IF BLOCK IS FULL OR IF IFL IS 1
|
---|
1200 | IF ( IFL .GE. 1 .OR. IBLK2 .EQ. NSUBBL ) THEN
|
---|
1201 | NRECER = NRECER + 1
|
---|
1202 |
|
---|
1203 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
1204 | c WRITE(CETAPE) ((OUTBF2(I,K),I=1,MAXBF2),K=1,NSUBBL)
|
---|
1205 | call jccersave(outbf2)
|
---|
1206 | c>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
---|
1207 | IBLK2 = 0
|
---|
1208 | DO 4 K = 1,NSUBBL
|
---|
1209 | DO 4 I = 1,MAXBF2
|
---|
1210 | OUTBF2(I,K) = 0.0
|
---|
1211 | 4 CONTINUE
|
---|
1212 | ENDIF
|
---|
1213 |
|
---|
1214 | RETURN
|
---|
1215 | END
|
---|