]> git.uio.no Git - u/mrichter/AliRoot.git/blame - HIJING/hipyset1_35/luindf_hijing.F
All printout under verbosity level control.
[u/mrichter/AliRoot.git] / HIJING / hipyset1_35 / luindf_hijing.F
CommitLineData
e74335a4 1* $Id$
2
3C*********************************************************************
4
5 SUBROUTINE LUINDF_HIJING(IP)
6
7C...Purpose: to handle the fragmentation of a jet system (or a single
8C...jet) according to independent fragmentation models.
9 IMPLICIT DOUBLE PRECISION(D)
10#include "lujets_hijing.inc"
11#include "ludat1_hijing.inc"
12#include "ludat2_hijing.inc"
13 DIMENSION DPS(5),PSI(4),NFI(3),NFL(3),IFET(3),KFLF(3),
14 &KFLO(2),PXO(2),PYO(2),WO(2)
15
16C...Reset counters. Identify parton system and take copy. Check flavour.
17 NSAV=N
18 NJET=0
19 KQSUM=0
20 DO 100 J=1,5
21 100 DPS(J)=0.
22 I=IP-1
23 110 I=I+1
24 IF(I.GT.MIN(N,MSTU(4)-MSTU(32))) THEN
25 CALL LUERRM_HIJING(12
26 $ ,'(LUINDF_HIJING:) failed to reconstruct jet system')
27 IF(MSTU(21).GE.1) RETURN
28 ENDIF
29 IF(K(I,1).NE.1.AND.K(I,1).NE.2) GOTO 110
30 KC=LUCOMP_HIJING(K(I,2))
31 IF(KC.EQ.0) GOTO 110
32 KQ=KCHG(KC,2)*ISIGN(1,K(I,2))
33 IF(KQ.EQ.0) GOTO 110
34 NJET=NJET+1
35 IF(KQ.NE.2) KQSUM=KQSUM+KQ
36 DO 120 J=1,5
37 K(NSAV+NJET,J)=K(I,J)
38 P(NSAV+NJET,J)=P(I,J)
39 120 DPS(J)=DPS(J)+P(I,J)
40 K(NSAV+NJET,3)=I
41 IF(K(I,1).EQ.2.OR.(MSTJ(3).LE.5.AND.N.GT.I.AND.
42 &K(I+1,1).EQ.2)) GOTO 110
43 IF(NJET.NE.1.AND.KQSUM.NE.0) THEN
44 CALL LUERRM_HIJING(12
45 $ ,'(LUINDF_HIJING:) unphysical flavour combination')
46 IF(MSTU(21).GE.1) RETURN
47 ENDIF
48
49C...Boost copied system to CM frame. Find CM energy and sum flavours.
50 IF(NJET.NE.1) CALL LUDBRB_HIJING(NSAV+1,NSAV+NJET,0.,0.,-DPS(1)
51 $ /DPS(4),-DPS(2)/DPS(4),-DPS(3)/DPS(4))
52 PECM=0.
53 DO 130 J=1,3
54 130 NFI(J)=0
55 DO 140 I=NSAV+1,NSAV+NJET
56 PECM=PECM+P(I,4)
57 KFA=IABS(K(I,2))
58 IF(KFA.LE.3) THEN
59 NFI(KFA)=NFI(KFA)+ISIGN(1,K(I,2))
60 ELSEIF(KFA.GT.1000) THEN
61 KFLA=MOD(KFA/1000,10)
62 KFLB=MOD(KFA/100,10)
63 IF(KFLA.LE.3) NFI(KFLA)=NFI(KFLA)+ISIGN(1,K(I,2))
64 IF(KFLB.LE.3) NFI(KFLB)=NFI(KFLB)+ISIGN(1,K(I,2))
65 ENDIF
66 140 CONTINUE
67
68C...Loop over attempts made. Reset counters.
69 NTRY=0
70 150 NTRY=NTRY+1
71 N=NSAV+NJET
72 IF(NTRY.GT.200) THEN
73 CALL LUERRM_HIJING(14
74 $ ,'(LUINDF_HIJING:) caught in infinite loop')
75 IF(MSTU(21).GE.1) RETURN
76 ENDIF
77 DO 160 J=1,3
78 NFL(J)=NFI(J)
79 IFET(J)=0
80 160 KFLF(J)=0
81
82C...Loop over jets to be fragmented.
83 DO 230 IP1=NSAV+1,NSAV+NJET
84 MSTJ(91)=0
85 NSAV1=N
86
87C...Initial flavour and momentum values. Jet along +z axis.
88 KFLH=IABS(K(IP1,2))
89 IF(KFLH.GT.10) KFLH=MOD(KFLH/1000,10)
90 KFLO(2)=0
91 WF=P(IP1,4)+SQRT(P(IP1,1)**2+P(IP1,2)**2+P(IP1,3)**2)
92
93C...Initial values for quark or diquark jet.
94 170 IF(IABS(K(IP1,2)).NE.21) THEN
95 NSTR=1
96 KFLO(1)=K(IP1,2)
97 CALL LUPTDI_HIJING(0,PXO(1),PYO(1))
98 WO(1)=WF
99
100C...Initial values for gluon treated like random quark jet.
101 ELSEIF(MSTJ(2).LE.2) THEN
102 NSTR=1
103 IF(MSTJ(2).EQ.2) MSTJ(91)=1
104 KFLO(1)=INT(1.+(2.+PARJ(2))*RLU_HIJING(0))*(-1)
105 $ **INT(RLU_HIJING(0)+0.5)
106 CALL LUPTDI_HIJING(0,PXO(1),PYO(1))
107 WO(1)=WF
108
109C...Initial values for gluon treated like quark-antiquark jet pair,
110C...sharing energy according to Altarelli-Parisi splitting function.
111 ELSE
112 NSTR=2
113 IF(MSTJ(2).EQ.4) MSTJ(91)=1
114 KFLO(1)=INT(1.+(2.+PARJ(2))*RLU_HIJING(0))*(-1)
115 $ **INT(RLU_HIJING(0)+0.5)
116 KFLO(2)=-KFLO(1)
117 CALL LUPTDI_HIJING(0,PXO(1),PYO(1))
118 PXO(2)=-PXO(1)
119 PYO(2)=-PYO(1)
120 WO(1)=WF*RLU_HIJING(0)**(1./3.)
121 WO(2)=WF-WO(1)
122 ENDIF
123
124C...Initial values for rank, flavour, pT and W+.
125 DO 220 ISTR=1,NSTR
126 180 I=N
127 IRANK=0
128 KFL1=KFLO(ISTR)
129 PX1=PXO(ISTR)
130 PY1=PYO(ISTR)
131 W=WO(ISTR)
132
133C...New hadron. Generate flavour and hadron species.
134 190 I=I+1
135 IF(I.GE.MSTU(4)-MSTU(32)-NJET-5) THEN
136 CALL LUERRM_HIJING(11
137 $ ,'(LUINDF_HIJING:) no more memory left in LUJETS_HIJING')
138 IF(MSTU(21).GE.1) RETURN
139 ENDIF
140 IRANK=IRANK+1
141 K(I,1)=1
142 K(I,3)=IP1
143 K(I,4)=0
144 K(I,5)=0
145 200 CALL LUKFDI_HIJING(KFL1,0,KFL2,K(I,2))
146 IF(K(I,2).EQ.0) GOTO 180
147 IF(MSTJ(12).GE.3.AND.IRANK.EQ.1.AND.IABS(KFL1).LE.10.AND.
148 &IABS(KFL2).GT.10) THEN
149 IF(RLU_HIJING(0).GT.PARJ(19)) GOTO 200
150 ENDIF
151
152C...Find hadron mass. Generate four-momentum.
153 P(I,5)=ULMASS_HIJING(K(I,2))
154 CALL LUPTDI_HIJING(KFL1,PX2,PY2)
155 P(I,1)=PX1+PX2
156 P(I,2)=PY1+PY2
157 PR=P(I,5)**2+P(I,1)**2+P(I,2)**2
158 CALL LUZDIS_HIJING(KFL1,KFL2,PR,Z)
159 P(I,3)=0.5*(Z*W-PR/(Z*W))
160 P(I,4)=0.5*(Z*W+PR/(Z*W))
161 IF(MSTJ(3).GE.1.AND.IRANK.EQ.1.AND.KFLH.GE.4.AND.
162 &P(I,3).LE.0.001) THEN
163 IF(W.GE.P(I,5)+0.5*PARJ(32)) GOTO 180
164 P(I,3)=0.0001
165 P(I,4)=SQRT(PR)
166 Z=P(I,4)/W
167 ENDIF
168
169C...Remaining flavour and momentum.
170 KFL1=-KFL2
171 PX1=-PX2
172 PY1=-PY2
173 W=(1.-Z)*W
174 DO 210 J=1,5
175 210 V(I,J)=0.
176
177C...Check if pL acceptable. Go back for new hadron if enough energy.
178 IF(MSTJ(3).GE.0.AND.P(I,3).LT.0.) I=I-1
179 IF(W.GT.PARJ(31)) GOTO 190
180 220 N=I
181 IF(MOD(MSTJ(3),5).EQ.4.AND.N.EQ.NSAV1) WF=WF+0.1*PARJ(32)
182 IF(MOD(MSTJ(3),5).EQ.4.AND.N.EQ.NSAV1) GOTO 170
183
184C...Rotate jet to new direction.
185 THE=ULANGL_HIJING(P(IP1,3),SQRT(P(IP1,1)**2+P(IP1,2)**2))
186 PHI=ULANGL_HIJING(P(IP1,1),P(IP1,2))
187 CALL LUDBRB_HIJING(NSAV1+1,N,THE,PHI,0D0,0D0,0D0)
188 K(K(IP1,3),4)=NSAV1+1
189 K(K(IP1,3),5)=N
190
191C...End of jet generation loop. Skip conservation in some cases.
192 230 CONTINUE
193 IF(NJET.EQ.1.OR.MSTJ(3).LE.0) GOTO 470
194 IF(MOD(MSTJ(3),5).NE.0.AND.N-NSAV-NJET.LT.2) GOTO 150
195
196C...Subtract off produced hadron flavours, finished if zero.
197 DO 240 I=NSAV+NJET+1,N
198 KFA=IABS(K(I,2))
199 KFLA=MOD(KFA/1000,10)
200 KFLB=MOD(KFA/100,10)
201 KFLC=MOD(KFA/10,10)
202 IF(KFLA.EQ.0) THEN
203 IF(KFLB.LE.3) NFL(KFLB)=NFL(KFLB)-ISIGN(1,K(I,2))*(-1)**KFLB
204 IF(KFLC.LE.3) NFL(KFLC)=NFL(KFLC)+ISIGN(1,K(I,2))*(-1)**KFLB
205 ELSE
206 IF(KFLA.LE.3) NFL(KFLA)=NFL(KFLA)-ISIGN(1,K(I,2))
207 IF(KFLB.LE.3) NFL(KFLB)=NFL(KFLB)-ISIGN(1,K(I,2))
208 IF(KFLC.LE.3) NFL(KFLC)=NFL(KFLC)-ISIGN(1,K(I,2))
209 ENDIF
210 240 CONTINUE
211 NREQ=(IABS(NFL(1))+IABS(NFL(2))+IABS(NFL(3))-IABS(NFL(1)+
212 &NFL(2)+NFL(3)))/2+IABS(NFL(1)+NFL(2)+NFL(3))/3
213 IF(NREQ.EQ.0) GOTO 320
214
215C...Take away flavour of low-momentum particles until enough freedom.
216 NREM=0
217 250 IREM=0
218 P2MIN=PECM**2
219 DO 260 I=NSAV+NJET+1,N
220 P2=P(I,1)**2+P(I,2)**2+P(I,3)**2
221 IF(K(I,1).EQ.1.AND.P2.LT.P2MIN) IREM=I
222 260 IF(K(I,1).EQ.1.AND.P2.LT.P2MIN) P2MIN=P2
223 IF(IREM.EQ.0) GOTO 150
224 K(IREM,1)=7
225 KFA=IABS(K(IREM,2))
226 KFLA=MOD(KFA/1000,10)
227 KFLB=MOD(KFA/100,10)
228 KFLC=MOD(KFA/10,10)
229 IF(KFLA.GE.4.OR.KFLB.GE.4) K(IREM,1)=8
230 IF(K(IREM,1).EQ.8) GOTO 250
231 IF(KFLA.EQ.0) THEN
232 ISGN=ISIGN(1,K(IREM,2))*(-1)**KFLB
233 IF(KFLB.LE.3) NFL(KFLB)=NFL(KFLB)+ISGN
234 IF(KFLC.LE.3) NFL(KFLC)=NFL(KFLC)-ISGN
235 ELSE
236 IF(KFLA.LE.3) NFL(KFLA)=NFL(KFLA)+ISIGN(1,K(IREM,2))
237 IF(KFLB.LE.3) NFL(KFLB)=NFL(KFLB)+ISIGN(1,K(IREM,2))
238 IF(KFLC.LE.3) NFL(KFLC)=NFL(KFLC)+ISIGN(1,K(IREM,2))
239 ENDIF
240 NREM=NREM+1
241 NREQ=(IABS(NFL(1))+IABS(NFL(2))+IABS(NFL(3))-IABS(NFL(1)+
242 &NFL(2)+NFL(3)))/2+IABS(NFL(1)+NFL(2)+NFL(3))/3
243 IF(NREQ.GT.NREM) GOTO 250
244 DO 270 I=NSAV+NJET+1,N
245 270 IF(K(I,1).EQ.8) K(I,1)=1
246
247C...Find combination of existing and new flavours for hadron.
248 280 NFET=2
249 IF(NFL(1)+NFL(2)+NFL(3).NE.0) NFET=3
250 IF(NREQ.LT.NREM) NFET=1
251 IF(IABS(NFL(1))+IABS(NFL(2))+IABS(NFL(3)).EQ.0) NFET=0
252 DO 290 J=1,NFET
253 IFET(J)=1+(IABS(NFL(1))+IABS(NFL(2))+IABS(NFL(3)))*RLU_HIJING(0)
254 KFLF(J)=ISIGN(1,NFL(1))
255 IF(IFET(J).GT.IABS(NFL(1))) KFLF(J)=ISIGN(2,NFL(2))
256 290 IF(IFET(J).GT.IABS(NFL(1))+IABS(NFL(2))) KFLF(J)=ISIGN(3,NFL(3))
257 IF(NFET.EQ.2.AND.(IFET(1).EQ.IFET(2).OR.KFLF(1)*KFLF(2).GT.0))
258 &GOTO 280
259 IF(NFET.EQ.3.AND.(IFET(1).EQ.IFET(2).OR.IFET(1).EQ.IFET(3).OR.
260 &IFET(2).EQ.IFET(3).OR.KFLF(1)*KFLF(2).LT.0.OR.KFLF(1)*KFLF(3).
261 &LT.0.OR.KFLF(1)*(NFL(1)+NFL(2)+NFL(3)).LT.0)) GOTO 280
262 IF(NFET.EQ.0) KFLF(1)=1+INT((2.+PARJ(2))*RLU_HIJING(0))
263 IF(NFET.EQ.0) KFLF(2)=-KFLF(1)
264 IF(NFET.EQ.1) KFLF(2)=ISIGN(1+INT((2.+PARJ(2))*RLU_HIJING(0)),
265 $ -KFLF(1))
266 IF(NFET.LE.2) KFLF(3)=0
267 IF(KFLF(3).NE.0) THEN
268 KFLFC=ISIGN(1000*MAX(IABS(KFLF(1)),IABS(KFLF(3)))+
269 & 100*MIN(IABS(KFLF(1)),IABS(KFLF(3)))+1,KFLF(1))
270 IF(KFLF(1).EQ.KFLF(3).OR.(1.+3.*PARJ(4))*RLU_HIJING(0).GT.1.)
271 & KFLFC=KFLFC+ISIGN(2,KFLFC)
272 ELSE
273 KFLFC=KFLF(1)
274 ENDIF
275 CALL LUKFDI_HIJING(KFLFC,KFLF(2),KFLDMP,KF)
276 IF(KF.EQ.0) GOTO 280
277 DO 300 J=1,MAX(2,NFET)
278 300 NFL(IABS(KFLF(J)))=NFL(IABS(KFLF(J)))-ISIGN(1,KFLF(J))
279
280C...Store hadron at random among free positions.
281 NPOS=MIN(1+INT(RLU_HIJING(0)*NREM),NREM)
282 DO 310 I=NSAV+NJET+1,N
283 IF(K(I,1).EQ.7) NPOS=NPOS-1
284 IF(K(I,1).EQ.1.OR.NPOS.NE.0) GOTO 310
285 K(I,1)=1
286 K(I,2)=KF
287 P(I,5)=ULMASS_HIJING(K(I,2))
288 P(I,4)=SQRT(P(I,1)**2+P(I,2)**2+P(I,3)**2+P(I,5)**2)
289 310 CONTINUE
290 NREM=NREM-1
291 NREQ=(IABS(NFL(1))+IABS(NFL(2))+IABS(NFL(3))-IABS(NFL(1)+
292 &NFL(2)+NFL(3)))/2+IABS(NFL(1)+NFL(2)+NFL(3))/3
293 IF(NREM.GT.0) GOTO 280
294
295C...Compensate for missing momentum in global scheme (3 options).
296 320 IF(MOD(MSTJ(3),5).NE.0.AND.MOD(MSTJ(3),5).NE.4) THEN
297 DO 330 J=1,3
298 PSI(J)=0.
299 DO 330 I=NSAV+NJET+1,N
300 330 PSI(J)=PSI(J)+P(I,J)
301 PSI(4)=PSI(1)**2+PSI(2)**2+PSI(3)**2
302 PWS=0.
303 DO 340 I=NSAV+NJET+1,N
304 IF(MOD(MSTJ(3),5).EQ.1) PWS=PWS+P(I,4)
305 IF(MOD(MSTJ(3),5).EQ.2) PWS=PWS+SQRT(P(I,5)**2+(PSI(1)*P(I,1)+
306 & PSI(2)*P(I,2)+PSI(3)*P(I,3))**2/PSI(4))
307 340 IF(MOD(MSTJ(3),5).EQ.3) PWS=PWS+1.
308 DO 360 I=NSAV+NJET+1,N
309 IF(MOD(MSTJ(3),5).EQ.1) PW=P(I,4)
310 IF(MOD(MSTJ(3),5).EQ.2) PW=SQRT(P(I,5)**2+(PSI(1)*P(I,1)+
311 & PSI(2)*P(I,2)+PSI(3)*P(I,3))**2/PSI(4))
312 IF(MOD(MSTJ(3),5).EQ.3) PW=1.
313 DO 350 J=1,3
314 350 P(I,J)=P(I,J)-PSI(J)*PW/PWS
315 360 P(I,4)=SQRT(P(I,1)**2+P(I,2)**2+P(I,3)**2+P(I,5)**2)
316
317C...Compensate for missing momentum withing each jet separately.
318 ELSEIF(MOD(MSTJ(3),5).EQ.4) THEN
319 DO 370 I=N+1,N+NJET
320 K(I,1)=0
321 DO 370 J=1,5
322 370 P(I,J)=0.
323 DO 390 I=NSAV+NJET+1,N
324 IR1=K(I,3)
325 IR2=N+IR1-NSAV
326 K(IR2,1)=K(IR2,1)+1
327 PLS=(P(I,1)*P(IR1,1)+P(I,2)*P(IR1,2)+P(I,3)*P(IR1,3))/
328 & (P(IR1,1)**2+P(IR1,2)**2+P(IR1,3)**2)
329 DO 380 J=1,3
330 380 P(IR2,J)=P(IR2,J)+P(I,J)-PLS*P(IR1,J)
331 P(IR2,4)=P(IR2,4)+P(I,4)
332 390 P(IR2,5)=P(IR2,5)+PLS
333 PSS=0.
334 DO 400 I=N+1,N+NJET
335 400 IF(K(I,1).NE.0) PSS=PSS+P(I,4)/(PECM*(0.8*P(I,5)+0.2))
336 DO 420 I=NSAV+NJET+1,N
337 IR1=K(I,3)
338 IR2=N+IR1-NSAV
339 PLS=(P(I,1)*P(IR1,1)+P(I,2)*P(IR1,2)+P(I,3)*P(IR1,3))/
340 & (P(IR1,1)**2+P(IR1,2)**2+P(IR1,3)**2)
341 DO 410 J=1,3
342 410 P(I,J)=P(I,J)-P(IR2,J)/K(IR2,1)+(1./(P(IR2,5)*PSS)-1.)*PLS*
343 & P(IR1,J)
344 420 P(I,4)=SQRT(P(I,1)**2+P(I,2)**2+P(I,3)**2+P(I,5)**2)
345 ENDIF
346
347C...Scale momenta for energy conservation.
348 IF(MOD(MSTJ(3),5).NE.0) THEN
349 PMS=0.
350 PES=0.
351 PQS=0.
352 DO 430 I=NSAV+NJET+1,N
353 PMS=PMS+P(I,5)
354 PES=PES+P(I,4)
355 430 PQS=PQS+P(I,5)**2/P(I,4)
356 IF(PMS.GE.PECM) GOTO 150
357 NECO=0
358 440 NECO=NECO+1
359 PFAC=(PECM-PQS)/(PES-PQS)
360 PES=0.
361 PQS=0.
362 DO 460 I=NSAV+NJET+1,N
363 DO 450 J=1,3
364 450 P(I,J)=PFAC*P(I,J)
365 P(I,4)=SQRT(P(I,1)**2+P(I,2)**2+P(I,3)**2+P(I,5)**2)
366 PES=PES+P(I,4)
367 460 PQS=PQS+P(I,5)**2/P(I,4)
368 IF(NECO.LT.10.AND.ABS(PECM-PES).GT.2E-6*PECM) GOTO 440
369 ENDIF
370
371C...Origin of produced particles and parton daughter pointers.
372 470 DO 480 I=NSAV+NJET+1,N
373 IF(MSTU(16).NE.2) K(I,3)=NSAV+1
374 480 IF(MSTU(16).EQ.2) K(I,3)=K(K(I,3),3)
375 DO 490 I=NSAV+1,NSAV+NJET
376 I1=K(I,3)
377 K(I1,1)=K(I1,1)+10
378 IF(MSTU(16).NE.2) THEN
379 K(I1,4)=NSAV+1
380 K(I1,5)=NSAV+1
381 ELSE
382 K(I1,4)=K(I1,4)-NJET+1
383 K(I1,5)=K(I1,5)-NJET+1
384 IF(K(I1,5).LT.K(I1,4)) THEN
385 K(I1,4)=0
386 K(I1,5)=0
387 ENDIF
388 ENDIF
389 490 CONTINUE
390
391C...Document independent fragmentation system. Remove copy of jets.
392 NSAV=NSAV+1
393 K(NSAV,1)=11
394 K(NSAV,2)=93
395 K(NSAV,3)=IP
396 K(NSAV,4)=NSAV+1
397 K(NSAV,5)=N-NJET+1
398 DO 500 J=1,4
399 P(NSAV,J)=DPS(J)
400 500 V(NSAV,J)=V(IP,J)
401 P(NSAV,5)=SQRT(MAX(0D0,DPS(4)**2-DPS(1)**2-DPS(2)**2-DPS(3)**2))
402 V(NSAV,5)=0.
403 DO 510 I=NSAV+NJET,N
404 DO 510 J=1,5
405 K(I-NJET+1,J)=K(I,J)
406 P(I-NJET+1,J)=P(I,J)
407 510 V(I-NJET+1,J)=V(I,J)
408 N=N-NJET+1
409
410C...Boost back particle system. Set production vertices.
411 IF(NJET.NE.1) CALL LUDBRB_HIJING(NSAV+1,N,0.,0.,DPS(1)/DPS(4),
412 &DPS(2)/DPS(4),DPS(3)/DPS(4))
413 DO 520 I=NSAV+1,N
414 DO 520 J=1,4
415 520 V(I,J)=V(IP,J)
416
417 RETURN
418 END