/[PAMELA software]/DarthVader/TrackerLevel2/src/F77/analysissubroutines.f
ViewVC logotype

Contents of /DarthVader/TrackerLevel2/src/F77/analysissubroutines.f

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.43 - (show annotations) (download)
Mon Dec 14 10:51:40 2009 UTC (15 years, 1 month ago) by pam-fi
Branch: MAIN
Changes since 1.42: +18 -8 lines
bug fixed: check on maximum number of tracks

1 ************************************************************
2 * The following subroutines
3 * - track_finding >> hough transform
4 * - track_fitting >> bob golden fitting
5 * all the procedures to create LEVEL2 data, starting from LEVEL1 data.
6 *
7 *
8 *
9 * (This subroutine and all the dependent subroutines
10 * will be included in the flight software)
11 ************************************************************
12 subroutine track_finding(iflag)
13
14 include 'commontracker.f'
15 include 'level1.f'
16 include 'common_momanhough.f'
17 include 'common_mech.f'
18 include 'common_xyzPAM.f'
19 include 'common_mini_2.f'
20 include 'calib.f'
21 include 'level2.f'
22
23 c print*,'======================================================'
24 c$$$ do ic=1,NCLSTR1
25 c$$$ if(.false.
26 c$$$ $ .or.nsatstrips(ic).gt.0
27 c$$$c $ .or.nbadstrips(0,ic).gt.0
28 c$$$c $ .or.nbadstrips(4,ic).gt.0
29 c$$$c $ .or.nbadstrips(3,ic).gt.0
30 c$$$ $ .or..false.)then
31 c$$$ print*,'--- cl-',ic,' ------------------------'
32 c$$$ istart = INDSTART(IC)
33 c$$$ istop = TOTCLLENGTH
34 c$$$ if(ic.lt.NCLSTR1)istop=INDSTART(IC+1)-1
35 c$$$ print*,'ADC ',(CLADC(i),i=istart,istop)
36 c$$$ print*,'s/n ',(CLSIGNAL(i)/CLSIGMA(i),i=istart,istop)
37 c$$$ print*,'sgnl ',(CLSIGNAL(i),i=istart,istop)
38 c$$$ print*,'strip ',(i-INDMAX(ic),i=istart,istop)
39 c$$$ print*,'view ',VIEW(ic)
40 c$$$ print*,'maxs ',MAXS(ic)
41 c$$$ print*,'COG4 ',cog(4,ic)
42 c$$$ ff = fbad_cog(4,ic)
43 c$$$ print*,'fbad ',ff
44 c$$$ print*,(CLBAD(i),i=istart,istop)
45 c$$$ bb=nbadstrips(0,ic)
46 c$$$ print*,'#BAD (tot)',bb
47 c$$$ bb=nbadstrips(4,ic)
48 c$$$ print*,'#BAD (4)',bb
49 c$$$ bb=nbadstrips(3,ic)
50 c$$$ print*,'#BAD (3)',bb
51 c$$$ ss=nsatstrips(ic)
52 c$$$ print*,'#saturated ',ss
53 c$$$ endif
54 c$$$ enddo
55
56 *-------------------------------------------------------------------------------
57 * STEP 1
58 *-------------------------------------------------------------------------------
59 * X-Y cluster association
60 *
61 * Clusters are associated to form COUPLES
62 * Clusters not associated in any couple are called SINGLETS
63 *
64 * Track identification (Hough transform) and fitting is first done on couples.
65 * Hence singlets are possibly added to the track.
66 *
67 * Variables assigned by the routine "cl_to_couples" are those in the
68 * common blocks:
69 * - common/clusters/cl_good
70 * - common/couples/clx,cly,ncp_plane,ncp_tot,cp_useds1,cp_useds2
71 * - common/singlets/ncls,cls,cl_single
72 *-------------------------------------------------------------------------------
73 *-------------------------------------------------------------------------------
74
75 call cl_to_couples(iflag)
76 if(iflag.eq.1)then !bad event
77 goto 880 !go to next event
78 endif
79 if(ncp_tot.eq.0)goto 880 !go to next event
80 *-----------------------------------------------------
81 *-----------------------------------------------------
82 * HOUGH TRASFORM
83 *-----------------------------------------------------
84 *-----------------------------------------------------
85
86
87 *-------------------------------------------------------------------------------
88 * STEP 2
89 *-------------------------------------------------------------------------------
90 *
91 * Association of couples to form
92 * - DOUBLETS in YZ view
93 * - TRIPLETS in XZ view
94 *
95 * Variables assigned by the routine "cp_to_doubtrip" are those in the
96 * common blocks:
97 * - common/hough_param/
98 * $ alfayz1, !Y0
99 * $ alfayz2, !tg theta-yz
100 * $ alfaxz1, !X0
101 * $ alfaxz2, !tg theta-xz
102 * $ alfaxz3 !1/r
103 * - common/doublets/ndblt,cpyz1,cpyz2
104 * - common/triplets/ntrpt,cpxz1,cpxz2,cpxz3
105 *-------------------------------------------------------------------------------
106 *-------------------------------------------------------------------------------
107
108
109 call cp_to_doubtrip(iflag)
110 if(iflag.eq.1)then !bad event
111 goto 880 !go to next event
112 endif
113 if(ndblt.eq.0.or.ntrpt.eq.0)goto 880 !go to next event
114
115
116 *-------------------------------------------------------------------------------
117 * STEP 3
118 *-------------------------------------------------------------------------------
119 *
120 * Classification of doublets and triplets to form CLOUDS,
121 * according to distance in parameter space.
122 *
123 * cloud = cluster of points (doublets/triplets) in parameter space
124 *
125 *
126 *
127 * Variables assigned by the routine "doub_to_YZcloud" are those in the
128 * common blocks:
129 * - common/clouds_yz/
130 * $ nclouds_yz
131 * $ ,alfayz1_av,alfayz2_av
132 * $ ,ptcloud_yz,db_cloud,cpcloud_yz
133 *
134 * Variables assigned by the routine "trip_to_XZcloud" are those in the
135 * common blocks:
136 * common/clouds_xz/
137 * $ nclouds_xz xz2_av,alfaxz3_av
138 * $ ,ptcloud_xz,tr_cloud,cpcloud_xz
139 *-------------------------------------------------------------------------------
140 *-------------------------------------------------------------------------------
141 * count number of hit planes
142 planehit=0
143 do np=1,nplanes
144 if(ncp_plane(np).ne.0)then
145 planehit=planehit+1
146 endif
147 enddo
148 if(planehit.lt.3) goto 880 ! exit
149
150 nptxz_min=x_min_start
151 nplxz_min=x_min_start
152
153 nptyz_min=y_min_start
154 nplyz_min=y_min_start
155
156 cutdistyz=cutystart
157 cutdistxz=cutxstart
158
159 878 continue
160 call doub_to_YZcloud(iflag)
161 if(iflag.eq.1)then !bad event
162 goto 880 !fill ntp and go to next event
163 endif
164 * ------------------------------------------------
165 * first try to release the tolerance
166 * ------------------------------------------------
167 if(nclouds_yz.eq.0.and.cutdistyz.lt.maxcuty)then
168 if(cutdistyz.lt.maxcuty/2)then
169 cutdistyz=cutdistyz+cutystep
170 else
171 cutdistyz=cutdistyz+(3*cutystep)
172 endif
173 if(DEBUG.EQ.1)print*,'try again - cutdistyz ',cutdistyz
174 goto 878
175 endif
176 * ------------------------------------------------
177 * hence reduce the minimum number of plane
178 * ------------------------------------------------
179 if(nclouds_yz.eq.0.and.nplyz_min.gt.3)then
180 nplyz_min=nplyz_min-1
181 if(DEBUG.EQ.1)print*,'try again - nplyz_min ',nplyz_min
182 goto 878
183 endif
184
185 if(nclouds_yz.eq.0)goto 880 !go to next event
186
187
188 ccc if(planehit.eq.3) goto 881
189
190 879 continue
191 call trip_to_XZcloud(iflag)
192 if(iflag.eq.1)then !bad event
193 goto 880 !fill ntp and go to next event
194 endif
195 * ------------------------------------------------
196 * first try to release the tolerance
197 * ------------------------------------------------
198 if(nclouds_xz.eq.0.and.cutdistxz.lt.maxcutx)then
199 cutdistxz=cutdistxz+cutxstep
200 if(DEBUG.EQ.1)print*,'try again - cutdistxz ',cutdistxz
201 goto 879
202 endif
203 * ------------------------------------------------
204 * hence reduce the minimum number of plane
205 * ------------------------------------------------
206 if(nclouds_xz.eq.0.and.nplxz_min.gt.3)then
207 nplxz_min=nplxz_min-1
208 if(DEBUG.EQ.1)print*,'try again - nplxz_min ',nplxz_min
209 goto 879
210 endif
211
212 if(nclouds_xz.eq.0)goto 880 !go to next event
213
214
215 c$$$ 881 continue
216 c$$$* if there is at least three planes on the Y view decreases cuts on X view
217 c$$$ if(nclouds_xz.eq.0.and.nclouds_yz.gt.0.and.
218 c$$$ $ nplxz_min.ne.y_min_start)then
219 c$$$ nptxz_min=x_min_step
220 c$$$ nplxz_min=x_min_start-x_min_step
221 c$$$ goto 879
222 c$$$ endif
223
224 880 return
225 end
226
227 ************************************************************
228
229
230 subroutine track_fitting(iflag)
231
232 include 'commontracker.f'
233 include 'level1.f'
234 include 'common_momanhough.f'
235 include 'common_mech.f'
236 include 'common_xyzPAM.f'
237 include 'common_mini_2.f'
238 include 'calib.f'
239 include 'level2.f'
240
241 c include 'momanhough_init.f'
242
243 logical FIMAGE !
244 real trackimage(NTRACKSMAX)
245 real*8 AL_GUESS(5)
246
247 *-------------------------------------------------------------------------------
248 * STEP 4 (ITERATED until any other physical track isn't found)
249 *-------------------------------------------------------------------------------
250 *
251 * YZ and XZ clouds are combined in order to obtain the initial guess
252 * of the candidate-track parameters.
253 * A minimum number of matching couples between YZ and XZ clouds is required.
254 *
255 * A TRACK CANDIDATE is defined by
256 * - the couples resulting from the INTERSECTION of the two clouds, and
257 * - the associated track parameters (evaluated by performing a zero-order
258 * track fitting)
259 *
260 * The NTRACKS candidate-track parameters are stored in common block:
261 *
262 * - common/track_candidates/NTRACKS,AL_STORE
263 * $ ,XV_STORE,YV_STORE,ZV_STORE
264 * $ ,XM_STORE,YM_STORE,ZM_STORE
265 * $ ,RESX_STORE,RESY_STORE
266 * $ ,AXV_STORE,AYV_STORE
267 * $ ,XGOOD_STORE,YGOOD_STORE
268 * $ ,CP_STORE,RCHI2_STORE
269 *
270 *-------------------------------------------------------------------------------
271 *-------------------------------------------------------------------------------
272 ccc ntrk=0 !counter of identified physical tracks
273
274 c11111 continue !<<<<<<< come here when performing a new search
275 continue !<<<<<<< come here when performing a new search
276
277 if(nclouds_xz.eq.0)goto 880 !go to next event
278 if(nclouds_yz.eq.0)goto 880 !go to next event
279
280 c iflag=0
281 call clouds_to_ctrack(iflag)
282 if(iflag.eq.1)then !no candidate tracks found
283 goto 880 !fill ntp and go to next event
284 endif
285 if(ntracks.eq.0)goto 880 !go to next event
286
287 FIMAGE=.false. !processing best track (not track image)
288 ibest=0 !best track among candidates
289 iimage=0 !track image
290 * ------------- select the best track -------------
291 c$$$ rchi2best=1000000000.
292 c$$$ do i=1,ntracks
293 c$$$ if(RCHI2_STORE(i).lt.rchi2best.and.
294 c$$$ $ RCHI2_STORE(i).gt.0)then
295 c$$$ ibest=i
296 c$$$ rchi2best=RCHI2_STORE(i)
297 c$$$ endif
298 c$$$ enddo
299 c$$$ if(ibest.eq.0)goto 880 !>> no good candidates
300
301 * -------------------------------------------------------
302 * order track-candidates according to:
303 * 1st) decreasing n.points
304 * 2nd) increasing chi**2
305 * -------------------------------------------------------
306 rchi2best=1000000000.
307 ndofbest=0
308 do i=1,ntracks
309 ndof=0
310 do ii=1,nplanes
311 ndof=ndof
312 $ +int(xgood_store(ii,i))
313 $ +int(ygood_store(ii,i))
314 enddo
315 if(ndof.gt.ndofbest)then
316 ibest=i
317 rchi2best=RCHI2_STORE(i)
318 ndofbest=ndof
319 elseif(ndof.eq.ndofbest)then
320 if(RCHI2_STORE(i).lt.rchi2best.and.
321 $ RCHI2_STORE(i).gt.0)then
322 ibest=i
323 rchi2best=RCHI2_STORE(i)
324 ndofbest=ndof
325 endif
326 endif
327 enddo
328
329
330 if(ibest.eq.0)goto 880 !>> no good candidates
331 *-------------------------------------------------------------------------------
332 * The best track candidate (ibest) is selected and a new fitting is performed.
333 * Previous to this, the track is refined by:
334 * - possibly adding new COUPLES or SINGLETS from the missing planes
335 * - evaluating the coordinates with improved PFAs
336 * ( angle-dependent ETA algorithms )
337 *-------------------------------------------------------------------------------
338
339 1212 continue !<<<<< come here to fit track-image
340
341 if(.not.FIMAGE)then !processing best candidate
342 icand=ibest
343 else !processing image
344 icand=iimage
345 iimage=0
346 endif
347 if(icand.eq.0)then
348 if(VERBOSE.EQ.1)then
349 print*,'HAI FATTO UN CASINO!!!!!! icand = ',icand
350 $ ,ibest,iimage
351 endif
352 return
353 endif
354
355 * *-*-*-*-*-*-*-*-*-*-*-*-*-*-*
356 call refine_track(icand)
357 * *-*-*-*-*-*-*-*-*-*-*-*-*-*-*
358
359 * **********************************************************
360 * ************************** FIT *** FIT *** FIT *** FIT ***
361 * **********************************************************
362 call guess()
363 do i=1,5
364 AL_GUESS(i)=AL(i)
365 enddo
366
367 do i=1,5
368 AL(i)=dble(AL_STORE(i,icand))
369 enddo
370
371 IDCAND = icand !fitted track-candidate
372 ifail=0 !error flag in chi2 computation
373 jstep=0 !# minimization steps
374
375 iprint=0
376 c if(DEBUG.EQ.1)iprint=1
377 if(VERBOSE.EQ.1)iprint=1
378 if(DEBUG.EQ.1)iprint=2
379 call mini2(jstep,ifail,iprint)
380 cc if(ifail.ne.0) then
381 if(ifail.ne.0.or.CHI2.ne.CHI2) then !new
382 if(CHI2.ne.CHI2)CHI2=-9999. !new
383 if(VERBOSE.EQ.1)then
384 print *,
385 $ '*** MINIMIZATION FAILURE *** (after refinement) '
386 $ ,iev
387 endif
388 endif
389
390 if(DEBUG.EQ.1)then
391 print*,'----------------------------- improved track coord'
392 22222 format(i2,' * ',3f10.4,' --- ',4f10.4,' --- ',2f4.0,2f10.5)
393 do ip=1,6
394 write(*,22222)ip,zm(ip),xm(ip),ym(ip)
395 $ ,xm_A(ip),ym_A(ip),xm_B(ip),ym_B(ip)
396 $ ,xgood(ip),ygood(ip),resx(ip),resy(ip)
397 enddo
398 endif
399
400 c rchi2=chi2/dble(ndof)
401 if(DEBUG.EQ.1)then
402 print*,' '
403 print*,'****** SELECTED TRACK *************'
404 print*,'# R. chi2 RIG'
405 print*,' --- ',chi2,' --- '
406 $ ,1./abs(AL(5))
407 print*,'***********************************'
408 endif
409 * **********************************************************
410 * ************************** FIT *** FIT *** FIT *** FIT ***
411 * **********************************************************
412
413
414 * ------------- search if the track has an IMAGE -------------
415 * ------------- (also this is stored ) -------------
416 if(FIMAGE)goto 122 !>>> jump! (this is already an image)
417
418 * -----------------------------------------------------
419 * first check if the track is ambiguous
420 * -----------------------------------------------------
421 * (modified on august 2007 by ElenaV)
422 is1=0
423 do ip=1,NPLANES
424 if(SENSOR_STORE(ip,icand).ne.0)then
425 is1=SENSOR_STORE(ip,icand)
426 if(ip.eq.6)is1=3-is1 !last plane inverted
427 endif
428 enddo
429 if(is1.eq.0)then
430 if(WARNING.EQ.1)print*,'** WARNING ** sensor=0'
431 goto 122 !jump
432 endif
433 do ip=1,NPLANES
434 is2 = SENSOR_STORE(ip,icand) !sensor
435 if(ip.eq.6.and.is2.ne.0)is2=3-is2 !last plane inverted
436 if(
437 $ (is1.ne.is2.and.is2.ne.0)
438 $ )goto 122 !jump (this track cannot have an image)
439 enddo
440 if(DEBUG.eq.1)print*,' >>> ambiguous track! '
441 * ---------------------------------------------------------------
442 * take the candidate with the greatest number of matching couples
443 * if more than one satisfies the requirement,
444 * choose the one with more points and lower chi2
445 * ---------------------------------------------------------------
446 * count the number of matching couples
447 ncpmax = 0
448 iimage = 0 !id of candidate with better matching
449 do i=1,ntracks
450 ncp=0
451 do ip=1,nplanes
452 if(CP_STORE(nplanes-ip+1,icand).ne.0)then
453 if(
454 $ CP_STORE(nplanes-ip+1,i).ne.0
455 $ .and.
456 $ CP_STORE(nplanes-ip+1,icand).eq.
457 $ -1*CP_STORE(nplanes-ip+1,i)
458 $ )then
459 ncp=ncp+1 !ok
460 elseif(
461 $ CP_STORE(nplanes-ip+1,i).ne.0
462 $ .and.
463 $ CP_STORE(nplanes-ip+1,icand).ne.
464 $ -1*CP_STORE(nplanes-ip+1,i)
465 $ )then
466 ncp = 0
467 goto 117 !it is not an image candidate
468 else
469
470 endif
471 endif
472 enddo
473 117 continue
474 trackimage(i)=ncp !number of matching couples
475 if(ncp>ncpmax)then
476 ncpmax=ncp
477 iimage=i
478 endif
479 enddo
480 * check if there are more than one image candidates
481 ngood=0
482 do i=1,ntracks
483 if( ncpmax.ne.0.and.trackimage(i).eq.ncpmax )ngood=ngood+1
484 enddo
485 if(DEBUG.eq.1)print*,' n.image-candidates : ',ngood
486 * if there are, choose the best one
487 if(ngood.gt.0)then
488 * -------------------------------------------------------
489 * order track-candidates according to:
490 * 1st) decreasing n.points
491 * 2nd) increasing chi**2
492 * -------------------------------------------------------
493 rchi2best=1000000000.
494 ndofbest=0
495 do i=1,ntracks
496 if( trackimage(i).eq.ncpmax )then
497 ndof=0
498 do ii=1,nplanes
499 ndof=ndof
500 $ +int(xgood_store(ii,i))
501 $ +int(ygood_store(ii,i))
502 enddo
503 if(ndof.gt.ndofbest)then
504 iimage=i
505 rchi2best=RCHI2_STORE(i)
506 ndofbest=ndof
507 elseif(ndof.eq.ndofbest)then
508 if(RCHI2_STORE(i).lt.rchi2best.and.
509 $ RCHI2_STORE(i).gt.0)then
510 iimage=i
511 rchi2best=RCHI2_STORE(i)
512 ndofbest=ndof
513 endif
514 endif
515 endif
516 enddo
517
518 if(DEBUG.EQ.1)then
519 print*,'Track candidate ',iimage
520 $ ,' >>> TRACK IMAGE >>> of'
521 $ ,ibest
522 endif
523
524 endif
525
526
527 122 continue
528
529
530 * --- and store the results --------------------------------
531 if(ntrk.eq.NTRKMAX)then
532 if(verbose.eq.1)
533 $ print*,
534 $ '** warning ** number of identified '//
535 $ 'tracks exceeds vector dimension '
536 $ ,'( ',NTRKMAX,' )'
537 cc good2=.false.
538 goto 880 !fill ntp and go to next event
539 endif
540
541 ntrk = ntrk + 1 !counter of found tracks
542 if(.not.FIMAGE
543 $ .and.iimage.eq.0) image(ntrk)= 0
544 if(.not.FIMAGE
545 $ .and.iimage.ne.0)image(ntrk)=ntrk+1 !this is the image of the next
546 if(FIMAGE) image(ntrk)=ntrk-1 !this is the image of the previous
547 call fill_level2_tracks(ntrk) !==> good2=.true.
548
549 c$$$ if(ntrk.eq.NTRKMAX)then
550 c$$$ if(verbose.eq.1)
551 c$$$ $ print*,
552 c$$$ $ '** warning ** number of identified '//
553 c$$$ $ 'tracks exceeds vector dimension '
554 c$$$ $ ,'( ',NTRKMAX,' )'
555 c$$$cc good2=.false.
556 c$$$ goto 880 !fill ntp and go to next event
557 c$$$ endif
558 if(iimage.ne.0)then
559 FIMAGE=.true. !
560 goto 1212 !>>> fit image-track
561 endif
562
563
564 880 return
565 end
566
567
568
569 ************************************************************
570 ************************************************************
571 ************************************************************
572 ************************************************************
573 *
574 * This routine provides the coordinates (in cm) in the PAMELA reference system:
575 * - of the point associated with a COUPLE ---> (xPAM,yPAM,zPAM)
576 * - of the extremes of the segment
577 * associated with a SINGLET ---------------> (xPAM_A,yPAM_A,zPAM_A)
578 * ---> (xPAM_B,yPAM_B,zPAM_B)
579 *
580 * It also assigns the spatial resolution to the evaluated coordinates,
581 * as a function (in principle) of the multiplicity, the angle, the PFA etc...
582 *
583 *
584 * To call the routine you must pass the arguments:
585 * icx - ID of cluster x
586 * icy - ID of cluster y
587 * sensor - sensor (1,2)
588 * PFAx - Position Finding Algorithm in x (COG2,ETA2,...)
589 * PFAy - Position Finding Algorithm in y (COG2,ETA2,...)
590 * angx - Projected angle in x
591 * angy - Projected angle in y
592 * bfx - x-component of magnetci field
593 * bfy - y-component of magnetic field
594 *
595 * --------- COUPLES -------------------------------------------------------
596 * The couple defines a point in the space.
597 * The coordinates of the point are evaluated as follows:
598 * 1 - the corrected coordinates relative to the sensor are evaluated
599 * according to the chosen PFA --> (xi,yi,0)
600 * 2 - coordinates are rotated and traslated, according to the aligmnet
601 * parameters, and expressed in the reference system of the mechanical
602 * sensor --> (xrt,yrt,zrt)
603 * 3 - coordinates are finally converted to the PAMELA reference system
604 * --> (xPAM,yPAM,zPAM)
605 *
606 * --------- SINGLETS -------------------------------------------------------
607 * Since a coordinate is missing, the singlet defines not a point
608 * in the space but a segment AB (parallel to the strips).
609 * In this case the routine returns the coordinates in the PAMELA reference
610 * system of the two extremes A and B of the segment:
611 * --> (xPAM_A,yPAM_A,zPAM_A)
612 * --> (xPAM_B,yPAM_B,zPAM_B)
613 *
614 * ==========================================================
615 *
616 * The output of the routine is stored in the commons:
617 *
618 * double precision xPAM,yPAM,zPAM
619 * common/coord_xyz_PAM/xPAM,yPAM,zPAM
620 *
621 * double precision xPAM_A,yPAM_A,zPAM_A
622 * double precision xPAM_B,yPAM_B,zPAM_B
623 * common/coord_AB_PAM/xPAM_A,yPAM_A,zPAM_A,xPAM_B,yPAM_B,zPAM_B
624 *
625 * double precision resxPAM,resyPAM
626 * common/resolution_PAM/resxPAM,resyPAM
627 *
628 * (in file common_xyzPAM.f)
629 *
630 *
631
632 subroutine xyz_PAM(icx,icy,sensor,PFAx,PFAy,ax,ay,bfx,bfy)
633
634
635 include 'commontracker.f'
636 include 'level1.f'
637 include 'calib.f'
638 include 'common_align.f'
639 include 'common_mech.f'
640 include 'common_xyzPAM.f'
641
642 integer icx,icy !X-Y cluster ID
643 integer sensor
644 integer viewx,viewy
645 character*4 PFAx,PFAy !PFA to be used
646 real ax,ay !X-Y geometric angle
647 real angx,angy !X-Y effective angle
648 real bfx,bfy !X-Y b-field components
649
650 real stripx,stripy
651
652 double precision xi,yi,zi
653 double precision xi_A,yi_A,zi_A
654 double precision xi_B,yi_B,zi_B
655 double precision xrt,yrt,zrt
656 double precision xrt_A,yrt_A,zrt_A
657 double precision xrt_B,yrt_B,zrt_B
658
659
660 parameter (ndivx=30)
661
662
663
664 resxPAM = 0
665 resyPAM = 0
666
667 xPAM = 0.D0
668 yPAM = 0.D0
669 zPAM = 0.D0
670 xPAM_A = 0.D0
671 yPAM_A = 0.D0
672 zPAM_A = 0.D0
673 xPAM_B = 0.D0
674 yPAM_B = 0.D0
675 zPAM_B = 0.D0
676
677 if(sensor.lt.1.or.sensor.gt.2)then
678 print*,'xyz_PAM ***ERROR*** wrong input '
679 print*,'sensor ',sensor
680 icx=0
681 icy=0
682 endif
683
684 * -----------------
685 * CLUSTER X
686 * -----------------
687 if(icx.ne.0)then
688
689 viewx = VIEW(icx)
690 nldx = nld(MAXS(icx),VIEW(icx))
691 nplx = npl(VIEW(icx))
692 c resxPAM = RESXAV
693 stripx = float(MAXS(icx))
694
695 if(
696 $ viewx.lt.1.or.
697 $ viewx.gt.12.or.
698 $ nldx.lt.1.or.
699 $ nldx.gt.3.or.
700 $ stripx.lt.1.or.
701 $ stripx.gt.3072.or.
702 $ .false.)then
703 print*,'xyz_PAM ***ERROR*** wrong input '
704 print*,'icx ',icx,'view ',viewx,'nld ',nldx,'strip ',stripx
705 icx = 0
706 goto 10
707 endif
708
709 * --------------------------
710 * magnetic-field corrections
711 * --------------------------
712 stripx = stripx + fieldcorr(viewx,bfy)
713 angx = effectiveangle(ax,viewx,bfy)
714
715 call applypfa(PFAx,icx,angx,corr,res)
716 stripx = stripx + corr
717 resxPAM = res
718
719 10 continue
720 endif
721
722 * -----------------
723 * CLUSTER Y
724 * -----------------
725
726 if(icy.ne.0)then
727
728 viewy = VIEW(icy)
729 nldy = nld(MAXS(icy),VIEW(icy))
730 nply = npl(VIEW(icy))
731 c resyPAM = RESYAV
732 stripy = float(MAXS(icy))
733
734 if(
735 $ viewy.lt.1.or.
736 $ viewy.gt.12.or.
737 $ nldy.lt.1.or.
738 $ nldy.gt.3.or.
739 $ stripy.lt.1.or.
740 $ stripy.gt.3072.or.
741 $ .false.)then
742 print*,'xyz_PAM ***ERROR*** wrong input '
743 print*,'icy ',icy,'view ',viewy,'nld ',nldy,'strip ',stripy
744 icy = 0
745 goto 20
746 endif
747
748 if(icx.ne.0.and.(nply.ne.nplx.or.nldy.ne.nldx))then
749 if(DEBUG.EQ.1) then
750 print*,'xyz_PAM ***ERROR*** invalid cluster couple!!! '
751 $ ,icx,icy
752 endif
753 goto 100
754 endif
755
756 * --------------------------
757 * magnetic-field corrections
758 * --------------------------
759 stripy = stripy + fieldcorr(viewy,bfx)
760 angy = effectiveangle(ay,viewy,bfx)
761
762 call applypfa(PFAy,icy,angy,corr,res)
763 stripy = stripy + corr
764 resyPAM = res
765
766 20 continue
767 endif
768
769
770 c===========================================================
771 C COUPLE
772 C===========================================================
773 if(icx.ne.0.and.icy.ne.0)then
774
775 c------------------------------------------------------------------------
776 c (xi,yi,zi) = mechanical coordinates in the silicon sensor frame
777 c------------------------------------------------------------------------
778 if(((mod(int(stripx+0.5)-1,1024)+1).le.3)
779 $ .or.((mod(int(stripx+0.5)-1,1024)+1).ge.1022)) then !X has 1018 strips...
780 if(DEBUG.EQ.1) then
781 print*,'xyz_PAM (couple):',
782 $ ' WARNING: false X strip: strip ',stripx
783 endif
784 endif
785 xi = dcoordsi(stripx,viewx)
786 yi = dcoordsi(stripy,viewy)
787 zi = 0.D0
788
789 c------------------------------------------------------------------------
790 c (xrt,yrt,zrt) = rototranslated coordinates in the silicon sensor frame
791 c------------------------------------------------------------------------
792 c N.B. I convert angles from microradiants to radiants
793
794 xrt = xi
795 $ - omega(nplx,nldx,sensor)*yi
796 $ + gamma(nplx,nldx,sensor)*zi
797 $ + dx(nplx,nldx,sensor)
798
799 yrt = omega(nplx,nldx,sensor)*xi
800 $ + yi
801 $ - beta(nplx,nldx,sensor)*zi
802 $ + dy(nplx,nldx,sensor)
803
804 zrt = -gamma(nplx,nldx,sensor)*xi
805 $ + beta(nplx,nldx,sensor)*yi
806 $ + zi
807 $ + dz(nplx,nldx,sensor)
808
809 c xrt = xi
810 c yrt = yi
811 c zrt = zi
812
813 c------------------------------------------------------------------------
814 c (xPAM,yPAM,zPAM) = measured coordinates (in cm)
815 c in PAMELA reference system
816 c------------------------------------------------------------------------
817
818 xPAM = dcoord(xrt,viewx,nldx,sensor) / 1.d4
819 yPAM = dcoord(yrt,viewy,nldy,sensor) / 1.d4
820 zPAM = ( zrt + z_mech_sensor(nplx,nldx,sensor)*1000. ) / 1.d4
821
822 xPAM_A = 0.D0
823 yPAM_A = 0.D0
824 zPAM_A = 0.D0
825
826 xPAM_B = 0.D0
827 yPAM_B = 0.D0
828 zPAM_B = 0.D0
829
830 elseif(
831 $ (icx.ne.0.and.icy.eq.0).or.
832 $ (icx.eq.0.and.icy.ne.0).or.
833 $ .false.
834 $ )then
835
836 c------------------------------------------------------------------------
837 c (xi,yi,zi) = mechanical coordinates in the silicon sensor frame
838 c------------------------------------------------------------------------
839
840 if(icy.ne.0)then
841 c===========================================================
842 C Y-SINGLET
843 C===========================================================
844 nplx = nply
845 nldx = nldy
846 viewx = viewy + 1
847
848 xi = dcoordsi(0.5*(nstrips+1),viewx) !sensor center
849 yi = dcoordsi(stripy,viewy)
850 zi = 0.D0
851
852 xi_A = edgeY_d - SiDimX/2
853 yi_A = yi
854 zi_A = 0.
855
856 xi_B = SiDimX/2 - edgeY_u
857 yi_B = yi
858 zi_B = 0.
859
860
861 elseif(icx.ne.0)then
862 c===========================================================
863 C X-SINGLET
864 C===========================================================
865
866 nply = nplx
867 nldy = nldx
868 viewy = viewx - 1
869
870 if(((mod(int(stripx+0.5)-1,1024)+1).le.3)
871 $ .or.((mod(int(stripx+0.5)-1,1024)+1).ge.1022)) then !X has 1018 strips...
872 if(DEBUG.EQ.1) then
873 print*,'xyz_PAM (X-singlet):',
874 $ ' WARNING: false X strip: strip ',stripx
875 endif
876 endif
877
878 xi = dcoordsi(stripx,viewx)
879 yi = dcoordsi(0.5*(nstrips+1),viewy) !sensor center
880 zi = 0.D0
881
882 xi_A = xi
883 yi_A = edgeX_d - SiDimY/2
884 zi_A = 0.
885
886 xi_B = xi
887 yi_B = SiDimY/2 - edgeX_u
888 zi_B = 0.
889
890 if(viewy.eq.11)then
891 yi = yi_A
892 yi_A = yi_B
893 yi_B = yi
894 endif
895
896
897 else
898 if(DEBUG.EQ.1) then
899 print *,'routine xyz_PAM ---> not properly used !!!'
900 print *,'icx = ',icx
901 print *,'icy = ',icy
902 endif
903 goto 100
904
905 endif
906 c------------------------------------------------------------------------
907 c (xrt,yrt,zrt) = rototranslated coordinates in the silicon sensor frame
908 c------------------------------------------------------------------------
909 c N.B. I convert angles from microradiants to radiants
910
911 xrt_A = xi_A
912 $ - omega(nplx,nldx,sensor)*yi_A
913 $ + gamma(nplx,nldx,sensor)*zi_A
914 $ + dx(nplx,nldx,sensor)
915
916 yrt_A = omega(nplx,nldx,sensor)*xi_A
917 $ + yi_A
918 $ - beta(nplx,nldx,sensor)*zi_A
919 $ + dy(nplx,nldx,sensor)
920
921 zrt_A = -gamma(nplx,nldx,sensor)*xi_A
922 $ + beta(nplx,nldx,sensor)*yi_A
923 $ + zi_A
924 $ + dz(nplx,nldx,sensor)
925
926 xrt_B = xi_B
927 $ - omega(nplx,nldx,sensor)*yi_B
928 $ + gamma(nplx,nldx,sensor)*zi_B
929 $ + dx(nplx,nldx,sensor)
930
931 yrt_B = omega(nplx,nldx,sensor)*xi_B
932 $ + yi_B
933 $ - beta(nplx,nldx,sensor)*zi_B
934 $ + dy(nplx,nldx,sensor)
935
936 zrt_B = -gamma(nplx,nldx,sensor)*xi_B
937 $ + beta(nplx,nldx,sensor)*yi_B
938 $ + zi_B
939 $ + dz(nplx,nldx,sensor)
940
941
942
943 xrt = xi
944 $ - omega(nplx,nldx,sensor)*yi
945 $ + gamma(nplx,nldx,sensor)*zi
946 $ + dx(nplx,nldx,sensor)
947
948 yrt = omega(nplx,nldx,sensor)*xi
949 $ + yi
950 $ - beta(nplx,nldx,sensor)*zi
951 $ + dy(nplx,nldx,sensor)
952
953 zrt = -gamma(nplx,nldx,sensor)*xi
954 $ + beta(nplx,nldx,sensor)*yi
955 $ + zi
956 $ + dz(nplx,nldx,sensor)
957
958
959
960 c xrt = xi
961 c yrt = yi
962 c zrt = zi
963
964 c------------------------------------------------------------------------
965 c (xPAM,yPAM,zPAM) = measured coordinates (in cm)
966 c in PAMELA reference system
967 c------------------------------------------------------------------------
968
969 xPAM = dcoord(xrt,viewx,nldx,sensor) / 1.d4
970 yPAM = dcoord(yrt,viewy,nldy,sensor) / 1.d4
971 zPAM = ( zrt + z_mech_sensor(nplx,nldx,sensor)*1000. ) / 1.d4
972 c$$$ xPAM = 0.D0
973 c$$$ yPAM = 0.D0
974 c$$$ zPAM = 0.D0
975
976 xPAM_A = dcoord(xrt_A,viewx,nldx,sensor) / 1.d4
977 yPAM_A = dcoord(yrt_A,viewy,nldy,sensor) / 1.d4
978 zPAM_A = ( zrt_A + z_mech_sensor(nplx,nldx,sensor)*1000.)/ 1.d4
979
980 xPAM_B = dcoord(xrt_B,viewx,nldx,sensor) / 1.d4
981 yPAM_B = dcoord(yrt_B,viewy,nldy,sensor) / 1.d4
982 zPAM_B = ( zrt_B + z_mech_sensor(nplx,nldx,sensor)*1000.)/ 1.d4
983
984
985
986 else
987 if(DEBUG.EQ.1) then
988 print *,'routine xyz_PAM ---> not properly used !!!'
989 print *,'icx = ',icx
990 print *,'icy = ',icy
991 endif
992 endif
993
994
995
996 100 continue
997 end
998
999 ************************************************************************
1000 * Call xyz_PAM subroutine with default PFA and fill the mini2 common.
1001 * (done to be called from c/c++)
1002 ************************************************************************
1003
1004 subroutine xyzpam(ip,icx,icy,lad,sensor,ax,ay,bfx,bfy)
1005
1006 include 'commontracker.f'
1007 include 'level1.f'
1008 include 'common_mini_2.f'
1009 include 'common_xyzPAM.f'
1010 include 'common_mech.f'
1011 include 'calib.f'
1012
1013 * flag to chose PFA
1014 c$$$ character*10 PFA
1015 c$$$ common/FINALPFA/PFA
1016
1017 integer icx,icy !X-Y cluster ID
1018 integer sensor
1019 character*4 PFAx,PFAy !PFA to be used
1020 real ax,ay !X-Y geometric angle
1021 real bfx,bfy !X-Y b-field components
1022
1023 ipx=0
1024 ipy=0
1025
1026 c$$$ PFAx = 'COG4'!PFA
1027 c$$$ PFAy = 'COG4'!PFA
1028
1029
1030 if(icx.gt.nclstr1.or.icy.gt.nclstr1)then
1031 print*,'xyzpam: ***WARNING*** clusters ',icx,icy
1032 $ ,' do not exists (n.clusters=',nclstr1,')'
1033 icx = -1*icx
1034 icy = -1*icy
1035 return
1036
1037 endif
1038
1039 call idtoc(pfaid,PFAx)
1040 call idtoc(pfaid,PFAy)
1041
1042
1043 if(icx.ne.0.and.icy.ne.0)then
1044
1045 ipx=npl(VIEW(icx))
1046 ipy=npl(VIEW(icy))
1047
1048 if( (nplanes-ipx+1).ne.ip )then
1049 print*,'xyzpam: ***WARNING*** cluster ',icx
1050 $ ,' does not belong to plane: ',ip
1051 icx = -1*icx
1052 return
1053 endif
1054 if( (nplanes-ipy+1).ne.ip )then
1055 print*,'xyzpam: ***WARNING*** cluster ',icy
1056 $ ,' does not belong to plane: ',ip
1057 icy = -1*icy
1058 return
1059 endif
1060
1061 call xyz_PAM(icx,icy,sensor,PFAx,PFAy,ax,ay,bfx,bfy)
1062
1063 xgood(ip) = 1.
1064 ygood(ip) = 1.
1065 resx(ip) = resxPAM
1066 resy(ip) = resyPAM
1067
1068 xm(ip) = xPAM
1069 ym(ip) = yPAM
1070 zm(ip) = zPAM
1071 xm_A(ip) = 0.D0
1072 ym_A(ip) = 0.D0
1073 xm_B(ip) = 0.D0
1074 ym_B(ip) = 0.D0
1075
1076 c zv(ip) = zPAM
1077
1078 elseif(icx.eq.0.and.icy.ne.0)then
1079
1080 ipy=npl(VIEW(icy))
1081 if( (nplanes-ipy+1).ne.ip )then
1082 print*,'xyzpam: ***WARNING*** cluster ',icy
1083 $ ,' does not belong to plane: ',ip
1084 icy = -1*icy
1085 return
1086 endif
1087
1088 call xyz_PAM(icx,icy,sensor,PFAx,PFAy,ax,ay,bfx,bfy)
1089
1090 xgood(ip) = 0.
1091 ygood(ip) = 1.
1092 resx(ip) = 1000.
1093 resy(ip) = resyPAM
1094
1095 c$$$ xm(ip) = -100.
1096 c$$$ ym(ip) = -100.
1097 c$$$ zm(ip) = (zPAM_A+zPAM_B)/2.
1098 xm(ip) = xPAM
1099 ym(ip) = yPAM
1100 zm(ip) = zPAM
1101 xm_A(ip) = xPAM_A
1102 ym_A(ip) = yPAM_A
1103 xm_B(ip) = xPAM_B
1104 ym_B(ip) = yPAM_B
1105
1106 c zv(ip) = (zPAM_A+zPAM_B)/2.
1107
1108 elseif(icx.ne.0.and.icy.eq.0)then
1109
1110 ipx=npl(VIEW(icx))
1111
1112 if( (nplanes-ipx+1).ne.ip )then
1113 print*,'xyzpam: ***WARNING*** cluster ',icx
1114 $ ,' does not belong to plane: ',ip
1115 icx = -1*icx
1116 return
1117 endif
1118
1119 call xyz_PAM(icx,icy,sensor,PFAx,PFAy,ax,ay,bfx,bfy)
1120
1121 xgood(ip) = 1.
1122 ygood(ip) = 0.
1123 resx(ip) = resxPAM
1124 resy(ip) = 1000.
1125
1126 c$$$ xm(ip) = -100.
1127 c$$$ ym(ip) = -100.
1128 c$$$ zm(ip) = (zPAM_A+zPAM_B)/2.
1129 xm(ip) = xPAM
1130 ym(ip) = yPAM
1131 zm(ip) = zPAM
1132 xm_A(ip) = xPAM_A
1133 ym_A(ip) = yPAM_A
1134 xm_B(ip) = xPAM_B
1135 ym_B(ip) = yPAM_B
1136
1137 c zv(ip) = (zPAM_A+zPAM_B)/2.
1138
1139 else
1140
1141 il = 2
1142 if(lad.ne.0)il=lad
1143 is = 1
1144 if(sensor.ne.0)is=sensor
1145
1146 xgood(ip) = 0.
1147 ygood(ip) = 0.
1148 resx(ip) = 1000.
1149 resy(ip) = 1000.
1150
1151 xm(ip) = -100.
1152 ym(ip) = -100.
1153 zm(ip) = z_mech_sensor(nplanes-ip+1,il,is)*1000./1.d4
1154 xm_A(ip) = 0.
1155 ym_A(ip) = 0.
1156 xm_B(ip) = 0.
1157 ym_B(ip) = 0.
1158
1159 c zv(ip) = z_mech_sensor(nplanes-ip+1,il,is)*1000./1.d4
1160
1161 endif
1162
1163 if(DEBUG.EQ.1)then
1164 22222 format(i2,' * ',3f10.4,' --- ',4f10.4,' --- ',2f4.0,2f10.5)
1165 write(*,22222)ip,zm(ip),xm(ip),ym(ip)
1166 $ ,xm_A(ip),ym_A(ip),xm_B(ip),ym_B(ip)
1167 $ ,xgood(ip),ygood(ip),resx(ip),resy(ip)
1168 endif
1169 end
1170
1171 ********************************************************************************
1172 ********************************************************************************
1173 ********************************************************************************
1174 *
1175 * The function distance_to(XP,YP) should be used after
1176 * a call to the xyz_PAM routine and it evaluate the
1177 * NORMALIZED distance (PROJECTED on the XY plane) between
1178 * the point (XP,YP), argument of the function,
1179 * and:
1180 *
1181 * - the point (xPAM,yPAM,zPAM), in the case of a COUPLE
1182 * or
1183 * - the segment (xPAM_A,yPAM_A,zPAM_A)-(xPAM_B,yPAM_B,zPAM_B),
1184 * in the case of a SINGLET.
1185 *
1186 * ( The routine xyz_PAM fills the common defined in "common_xyzPAM.f",
1187 * which stores the coordinates of the couple/singlet )
1188 *
1189 ********************************************************************************
1190
1191 real function distance_to(rXPP,rYPP)
1192
1193 include 'common_xyzPAM.f'
1194
1195 * -----------------------------------
1196 * it computes the normalized distance
1197 * ( i.e. distance/resolution )
1198 * -----------------------------------
1199
1200 real rXPP,rYPP
1201 double precision XPP,YPP
1202 double precision distance,RE
1203 double precision BETA,ALFA,xmi,ymi
1204
1205 XPP=DBLE(rXPP)
1206 YPP=DBLE(rYPP)
1207
1208 * ----------------------
1209 if (
1210 c$$$ + xPAM.eq.0.and.
1211 c$$$ + yPAM.eq.0.and.
1212 c$$$ + zPAM.eq.0.and.
1213 + xPAM_A.ne.0.and.
1214 + yPAM_A.ne.0.and.
1215 + zPAM_A.ne.0.and.
1216 + xPAM_B.ne.0.and.
1217 + yPAM_B.ne.0.and.
1218 + zPAM_B.ne.0.and.
1219 + .true.)then
1220 * -----------------------
1221 * DISTANCE TO --- SINGLET
1222 * -----------------------
1223 if(abs(sngl(xPAM_B-xPAM_A)).lt.abs(sngl(yPAM_B-yPAM_A)))then
1224 * |||---------- X CLUSTER
1225
1226 BETA = (xPAM_B-xPAM_A)/(yPAM_B-yPAM_A)
1227 ALFA = xPAM_A - BETA * yPAM_A
1228
1229 ymi = ( YPP + BETA*XPP - BETA*ALFA )/(1+BETA**2)
1230 if(ymi.lt.dmin1(yPAM_A,yPAM_B))ymi=dmin1(yPAM_A,yPAM_B)
1231 if(ymi.gt.dmax1(yPAM_A,yPAM_B))ymi=dmax1(yPAM_A,yPAM_B)
1232 xmi = ALFA + BETA * ymi
1233 RE = resxPAM
1234
1235 else
1236 * |||---------- Y CLUSTER
1237
1238 BETA = (yPAM_B-yPAM_A)/(xPAM_B-xPAM_A)
1239 ALFA = yPAM_A - BETA * xPAM_A
1240
1241 xmi = ( XPP + BETA*YPP - BETA*ALFA )/(1+BETA**2)
1242 if(xmi.lt.dmin1(xPAM_A,xPAM_B))xmi=dmin1(xPAM_A,xPAM_B)
1243 if(xmi.gt.dmax1(xPAM_A,xPAM_B))xmi=dmax1(xPAM_A,xPAM_B)
1244 ymi = ALFA + BETA * xmi
1245 RE = resyPAM
1246
1247 endif
1248
1249 distance=
1250 $ ((xmi-XPP)**2+(ymi-YPP)**2)!QUIQUI
1251 cc $ ((xmi-XPP)**2+(ymi-YPP)**2)/RE**2
1252 distance=dsqrt(distance)
1253
1254
1255
1256 * ----------------------
1257 elseif(
1258 c$$$ + xPAM.ne.0.and.
1259 c$$$ + yPAM.ne.0.and.
1260 c$$$ + zPAM.ne.0.and.
1261 + xPAM_A.eq.0.and.
1262 + yPAM_A.eq.0.and.
1263 + zPAM_A.eq.0.and.
1264 + xPAM_B.eq.0.and.
1265 + yPAM_B.eq.0.and.
1266 + zPAM_B.eq.0.and.
1267 + .true.)then
1268 * ----------------------
1269 * DISTANCE TO --- COUPLE
1270 * ----------------------
1271
1272 distance=
1273 $ ((xPAM-XPP))**2 !QUIQUI
1274 $ +
1275 $ ((yPAM-YPP))**2
1276 c$$$ $ ((xPAM-XPP)/resxPAM)**2
1277 c$$$ $ +
1278 c$$$ $ ((yPAM-YPP)/resyPAM)**2
1279 distance=dsqrt(distance)
1280
1281
1282 else
1283
1284 endif
1285
1286 distance_to = sngl(distance)
1287
1288 return
1289 end
1290
1291 ********************************************************************************
1292 ********************************************************************************
1293 ********************************************************************************
1294 ********************************************************************************
1295
1296 subroutine whichsensor(nplPAM,xPAM,yPAM,ladder,sensor)
1297 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
1298 * Given the plane (1-6 from BOTTOM to TOP!!) and the (xPAM,yPAM)
1299 * coordinates (in the PAMELA reference system), it returns
1300 * the ladder and the sensor which the point belongs to.
1301 *
1302 * The method to assign a point to a sensor consists in
1303 * - calculating the sum of the distances between the point
1304 * and the sensor edges
1305 * - requiring that it is less-equal than (SiDimX+SiDimY)
1306 *
1307 * NB -- SiDimX and SiDimY are not the dimentions of the SENSITIVE volume
1308 * but of the whole silicon sensor
1309 *
1310 * CONVENTION:
1311 * - sensor 1 is the one closest to the hybrid
1312 * - ladder 1 is the first to be read out (strips from 1 to 1024)
1313 *
1314 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
1315 include 'commontracker.f'
1316 include 'common_align.f'
1317
1318 integer ladder,sensor,viewx,viewy
1319 real c1(4),c2(4),c3(4)
1320 data c1/1.,0.,0.,1./
1321 data c2/1.,-1.,-1.,1./
1322 data c3/1.,1.,0.,0./
1323 double precision yvvv,xvvv
1324 double precision xi,yi,zi
1325 double precision xrt,yrt,zrt
1326 real AA,BB
1327 double precision yvv(4),xvv(4)
1328
1329 * tollerance to consider the track inside the sensitive area
1330 real ptoll
1331 data ptoll/150./ !um
1332
1333 external nviewx,nviewy,dcoordsi,dcoord
1334
1335 nplpt = nplPAM !plane
1336 viewx = nviewx(nplpt)
1337 viewy = nviewy(nplpt)
1338
1339 do il=1,nladders_view
1340 do is=1,2
1341
1342 do iv=1,4 !loop on sensor vertexes
1343 stripx = (il-c1(iv))*1024 + c1(iv) + c2(iv)*3
1344 stripy = (il-c3(iv))*1024 + c3(iv)
1345 c------------------------------------------------------------------------
1346 c (xi,yi,zi) = mechanical coordinates in the silicon sensor frame
1347 c------------------------------------------------------------------------
1348 xi = dcoordsi(stripx,viewx)
1349 yi = dcoordsi(stripy,viewy)
1350 zi = 0.D0
1351 c------------------------------------------------------------------------
1352 c (xrt,yrt,zrt) = rototranslated coordinates in the silicon sensor frame
1353 c------------------------------------------------------------------------
1354 c N.B. I convert angles from microradiants to radiants
1355 xrt = xi
1356 $ - omega(nplpt,il,is)*yi
1357 $ + gamma(nplpt,il,is)*zi
1358 $ + dx(nplpt,il,is)
1359 yrt = omega(nplpt,il,is)*xi
1360 $ + yi
1361 $ - beta(nplpt,il,is)*zi
1362 $ + dy(nplpt,il,is)
1363 zrt = -gamma(nplpt,il,is)*xi
1364 $ + beta(nplpt,il,is)*yi
1365 $ + zi
1366 $ + dz(nplpt,il,is)
1367 c------------------------------------------------------------------------
1368 c measured coordinates (in cm) in PAMELA reference system
1369 c------------------------------------------------------------------------
1370 yvvv = dcoord(yrt,viewy,il,is) / 1.d4
1371 xvvv = dcoord(xrt,viewx,il,is) / 1.d4
1372
1373 yvv(iv)=sngl(yvvv)
1374 xvv(iv)=sngl(xvvv)
1375 enddo !end loop on sensor vertexes
1376
1377 dtot=0.
1378 do iside=1,4,2 !loop on sensor edges X
1379 iv1=iside
1380 iv2=mod(iside,4)+1
1381 * straight line passing trhough two consecutive vertexes
1382 AA = (yvv(iv1)-yvv(iv2))/(xvv(iv1)-xvv(iv2))
1383 BB = yvv(iv1) - AA*xvv(iv1)
1384 * point along the straight line closer to the track
1385 xoo = (xPAM+AA*yPAM-AA*BB)/(1+AA**2)
1386 yoo = AA*xoo + BB
1387 * sum of the distances
1388 dtot = dtot +
1389 $ sqrt((xPAM-xoo)**2+(yPAM-yoo)**2)
1390 enddo !end loop on sensor edges
1391 do iside=2,4,2 !loop on sensor edges Y
1392 iv1=iside
1393 iv2=mod(iside,4)+1
1394 * straight line passing trhough two consecutive vertexes
1395 AA = (xvv(iv1)-xvv(iv2))/(yvv(iv1)-yvv(iv2))
1396 BB = xvv(iv1) - AA*yvv(iv1)
1397 * point along the straight line closer to the track
1398 yoo = (yPAM+AA*xPAM-AA*BB)/(1+AA**2)
1399 xoo = AA*yoo + BB
1400 * sum of the distances
1401 dtot = dtot +
1402 $ sqrt((xPAM-xoo)**2+(yPAM-yoo)**2)
1403 enddo !end loop on sensor edges
1404
1405
1406 * half-perimeter of sensitive area
1407 Perim =
1408 $ SiDimX - edgeX_l - edgeX_r
1409 $ +SiDimY - edgeY_l - edgeY_r
1410 Perim = (Perim + ptoll)/1.e4
1411 if(dtot.le.Perim)goto 100
1412
1413
1414 enddo
1415 enddo
1416
1417 ladder = 0
1418 sensor = 0
1419 goto 200
1420
1421 100 continue
1422 ladder = il
1423 sensor = is
1424
1425
1426 200 return
1427 end
1428
1429
1430
1431 *************************************************************************
1432
1433 subroutine reverse(v,n,temp) !invert the order of the components of v(n) vector
1434
1435 implicit double precision (A-H,O-Z)
1436
1437 dimension v(*)
1438 dimension temp(*)
1439 integer i,n
1440
1441 do i=1,n
1442 temp(i)=v(n+1-i)
1443 enddo
1444
1445 do i=1,n
1446 v(i)=temp(i)
1447 enddo
1448
1449 return
1450 end
1451
1452 *************************************************************************
1453 *************************************************************************
1454 *************************************************************************
1455 *************************************************************************
1456 *************************************************************************
1457 *************************************************************************
1458 *************************************************************************
1459 *************************************************************************
1460 *************************************************************************
1461 *************************************************************************
1462 *************************************************************************
1463 *************************************************************************
1464 *************************************************************************
1465 *************************************************************************
1466 *************************************************************************
1467 integer function ip_cp(id)
1468 *
1469 * given the couple id,
1470 * it returns the plane number
1471 *
1472 include 'commontracker.f'
1473 include 'level1.f'
1474 c include 'common_analysis.f'
1475 include 'common_momanhough.f'
1476
1477 ip_cp=0
1478 ncpp=0
1479 do ip=1,nplanes
1480 ncpp=ncpp+ncp_plane(ip)
1481 if(ncpp.ge.abs(id))then
1482 ip_cp=ip
1483 goto 100
1484 endif
1485 enddo
1486 100 continue
1487 return
1488 end
1489
1490
1491 integer function is_cp(id)
1492 *
1493 * given the couple id,
1494 * it returns the sensor number
1495 *
1496 is_cp=0
1497 if(id.lt.0)is_cp=1
1498 if(id.gt.0)is_cp=2
1499
1500 return
1501 end
1502
1503
1504 integer function icp_cp(id)
1505 *
1506 * given the couple id,
1507 * it returns the id number ON THE PLANE
1508 *
1509 include 'commontracker.f'
1510 include 'level1.f'
1511 c include 'common_analysis.f'
1512 include 'common_momanhough.f'
1513
1514 icp_cp=0
1515
1516 ncpp=0
1517 do ip=1,nplanes
1518 ncppold=ncpp
1519 ncpp=ncpp+ncp_plane(ip)
1520 if(ncpp.ge.abs(id))then
1521 icp_cp=abs(id)-ncppold
1522 goto 100
1523 endif
1524 enddo
1525 100 continue
1526 return
1527 end
1528
1529
1530
1531 integer function id_cp(ip,icp,is)
1532 *
1533 * given a plane, a couple and the sensor
1534 * it returns the absolute couple id
1535 * negative if sensor =1
1536 * positive if sensor =2
1537 *
1538 include 'commontracker.f'
1539 include 'level1.f'
1540 c include 'calib.f'
1541 c include 'level1.f'
1542 c include 'common_analysis.f'
1543 include 'common_momanhough.f'
1544
1545 id_cp=0
1546
1547 if(ip.gt.1)then
1548 do i=1,ip-1
1549 id_cp = id_cp + ncp_plane(i)
1550 enddo
1551 endif
1552
1553 id_cp = id_cp + icp
1554
1555 if(is.eq.1) id_cp = -id_cp
1556
1557 return
1558 end
1559
1560
1561
1562
1563 *************************************************************************
1564 *************************************************************************
1565 *************************************************************************
1566 *************************************************************************
1567 *************************************************************************
1568 *************************************************************************
1569
1570
1571 ***************************************************
1572 * *
1573 * *
1574 * *
1575 * *
1576 * *
1577 * *
1578 **************************************************
1579
1580 subroutine cl_to_couples(iflag)
1581
1582 include 'commontracker.f'
1583 include 'level1.f'
1584 include 'common_momanhough.f'
1585 c include 'momanhough_init.f'
1586 include 'calib.f'
1587 c include 'level1.f'
1588
1589 * output flag
1590 * --------------
1591 * 0 = good event
1592 * 1 = bad event
1593 * --------------
1594 integer iflag
1595
1596 integer badseed,badclx,badcly
1597
1598 iflag = iflag
1599 if(DEBUG.EQ.1)print*,'cl_to_couples:'
1600
1601 cc if(RECOVER_SINGLETS.and..not.SECOND_SEARCH)goto 80
1602
1603 * init variables
1604 do ip=1,nplanes
1605 do ico=1,ncouplemax
1606 clx(ip,ico)=0
1607 cly(ip,ico)=0
1608 enddo
1609 ncp_plane(ip)=0
1610 do icl=1,nclstrmax_level2
1611 cls(ip,icl)=1
1612 enddo
1613 ncls(ip)=0
1614 enddo
1615 do icl=1,nclstrmax_level2
1616 cl_single(icl) = 1 !all are single
1617 cl_good(icl) = 0 !all are bad
1618 enddo
1619 do iv=1,nviews
1620 ncl_view(iv) = 0
1621 mask_view(iv) = 0 !all included
1622 enddo
1623
1624 * count number of cluster per view
1625 do icl=1,nclstr1
1626 ncl_view(VIEW(icl)) = ncl_view(VIEW(icl)) + 1
1627 enddo
1628 * mask views with too many clusters
1629 do iv=1,nviews
1630 if( ncl_view(iv).gt. nclusterlimit)then
1631 c mask_view(iv) = 1
1632 mask_view(iv) = mask_view(iv) + 2**0
1633 if(DEBUG.EQ.1)
1634 $ print*,' * WARNING * cl_to_couple: n.clusters > '
1635 $ ,nclusterlimit,' on view ', iv,' --> masked!'
1636 endif
1637 enddo
1638
1639
1640 * start association
1641 ncouples=0
1642 do icx=1,nclstr1 !loop on cluster (X)
1643 if(mod(VIEW(icx),2).eq.1)goto 10
1644
1645 if(cl_used(icx).ne.0)goto 10
1646
1647 * ----------------------------------------------------
1648 * jump masked views (X VIEW)
1649 * ----------------------------------------------------
1650 if( mask_view(VIEW(icx)).ne.0 ) goto 10
1651 * ----------------------------------------------------
1652 * cut on charge (X VIEW)
1653 * ----------------------------------------------------
1654 if(sgnl(icx)/mip(VIEW(icx),LADDER(icx)).lt.dedx_x_min)then
1655 cl_single(icx)=0
1656 goto 10
1657 endif
1658 * ----------------------------------------------------
1659 * cut BAD (X VIEW)
1660 * ----------------------------------------------------
1661 badseed=BAD(VIEW(icx),nvk(MAXS(icx)),nst(MAXS(icx)))
1662 ifirst=INDSTART(icx)
1663 if(icx.ne.nclstr1) then
1664 ilast=INDSTART(icx+1)-1
1665 else
1666 ilast=TOTCLLENGTH
1667 endif
1668 badclx=badseed
1669 do igood=-ngoodstr,ngoodstr
1670 ibad=1
1671 if((INDMAX(icx)+igood).gt.ifirst.and.
1672 $ (INDMAX(icx)+igood).lt.ilast.and.
1673 $ .true.)then
1674 ibad=BAD(VIEW(icx),
1675 $ nvk(MAXS(icx)+igood),
1676 $ nst(MAXS(icx)+igood))
1677 endif
1678 badclx=badclx*ibad
1679 enddo
1680 * ----------------------------------------------------
1681 * >>> eliminato il taglio sulle BAD <<<
1682 * ----------------------------------------------------
1683 c if(badcl.eq.0)then
1684 c cl_single(icx)=0
1685 c goto 10
1686 c endif
1687 * ----------------------------------------------------
1688
1689 cl_good(icx)=1
1690 nplx=npl(VIEW(icx))
1691 nldx=nld(MAXS(icx),VIEW(icx))
1692
1693 do icy=1,nclstr1 !loop on cluster (Y)
1694 if(mod(VIEW(icy),2).eq.0)goto 20
1695
1696 if(cl_used(icx).ne.0)goto 20
1697
1698 * ----------------------------------------------------
1699 * jump masked views (Y VIEW)
1700 * ----------------------------------------------------
1701 if( mask_view(VIEW(icy)).ne.0 ) goto 20
1702
1703 * ----------------------------------------------------
1704 * cut on charge (Y VIEW)
1705 * ----------------------------------------------------
1706 if(sgnl(icy)/mip(VIEW(icy),LADDER(icy)) .lt.dedx_y_min)then
1707 cl_single(icy)=0
1708 goto 20
1709 endif
1710 * ----------------------------------------------------
1711 * cut BAD (Y VIEW)
1712 * ----------------------------------------------------
1713 badseed=BAD(VIEW(icy),nvk(MAXS(icy)),nst(MAXS(icy)))
1714 ifirst=INDSTART(icy)
1715 if(icy.ne.nclstr1) then
1716 ilast=INDSTART(icy+1)-1
1717 else
1718 ilast=TOTCLLENGTH
1719 endif
1720 badcly=badseed
1721 do igood=-ngoodstr,ngoodstr
1722 ibad=1
1723 if((INDMAX(icy)+igood).gt.ifirst.and.
1724 $ (INDMAX(icy)+igood).lt.ilast.and.
1725 $ .true.)
1726 $ ibad=BAD(VIEW(icy),
1727 $ nvk(MAXS(icy)+igood),
1728 $ nst(MAXS(icy)+igood))
1729 badcly=badcly*ibad
1730 enddo
1731 * ----------------------------------------------------
1732 * >>> eliminato il taglio sulle BAD <<<
1733 * ----------------------------------------------------
1734 c if(badcl.eq.0)then
1735 c cl_single(icy)=0
1736 c goto 20
1737 c endif
1738 * ----------------------------------------------------
1739
1740 cl_good(icy)=1
1741 nply=npl(VIEW(icy))
1742 nldy=nld(MAXS(icy),VIEW(icy))
1743
1744 * ----------------------------------------------
1745 * CONDITION TO FORM A COUPLE
1746 * ----------------------------------------------
1747 * geometrical consistency (same plane and ladder)
1748 if(nply.eq.nplx.and.nldy.eq.nldx)then
1749 * charge correlation
1750 * (modified to be applied only below saturation... obviously)
1751
1752 if( .not.(sgnl(icy).gt.chsaty.and.sgnl(icx).gt.chsatx)
1753 $ .and.
1754 $ .not.(sgnl(icy).lt.chmipy.and.sgnl(icx).lt.chmipx)
1755 $ .and.
1756 $ (badclx.eq.1.and.badcly.eq.1)
1757 $ .and.
1758 $ .true.)then
1759
1760 ddd=(sgnl(icy)
1761 $ -kch(nplx,nldx)*sgnl(icx)-cch(nplx,nldx))
1762 ddd=ddd/sqrt(kch(nplx,nldx)**2+1)
1763
1764 c cut = chcut * sch(nplx,nldx)
1765
1766 sss=(kch(nplx,nldx)*sgnl(icy)+sgnl(icx)
1767 $ -kch(nplx,nldx)*cch(nplx,nldx))
1768 sss=sss/sqrt(kch(nplx,nldx)**2+1)
1769 cut = chcut * (16 + sss/50.)
1770
1771 if(abs(ddd).gt.cut)then
1772 goto 20 !charge not consistent
1773 endif
1774 endif
1775
1776 if(ncp_plane(nplx).gt.ncouplemax)then
1777 if(verbose.eq.1)print*,
1778 $ '** warning ** number of identified '//
1779 $ 'couples on plane ',nplx,
1780 $ 'exceeds vector dimention '
1781 $ ,'( ',ncouplemax,' ) --> masked!'
1782 c mask_view(nviewx(nplx)) = 2
1783 c mask_view(nviewy(nply)) = 2
1784 mask_view(nviewx(nplx))= mask_view(nviewx(nplx))+ 2**1
1785 mask_view(nviewy(nply))= mask_view(nviewy(nply))+ 2**1
1786 goto 10
1787 endif
1788
1789 * ------------------> COUPLE <------------------
1790 ncp_plane(nplx) = ncp_plane(nplx) + 1
1791 clx(nplx,ncp_plane(nplx))=icx
1792 cly(nply,ncp_plane(nplx))=icy
1793 cl_single(icx)=0
1794 cl_single(icy)=0
1795 * ----------------------------------------------
1796
1797 endif
1798
1799 20 continue
1800 enddo !end loop on clusters(Y)
1801
1802 10 continue
1803 enddo !end loop on clusters(X)
1804
1805 do icl=1,nclstr1
1806 if(cl_single(icl).eq.1)then
1807 ip=npl(VIEW(icl))
1808 ncls(ip)=ncls(ip)+1
1809 cls(ip,ncls(ip))=icl
1810 endif
1811 enddo
1812
1813 c 80 continue
1814 continue
1815
1816
1817 if(DEBUG.EQ.1)then
1818 print*,'clusters ',nclstr1
1819 print*,'good ',(cl_good(i),i=1,nclstr1)
1820 print*,'used ',(cl_used(i),i=1,nclstr1)
1821 print*,'singlets',(cl_single(i),i=1,nclstr1)
1822 print*,'couples per plane: ',(ncp_plane(ip),ip=1,nplanes)
1823 endif
1824
1825
1826 if(.not.RECOVER_SINGLETS)goto 81
1827
1828 * ////////////////////////////////////////////////
1829 * PATCH to recover events with less than 3 couples
1830 * ////////////////////////////////////////////////
1831 * loop over singlet and create "fake" couples
1832 * (with clx=0 or cly=0)
1833 *
1834
1835 if(DEBUG.EQ.1)
1836 $ print*,'>>> Recover singlets '
1837 $ ,'(creates fake couples) <<<'
1838 do icl=1,nclstr1
1839 if(
1840 $ cl_single(icl).eq.1.and.
1841 $ cl_used(icl).eq.0.and.
1842 $ .true.)then
1843 * ----------------------------------------------------
1844 * jump masked views
1845 * ----------------------------------------------------
1846 if( mask_view(VIEW(icl)).ne.0 ) goto 21
1847 if(mod(VIEW(icl),2).eq.0)then !=== X views
1848 * ----------------------------------------------------
1849 * cut on charge (X VIEW)
1850 * ----------------------------------------------------
1851 if(sgnl(icl).lt.dedx_x_min) goto 21
1852
1853 nplx=npl(VIEW(icl))
1854 * ------------------> (FAKE) COUPLE <-----------------
1855 ncp_plane(nplx) = ncp_plane(nplx) + 1
1856 clx(nplx,ncp_plane(nplx))=icl
1857 cly(nplx,ncp_plane(nplx))=0
1858 c$$$ cl_single(icl)=0! I leave the cluster tagged as singlet!!!
1859 * ----------------------------------------------------
1860
1861 else !=== Y views
1862 * ----------------------------------------------------
1863 * cut on charge (Y VIEW)
1864 * ----------------------------------------------------
1865 if(sgnl(icl).lt.dedx_y_min) goto 21
1866
1867 nply=npl(VIEW(icl))
1868 * ------------------> (FAKE) COUPLE <-----------------
1869 ncp_plane(nply) = ncp_plane(nply) + 1
1870 clx(nply,ncp_plane(nply))=0
1871 cly(nply,ncp_plane(nply))=icl
1872 c$$$ cl_single(icl)=0! I leave the cluster tagged as singlet!!!
1873 * ----------------------------------------------------
1874
1875 endif
1876 endif !end "single" condition
1877 21 continue
1878 enddo !end loop over clusters
1879
1880 if(DEBUG.EQ.1)
1881 $ print*,'couples per plane: ',(ncp_plane(ip),ip=1,nplanes)
1882
1883
1884 81 continue
1885
1886 ncp_tot=0
1887 do ip=1,NPLANES
1888 ncp_tot = ncp_tot + ncp_plane(ip)
1889 enddo
1890 if(DEBUG.EQ.1)
1891 $ print*,'n.couple tot: ',ncp_tot
1892
1893 return
1894 end
1895
1896 ***************************************************
1897 * *
1898 * *
1899 * *
1900 * *
1901 * *
1902 * *
1903 **************************************************
1904
1905 subroutine cp_to_doubtrip(iflag)
1906
1907 include 'commontracker.f'
1908 include 'level1.f'
1909 include 'common_momanhough.f'
1910 include 'common_xyzPAM.f'
1911 include 'common_mini_2.f'
1912 include 'calib.f'
1913
1914
1915 * output flag
1916 * --------------
1917 * 0 = good event
1918 * 1 = bad event
1919 * --------------
1920 integer iflag
1921
1922
1923 * -----------------------------
1924 * DOUBLETS/TRIPLETS coordinates
1925 c double precision xm1,ym1,zm1
1926 c double precision xm2,ym2,zm2
1927 c double precision xm3,ym3,zm3
1928
1929 real xm1,ym1,zm1
1930 real xm2,ym2,zm2
1931 real xm3,ym3,zm3
1932 * -----------------------------
1933 * variable needed for tricircle:
1934 real xp(3),zp(3)!TRIPLETS coordinates, to find a circle
1935 EQUIVALENCE (xm1,xp(1))
1936 EQUIVALENCE (xm2,xp(2))
1937 EQUIVALENCE (xm3,xp(3))
1938 EQUIVALENCE (zm1,zp(1))
1939 EQUIVALENCE (zm2,zp(2))
1940 EQUIVALENCE (zm3,zp(3))
1941 real angp(3),resp(3),chi
1942 real xc,zc,radius
1943 * -----------------------------
1944
1945 if(DEBUG.EQ.1)print*,'cp_to_doubtrip:'
1946
1947 * --------------------------------------------
1948 * put a limit to the maximum number of couples
1949 * per plane, in order to apply hough transform
1950 * (couples recovered during track refinement)
1951 * --------------------------------------------
1952 do ip=1,nplanes
1953 if(ncp_plane(ip).gt.ncouplelimit)then
1954 mask_view(nviewx(ip)) = mask_view(nviewx(ip)) + 2**7
1955 mask_view(nviewy(ip)) = mask_view(nviewy(ip)) + 2**7
1956 endif
1957 enddo
1958
1959
1960 ndblt=0 !number of doublets
1961 ntrpt=0 !number of triplets
1962
1963 do ip1=1,(nplanes-1) !loop on planes - COPPIA 1
1964 c$$$ print*,'(1) ip ',ip1
1965 c$$$ $ ,mask_view(nviewx(ip1))
1966 c$$$ $ ,mask_view(nviewy(ip1))
1967 if( mask_view(nviewx(ip1)).ne.0 .or.
1968 $ mask_view(nviewy(ip1)).ne.0 )goto 10 !skip plane
1969 do is1=1,2 !loop on sensors - COPPIA 1
1970 do icp1=1,ncp_plane(ip1) !loop on COPPIA 1
1971 icx1=clx(ip1,icp1)
1972 icy1=cly(ip1,icp1)
1973
1974 c$$$ print*,'(1) ip ',ip1,' icp ',icp1
1975
1976 c call xyz_PAM(icx1,icy1,is1,'COG2','COG2',0.,0.)!(1)
1977 c call xyz_PAM(icx1,icy1,is1,PFAdef,PFAdef,0.,0.) !(1)
1978 call xyz_PAM(icx1,icy1,is1,PFAdef,PFAdef,0.,0.,0.,0.)
1979 xm1=xPAM
1980 ym1=yPAM
1981 zm1=zPAM
1982
1983 do ip2=(ip1+1),nplanes !loop on planes - COPPIA 2
1984 c$$$ print*,'(2) ip ',ip2
1985 c$$$ $ ,mask_view(nviewx(ip2))
1986 c$$$ $ ,mask_view(nviewy(ip2))
1987 if( mask_view(nviewx(ip2)).ne.0 .or.
1988 $ mask_view(nviewy(ip2)).ne.0 )goto 20 !skip plane
1989 do is2=1,2 !loop on sensors -ndblt COPPIA 2
1990 do icp2=1,ncp_plane(ip2) !loop on COPPIA 2
1991 icx2=clx(ip2,icp2)
1992 icy2=cly(ip2,icp2)
1993
1994 c$$$ print*,'(2) ip ',ip2,' icp ',icp2
1995
1996 c call xyz_PAM
1997 c $ (icx2,icy2,is2,'COG2','COG2',0.,0.)!(1)
1998 c call xyz_PAM
1999 c $ (icx2,icy2,is2,PFAdef,PFAdef,0.,0.) !(1)
2000 call xyz_PAM
2001 $ (icx2,icy2,is2,PFAdef,PFAdef,0.,0.,0.,0.)
2002 xm2=xPAM
2003 ym2=yPAM
2004 zm2=zPAM
2005
2006 * ---------------------------------------------------
2007 * both couples must have a y-cluster
2008 * (condition necessary when in RECOVER_SINGLETS mode)
2009 * ---------------------------------------------------
2010 if(icy1.eq.0.or.icy2.eq.0)goto 111
2011
2012 if(cl_used(icy1).ne.0)goto 111
2013 if(cl_used(icy2).ne.0)goto 111
2014
2015
2016 * - - - - - - - - - - - - - - - - - - - - - - - - - - - -
2017 * track parameters on Y VIEW
2018 * (2 couples needed)
2019 * - - - - - - - - - - - - - - - - - - - - - - - - - - - -
2020 if(ndblt.eq.ndblt_max)then
2021 if(verbose.eq.1)print*,
2022 $ '** warning ** number of identified '//
2023 $ 'doublets exceeds vector dimention '
2024 $ ,'( ',ndblt_max,' )'
2025 c good2=.false.
2026 c goto 880 !fill ntp and go to next event
2027 do iv=1,12
2028 c mask_view(iv) = 3
2029 mask_view(iv) = mask_view(iv)+ 2**2
2030 enddo
2031 iflag=1
2032 return
2033 endif
2034
2035
2036 ccc print*,'<doublet> ',icp1,icp2
2037
2038 ndblt = ndblt + 1
2039 * store doublet info
2040 cpyz1(ndblt)=id_cp(ip1,icp1,is1)
2041 cpyz2(ndblt)=id_cp(ip2,icp2,is2)
2042 * tg(th_yz)
2043 alfayz2(ndblt)=(ym1-ym2)/(zm1-zm2)
2044 * y0 (cm)
2045 alfayz1(ndblt)=alfayz2(ndblt)*(zini-zm1)+ym1
2046
2047 **** -----------------------------------------------****
2048 **** reject non phisical couples ****
2049 **** -----------------------------------------------****
2050 if(SECOND_SEARCH)goto 111
2051 if(
2052 $ abs(alfayz2(ndblt)).gt.alfyz2_max
2053 $ .or.
2054 $ abs(alfayz1(ndblt)).gt.alfyz1_max
2055 $ )ndblt = ndblt-1
2056
2057
2058 111 continue
2059 * - - - - - - - - - - - - - - - - - - - - - - - - - - - -
2060 * track parameters on Y VIEW - end
2061 * - - - - - - - - - - - - - - - - - - - - - - - - - - - -
2062
2063
2064 if(icx1.ne.0)then
2065 if(cl_used(icx1).ne.0)goto 31
2066 endif
2067 if(icx2.ne.0)then
2068 if(cl_used(icx2).ne.0)goto 31
2069 endif
2070
2071 if(ip2.eq.nplanes)goto 31 !no possible combination with 3 couples
2072
2073 do ip3=(ip2+1),nplanes !loop on planes - COPPIA 3
2074 c$$$ print*,'(3) ip ',ip3
2075 c$$$ $ ,mask_view(nviewx(ip3))
2076 c$$$ $ ,mask_view(nviewy(ip3))
2077 if( mask_view(nviewx(ip3)).ne.0 .or.
2078 $ mask_view(nviewy(ip3)).ne.0 )goto 30 !skip plane
2079 do is3=1,2 !loop on sensors - COPPIA 3
2080
2081 do icp3=1,ncp_plane(ip3) !loop on COPPIA 3
2082 icx3=clx(ip3,icp3)
2083 icy3=cly(ip3,icp3)
2084
2085 c$$$ print*,'(3) ip ',ip3,' icp ',icp3
2086
2087 * ---------------------------------------------------
2088 * all three couples must have a x-cluster
2089 * (condition necessary when in RECOVER_SINGLETS mode)
2090 * ---------------------------------------------------
2091 if(
2092 $ icx1.eq.0.or.
2093 $ icx2.eq.0.or.
2094 $ icx3.eq.0.or.
2095 $ .false.)goto 29
2096
2097 if(cl_used(icx1).ne.0)goto 29
2098 if(cl_used(icx2).ne.0)goto 29
2099 if(cl_used(icx3).ne.0)goto 29
2100
2101 c call xyz_PAM
2102 c $ (icx3,icy3,is3,'COG2','COG2',0.,0.)!(1)
2103 c call xyz_PAM
2104 c $ (icx3,icy3,is3,PFAdef,PFAdef,0.,0.) !(1)
2105 call xyz_PAM
2106 $ (icx3,icy3,is3,PFAdef,PFAdef
2107 $ ,0.,0.,0.,0.)
2108 xm3=xPAM
2109 ym3=yPAM
2110 zm3=zPAM
2111
2112
2113 * find the circle passing through the three points
2114 iflag_t = DEBUG
2115 call tricircle(3,xp,zp,angp,resp,chi
2116 $ ,xc,zc,radius,iflag_t)
2117 * the circle must intersect the reference plane
2118 cc if(iflag.ne.0)goto 29
2119 if(iflag_t.ne.0)then
2120 * if tricircle fails, evaluate a straight line
2121 if(DEBUG.eq.1)
2122 $ print*,'TRICIRCLE failure'
2123 $ ,' >>> straight line'
2124 radius=0.
2125 xc=0.
2126 yc=0.
2127
2128 SZZ=0.
2129 SZX=0.
2130 SSX=0.
2131 SZ=0.
2132 S1=0.
2133 X0=0.
2134 Ax=0.
2135 BX=0.
2136 DO I=1,3
2137 XX = XP(I)
2138 SZZ=SZZ+ZP(I)*ZP(I)
2139 SZX=SZX+ZP(I)*XX
2140 SSX=SSX+XX
2141 SZ=SZ+ZP(I)
2142 S1=S1+1.
2143 ENDDO
2144 DET=SZZ*S1-SZ*SZ
2145 AX=(SZX*S1-SZ*SSX)/DET
2146 BX=(SZZ*SSX-SZX*SZ)/DET
2147 X0 = AX*ZINI+BX
2148
2149 endif
2150
2151 if( .not.SECOND_SEARCH.and.
2152 $ radius**2.lt.(ZINI-zc)**2)goto 29
2153
2154 * - - - - - - - - - - - - - - - - - - - - - - - - - - - -
2155 * track parameters on X VIEW
2156 * (3 couples needed)
2157 * - - - - - - - - - - - - - - - - - - - - - - - - - - - -
2158 if(ntrpt.eq.ntrpt_max)then
2159 if(verbose.eq.1)print*,
2160 $ '** warning **'//
2161 $ ' number of identified '//
2162 $ 'triplets exceeds'//
2163 $ ' vector dimention '
2164 $ ,'( ',ntrpt_max,' )'
2165 c good2=.false.
2166 c goto 880 !fill ntp and go to next event
2167 do iv=1,nviews
2168 c mask_view(iv) = 4
2169 mask_view(iv) =
2170 $ mask_view(iv)+ 2**3
2171 enddo
2172 iflag=1
2173 return
2174 endif
2175
2176 ccc print*,'<triplet> ',icp1,icp2,icp3
2177
2178 ntrpt = ntrpt +1
2179 * store triplet info
2180 cpxz1(ntrpt)=id_cp(ip1,icp1,is1)
2181 cpxz2(ntrpt)=id_cp(ip2,icp2,is2)
2182 cpxz3(ntrpt)=id_cp(ip3,icp3,is3)
2183
2184 if(radius.ne.0.and.xc.lt.0)then
2185 *************POSITIVE DEFLECTION
2186 alfaxz1(ntrpt) = xc+sqrt(radius**2-(ZINI-zc)**2)
2187 alfaxz2(ntrpt) = (ZINI-zc)/sqrt(radius**2-(ZINI-zc)**2)
2188 alfaxz3(ntrpt) = 1/radius
2189 else if(radius.ne.0.and.xc.ge.0)then
2190 *************NEGATIVE DEFLECTION
2191 alfaxz1(ntrpt) = xc-sqrt(radius**2-(ZINI-zc)**2)
2192 alfaxz2(ntrpt) = -(ZINI-zc)/sqrt(radius**2-(ZINI-zc)**2)
2193 alfaxz3(ntrpt) = -1/radius
2194 else if(radius.eq.0)then
2195 *************straight fit
2196 alfaxz1(ntrpt) = X0
2197 alfaxz2(ntrpt) = AX
2198 alfaxz3(ntrpt) = 0.
2199 endif
2200
2201 c$$$ print*,'alfaxz1 ', alfaxz1(ntrpt)
2202 c$$$ print*,'alfaxz2 ', alfaxz2(ntrpt)
2203 c$$$ print*,'alfaxz3 ', alfaxz3(ntrpt)
2204
2205 **** -----------------------------------------------****
2206 **** reject non phisical triplets ****
2207 **** -----------------------------------------------****
2208 if(SECOND_SEARCH)goto 29
2209 if(
2210 $ abs(alfaxz2(ntrpt)).gt.
2211 $ alfxz2_max
2212 $ .or.
2213 $ abs(alfaxz1(ntrpt)).gt.
2214 $ alfxz1_max
2215 $ )ntrpt = ntrpt-1
2216
2217 * - - - - - - - - - - - - - - - - - - - - - - - - - - - -
2218 * track parameters on X VIEW - end
2219 * - - - - - - - - - - - - - - - - - - - - - - - - - - - -
2220
2221 29 continue
2222 enddo !end loop on COPPIA 3
2223 enddo !end loop on sensors - COPPIA 3
2224 30 continue
2225 enddo !end loop on planes - COPPIA 3
2226
2227 31 continue
2228 c 1 enddo !end loop on COPPIA 2
2229 enddo !end loop on COPPIA 2
2230 enddo !end loop on sensors - COPPIA 2
2231 20 continue
2232 enddo !end loop on planes - COPPIA 2
2233
2234 c 11 continue
2235 continue
2236 enddo !end loop on COPPIA1
2237 enddo !end loop on sensors - COPPIA 1
2238 10 continue
2239 enddo !end loop on planes - COPPIA 1
2240
2241 if(DEBUG.EQ.1)then
2242 print*,'--- doublets ',ndblt
2243 print*,'--- triplets ',ntrpt
2244 endif
2245
2246 c goto 880 !ntp fill
2247
2248
2249 return
2250 end
2251
2252
2253
2254 ***************************************************
2255 * *
2256 * *
2257 * *
2258 * *
2259 * *
2260 * *
2261 **************************************************
2262
2263 subroutine doub_to_YZcloud(iflag)
2264
2265 include 'commontracker.f'
2266 include 'level1.f'
2267 include 'common_momanhough.f'
2268 c include 'momanhough_init.f'
2269
2270
2271 * output flag
2272 * --------------
2273 * 0 = good event
2274 * 1 = bad event
2275 * --------------
2276 integer iflag
2277
2278 integer db_used(ndblt_max)
2279 integer db_temp(ndblt_max)
2280 integer db_all(ndblt_max) !stores db ID in each cloud
2281
2282 integer hit_plane(nplanes)
2283
2284 * mask for used couples
2285 integer cp_useds1(ncouplemaxtot) ! sensor 1
2286 integer cp_useds2(ncouplemaxtot) ! sensor 2
2287
2288 if(DEBUG.EQ.1)print*,'doub_to_YZcloud:'
2289
2290 *~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2291 * classification of DOUBLETS
2292 * according to distance in parameter space
2293 * (cloud = group of points (doublets) in parameter space)
2294 *~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2295 do idb=1,ndblt
2296 db_used(idb)=0
2297 enddo
2298
2299 distance=0
2300 nclouds_yz=0 !number of clouds
2301 npt_tot=0
2302 nloop=0
2303 90 continue
2304 do idb1=1,ndblt !loop (1) on DOUBLETS
2305 if(db_used(idb1).eq.1)goto 2228 !db already included in a cloud
2306
2307 do icp=1,ncp_tot
2308 cp_useds1(icp)=0 !init
2309 cp_useds2(icp)=0 !init
2310 enddo
2311 do idb=1,ndblt
2312 db_all(idb)=0
2313 enddo
2314 if(cpyz1(idb1).gt.0)cp_useds2(cpyz1(idb1))=1
2315 if(cpyz1(idb1).lt.0)cp_useds1(-cpyz1(idb1))=1
2316 if(cpyz2(idb1).gt.0)cp_useds2(cpyz2(idb1))=1
2317 if(cpyz2(idb1).lt.0)cp_useds1(-cpyz2(idb1))=1
2318 temp1 = alfayz1(idb1)
2319 temp2 = alfayz2(idb1)
2320 npt=1 !counter of points in the cloud
2321
2322 db_all(npt) = idb1
2323
2324 nptloop=1
2325 db_temp(1)=idb1
2326
2327 88 continue
2328
2329 npv=0 !# new points inlcuded
2330 do iloop=1,nptloop
2331 idbref=db_temp(iloop) !local point of reference
2332 ccccc if(db_used(idbref).eq.1)goto 1188 !next
2333
2334 do idb2=1,ndblt !loop (2) on DOUBLETS
2335 if(idb2.eq.idbref)goto 1118 !next doublet
2336 if(db_used(idb2).eq.1)goto 1118
2337
2338
2339 * doublet distance in parameter space
2340 distance=
2341 $ ((alfayz1(idbref)-alfayz1(idb2))/Dalfayz1)**2
2342 $ +((alfayz2(idbref)-alfayz2(idb2))/Dalfayz2)**2
2343 distance = sqrt(distance)
2344
2345 if(distance.lt.cutdistyz)then
2346
2347 if(cpyz1(idb2).gt.0)cp_useds2(cpyz1(idb2))=1
2348 if(cpyz1(idb2).lt.0)cp_useds1(-cpyz1(idb2))=1
2349 if(cpyz2(idb2).gt.0)cp_useds2(cpyz2(idb2))=1
2350 if(cpyz2(idb2).lt.0)cp_useds1(-cpyz2(idb2))=1
2351 npt = npt + 1 !counter of points in the cloud
2352
2353 npv = npv +1
2354 db_temp(npv) = idb2
2355 db_used(idbref) = 1
2356 db_used(idb2) = 1
2357
2358 db_all(npt) = idb2
2359
2360 temp1 = temp1 + alfayz1(idb2)
2361 temp2 = temp2 + alfayz2(idb2)
2362 endif
2363
2364 1118 continue
2365 enddo !end loop (2) on DOUBLETS
2366
2367 c 1188 continue
2368 continue
2369 enddo !end loop on... bo?
2370
2371 nptloop=npv
2372 if(nptloop.ne.0)goto 88
2373
2374 * ------------------------------------------
2375 * stores the cloud only if
2376 * 1) it includes a minimum number of REAL couples
2377 * 1bis) it inlcudes a minimum number of doublets
2378 * 2) it is not already stored
2379 * ------------------------------------------
2380 do ip=1,nplanes
2381 hit_plane(ip)=0
2382 enddo
2383 ncpused=0
2384 do icp=1,ncp_tot
2385 if(
2386 $ (cp_useds1(icp).ne.0.or.cp_useds2(icp).ne.0).and.
2387 $ .true.)then
2388 ncpused=ncpused+1
2389 ip=ip_cp(icp)
2390 hit_plane(ip)=1
2391 endif
2392 enddo
2393 nplused=0
2394 do ip=1,nplanes
2395 nplused=nplused+ hit_plane(ip)
2396 enddo
2397
2398 if(nplused.lt.nplyz_min)goto 2228 !next doublet
2399
2400 * ~~~~~~~~~~~~~~~~~
2401 * >>> NEW CLOUD <<<
2402
2403 if(nclouds_yz.ge.ncloyz_max)then
2404 if(verbose.eq.1)print*,
2405 $ '** warning ** number of identified '//
2406 $ 'YZ clouds exceeds vector dimention '
2407 $ ,'( ',ncloyz_max,' )'
2408 c good2=.false.
2409 c goto 880 !fill ntp and go to next event
2410 do iv=1,nviews
2411 c mask_view(iv) = 5
2412 mask_view(iv) = mask_view(iv) + 2**4
2413 enddo
2414 iflag=1
2415 return
2416 endif
2417
2418 nclouds_yz = nclouds_yz + 1 !increase counter
2419 alfayz1_av(nclouds_yz) = temp1/npt !store average parameter
2420 alfayz2_av(nclouds_yz) = temp2/npt ! "
2421 do icp=1,ncp_tot
2422 cpcloud_yz(nclouds_yz,icp)=
2423 $ cp_useds1(icp)+2*cp_useds2(icp) !store cp info
2424 enddo
2425 ptcloud_yz(nclouds_yz)=npt
2426 c ptcloud_yz_nt(nclouds_yz)=npt
2427 do ipt=1,npt
2428 db_cloud(npt_tot+ipt) = db_all(ipt)
2429 enddo
2430 npt_tot=npt_tot+npt
2431 if(DEBUG.EQ.1)then
2432 print*,'>>>> cloud ',nclouds_yz,' --- ',npt,' points'
2433 print*,'- alfayz1 ',alfayz1_av(nclouds_yz)
2434 print*,'- alfayz2 ',alfayz2_av(nclouds_yz)
2435 print*,'cp_useds1 ',(cp_useds1(icp),icp=1,ncp_tot)
2436 print*,'cp_useds2 ',(cp_useds2(icp),icp=1,ncp_tot)
2437 print*,'cpcloud_yz '
2438 $ ,(cpcloud_yz(nclouds_yz,icp),icp=1,ncp_tot)
2439 print*,'hit_plane ',(hit_plane(ip),ip=1,nplanes)
2440 endif
2441 * >>> NEW CLOUD <<<
2442 * ~~~~~~~~~~~~~~~~~
2443 2228 continue
2444 enddo !end loop (1) on DOUBLETS
2445
2446
2447 if(nloop.lt.nstepy)then
2448 cutdistyz = cutdistyz+cutystep
2449 nloop = nloop+1
2450 goto 90
2451 endif
2452
2453 if(DEBUG.EQ.1)then
2454 print*,'Y-Z total clouds ',nclouds_yz
2455 endif
2456
2457
2458 return
2459 end
2460
2461
2462
2463
2464
2465 ***************************************************
2466 * *
2467 * *
2468 * *
2469 * *
2470 * *
2471 * *
2472 **************************************************
2473
2474 subroutine trip_to_XZcloud(iflag)
2475
2476 include 'commontracker.f'
2477 include 'level1.f'
2478 include 'common_momanhough.f'
2479 c include 'momanhough_init.f'
2480
2481
2482 * output flag
2483 * --------------
2484 * 0 = good event
2485 * 1 = bad event
2486 * --------------
2487 integer iflag
2488
2489 integer tr_used(ntrpt_max)
2490 integer tr_temp(ntrpt_max)
2491 integer tr_incl(ntrpt_max)
2492 integer tr_all(ntrpt_max) !stores tr ID in each cloud
2493
2494 integer hit_plane(nplanes)
2495
2496 * mask for used couples
2497 integer cp_useds1(ncouplemaxtot) ! sensor 1
2498 integer cp_useds2(ncouplemaxtot) ! sensor 2
2499
2500 if(DEBUG.EQ.1)print*,'trip_to_XZcloud:'
2501
2502 *~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2503 * classification of TRIPLETS
2504 * according to distance in parameter space
2505 *~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2506 do itr=1,ntrpt
2507 tr_used(itr)=0
2508 enddo
2509
2510 distance=0
2511 nclouds_xz=0 !number of clouds
2512 npt_tot=0 !total number of selected triplets
2513 nloop=0
2514 91 continue
2515 do itr1=1,ntrpt !loop (1) on TRIPLETS
2516 if(tr_used(itr1).eq.1)goto 22288 !already included in a cloud
2517
2518 do icp=1,ncp_tot
2519 cp_useds1(icp)=0
2520 cp_useds2(icp)=0
2521 enddo
2522 do itr=1,ntrpt
2523 tr_all(itr)=0 !list of included triplets
2524 enddo
2525 if(cpxz1(itr1).gt.0)cp_useds2(cpxz1(itr1))=1
2526 if(cpxz1(itr1).lt.0)cp_useds1(-cpxz1(itr1))=1
2527 if(cpxz2(itr1).gt.0)cp_useds2(cpxz2(itr1))=1
2528 if(cpxz2(itr1).lt.0)cp_useds1(-cpxz2(itr1))=1
2529 if(cpxz3(itr1).gt.0)cp_useds2(cpxz3(itr1))=1
2530 if(cpxz3(itr1).lt.0)cp_useds1(-cpxz3(itr1))=1
2531 temp1 = alfaxz1(itr1)
2532 temp2 = alfaxz2(itr1)
2533 temp3 = alfaxz3(itr1)
2534 npt=1 !counter of points in the cloud
2535
2536 tr_all(npt) = itr1
2537
2538 nptloop=1
2539 c tr_temp(1)=itr1
2540 tr_incl(1)=itr1
2541
2542 8881 continue
2543
2544 npv=0 !# new points inlcuded
2545 do iloop=1,nptloop
2546 itrref=tr_incl(iloop) !local point of reference
2547 do itr2=1,ntrpt !loop (2) on TRIPLETS
2548 if(itr2.eq.itr1)goto 11188 !next triplet
2549 if(tr_used(itr2).eq.1)goto 11188 !next triplet
2550
2551
2552 * triplet distance in parameter space
2553 * solo i due parametri spaziali per il momemnto
2554 distance=
2555 $ ((alfaxz1(itrref)-alfaxz1(itr2))/Dalfaxz1)**2
2556 $ +((alfaxz2(itrref)-alfaxz2(itr2))/Dalfaxz2)**2
2557 distance = sqrt(distance)
2558
2559
2560 * ------------------------------------------------------------------------
2561 * FORCE INCLUSION OF TRIPLETS COMPOSED BY SAME COUPLES, IGNORING THE IMAGE
2562 * ------------------------------------------------------------------------
2563 * (added in august 2007)
2564 istrimage=0
2565 if(
2566 $ abs(cpxz1(itrref)).eq.abs(cpxz1(itr2)).and.
2567 $ abs(cpxz2(itrref)).eq.abs(cpxz2(itr2)).and.
2568 $ abs(cpxz3(itrref)).eq.abs(cpxz3(itr2)).and.
2569 $ .true.)istrimage=1
2570
2571 if(distance.lt.cutdistxz.or.istrimage.eq.1)then
2572 if(cpxz1(itr2).gt.0)cp_useds2(cpxz1(itr2))=1
2573 if(cpxz1(itr2).lt.0)cp_useds1(-cpxz1(itr2))=1
2574 if(cpxz2(itr2).gt.0)cp_useds2(cpxz2(itr2))=1
2575 if(cpxz2(itr2).lt.0)cp_useds1(-cpxz2(itr2))=1
2576 if(cpxz3(itr2).gt.0)cp_useds2(cpxz3(itr2))=1
2577 if(cpxz3(itr2).lt.0)cp_useds1(-cpxz3(itr2))=1
2578 npt = npt + 1 !counter of points in the cloud
2579
2580 npv = npv +1
2581 tr_temp(npv) = itr2
2582 tr_used(itrref) = 1
2583 tr_used(itr2) = 1
2584
2585 tr_all(npt) = itr2
2586
2587 temp1 = temp1 + alfaxz1(itr2)
2588 temp2 = temp2 + alfaxz2(itr2)
2589 temp3 = temp3 + alfaxz3(itr2)
2590 endif
2591
2592 11188 continue
2593 enddo !end loop (2) on TRIPLETS
2594
2595 c11888 continue
2596 continue
2597 enddo !end loop on... bo?
2598
2599 nptloop=npv
2600 do i=1,npv
2601 tr_incl(i)=tr_temp(i)
2602 enddo
2603 if(nptloop.ne.0)goto 8881
2604
2605 * ------------------------------------------
2606 * stores the cloud only if
2607 * 1) it includes a minimum number of REAL couples
2608 * 1bis)
2609 * 2) it is not already stored
2610 * ------------------------------------------
2611 do ip=1,nplanes
2612 hit_plane(ip)=0
2613 enddo
2614 ncpused=0
2615 do icp=1,ncp_tot
2616 if(
2617 $ (cp_useds1(icp).ne.0.or.cp_useds2(icp).ne.0).and.
2618 $ .true.)then
2619 ncpused=ncpused+1
2620 ip=ip_cp(icp)
2621 hit_plane(ip)=1
2622 endif
2623 enddo
2624 nplused=0
2625 do ip=1,nplanes
2626 nplused=nplused+ hit_plane(ip)
2627 enddo
2628 if(nplused.lt.nplxz_min)goto 22288 !next triplet
2629
2630 * ~~~~~~~~~~~~~~~~~
2631 * >>> NEW CLOUD <<<
2632 if(nclouds_xz.ge.ncloxz_max)then
2633 if(verbose.eq.1)print*,
2634 $ '** warning ** number of identified '//
2635 $ 'XZ clouds exceeds vector dimention '
2636 $ ,'( ',ncloxz_max,' )'
2637 c good2=.false.
2638 c goto 880 !fill ntp and go to next event
2639 do iv=1,nviews
2640 c mask_view(iv) = 6
2641 mask_view(iv) = mask_view(iv) + 2**5
2642 enddo
2643 iflag=1
2644 return
2645 endif
2646 nclouds_xz = nclouds_xz + 1 !increase counter
2647 alfaxz1_av(nclouds_xz) = temp1/npt !store average parameter
2648 alfaxz2_av(nclouds_xz) = temp2/npt ! "
2649 alfaxz3_av(nclouds_xz) = temp3/npt ! "
2650 do icp=1,ncp_tot
2651 cpcloud_xz(nclouds_xz,icp)=
2652 $ cp_useds1(icp)+2*cp_useds2(icp) !store cp info
2653 enddo
2654 ptcloud_xz(nclouds_xz)=npt
2655 do ipt=1,npt
2656 tr_cloud(npt_tot+ipt) = tr_all(ipt)
2657 enddo
2658 npt_tot=npt_tot+npt
2659
2660 if(DEBUG.EQ.1)then
2661 print*,'>>>> cloud ',nclouds_xz,' --- ',npt,' points'
2662 print*,'- alfaxz1 ',alfaxz1_av(nclouds_xz)
2663 print*,'- alfaxz2 ',alfaxz2_av(nclouds_xz)
2664 print*,'- alfaxz3 ',alfaxz3_av(nclouds_xz)
2665 print*,'cp_useds1 ',(cp_useds1(icp),icp=1,ncp_tot)
2666 print*,'cp_useds2 ',(cp_useds2(icp),icp=1,ncp_tot)
2667 print*,'cpcloud_xz '
2668 $ ,(cpcloud_xz(nclouds_xz,icp),icp=1,ncp_tot)
2669 print*,'hit_plane ',(hit_plane(ip),ip=1,nplanes)
2670 endif
2671 * >>> NEW CLOUD <<<
2672 * ~~~~~~~~~~~~~~~~~
2673 22288 continue
2674 enddo !end loop (1) on DOUBLETS
2675
2676 if(nloop.lt.nstepx)then
2677 cutdistxz=cutdistxz+cutxstep
2678 nloop=nloop+1
2679 goto 91
2680 endif
2681
2682 if(DEBUG.EQ.1)then
2683 print*,'X-Z total clouds ',nclouds_xz
2684 endif
2685
2686
2687 return
2688 end
2689
2690
2691 ***************************************************
2692 * *
2693 * *
2694 * *
2695 * *
2696 * *
2697 * *
2698 **************************************************
2699
2700 subroutine clouds_to_ctrack(iflag)
2701
2702 include 'commontracker.f'
2703 include 'level1.f'
2704 include 'common_momanhough.f'
2705 include 'common_xyzPAM.f'
2706 include 'common_mini_2.f'
2707 include 'common_mech.f'
2708
2709
2710
2711 * output flag
2712 * --------------
2713 * 0 = good event
2714 * 1 = bad event
2715 * --------------
2716 integer iflag
2717
2718 * -----------------------------------------------------------
2719 * mask to store (locally) the couples included
2720 * in the intersection bewteen a XZ and YZ cloud
2721 integer cpintersec(ncouplemaxtot)
2722 * -----------------------------------------------------------
2723 * list of matching couples in the combination
2724 * between a XZ and YZ cloud
2725 integer cp_match(nplanes,2*ncouplemax)
2726 integer ncp_match(nplanes)
2727 * -----------------------------------------------------------
2728 integer hit_plane(nplanes)
2729 * -----------------------------------------------------------
2730 * variables for track fitting
2731 double precision AL_INI(5)
2732 * -----------------------------------------------------------
2733
2734 if(DEBUG.EQ.1)print*,'clouds_to_ctrack:'
2735
2736
2737 ntracks=0 !counter of track candidates
2738
2739 do iyz=1,nclouds_yz !loop on YZ clouds
2740 do ixz=1,nclouds_xz !loop on XZ clouds
2741
2742 * --------------------------------------------------
2743 * check of consistency of the clouds
2744 * ---> required a minimum number of matching couples
2745 * the track fit will be performed on the INTERSECTION
2746 * of the two clouds
2747 * --------------------------------------------------
2748 do ip=1,nplanes
2749 hit_plane(ip)=0 !n.matching couples (REAL couples, not SINGLETS)
2750 ncp_match(ip)=0 !n.matching couples per plane
2751 do icpp=1,ncouplemax
2752 cp_match(ip,icpp)=0 !init couple list
2753 enddo
2754 enddo
2755 ncp_ok=0 !count n.matching-couples
2756 ncpx_ok=0 !count n.matching-couples with x cluster
2757 ncpy_ok=0 !count n.matching-couples with y cluster
2758
2759
2760 do icp=1,ncp_tot !loop over couples
2761
2762 if(.not.RECOVER_SINGLETS)then
2763 * ------------------------------------------------------
2764 * if NOT in RECOVER_SINGLETS mode, take the intersection
2765 * between xz yz clouds
2766 * ------------------------------------------------------
2767 cpintersec(icp)=min(
2768 $ cpcloud_yz(iyz,icp),
2769 $ cpcloud_xz(ixz,icp))
2770 * cpintersec is >0 if yz and xz clouds contain the same image of couple icp
2771 * ------------------------------------------------------
2772 * discard the couple if the sensor is in conflict
2773 * ------------------------------------------------------
2774 if(
2775 $ (cpcloud_yz(iyz,icp).eq.1.and.cpcloud_xz(ixz,icp).eq.2).or.
2776 $ (cpcloud_yz(iyz,icp).eq.2.and.cpcloud_xz(ixz,icp).eq.1).or.
2777 $ .false.)cpintersec(icp)=0
2778 else
2779 * ------------------------------------------------------
2780 * if RECOVER_SINGLETS take the union
2781 * (otherwise the fake couples formed by singlets would be
2782 * discarded)
2783 * ------------------------------------------------------
2784 cpintersec(icp)=max(
2785 $ cpcloud_yz(iyz,icp),
2786 $ cpcloud_xz(ixz,icp))
2787 c$$$ if(cpcloud_yz(iyz,icp).gt.0)
2788 c$$$ $ cpintersec(icp)=cpcloud_yz(iyz,icp)
2789 * cpintersec is >0 if either yz or xz cloud contains the couple icp
2790 endif
2791
2792 c$$$ print*,icp,ip_cp(icp),' -- ',cpintersec(icp)
2793
2794 if(cpintersec(icp).ne.0)then
2795
2796 ip=ip_cp(icp)
2797 hit_plane(ip)=1
2798 c$$$ if(clx(ip,icp).gt.0.and.cly(ip,icp).gt.0)
2799 c$$$ $ ncp_ok=ncp_ok+1
2800 c$$$ if(clx(ip,icp).gt.0.and.cly(ip,icp).eq.0)
2801 c$$$ $ ncpx_ok=ncpx_ok+1
2802 c$$$ if(clx(ip,icp).eq.0.and.cly(ip,icp).gt.0)
2803 c$$$ $ ncpy_ok=ncpy_ok+1
2804
2805 if( cpcloud_yz(iyz,icp).gt.0.and.
2806 $ cpcloud_xz(ixz,icp).gt.0)
2807 $ ncp_ok=ncp_ok+1
2808 if( cpcloud_yz(iyz,icp).gt.0.and.
2809 $ cpcloud_xz(ixz,icp).eq.0)
2810 $ ncpy_ok=ncpy_ok+1
2811 if( cpcloud_yz(iyz,icp).eq.0.and.
2812 $ cpcloud_xz(ixz,icp).gt.0)
2813 $ ncpx_ok=ncpx_ok+1
2814
2815 if(cpintersec(icp).eq.1)then
2816 * 1) only the couple image in sensor 1 matches
2817 id=-icp
2818 ncp_match(ip)=ncp_match(ip)+1
2819 cp_match(ip,ncp_match(ip))=id
2820 elseif(cpintersec(icp).eq.2)then
2821 * 2) only the couple image in sensor 2 matches
2822 id=icp
2823 ncp_match(ip)=ncp_match(ip)+1
2824 cp_match(ip,ncp_match(ip))=id
2825 else
2826 * 3) both couple images match
2827 id=icp
2828 do is=1,2
2829 id=-id
2830 ncp_match(ip)=ncp_match(ip)+1
2831 cp_match(ip,ncp_match(ip))=id
2832 enddo
2833 endif
2834 endif !end matching condition
2835 enddo !end loop on couples
2836
2837 nplused=0
2838 do ip=1,nplanes
2839 nplused=nplused+ hit_plane(ip)
2840 enddo
2841
2842 if(nplused.lt.3)goto 888 !next combination
2843 ccc if(nplused.lt.nplxz_min)goto 888 !next combination
2844 ccc if(nplused.lt.nplyz_min)goto 888 !next combination
2845 * -----------------------------------------------------------
2846 * if in RECOVER_SINGLET mode, the two clouds must have
2847 * at least ONE intersecting real couple
2848 * -----------------------------------------------------------
2849 if(ncp_ok.lt.1)goto 888 !next combination
2850
2851 if(DEBUG.EQ.1)then
2852 print*,'////////////////////////////'
2853 print*,'Cloud combination (Y,X): ',iyz,ixz
2854 print*,' db ',ptcloud_yz(iyz)
2855 print*,' tr ',ptcloud_xz(ixz)
2856 print*,' -----> # matching couples ',ncp_ok
2857 print*,' -----> # fake couples (X)',ncpx_ok
2858 print*,' -----> # fake couples (Y)',ncpy_ok
2859 do icp=1,ncp_tot
2860 print*,'cp ',icp,' >'
2861 $ ,' x ',cpcloud_xz(ixz,icp)
2862 $ ,' y ',cpcloud_yz(iyz,icp)
2863 $ ,' ==> ',cpintersec(icp)
2864 enddo
2865 endif
2866
2867 if(DEBUG.EQ.1)then
2868 print*,'1 >>> ',(cp_match(6,i),i=1,ncp_match(6))
2869 print*,'2 >>> ',(cp_match(5,i),i=1,ncp_match(5))
2870 print*,'3 >>> ',(cp_match(4,i),i=1,ncp_match(4))
2871 print*,'4 >>> ',(cp_match(3,i),i=1,ncp_match(3))
2872 print*,'5 >>> ',(cp_match(2,i),i=1,ncp_match(2))
2873 print*,'6 >>> ',(cp_match(1,i),i=1,ncp_match(1))
2874 endif
2875
2876 do icp1=1,max(1,ncp_match(1))
2877 hit_plane(1)=icp1
2878 if(ncp_match(1).eq.0)hit_plane(1)=0 !-icp1
2879
2880 do icp2=1,max(1,ncp_match(2))
2881 hit_plane(2)=icp2
2882 if(ncp_match(2).eq.0)hit_plane(2)=0 !-icp2
2883
2884 do icp3=1,max(1,ncp_match(3))
2885 hit_plane(3)=icp3
2886 if(ncp_match(3).eq.0)hit_plane(3)=0 !-icp3
2887
2888 do icp4=1,max(1,ncp_match(4))
2889 hit_plane(4)=icp4
2890 if(ncp_match(4).eq.0)hit_plane(4)=0 !-icp4
2891
2892 do icp5=1,max(1,ncp_match(5))
2893 hit_plane(5)=icp5
2894 if(ncp_match(5).eq.0)hit_plane(5)=0 !-icp5
2895
2896 do icp6=1,max(1,ncp_match(6))
2897 hit_plane(6)=icp6
2898 if(ncp_match(6).eq.0)hit_plane(6)=0 !-icp6
2899
2900 if(DEBUG.eq.1)
2901 $ print*,'combination: '
2902 $ ,cp_match(6,icp1)
2903 $ ,cp_match(5,icp2)
2904 $ ,cp_match(4,icp3)
2905 $ ,cp_match(3,icp4)
2906 $ ,cp_match(2,icp5)
2907 $ ,cp_match(1,icp6)
2908
2909
2910 * ---------------------------------------
2911 * check if this group of couples has been
2912 * already fitted
2913 * ---------------------------------------
2914 do ica=1,ntracks
2915 isthesame=1
2916 do ip=1,NPLANES
2917 if(hit_plane(ip).ne.0)then
2918 if( CP_STORE(nplanes-ip+1,ica)
2919 $ .ne.
2920 $ cp_match(ip,hit_plane(ip)) )
2921 $ isthesame=0
2922 else
2923 if( CP_STORE(nplanes-ip+1,ica)
2924 $ .ne.
2925 $ 0 )
2926 $ isthesame=0
2927 endif
2928 enddo
2929 if(isthesame.eq.1)then
2930 if(DEBUG.eq.1)
2931 $ print*,'(already fitted)'
2932 goto 666 !jump to next combination
2933 endif
2934 enddo
2935
2936 call track_init !init TRACK common
2937
2938 do ip=1,nplanes !loop on planes (bottom to top)
2939 if(hit_plane(ip).ne.0)then
2940 id=cp_match(ip,hit_plane(ip))
2941 is=is_cp(id)
2942 icp=icp_cp(id)
2943 if(ip_cp(id).ne.ip)
2944 $ print*,'OKKIO!!'
2945 $ ,'id ',id,is,icp
2946 $ ,ip_cp(id),ip
2947 icx=clx(ip,icp)
2948 icy=cly(ip,icp)
2949 * *************************
2950 c call xyz_PAM(icx,icy,is,
2951 c $ 'COG2','COG2',0.,0.)
2952 c call xyz_PAM(icx,icy,is, !(1)
2953 c $ PFAdef,PFAdef,0.,0.) !(1)
2954 call xyz_PAM(icx,icy,is, !(1)
2955 $ PFAdef,PFAdef,0.,0.,0.,0.)
2956 * *************************
2957 * -----------------------------
2958 if(icx.gt.0.and.icy.gt.0)then
2959 xgood(nplanes-ip+1)=1.
2960 ygood(nplanes-ip+1)=1.
2961 xm(nplanes-ip+1)=xPAM
2962 ym(nplanes-ip+1)=yPAM
2963 zm(nplanes-ip+1)=zPAM
2964 resx(nplanes-ip+1)=resxPAM
2965 resy(nplanes-ip+1)=resyPAM
2966 if(DEBUG.EQ.1)print*,'(X,Y)'
2967 $ ,nplanes-ip+1,xPAM,yPAM
2968 else
2969 xm_A(nplanes-ip+1) = xPAM_A
2970 ym_A(nplanes-ip+1) = yPAM_A
2971 xm_B(nplanes-ip+1) = xPAM_B
2972 ym_B(nplanes-ip+1) = yPAM_B
2973 zm(nplanes-ip+1)
2974 $ = (zPAM_A+zPAM_B)/2.
2975 resx(nplanes-ip+1) = resxPAM
2976 resy(nplanes-ip+1) = resyPAM
2977 if(icx.eq.0.and.icy.gt.0)then
2978 xgood(nplanes-ip+1)=0.
2979 ygood(nplanes-ip+1)=1.
2980 resx(nplanes-ip+1) = 1000.
2981 if(DEBUG.EQ.1)print*,'( Y)'
2982 $ ,nplanes-ip+1,xPAM,yPAM
2983 elseif(icx.gt.0.and.icy.eq.0)then
2984 xgood(nplanes-ip+1)=1.
2985 ygood(nplanes-ip+1)=0.
2986 if(DEBUG.EQ.1)print*,'(X )'
2987 $ ,nplanes-ip+1,xPAM,yPAM
2988 resy(nplanes-ip+1) = 1000.
2989 else
2990 print*,'both icx=0 and icy=0'
2991 $ ,' ==> IMPOSSIBLE!!'
2992 endif
2993 endif
2994 * -----------------------------
2995 endif
2996 enddo !end loop on planes
2997 * **********************************************************
2998 * ************************** FIT *** FIT *** FIT *** FIT ***
2999 * **********************************************************
3000 cccc scommentare se si usa al_ini della nuvola
3001 c$$$ do i=1,5
3002 c$$$ AL(i)=AL_INI(i)
3003 c$$$ enddo
3004 call guess()
3005 do i=1,5
3006 AL_INI(i)=AL(i)
3007 enddo
3008 ifail=0 !error flag in chi^2 computation
3009 jstep=0 !number of minimization steps
3010 iprint=0
3011 c if(DEBUG.EQ.1)iprint=1
3012 if(DEBUG.EQ.1)iprint=2
3013 call mini2(jstep,ifail,iprint)
3014 if(ifail.ne.0) then
3015 if(DEBUG.EQ.1)then
3016 print *,
3017 $ '*** MINIMIZATION FAILURE *** '
3018 $ //'(clouds_to_ctrack)'
3019 print*,'initial guess: '
3020
3021 print*,'AL_INI(1) = ',AL_INI(1)
3022 print*,'AL_INI(2) = ',AL_INI(2)
3023 print*,'AL_INI(3) = ',AL_INI(3)
3024 print*,'AL_INI(4) = ',AL_INI(4)
3025 print*,'AL_INI(5) = ',AL_INI(5)
3026 endif
3027 c chi2=-chi2
3028 endif
3029 * **********************************************************
3030 * ************************** FIT *** FIT *** FIT *** FIT ***
3031 * **********************************************************
3032
3033 if(chi2.le.0.)goto 666
3034 if(chi2.ge.1.e08)goto 666 !OPTIMIZATION
3035 if(chi2.ne.chi2)goto 666 !OPTIMIZATION
3036
3037 * --------------------------
3038 * STORE candidate TRACK INFO
3039 * --------------------------
3040 if(ntracks.eq.NTRACKSMAX)then
3041
3042 if(verbose.eq.1)print*,
3043 $ '** warning ** number of candidate tracks '//
3044 $ ' exceeds vector dimension '
3045 $ ,'( ',NTRACKSMAX,' )'
3046 c good2=.false.
3047 c goto 880 !fill ntp and go to next event
3048 do iv=1,nviews
3049 c mask_view(iv) = 7
3050 mask_view(iv) = mask_view(iv) + 2**6
3051 enddo
3052 iflag=1
3053 return
3054 endif
3055
3056 ntracks = ntracks + 1
3057
3058 do ip=1,nplanes !top to bottom
3059
3060 XV_STORE(ip,ntracks)=sngl(xv(ip))
3061 YV_STORE(ip,ntracks)=sngl(yv(ip))
3062 ZV_STORE(ip,ntracks)=sngl(zv(ip))
3063 XM_STORE(ip,ntracks)=sngl(xm(ip))
3064 YM_STORE(ip,ntracks)=sngl(ym(ip))
3065 ZM_STORE(ip,ntracks)=sngl(zm(ip))
3066 RESX_STORE(ip,ntracks)=sngl(resx(ip))
3067 RESY_STORE(ip,ntracks)=sngl(resy(ip))
3068 XV_STORE(ip,ntracks)=sngl(xv(ip))
3069 YV_STORE(ip,ntracks)=sngl(yv(ip))
3070 ZV_STORE(ip,ntracks)=sngl(zv(ip))
3071 AXV_STORE(ip,ntracks)=sngl(axv(ip))
3072 AYV_STORE(ip,ntracks)=sngl(ayv(ip))
3073 XGOOD_STORE(ip,ntracks)=sngl(xgood(ip))
3074 YGOOD_STORE(ip,ntracks)=sngl(ygood(ip))
3075 * NB! hit_plane is defined from bottom to top
3076 if(hit_plane(ip).ne.0)then
3077 CP_STORE(nplanes-ip+1,ntracks)=
3078 $ cp_match(ip,hit_plane(ip))
3079 SENSOR_STORE(nplanes-ip+1,ntracks)
3080 $ = is_cp(cp_match(ip,hit_plane(ip)))
3081
3082 icl=
3083 $ clx(ip,icp_cp(
3084 $ cp_match(ip,hit_plane(ip)
3085 $ )));
3086 if(icl.eq.0)
3087 $ icl=
3088 $ cly(ip,icp_cp(
3089 $ cp_match(ip,hit_plane(ip)
3090 $ )));
3091
3092 LADDER_STORE(nplanes-ip+1,ntracks)
3093 $ = LADDER(icl);
3094 else
3095 CP_STORE(nplanes-ip+1,ntracks)=0
3096 SENSOR_STORE(nplanes-ip+1,ntracks)=0
3097 LADDER_STORE(nplanes-ip+1,ntracks)=0
3098 endif
3099 BX_STORE(ip,ntracks)=0!I dont need it now
3100 BY_STORE(ip,ntracks)=0!I dont need it now
3101 CLS_STORE(ip,ntracks)=0
3102 do i=1,5
3103 AL_STORE(i,ntracks)=sngl(AL(i))
3104 enddo
3105 enddo
3106
3107 RCHI2_STORE(ntracks)=chi2
3108
3109 * --------------------------------
3110 * STORE candidate TRACK INFO - end
3111 * --------------------------------
3112
3113 666 continue
3114 enddo !end loop on cp in plane 6
3115 enddo !end loop on cp in plane 5
3116 enddo !end loop on cp in plane 4
3117 enddo !end loop on cp in plane 3
3118 enddo !end loop on cp in plane 2
3119 enddo !end loop on cp in plane 1
3120
3121 888 continue
3122 enddo !end loop on XZ couds
3123 enddo !end loop on YZ couds
3124
3125 if(ntracks.eq.0)then
3126 iflag=1
3127 cc return
3128 endif
3129
3130 if(DEBUG.EQ.1)then
3131 print*,'****** TRACK CANDIDATES *****************'
3132 print*,'# R. chi2 RIG ndof'
3133 do i=1,ntracks
3134 ndof=0 !(1)
3135 do ii=1,nplanes !(1)
3136 ndof=ndof !(1)
3137 $ +int(xgood_store(ii,i)) !(1)
3138 $ +int(ygood_store(ii,i)) !(1)
3139 enddo !(1)
3140 print*,i,' --- ',rchi2_store(i),' --- '
3141 $ ,1./abs(AL_STORE(5,i)),' --- ',ndof
3142 enddo
3143 print*,'*****************************************'
3144 endif
3145
3146
3147 return
3148 end
3149
3150
3151 ***************************************************
3152 * *
3153 * *
3154 * *
3155 * *
3156 * *
3157 * *
3158 **************************************************
3159
3160 subroutine refine_track(ibest)
3161
3162
3163 include 'commontracker.f'
3164 include 'level1.f'
3165 include 'common_momanhough.f'
3166 include 'common_xyzPAM.f'
3167 include 'common_mini_2.f'
3168 include 'common_mech.f'
3169 include 'calib.f'
3170
3171 * flag to chose PFA
3172 character*10 PFA
3173 common/FINALPFA/PFA
3174
3175 real k(6)
3176 DATA k/1.099730,0.418900,0.220939,0.220907,0.418771,1.100674/
3177
3178 real xp,yp,zp
3179 real xyzp(3),bxyz(3)
3180 equivalence (xp,xyzp(1)),(yp,xyzp(2)),(zp,xyzp(3))
3181
3182 if(DEBUG.EQ.1)print*,'refine_track:'
3183 * =================================================
3184 * new estimate of positions using ETA algorithm
3185 * and
3186 * search for new couples and single clusters to add
3187 * =================================================
3188 call track_init
3189 do ip=1,nplanes !loop on planes
3190
3191 if(DEBUG.EQ.1)print*,' ........... plane ',ip,' ........... '
3192
3193 xP=XV_STORE(nplanes-ip+1,ibest)
3194 yP=YV_STORE(nplanes-ip+1,ibest)
3195 zP=ZV_STORE(nplanes-ip+1,ibest)
3196 call gufld(xyzp,bxyz)
3197 BX_STORE(nplanes-ip+1,ibest)=bxyz(1)
3198 BY_STORE(nplanes-ip+1,ibest)=bxyz(2)
3199 c$$$ bxyz(1)=0
3200 c$$$ bxyz(2)=0
3201 c$$$ bxyz(3)=0
3202 * |||||||||||||||||||||||||||||||||||||||||||||||||
3203 * -------------------------------------------------
3204 * If the plane has been already included, it just
3205 * computes again the coordinates of the x-y couple
3206 * using improved PFAs
3207 * -------------------------------------------------
3208 * |||||||||||||||||||||||||||||||||||||||||||||||||
3209 c$$$ if(XGOOD_STORE(nplanes-ip+1,ibest).eq.1..and.
3210 c$$$ $ YGOOD_STORE(nplanes-ip+1,ibest).eq.1. )then
3211 c$$$
3212 c$$$ id=CP_STORE(nplanes-ip+1,ibest)
3213 c$$$
3214 c$$$ is=is_cp(id)
3215 c$$$ icp=icp_cp(id)
3216 c$$$ if(ip_cp(id).ne.ip)
3217 c$$$ $ print*,'OKKIO!!'
3218 c$$$ $ ,'id ',id,is,icp
3219 c$$$ $ ,ip_cp(id),ip
3220 c$$$ icx=clx(ip,icp)
3221 c$$$ icy=cly(ip,icp)
3222 c$$$c call xyz_PAM(icx,icy,is,
3223 c$$$c $ PFA,PFA,
3224 c$$$c $ AXV_STORE(nplanes-ip+1,ibest),
3225 c$$$c $ AYV_STORE(nplanes-ip+1,ibest))
3226 c$$$ call xyz_PAM(icx,icy,is,
3227 c$$$ $ PFA,PFA,
3228 c$$$ $ AXV_STORE(nplanes-ip+1,ibest),
3229 c$$$ $ AYV_STORE(nplanes-ip+1,ibest),
3230 c$$$ $ bxyz(1),
3231 c$$$ $ bxyz(2)
3232 c$$$ $ )
3233 c$$$
3234 c$$$ xm(nplanes-ip+1) = xPAM
3235 c$$$ ym(nplanes-ip+1) = yPAM
3236 c$$$ zm(nplanes-ip+1) = zPAM
3237 c$$$ xgood(nplanes-ip+1) = 1
3238 c$$$ ygood(nplanes-ip+1) = 1
3239 c$$$ resx(nplanes-ip+1) = resxPAM
3240 c$$$ resy(nplanes-ip+1) = resyPAM
3241 c$$$
3242 c$$$ dedxtrk_x(nplanes-ip+1)=sgnl(icx)/mip(VIEW(icx),LADDER(icx))
3243 c$$$ dedxtrk_y(nplanes-ip+1)=sgnl(icy)/mip(VIEW(icy),LADDER(icy))
3244 if(XGOOD_STORE(nplanes-ip+1,ibest).eq.1..or.
3245 $ YGOOD_STORE(nplanes-ip+1,ibest).eq.1. )then
3246
3247 id=CP_STORE(nplanes-ip+1,ibest)
3248
3249 is=is_cp(id)
3250 icp=icp_cp(id)
3251 if(ip_cp(id).ne.ip)
3252 $ print*,'OKKIO!!'
3253 $ ,'id ',id,is,icp
3254 $ ,ip_cp(id),ip
3255 icx=clx(ip,icp)
3256 icy=cly(ip,icp)
3257 c call xyz_PAM(icx,icy,is,
3258 c $ PFA,PFA,
3259 c $ AXV_STORE(nplanes-ip+1,ibest),
3260 c $ AYV_STORE(nplanes-ip+1,ibest))
3261 call xyz_PAM(icx,icy,is,
3262 $ PFA,PFA,
3263 $ AXV_STORE(nplanes-ip+1,ibest),
3264 $ AYV_STORE(nplanes-ip+1,ibest),
3265 $ bxyz(1),
3266 $ bxyz(2)
3267 $ )
3268
3269 if(icx.gt.0.and.icy.gt.0)then
3270 xm(nplanes-ip+1) = xPAM
3271 ym(nplanes-ip+1) = yPAM
3272 zm(nplanes-ip+1) = zPAM
3273 xm_A(nplanes-ip+1) = 0.
3274 ym_A(nplanes-ip+1) = 0.
3275 xm_B(nplanes-ip+1) = 0.
3276 ym_B(nplanes-ip+1) = 0.
3277 xgood(nplanes-ip+1) = 1
3278 ygood(nplanes-ip+1) = 1
3279 resx(nplanes-ip+1) = resxPAM
3280 resy(nplanes-ip+1) = resyPAM
3281 dedxtrk_x(nplanes-ip+1)=
3282 $ sgnl(icx)/mip(VIEW(icx),LADDER(icx))
3283 dedxtrk_y(nplanes-ip+1)=
3284 $ sgnl(icy)/mip(VIEW(icy),LADDER(icy))
3285 else
3286 xm(nplanes-ip+1) = 0.
3287 ym(nplanes-ip+1) = 0.
3288 zm(nplanes-ip+1) = (zPAM_A+zPAM_B)/2.
3289 xm_A(nplanes-ip+1) = xPAM_A
3290 ym_A(nplanes-ip+1) = yPAM_A
3291 xm_B(nplanes-ip+1) = xPAM_B
3292 ym_B(nplanes-ip+1) = yPAM_B
3293 xgood(nplanes-ip+1) = 0
3294 ygood(nplanes-ip+1) = 0
3295 resx(nplanes-ip+1) = 1000.!resxPAM
3296 resy(nplanes-ip+1) = 1000.!resyPAM
3297 dedxtrk_x(nplanes-ip+1)= 0
3298 dedxtrk_y(nplanes-ip+1)= 0
3299 if(icx.gt.0)then
3300 xgood(nplanes-ip+1) = 1
3301 resx(nplanes-ip+1) = resxPAM
3302 dedxtrk_x(nplanes-ip+1)=
3303 $ sgnl(icx)/mip(VIEW(icx),LADDER(icx))
3304 elseif(icy.gt.0)then
3305 ygood(nplanes-ip+1) = 1
3306 resy(nplanes-ip+1) = resyPAM
3307 dedxtrk_y(nplanes-ip+1)=
3308 $ sgnl(icy)/mip(VIEW(icy),LADDER(icy))
3309 endif
3310 endif
3311
3312 * |||||||||||||||||||||||||||||||||||||||||||||||||
3313 * -------------------------------------------------
3314 * If the plane has NOT been already included,
3315 * it tries to include a COUPLE or a single cluster
3316 * -------------------------------------------------
3317 * |||||||||||||||||||||||||||||||||||||||||||||||||
3318 else
3319
3320 xgood(nplanes-ip+1)=0
3321 ygood(nplanes-ip+1)=0
3322
3323 CP_STORE(nplanes-ip+1,ibest)=0 !re-init
3324 CLS_STORE(nplanes-ip+1,ibest)=0
3325
3326
3327 * --------------------------------------------------------------
3328 * determine which ladder and sensor are intersected by the track
3329 call whichsensor(ip,xP,yP,nldt,ist)
3330 * if the track hit the plane in a dead area, go to the next plane
3331 if(nldt.eq.0.or.ist.eq.0)goto 133
3332
3333 SENSOR_STORE(nplanes-ip+1,IBEST)=ist
3334 LADDER_STORE(nplanes-ip+1,IBEST)=nldt
3335 * --------------------------------------------------------------
3336
3337 if(DEBUG.EQ.1)then
3338 print*,
3339 $ '------ Plane ',ip,' intersected on LADDER ',nldt
3340 $ ,' SENSOR ',ist
3341 print*,
3342 $ '------ coord: ',XP,YP
3343 endif
3344
3345 * ===========================================
3346 * STEP 1 >>>>>>> try to include a new couple
3347 * ===========================================
3348 distmin=100000000.
3349 xmm = 0.
3350 ymm = 0.
3351 zmm = 0.
3352 rxmm = 0.
3353 rymm = 0.
3354 dedxmmx = 0. !(1)
3355 dedxmmy = 0. !(1)
3356 idm = 0 !ID of the closer couple
3357 distance=0.
3358 do icp=1,ncp_plane(ip) !loop on couples on plane icp
3359 icx=clx(ip,icp)
3360 icy=cly(ip,icp)
3361 if(icx.eq.0.or.icy.eq.0)goto 1188!if fake couple, jump to next
3362 if(LADDER(icx).ne.nldt.or. !If the ladder number does not match
3363 c $ cl_used(icx).eq.1.or. !or the X cluster is already used
3364 c $ cl_used(icy).eq.1.or. !or the Y cluster is already used
3365 $ cl_used(icx).ne.0.or. !or the X cluster is already used
3366 $ cl_used(icy).ne.0.or. !or the Y cluster is already used
3367 $ .false.)goto 1188 !then jump to next couple.
3368 *
3369 call xyz_PAM(icx,icy,ist,
3370 $ PFA,PFA,
3371 $ AXV_STORE(nplanes-ip+1,ibest),
3372 $ AYV_STORE(nplanes-ip+1,ibest),
3373 $ bxyz(1),
3374 $ bxyz(2)
3375 $ )
3376
3377 distance = distance_to(XP,YP)
3378 c distance = distance / RCHI2_STORE(ibest)!<<< MS !QUIQUI
3379 id=id_cp(ip,icp,ist)
3380 if(DEBUG.EQ.1)
3381 $ print*,'( couple ',id
3382 $ ,' ) distance ',distance
3383 if(distance.lt.distmin)then
3384 xmm = xPAM
3385 ymm = yPAM
3386 zmm = zPAM
3387 rxmm = resxPAM
3388 rymm = resyPAM
3389 distmin = distance
3390 idm = id
3391 dedxmmx = sgnl(icx)/mip(VIEW(icx),LADDER(icx)) !(1)(2)
3392 dedxmmy = sgnl(icy)/mip(VIEW(icy),LADDER(icy)) !(1)(2)
3393 clincnewc=10*sqrt(rymm**2+rxmm**2
3394 $ +RCHI2_STORE(ibest)*k(ip)*(cov(1,1)+cov(2,2)))
3395 endif
3396 1188 continue
3397 enddo !end loop on couples on plane icp
3398 if(distmin.le.clincnewc)then
3399 * -----------------------------------
3400 xm(nplanes-ip+1) = xmm !<<<
3401 ym(nplanes-ip+1) = ymm !<<<
3402 zm(nplanes-ip+1) = zmm !<<<
3403 xgood(nplanes-ip+1) = 1 !<<<
3404 ygood(nplanes-ip+1) = 1 !<<<
3405 resx(nplanes-ip+1)=rxmm !<<<
3406 resy(nplanes-ip+1)=rymm !<<<
3407 dedxtrk_x(nplanes-ip+1) = dedxmmx !<<<
3408 dedxtrk_y(nplanes-ip+1) = dedxmmy !<<<
3409 * -----------------------------------
3410 CP_STORE(nplanes-ip+1,ibest)=idm
3411 if(DEBUG.EQ.1)print*,'%%%% included couple ',idm
3412 $ ,' (dist.= ',distmin,', cut ',clincnewc,' )'
3413 goto 133 !next plane
3414 endif
3415 * ================================================
3416 * STEP 2 >>>>>>> try to include a single cluster
3417 * either from a couple or single
3418 * ================================================
3419 distmin=1000000.
3420 xmm_A = 0. !---------------------------
3421 ymm_A = 0. ! init variables that
3422 zmm_A = 0. ! define the SINGLET
3423 xmm_B = 0. !
3424 ymm_B = 0. !
3425 zmm_B = 0. !
3426 rxmm = 0. !
3427 rymm = 0. !
3428 dedxmmx = 0. !(1)
3429 dedxmmy = 0. !(1)
3430 iclm=0 !---------------------------
3431 distance=0.
3432
3433 *----- clusters inside couples -------------------------------------
3434 do icp=1,ncp_plane(ip) !loop on cluster inside couples
3435 icx=clx(ip,icp)
3436 icy=cly(ip,icp)
3437 if(icx.eq.0.or.icy.eq.0)goto 11882!if fake couple, jump to next
3438 id=id_cp(ip,icp,ist)
3439 if(LADDER(icx).ne.nldt)goto 11882 !if the ladder number does not match
3440 * !jump to the next couple
3441 *----- try cluster x -----------------------------------------------
3442 c if(cl_used(icx).eq.1)goto 11881 !if the X cluster is already used
3443 if(cl_used(icx).ne.0)goto 11881 !if the X cluster is already used !(3)
3444 * !jump to the Y cluster
3445 c call xyz_PAM(icx,0,ist,
3446 c $ PFA,PFA,
3447 c $ AXV_STORE(nplanes-ip+1,ibest),0.)
3448 call xyz_PAM(icx,0,ist,
3449 $ PFA,PFA,
3450 $ AXV_STORE(nplanes-ip+1,ibest),0.,
3451 $ bxyz(1),
3452 $ bxyz(2)
3453 $ )
3454 distance = distance_to(XP,YP)
3455 c distance = distance / RCHI2_STORE(ibest)!<<< MS !QUIQUI
3456 if(DEBUG.EQ.1)
3457 $ print*,'( cl-X ',icx
3458 $ ,' in cp ',id,' ) distance ',distance
3459 if(distance.lt.distmin)then
3460 xmm_A = xPAM_A
3461 ymm_A = yPAM_A
3462 zmm_A = zPAM_A
3463 xmm_B = xPAM_B
3464 ymm_B = yPAM_B
3465 zmm_B = zPAM_B
3466 rxmm = resxPAM
3467 rymm = resyPAM
3468 distmin = distance
3469 iclm = icx
3470 c dedxmm = sgnl(icx) !(1)
3471 dedxmmx = sgnl(icx)/mip(VIEW(icx),LADDER(icx)) !(1)(2)
3472 dedxmmy = 0. !(1)
3473 endif
3474 11881 continue
3475 *----- try cluster y -----------------------------------------------
3476 c if(cl_used(icy).eq.1)goto 11882 !if the Y cluster is already used
3477 if(cl_used(icy).ne.0)goto 11882 !if the Y cluster is already used !(3)
3478 * !jump to the next couple
3479 c call xyz_PAM(0,icy,ist,
3480 c $ PFA,PFA,
3481 c $ 0.,AYV_STORE(nplanes-ip+1,ibest))
3482 call xyz_PAM(0,icy,ist,
3483 $ PFA,PFA,
3484 $ 0.,AYV_STORE(nplanes-ip+1,ibest),
3485 $ bxyz(1),
3486 $ bxyz(2)
3487 $ )
3488 distance = distance_to(XP,YP)
3489 c distance = distance / RCHI2_STORE(ibest)!<<< MS !QUIQUI
3490 if(DEBUG.EQ.1)
3491 $ print*,'( cl-Y ',icy
3492 $ ,' in cp ',id,' ) distance ',distance
3493 if(distance.lt.distmin)then
3494 xmm_A = xPAM_A
3495 ymm_A = yPAM_A
3496 zmm_A = zPAM_A
3497 xmm_B = xPAM_B
3498 ymm_B = yPAM_B
3499 zmm_B = zPAM_B
3500 rxmm = resxPAM
3501 rymm = resyPAM
3502 distmin = distance
3503 iclm = icy
3504 c dedxmm = sgnl(icy) !(1)
3505 dedxmmx = 0. !(1)
3506 dedxmmy = sgnl(icy)/mip(VIEW(icy),LADDER(icy)) !(1)(2)
3507 endif
3508 11882 continue
3509 enddo !end loop on cluster inside couples
3510 *----- single clusters -----------------------------------------------
3511 do ic=1,ncls(ip) !loop on single clusters
3512 icl=cls(ip,ic)
3513 if(cl_used(icl).ne.0.or. !if the cluster is already used !(3)
3514 $ LADDER(icl).ne.nldt.or. !or the ladder number does not match
3515 $ .false.)goto 18882 !jump to the next singlet
3516 if(mod(VIEW(icl),2).eq.0)then!<---- X view
3517 call xyz_PAM(icl,0,ist,
3518 $ PFA,PFA,
3519 $ AXV_STORE(nplanes-ip+1,ibest),0.,
3520 $ bxyz(1),
3521 $ bxyz(2)
3522 $ )
3523 else !<---- Y view
3524 call xyz_PAM(0,icl,ist,
3525 $ PFA,PFA,
3526 $ 0.,AYV_STORE(nplanes-ip+1,ibest),
3527 $ bxyz(1),
3528 $ bxyz(2)
3529 $ )
3530 endif
3531
3532 distance = distance_to(XP,YP)
3533 c distance = distance / RCHI2_STORE(ibest)!<<< MS !QUIQUI
3534 if(DEBUG.EQ.1)
3535 $ print*,'( cl-s ',icl
3536 $ ,' ) distance ',distance
3537 if(distance.lt.distmin)then
3538 xmm_A = xPAM_A
3539 ymm_A = yPAM_A
3540 zmm_A = zPAM_A
3541 xmm_B = xPAM_B
3542 ymm_B = yPAM_B
3543 zmm_B = zPAM_B
3544 rxmm = resxPAM
3545 rymm = resyPAM
3546 distmin = distance
3547 iclm = icl
3548 if(mod(VIEW(icl),2).eq.0)then !<---- X view
3549 dedxmmx = sgnl(icl)/mip(VIEW(icl),LADDER(icl))
3550 dedxmmy = 0.
3551 else !<---- Y view
3552 dedxmmx = 0.
3553 dedxmmy = sgnl(icl)/mip(VIEW(icl),LADDER(icl))
3554 endif
3555 endif
3556 18882 continue
3557 enddo !end loop on single clusters
3558
3559 if(iclm.ne.0)then
3560 if(mod(VIEW(iclm),2).eq.0)then
3561 clincnew=
3562 $ 20*
3563 $ sqrt(rxmm**2+RCHI2_STORE(ibest)*k(ip)*cov(1,1))
3564 else if(mod(VIEW(iclm),2).ne.0)then
3565 clincnew=
3566 $ 10*
3567 $ sqrt(rymm**2+RCHI2_STORE(ibest)*k(ip)*cov(2,2))
3568 endif
3569
3570 if(distmin.le.clincnew)then
3571
3572 CLS_STORE(nplanes-ip+1,ibest)=iclm !<<<<
3573 * ----------------------------
3574 if(mod(VIEW(iclm),2).eq.0)then
3575 XGOOD(nplanes-ip+1)=1.
3576 resx(nplanes-ip+1)=rxmm
3577 if(DEBUG.EQ.1)
3578 $ print*,'%%%% included X-cl ',iclm
3579 $ ,'( chi^2, ',RCHI2_STORE(ibest)
3580 $ ,', dist.= ',distmin
3581 $ ,', cut ',clincnew,' )'
3582 else
3583 YGOOD(nplanes-ip+1)=1.
3584 resy(nplanes-ip+1)=rymm
3585 if(DEBUG.EQ.1)
3586 $ print*,'%%%% included Y-cl ',iclm
3587 $ ,'( chi^2, ',RCHI2_STORE(ibest)
3588 $ ,', dist.= ', distmin
3589 $ ,', cut ',clincnew,' )'
3590 endif
3591 * ----------------------------
3592 xm_A(nplanes-ip+1) = xmm_A
3593 ym_A(nplanes-ip+1) = ymm_A
3594 xm_B(nplanes-ip+1) = xmm_B
3595 ym_B(nplanes-ip+1) = ymm_B
3596 zm(nplanes-ip+1) = (zmm_A+zmm_B)/2.
3597 dedxtrk_x(nplanes-ip+1) = dedxmmx !<<<
3598 dedxtrk_y(nplanes-ip+1) = dedxmmy !<<<
3599 * ----------------------------
3600 endif
3601 endif
3602 endif
3603 133 continue
3604 enddo !end loop on planes
3605
3606
3607
3608 return
3609 end
3610
3611
3612 ***************************************************
3613 * *
3614 * *
3615 * *
3616 * *
3617 * *
3618 * *
3619 **************************************************
3620 *
3621
3622
3623
3624 * ****************************************************
3625
3626 subroutine init_level2
3627
3628 include 'commontracker.f'
3629 include 'level1.f'
3630 include 'common_momanhough.f'
3631 include 'level2.f'
3632
3633 * ---------------------------------
3634 * variables initialized from level1
3635 * ---------------------------------
3636 do i=1,nviews
3637 good2(i)=good1(i)
3638 do j=1,nva1_view
3639 vkflag(i,j)=1
3640 if(cnnev(i,j).le.0)then
3641 vkflag(i,j)=cnnev(i,j)
3642 endif
3643 enddo
3644 enddo
3645 * ----------------
3646 * level2 variables
3647 * ----------------
3648 NTRK = 0
3649 do it=1,NTRKMAX
3650 IMAGE(IT)=0
3651 CHI2_nt(IT) = -100000.
3652 do ip=1,nplanes
3653 XM_nt(IP,IT) = 0
3654 YM_nt(IP,IT) = 0
3655 ZM_nt(IP,IT) = 0
3656 RESX_nt(IP,IT) = 0
3657 RESY_nt(IP,IT) = 0
3658 TAILX_nt(IP,IT) = 0
3659 TAILY_nt(IP,IT) = 0
3660 XBAD(IP,IT) = 0
3661 YBAD(IP,IT) = 0
3662 XGOOD_nt(IP,IT) = 0
3663 YGOOD_nt(IP,IT) = 0
3664 LS(IP,IT) = 0
3665 DEDX_X(IP,IT) = 0
3666 DEDX_Y(IP,IT) = 0
3667 CLTRX(IP,IT) = 0
3668 CLTRY(IP,IT) = 0
3669 multmaxx(ip,it) = 0
3670 seedx(ip,it) = 0
3671 xpu(ip,it) = 0
3672 multmaxy(ip,it) = 0
3673 seedy(ip,it) = 0
3674 ypu(ip,it) = 0
3675 enddo
3676 do ipa=1,5
3677 AL_nt(IPA,IT) = 0
3678 do ipaa=1,5
3679 coval(ipa,ipaa,IT)=0
3680 enddo
3681 enddo
3682 enddo
3683 nclsx=0
3684 nclsy=0
3685 do ip=1,NSINGMAX
3686 planex(ip)=0
3687 xs(1,ip)=0
3688 xs(2,ip)=0
3689 sgnlxs(ip)=0
3690 planey(ip)=0
3691 ys(1,ip)=0
3692 ys(2,ip)=0
3693 sgnlys(ip)=0
3694 sxbad(ip)=0
3695 sybad(ip)=0
3696 multmaxsx(ip)=0
3697 multmaxsy(ip)=0
3698 enddo
3699 end
3700
3701
3702 ************************************************************
3703 *
3704 *
3705 *
3706 *
3707 *
3708 *
3709 *
3710 ************************************************************
3711
3712
3713 subroutine init_hough
3714
3715 include 'commontracker.f'
3716 include 'level1.f'
3717 include 'common_momanhough.f'
3718 include 'common_hough.f'
3719 include 'level2.f'
3720
3721 ntrpt_nt=0
3722 ndblt_nt=0
3723 NCLOUDS_XZ_nt=0
3724 NCLOUDS_YZ_nt=0
3725 do idb=1,ndblt_max_nt
3726 db_cloud_nt(idb)=0
3727 alfayz1_nt(idb)=0
3728 alfayz2_nt(idb)=0
3729 enddo
3730 do itr=1,ntrpt_max_nt
3731 tr_cloud_nt(itr)=0
3732 alfaxz1_nt(itr)=0
3733 alfaxz2_nt(itr)=0
3734 alfaxz3_nt(itr)=0
3735 enddo
3736 do idb=1,ncloyz_max
3737 ptcloud_yz_nt(idb)=0
3738 alfayz1_av_nt(idb)=0
3739 alfayz2_av_nt(idb)=0
3740 enddo
3741 do itr=1,ncloxz_max
3742 ptcloud_xz_nt(itr)=0
3743 alfaxz1_av_nt(itr)=0
3744 alfaxz2_av_nt(itr)=0
3745 alfaxz3_av_nt(itr)=0
3746 enddo
3747
3748 ntrpt=0
3749 ndblt=0
3750 NCLOUDS_XZ=0
3751 NCLOUDS_YZ=0
3752 do idb=1,ndblt_max
3753 db_cloud(idb)=0
3754 cpyz1(idb)=0
3755 cpyz2(idb)=0
3756 alfayz1(idb)=0
3757 alfayz2(idb)=0
3758 enddo
3759 do itr=1,ntrpt_max
3760 tr_cloud(itr)=0
3761 cpxz1(itr)=0
3762 cpxz2(itr)=0
3763 cpxz3(itr)=0
3764 alfaxz1(itr)=0
3765 alfaxz2(itr)=0
3766 alfaxz3(itr)=0
3767 enddo
3768 do idb=1,ncloyz_max
3769 ptcloud_yz(idb)=0
3770 alfayz1_av(idb)=0
3771 alfayz2_av(idb)=0
3772 do idbb=1,ncouplemaxtot
3773 cpcloud_yz(idb,idbb)=0
3774 enddo
3775 enddo
3776 do itr=1,ncloxz_max
3777 ptcloud_xz(itr)=0
3778 alfaxz1_av(itr)=0
3779 alfaxz2_av(itr)=0
3780 alfaxz3_av(itr)=0
3781 do itrr=1,ncouplemaxtot
3782 cpcloud_xz(itr,itrr)=0
3783 enddo
3784 enddo
3785 end
3786 ************************************************************
3787 *
3788 *
3789 *
3790 *
3791 *
3792 *
3793 *
3794 ************************************************************
3795
3796
3797 subroutine fill_level2_tracks(ntr)
3798
3799 * -------------------------------------------------------
3800 * This routine fills the ntr-th element of the variables
3801 * inside the level2_tracks common, which correspond
3802 * to the ntr-th track info.
3803 * -------------------------------------------------------
3804
3805
3806 include 'commontracker.f'
3807 include 'level1.f'
3808 include 'common_momanhough.f'
3809 include 'level2.f'
3810 include 'common_mini_2.f'
3811 include 'calib.f'
3812
3813 character*10 PFA
3814 common/FINALPFA/PFA
3815
3816 real sinth,phi,pig
3817 integer ssensor,sladder
3818 pig=acos(-1.)
3819
3820
3821
3822 * -------------------------------------
3823 chi2_nt(ntr) = sngl(chi2)
3824 nstep_nt(ntr) = nstep
3825 * -------------------------------------
3826 phi = al(4)
3827 sinth = al(3)
3828 if(sinth.lt.0)then
3829 sinth = -sinth
3830 phi = phi + pig
3831 endif
3832 npig = aint(phi/(2*pig))
3833 phi = phi - npig*2*pig
3834 if(phi.lt.0)
3835 $ phi = phi + 2*pig
3836 al(4) = phi
3837 al(3) = sinth
3838 do i=1,5
3839 al_nt(i,ntr) = sngl(al(i))
3840 do j=1,5
3841 coval(i,j,ntr) = sngl(cov(i,j))
3842 enddo
3843 enddo
3844 * -------------------------------------
3845 do ip=1,nplanes ! loop on planes
3846 xgood_nt(ip,ntr) = int(xgood(ip))
3847 ygood_nt(ip,ntr) = int(ygood(ip))
3848 xm_nt(ip,ntr) = sngl(xm(ip))
3849 ym_nt(ip,ntr) = sngl(ym(ip))
3850 zm_nt(ip,ntr) = sngl(zm(ip))
3851 RESX_nt(IP,ntr) = sngl(resx(ip))
3852 RESY_nt(IP,ntr) = sngl(resy(ip))
3853 TAILX_nt(IP,ntr) = 0.
3854 TAILY_nt(IP,ntr) = 0.
3855 xv_nt(ip,ntr) = sngl(xv(ip))
3856 yv_nt(ip,ntr) = sngl(yv(ip))
3857 zv_nt(ip,ntr) = sngl(zv(ip))
3858 axv_nt(ip,ntr) = sngl(axv(ip))
3859 ayv_nt(ip,ntr) = sngl(ayv(ip))
3860
3861 factor = sqrt(
3862 $ tan( acos(-1.) * sngl(axv(ip)) /180. )**2 +
3863 $ tan( acos(-1.) * sngl(ayv(ip)) /180. )**2 +
3864 $ 1. )
3865
3866 dedx_x(ip,ntr) = sngl(dedxtrk_x(ip)/factor)
3867 dedx_y(ip,ntr) = sngl(dedxtrk_y(ip)/factor)
3868
3869
3870 ccc print*,ip,'dedx >>> ',dedx_x(ip,ntr),dedx_y(ip,ntr)
3871
3872 ax = axv_nt(ip,ntr)
3873 ay = ayv_nt(ip,ntr)
3874 bfx = BX_STORE(ip,IDCAND)
3875 bfy = BY_STORE(ip,IDCAND)
3876 c$$$ if(ip.eq.6) ax = -1. * axv_nt(ip,ntr)
3877 c$$$ if(ip.eq.6) bfy = -1. * BY_STORE(ip,IDCAND)
3878 c$$$ tgtemp = tan(ax*acos(-1.)/180.) + pmuH_h*bfy*0.00001
3879 c$$$ angx = 180.*atan(tgtemp)/acos(-1.)
3880 c$$$ tgtemp = tan(ay*acos(-1.)/180.)+pmuH_e*bfx*0.00001
3881 c$$$ angy = 180.*atan(tgtemp)/acos(-1.)
3882
3883 angx = effectiveangle(ax,2*ip,bfy)
3884 angy = effectiveangle(ay,2*ip-1,bfx)
3885
3886
3887
3888 id = CP_STORE(ip,IDCAND) ! couple id
3889 icl = CLS_STORE(ip,IDCAND)
3890 ssensor = -1
3891 sladder = -1
3892 ssensor = SENSOR_STORE(ip,IDCAND)
3893 sladder = LADDER_STORE(ip,IDCAND)
3894 if(ip.eq.6.and.ssensor.ne.0)ssensor = 3 - ssensor !notazione paolo x align
3895 LS(IP,ntr) = ssensor+10*sladder
3896
3897 c if(id.ne.0)then
3898 CCCCCC(10 novembre 2009) PATCH X NUCLEI
3899 C non ho capito perche', ma durante il ritracciamento dei nuclei
3900 C (quando una traccia viene trovata ma non e' buona) c'e' qualche variabile
3901 C che non viene reinizializzata correttamente e i cluster esclusi
3902 C dal fit risultano ancora inclusi...
3903 C
3904 cltrx(ip,ntr) = 0
3905 cltry(ip,ntr) = 0
3906 if(
3907 $ xgood_nt(ip,ntr).eq.1.and.ygood_nt(ip,ntr).eq.1
3908 $ .and.
3909 $ id.ne.0)then
3910
3911 c >>> is a couple
3912 cltrx(ip,ntr) = clx(nplanes-ip+1,icp_cp(id))
3913 cltry(ip,ntr) = cly(nplanes-ip+1,icp_cp(id))
3914
3915 if(clx(nplanes-ip+1,icp_cp(id)).gt.0)then
3916
3917 cl_used(cltrx(ip,ntr)) = 1 !tag used clusters
3918
3919 xbad(ip,ntr)= nbadstrips(4,clx(nplanes-ip+1,icp_cp(id)))
3920
3921 if(nsatstrips(clx(nplanes-ip+1,icp_cp(id))).gt.0)
3922 $ dedx_x(ip,ntr)=-dedx_x(ip,ntr)
3923
3924 multmaxx(ip,ntr) = maxs(cltrx(ip,ntr))
3925 $ +10000*mult(cltrx(ip,ntr))
3926 seedx(ip,ntr) = clsignal(indmax(cltrx(ip,ntr)))
3927 $ /clsigma(indmax(cltrx(ip,ntr)))
3928 call applypfa(PFA,cltrx(ip,ntr),angx,corr,res)
3929 xpu(ip,ntr) = corr
3930
3931 endif
3932 if(cly(nplanes-ip+1,icp_cp(id)).gt.0)then
3933
3934 cl_used(cltry(ip,ntr)) = 1 !tag used clusters
3935
3936 ybad(ip,ntr)= nbadstrips(4,cly(nplanes-ip+1,icp_cp(id)))
3937
3938 if(nsatstrips(cly(nplanes-ip+1,icp_cp(id))).gt.0)
3939 $ dedx_y(ip,ntr)=-dedx_y(ip,ntr)
3940
3941 multmaxy(ip,ntr) = maxs(cltry(ip,ntr))
3942 $ +10000*mult(cltry(ip,ntr))
3943 seedy(ip,ntr) = clsignal(indmax(cltry(ip,ntr)))
3944 $ /clsigma(indmax(cltry(ip,ntr)))
3945 call applypfa(PFA,cltry(ip,ntr),angy,corr,res)
3946 ypu(ip,ntr) = corr
3947 endif
3948
3949 elseif(icl.ne.0)then
3950
3951 cl_used(icl) = 1 !tag used clusters
3952
3953 if(mod(VIEW(icl),2).eq.0)then
3954 cltrx(ip,ntr)=icl
3955 xbad(ip,ntr) = nbadstrips(4,icl)
3956
3957 if(nsatstrips(icl).gt.0)dedx_x(ip,ntr)=-dedx_x(ip,ntr)
3958
3959 multmaxx(ip,ntr) = maxs(cltrx(ip,ntr))
3960 $ +10000*mult(cltrx(ip,ntr))
3961 seedx(ip,ntr) = clsignal(indmax(cltrx(ip,ntr)))
3962 $ /clsigma(indmax(cltrx(ip,ntr)))
3963 call applypfa(PFA,cltrx(ip,ntr),angx,corr,res)
3964 xpu(ip,ntr) = corr
3965
3966 elseif(mod(VIEW(icl),2).eq.1)then
3967 cltry(ip,ntr)=icl
3968 ybad(ip,ntr) = nbadstrips(4,icl)
3969
3970 if(nsatstrips(icl).gt.0)dedx_y(ip,ntr)=-dedx_y(ip,ntr)
3971
3972 multmaxy(ip,ntr) = maxs(cltry(ip,ntr))
3973 $ +10000*mult(cltry(ip,ntr))
3974 seedy(ip,ntr) = clsignal(indmax(cltry(ip,ntr)))
3975 $ /clsigma(indmax(cltry(ip,ntr)))
3976 call applypfa(PFA,cltry(ip,ntr),angy,corr,res)
3977 ypu(ip,ntr) = corr
3978
3979 endif
3980
3981 endif
3982
3983 enddo
3984
3985 if(DEBUG.eq.1)then
3986 print*,'> STORING TRACK ',ntr
3987 print*,'clusters: '
3988 do ip=1,6
3989 print*,'> ',ip,' -- ',cltrx(ip,ntr),cltry(ip,ntr)
3990 enddo
3991 print*,'dedx: '
3992 do ip=1,6
3993 print*,'> ',ip,' -- ',dedx_x(ip,ntr),dedx_y(ip,ntr)
3994 enddo
3995 endif
3996
3997 end
3998
3999 subroutine fill_level2_siglets
4000
4001 * -------------------------------------------------------
4002 * This routine fills the elements of the variables
4003 * inside the level2_singletsx and level2_singletsy commons,
4004 * which store info on clusters outside the tracks
4005 * -------------------------------------------------------
4006
4007 include 'commontracker.f'
4008 include 'calib.f'
4009 include 'level1.f'
4010 include 'common_momanhough.f'
4011 include 'level2.f'
4012 include 'common_xyzPAM.f'
4013
4014 * count #cluster per plane not associated to any track
4015 nclsx = 0
4016 nclsy = 0
4017
4018 do iv = 1,nviews
4019 c if( mask_view(iv).ne.0 )good2(iv) = 20+mask_view(iv)
4020 good2(iv) = good2(iv) + mask_view(iv)*2**8
4021 enddo
4022
4023 if(DEBUG.eq.1)then
4024 print*,'> STORING SINGLETS '
4025 endif
4026
4027 do icl=1,nclstr1
4028
4029 ip=nplanes-npl(VIEW(icl))+1
4030
4031 if(cl_used(icl).eq.0)then !cluster not included in any track
4032
4033 if(mod(VIEW(icl),2).eq.0)then !=== X views
4034
4035 nclsx = nclsx + 1
4036 planex(nclsx) = ip
4037 sgnlxs(nclsx) = sgnl(icl)/mip(VIEW(icl),LADDER(icl))
4038 if(nsatstrips(icl).gt.0)sgnlxs(nclsx)=-sgnlxs(nclsx)
4039 clsx(nclsx) = icl
4040 sxbad(nclsx) = nbadstrips(1,icl)
4041 multmaxsx(nclsx) = maxs(icl)+10000*mult(icl)
4042
4043
4044 do is=1,2
4045 c call xyz_PAM(icl,0,is,'COG1',' ',0.,0.)
4046 c call xyz_PAM(icl,0,is,PFAdef,' ',0.,0.)
4047 call xyz_PAM(icl,0,is,PFAdef,' ',0.,0.,0.,0.)
4048 xs(is,nclsx) = (xPAM_A+xPAM_B)/2
4049 enddo
4050 else !=== Y views
4051 nclsy = nclsy + 1
4052 planey(nclsy) = ip
4053 sgnlys(nclsy) = sgnl(icl)/mip(VIEW(icl),LADDER(icl))
4054 if(nsatstrips(icl).gt.0)sgnlys(nclsy)=-sgnlys(nclsy)
4055 clsy(nclsy) = icl
4056 sybad(nclsy) = nbadstrips(1,icl)
4057 multmaxsy(nclsy) = maxs(icl)+10000*mult(icl)
4058
4059
4060 do is=1,2
4061 c call xyz_PAM(0,icl,is,' ','COG1',0.,0.)
4062 c call xyz_PAM(0,icl,is,' ',PFAdef,0.,0.)
4063 call xyz_PAM(0,icl,is,' ',PFAdef,0.,0.,0.,0.)
4064 ys(is,nclsy) = (yPAM_A+yPAM_B)/2
4065 enddo
4066 endif
4067 endif
4068
4069 ***** LO METTO QUI PERCHE` NON SO DOVE METTERLO
4070 whichtrack(icl) = cl_used(icl)
4071 * --------------------------------------------------
4072 * per non perdere la testa...
4073 * whichtrack(icl) e` una variabile del common level1
4074 * che serve solo per sapere quali cluster sono stati
4075 * associati ad una traccia, e permettere di salvare
4076 * solo questi nell'albero di uscita
4077 * --------------------------------------------------
4078
4079 enddo
4080 end
4081
4082 ***************************************************
4083 * *
4084 * *
4085 * *
4086 * *
4087 * *
4088 * *
4089 **************************************************
4090
4091 subroutine fill_hough
4092
4093 * -------------------------------------------------------
4094 * This routine fills the variables related to the hough
4095 * transform, for the debig n-tuple
4096 * -------------------------------------------------------
4097
4098 include 'commontracker.f'
4099 include 'level1.f'
4100 include 'common_momanhough.f'
4101 include 'common_hough.f'
4102 include 'level2.f'
4103
4104 if(.false.
4105 $ .or.ntrpt.gt.ntrpt_max_nt
4106 $ .or.ndblt.gt.ndblt_max_nt
4107 $ .or.NCLOUDS_XZ.gt.ncloxz_max
4108 $ .or.NCLOUDS_yZ.gt.ncloyz_max
4109 $ )then
4110 ntrpt_nt=0
4111 ndblt_nt=0
4112 NCLOUDS_XZ_nt=0
4113 NCLOUDS_YZ_nt=0
4114 else
4115 ndblt_nt=ndblt
4116 ntrpt_nt=ntrpt
4117 if(ndblt.ne.0)then
4118 do id=1,ndblt
4119 alfayz1_nt(id)=alfayz1(id) !Y0
4120 alfayz2_nt(id)=alfayz2(id) !tg theta-yz
4121 enddo
4122 endif
4123 if(ndblt.ne.0)then
4124 do it=1,ntrpt
4125 alfaxz1_nt(it)=alfaxz1(it) !X0
4126 alfaxz2_nt(it)=alfaxz2(it) !tg theta-xz
4127 alfaxz3_nt(it)=alfaxz3(it) !1/r
4128 enddo
4129 endif
4130 nclouds_yz_nt=nclouds_yz
4131 nclouds_xz_nt=nclouds_xz
4132 if(nclouds_yz.ne.0)then
4133 nnn=0
4134 do iyz=1,nclouds_yz
4135 ptcloud_yz_nt(iyz)=ptcloud_yz(iyz)
4136 alfayz1_av_nt(iyz)=alfayz1_av(iyz)
4137 alfayz2_av_nt(iyz)=alfayz2_av(iyz)
4138 nnn=nnn+ptcloud_yz(iyz)
4139 enddo
4140 do ipt=1,min(ndblt_max_nt,nnn)
4141 db_cloud_nt(ipt)=db_cloud(ipt)
4142 enddo
4143 endif
4144 if(nclouds_xz.ne.0)then
4145 nnn=0
4146 do ixz=1,nclouds_xz
4147 ptcloud_xz_nt(ixz)=ptcloud_xz(ixz)
4148 alfaxz1_av_nt(ixz)=alfaxz1_av(ixz)
4149 alfaxz2_av_nt(ixz)=alfaxz2_av(ixz)
4150 alfaxz3_av_nt(ixz)=alfaxz3_av(ixz)
4151 nnn=nnn+ptcloud_xz(ixz)
4152 enddo
4153 do ipt=1,min(ntrpt_max_nt,nnn)
4154 tr_cloud_nt(ipt)=tr_cloud(ipt)
4155 enddo
4156 endif
4157 endif
4158 end
4159

  ViewVC Help
Powered by ViewVC 1.1.23