/[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.34 - (show annotations) (download)
Wed Mar 5 17:00:20 2008 UTC (16 years, 10 months ago) by pam-fi
Branch: MAIN
CVS Tags: v5r00
Changes since 1.33: +21 -2 lines
modified TrkSinglet, optimized DoTrack2, fixed bug in evaluation of effective angle

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

  ViewVC Help
Powered by ViewVC 1.1.23