/[PAMELA software]/DarthVader/ToFLevel2/src/tofl2com.for
ViewVC logotype

Diff of /DarthVader/ToFLevel2/src/tofl2com.for

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.6 by mocchiut, Mon Apr 30 15:46:30 2007 UTC revision 1.8 by pam-de, Mon Mar 31 19:24:04 2008 UTC
# Line 1  Line 1 
1    
2  ******************************************************************************  C******************************************************************************
3  *  C
4  *  08-12-06 WM: adc_c-bug :  The raw ADc value was multiplied with cos(theta)  C  08-12-06 WM: adc_c-bug :  The raw ADc value was multiplied with cos(theta)
5  *  and AFTER that there was an if statement "if tof32(right,i,iadc) < 4095"  C  and AFTER that there was an if statement "if tof32(right,i,iadc) < 4095"
6  *  C
7  *  jan-07 GF: ADCflags(4,12) inserted to flag artificial ADC values  C  jan-07 GF: ADCflags(4,12) inserted to flag artificial ADC values
8  *  jan-07 WM: artificial ADC values created using attenuation calibration  C  jan-07 WM: artificial ADC values created using attenuation calibration
9  *  jan-07 WM: modified xtofpos flag "101". xtofpos must be inside physical  C  jan-07 WM: modified xtofpos flag "101". xtofpos must be inside physical
10  *             dimension of the paddle +/- 10 cm  C             dimension of the paddle +/- 10 cm
11  *  jan-07 WM: if xtofpos=101 then this paddle is not used for beta  C  jan-07 WM: if xtofpos=101 then this paddle is not used for beta
12  *             calculation  C             calculation
13  *  jan-07 WM: the definition for a "hit" is changed: Now we must have a  C  jan-07 WM: the definition for a "hit" is changed: Now we must have a
14  *             valid TDC signal on both sides  C             valid TDC signal on both sides
15  *  jan-07 WM: flag for PMTs #10 and #35 added, TDC=819 due to bit-shift  C  jan-07 WM: flag for PMTs #10 and #35 added, TDC=819 due to bit-shift
16  *  jan-07 WM: bug removed: in some cases tdc_tw was calculated due to a  C  jan-07 WM: bug removed: in some cases tdc_tw was calculated due to a
17  *             leftover "xhelp" value  C             leftover "xhelp" value
18  *  apr-07 WM: attenuation fit curve is now a double exponential fit  C  apr-07 WM: attenuation fit curve is now a double exponential fit
19  *             conversion from raw ADC to pC using calibration function  C             conversion from raw ADC to pC using calibration function
20  *             variables xtr_tof and ytr_tof inserted (filled with default)  C             variables xtr_tof and ytr_tof inserted (filled with default)
21  ******************************************************************************  C  jan-08 WM: Major Update: Time Walk correction introduced
22    C             Additionalyl we use the information from the "check_charge"
23    C             function to fill artificial ADC values and make small corrections
24    C             to the k1-parameter (for Z>2)
25    C  feb-08 WM: Calculation of beta(13) changed: First a mean beta is calculated,
26    C             then in a second step we check the residuals of the single
27    C             measurements, reject if > 10 sigma, calculate chi2 and "quality"
28    C             beta is taken as good if chi2<20 and quality>10
29    C  mar-08 WM: Call to "newbeta" changed, now a flag tells the function if the
30    C             call comes from "tofl2com" or form "toftrack"
31    C  mar-08 WM: Bug found in dEdx if check_charge>1
32    C******************************************************************************
33    
34        INTEGER FUNCTION TOFL2COM()        INTEGER FUNCTION TOFL2COM()
35  c      c    
# Line 34  C     Line 45  C    
45        LOGICAL check        LOGICAL check
46        REAL secure        REAL secure
47    
48        INTEGER j        INTEGER j,hitvec(6)
       REAL xhelp_a,xhelp_t  
49    
50        REAL dx,dy,dr,ds        REAL dx,dy,dr,ds
51        REAL yhelp,xhelp,xhelp1,xhelp2        REAL yhelp,xhelp,xhelp1,xhelp2
52        REAL c1,c2,sw,sxw,w_i        REAL c1,c2
       INTEGER icount  
53    
54  c      REAL xdummy  C      REAL sw,sxw,w_i
55    C      INTEGER icount
56    C      REAL beta_mean
57    
58        INTEGER tof11_j,tof21_j,tof31_j        INTEGER tof11_j,tof21_j,tof31_j
59        INTEGER tof12_j,tof22_j,tof32_j        INTEGER tof12_j,tof22_j,tof32_j
60    
       REAL beta_mean  
   
   
61  c     value for status of each PM-data  c     value for status of each PM-data
62  c     first index  : 1 = left, 2 = right  c     first index  : 1 = left, 2 = right
63  c     second index : 1... number of paddle  c     second index : 1... number of paddle
# Line 57  c     second index : 1... number of padd Line 65  c     second index : 1... number of padd
65        INTEGER tof21_event(2,2),tof22_event(2,2)        INTEGER tof21_event(2,2),tof22_event(2,2)
66        INTEGER tof31_event(2,3),tof32_event(2,3)        INTEGER tof31_event(2,3),tof32_event(2,3)
67    
68    
69          REAL y_coor_lin11c(8,2),x_coor_lin12c(6,2)
70          REAL x_coor_lin21c(2,2),y_coor_lin22c(2,2)
71          REAL y_coor_lin31c(3,2),x_coor_lin32c(3,2)
72    
73          DATA y_coor_lin11c(1,1),y_coor_lin11c(1,2) /-20.66,-2.497/
74          DATA y_coor_lin11c(2,1),y_coor_lin11c(2,2) /-9.10, -2.52/
75          DATA y_coor_lin11c(3,1),y_coor_lin11c(3,2) /-24.07,-2.12/
76          DATA y_coor_lin11c(4,1),y_coor_lin11c(4,2) /-13.40,-2.47/
77          DATA y_coor_lin11c(5,1),y_coor_lin11c(5,2) /-31.07,-2.32/
78          DATA y_coor_lin11c(6,1),y_coor_lin11c(6,2) /-21.69,-2.63/
79          DATA y_coor_lin11c(7,1),y_coor_lin11c(7,2) /-12.37,-2.65/
80          DATA y_coor_lin11c(8,1),y_coor_lin11c(8,2) /-10.81,-3.15/
81    
82          DATA x_coor_lin12c(1,1),x_coor_lin12c(1,2) /12.96, -2.65/
83          DATA x_coor_lin12c(2,1),x_coor_lin12c(2,2) /17.12,-2.44/
84          DATA x_coor_lin12c(3,1),x_coor_lin12c(3,2) /7.26, -1.98/
85          DATA x_coor_lin12c(4,1),x_coor_lin12c(4,2) /-22.52,-2.27/
86          DATA x_coor_lin12c(5,1),x_coor_lin12c(5,2) /-18.54,-2.28/
87          DATA x_coor_lin12c(6,1),x_coor_lin12c(6,2) /-7.67,-2.15/
88    
89          DATA x_coor_lin21c(1,1),x_coor_lin21c(1,2) /22.56,-1.56/
90          DATA x_coor_lin21c(2,1),x_coor_lin21c(2,2) /13.94,-1.56/
91    
92          DATA y_coor_lin22c(1,1),y_coor_lin22c(1,2) /-24.24,-2.23/
93          DATA y_coor_lin22c(2,1),y_coor_lin22c(2,2) /-45.99,-1.68/
94    
95          DATA y_coor_lin31c(1,1),y_coor_lin31c(1,2) /-22.99,-3.54/
96          DATA y_coor_lin31c(2,1),y_coor_lin31c(2,2) /-42.28,-4.10/
97          DATA y_coor_lin31c(3,1),y_coor_lin31c(3,2) /-41.29,-3.69/
98    
99          DATA x_coor_lin32c(1,1),x_coor_lin32c(1,2) /0.961, -3.22/
100          DATA x_coor_lin32c(2,1),x_coor_lin32c(2,2) /4.98,-3.48/
101          DATA x_coor_lin32c(3,1),x_coor_lin32c(3,2) /-22.08,-3.37/
102    
103                
104        REAL theta13        REAL theta13
105  C--   DATA ZTOF/53.74,53.04,23.94,23.44,-23.49,-24.34/ !Sergio 9.05.2006  C--   DATA ZTOF/53.74,53.04,23.94,23.44,-23.49,-24.34/ !Sergio 9.05.2006
# Line 70  C--   DATA ZTOF/53.74,53.04,23.94,23.44, Line 113  C--   DATA ZTOF/53.74,53.04,23.94,23.44,
113        REAL hepratio              REAL hepratio      
114    
115        INTEGER ihelp        INTEGER ihelp
116        REAL xkorr        REAL xkorr,btemp(12)
117    
118          REAL atten,pc_adc,check_charge,newbeta
119    
120          INTEGER IZ
121          REAL k1corrA1,k1corrB1,k1corrC1
122    
123        real atten,pc_adc  
124          INTEGER ifst
125          DATA  ifst /0/
126    
127  C---------------------------------------  C---------------------------------------
128  C      C    
# Line 82  C     Line 132  C    
132  C      C    
133  C     CALCULATE COMMON VARIABLES  C     CALCULATE COMMON VARIABLES
134  C      C    
135    C-------------------------------------------------------------------
136    
137  *******************************************************************          if (ifst.eq.0) then
       icounter = icounter + 1  
138    
139  *     amplitude has to be 'secure' higher than pedestal for an adc event          ifst=1
140        secure = 2.  
141    C     amplitude has to be 'secure' higher than pedestal for an adc event
142           secure = 2.
143    
144  C     ratio between helium and proton ca. 4  C     ratio between helium and proton ca. 4
145        hepratio = 4.  !         hepratio = 4.  !
146        offset = 1         offset = 1
147        slope = 2         slope = 2
148        left = 1         left = 1
149        right = 2         right = 2
150        none_ev = 0         none_ev = 0
151        none_find = 0         none_find = 0
152        tdc_ev = 1         tdc_ev = 1
153        adc_ev = 1         adc_ev = 1
154        itdc = 1         itdc = 1
155        iadc = 2         iadc = 2
156    
157    C--- These are the corrections to the k1-value for Z>2 particles
158           k1corrA1 = 0.
159           k1corrB1 = -5.0
160           k1corrC1=  8.0
161    
162    
163            ENDIF
164    C---------------------------------------------------------------------
165    
166          icounter = icounter + 1
167    
168    
169        do i=1,13        do i=1,13
170           betatof_a(i) = 100.          ! As in "troftrk.for"           betatof_a(i) = 100.          ! As in "troftrk.for"
171        enddo        enddo
172    
173          do i=1,6
174             hitvec(i) = -1
175          enddo
176    
177        do i=1,4        do i=1,4
178           do j=1,12           do j=1,12
179              adctof_c(i,j) = 1000.              adctof_c(i,j) = 1000.
# Line 151  C---  since this is standalone ToF fill Line 219  C---  since this is standalone ToF fill
219    
220  c the calibration files are read in the main program from xxx_tofcalib.rz  c the calibration files are read in the main program from xxx_tofcalib.rz
221    
   
222  c-------------------------get ToF data --------------------------------  c-------------------------get ToF data --------------------------------
223    
224  c     put the adc and tdc values from ntuple into tofxx(i,j,k) variables  c     put the adc and tdc values from ntuple into tofxx(i,j,k) variables
# Line 483  c     check if an other paddle has also Line 550  c     check if an other paddle has also
550                 ENDIF                 ENDIF
551              ENDIF              ENDIF
552           ENDIF           ENDIF
553        ENDDO         ENDDO
554    
555        do i=1,6         do i=1,6
556           tof_i_flag(i)=0           tof_i_flag(i)=0
557           tof_j_flag(i)=0           tof_j_flag(i)=0
558        enddo         enddo
559    
560           tof_i_flag(1)=tof11_i
561           tof_i_flag(2)=tof12_i
562           tof_i_flag(3)=tof21_i
563           tof_i_flag(4)=tof22_i
564           tof_i_flag(5)=tof31_i
565           tof_i_flag(6)=tof32_i
566    
567           tof_j_flag(1)=tof11_j
568           tof_j_flag(2)=tof12_j
569           tof_j_flag(3)=tof21_j
570           tof_j_flag(4)=tof22_j
571           tof_j_flag(5)=tof31_j
572           tof_j_flag(6)=tof32_j
573    
574           hitvec(1)=tof11_i
575           hitvec(2)=tof12_i
576           hitvec(3)=tof21_i
577           hitvec(4)=tof22_i
578           hitvec(5)=tof31_i
579           hitvec(6)=tof32_i
580    
581        tof_i_flag(1)=tof11_i  c       write(*,*) 'tofl2com',
582        tof_i_flag(2)=tof12_i  c     &   tof11_i,tof12_i,tof21_i,tof22_i,tof31_i,tof32_i
       tof_i_flag(3)=tof21_i  
       tof_i_flag(4)=tof22_i  
       tof_i_flag(5)=tof31_i  
       tof_i_flag(6)=tof32_i  
   
       tof_j_flag(1)=tof11_j  
       tof_j_flag(2)=tof12_j  
       tof_j_flag(3)=tof21_j  
       tof_j_flag(4)=tof22_j  
       tof_j_flag(5)=tof31_j  
       tof_j_flag(6)=tof32_j  
583    
           
584  C------------------------------------------------------------------  C------------------------------------------------------------------
585  C---  calculate track position in paddle using timing difference  C--  calculate track position in paddle using timing difference
586    C--  this calculation is preliminary and uses some standard
587    C--  calibration values, but we need to find a rough position to
588    C--  be able to calculate artificial ADC values (needed for the
589    C--  timewalk...
590  C------------------------------------------------------------------  C------------------------------------------------------------------
591    
592        do i=1,3         do i=1,3
593           xtofpos(i)=100.           xtofpos(i)=100.
594           ytofpos(i)=100.           ytofpos(i)=100.
595        enddo         enddo
596    
597  C-----------------------------S1 --------------------------------  C-----------------------------S1 --------------------------------
598    
599        IF (tof11_i.GT.none_find) THEN        IF (tof11_i.GT.none_find) THEN
600           ytofpos(1)  = ((tof11(1,tof11_i,itdc)-tof11(2,tof11_i,itdc))/2.           ytofpos(1)  = ((tof11(1,tof11_i,itdc)-tof11(2,tof11_i,itdc))/2.
601       +        -y_coor_lin11(tof11_i,offset))/y_coor_lin11(tof11_i,slope)       +   -y_coor_lin11c(tof11_i,offset))/y_coor_lin11c(tof11_i,slope)
602        endif        endif
603    
604        IF (tof12_i.GT.none_find) THEN        IF (tof12_i.GT.none_find) THEN
605           xtofpos(1)  = ((tof12(1,tof12_i,itdc)-tof12(2,tof12_i,itdc))/2.           xtofpos(1)  = ((tof12(1,tof12_i,itdc)-tof12(2,tof12_i,itdc))/2.
606       +        -x_coor_lin12(tof12_i,offset))/x_coor_lin12(tof12_i,slope)       +   -x_coor_lin12c(tof12_i,offset))/x_coor_lin12c(tof12_i,slope)
607        endif        endif
608    
609    
# Line 530  C-----------------------------S2 ------- Line 611  C-----------------------------S2 -------
611    
612        IF (tof21_i.GT.none_find) THEN        IF (tof21_i.GT.none_find) THEN
613           xtofpos(2) = ((tof21(1,tof21_i,itdc)-tof21(2,tof21_i,itdc))/2.           xtofpos(2) = ((tof21(1,tof21_i,itdc)-tof21(2,tof21_i,itdc))/2.
614       +        -x_coor_lin21(tof21_i,offset))/x_coor_lin21(tof21_i,slope)       +    -x_coor_lin21c(tof21_i,offset))/x_coor_lin21c(tof21_i,slope)
615        endif        endif
616    
617        IF (tof22_i.GT.none_find) THEN        IF (tof22_i.GT.none_find) THEN
618           ytofpos(2) = ((tof22(1,tof22_i,itdc)-tof22(2,tof22_i,itdc))/2.           ytofpos(2) = ((tof22(1,tof22_i,itdc)-tof22(2,tof22_i,itdc))/2.
619       +        -y_coor_lin22(tof22_i,offset))/y_coor_lin22(tof22_i,slope)       +    -y_coor_lin22c(tof22_i,offset))/y_coor_lin22c(tof22_i,slope)
620        endif        endif
621                
622    
# Line 543  C-----------------------------S3 ------- Line 624  C-----------------------------S3 -------
624    
625        IF (tof31_i.GT.none_find) THEN        IF (tof31_i.GT.none_find) THEN
626           ytofpos(3)  = ((tof31(1,tof31_i,itdc)-tof31(2,tof31_i,itdc))/2.           ytofpos(3)  = ((tof31(1,tof31_i,itdc)-tof31(2,tof31_i,itdc))/2.
627       +        -y_coor_lin31(tof31_i,offset))/y_coor_lin31(tof31_i,slope)       +    -y_coor_lin31c(tof31_i,offset))/y_coor_lin31c(tof31_i,slope)
628        endif        endif
629    
630        IF (tof32_i.GT.none_find) THEN        IF (tof32_i.GT.none_find) THEN
631           xtofpos(3)  = ((tof32(1,tof32_i,itdc)-tof32(2,tof32_i,itdc))/2.           xtofpos(3)  = ((tof32(1,tof32_i,itdc)-tof32(2,tof32_i,itdc))/2.
632       +        -x_coor_lin32(tof32_i,offset))/x_coor_lin32(tof32_i,slope)       +    -x_coor_lin32c(tof32_i,offset))/x_coor_lin32c(tof32_i,slope)
633        endif        endif
634    
635    
 c      do i=1,3  
 c         if (abs(xtofpos(i)).gt.100.) then  
 c            xtofpos(i)=101.  
 c         endif  
 c         if (abs(ytofpos(i)).gt.100.) then  
 c            ytofpos(i)=101.  
 c         endif  
 c      enddo  
   
 C--  restrict TDC measurements to physical paddle dimensions +/- 10 cm  
 C--  this cut is now stronger than in the old versions  
   
         if (abs(xtofpos(1)).gt.31.)  xtofpos(1)=101.  
         if (abs(xtofpos(2)).gt.19.)  xtofpos(2)=101.  
         if (abs(xtofpos(3)).gt.19.)  xtofpos(3)=101.  
   
         if (abs(ytofpos(1)).gt.26.)  ytofpos(1)=101.  
         if (abs(ytofpos(2)).gt.18.)  ytofpos(2)=101.  
         if (abs(ytofpos(3)).gt.18.)  ytofpos(3)=101.  
   
   
636  C----------------------------------------------------------------------  C----------------------------------------------------------------------
637  C---------------------  zenith angle theta  ---------------------------  C---------------------  zenith angle theta  ---------------------------
638  C----------------------------------------------------------------------  C----------------------------------------------------------------------
# Line 589  C--------------------------------------- Line 649  C---------------------------------------
649           dr = sqrt(dx*dx+dy*dy)           dr = sqrt(dx*dx+dy*dy)
650           theta13 = atan(dr/tofarm13)           theta13 = atan(dr/tofarm13)
651    
 C------------------------------------------------------------------  
 c      dx=0.  
 c      dy=0.  
 c      dr=0.  
 c      theta12 = 0.  
 c  
 c         IF ((tof12_i.GT.none_find).AND.(tof21_i.GT.none_find))  
 c     &        dx  = xtofpos(1) - xtofpos(2)  
 c         IF ((tof11_i.GT.none_find).AND.(tof22_i.GT.none_find))  
 c     &        dy  = ytofpos(1) - ytofpos(2)  
 c         dr = sqrt(dx*dx+dy*dy)  
 c         theta12 = atan(dr/tofarm12)  
 c          
 c      dx=0.  
 c      dy=0.  
 c      dr=0.  
 c      theta23 = 0.  
 c  
 c         IF ((tof21_i.GT.none_find).AND.(tof32_i.GT.none_find))  
 c     &        dx  = xtofpos(2) - xtofpos(3)  
 c         IF ((tof22_i.GT.none_find).AND.(tof31_i.GT.none_find))  
 c     &        dy  = ytofpos(2) - ytofpos(3)  
 c         dr = sqrt(dx*dx+dy*dy)  
 c         theta23 = atan(dr/tofarm23)  
 c          
 C---------------------------------------------------------------------  
652    
653    C----------------------------------------------------------------------
654    C--- check charge:
655    C--- if Z=2 we should use the attenuation curve for helium to
656    C--- fill the artificail ADC values and NOT divide by "hepratio"
657    C--- if Z>2 we should do a correction to
658    C--- the k1 constants in the beta calculation
659    C----------------------------------------------------------------------
660    
661             iz = int(check_charge(theta13,hitvec))
662    C         write(*,*) 'in tofl2com',iz
663    
664  C--------------------------------------------------------------------  C--------------------------------------------------------------------
665  C---- if TDCleft.and.TDCright and NO ADC insert artificial ADC  C---- if TDCleft.and.TDCright and NO ADC insert artificial ADC
# Line 638  C----------------------------  S1 ------ Line 682  C----------------------------  S1 ------
682    
683         IF (tof11_i.GT.none_find.AND.abs(yhelp).lt.100) THEN         IF (tof11_i.GT.none_find.AND.abs(yhelp).lt.100) THEN
684           i = tof11_i           i = tof11_i
 c         if (tof11(left,i,iadc).eq.4095) then  
685           if (adc(ch11a(i),hb11a(i)).eq.4095) then           if (adc(ch11a(i),hb11a(i)).eq.4095) then
686              xkorr = atten(left,11,i,yhelp)              xkorr = atten(left,11,i,yhelp)
687              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
688              tof11(left,i,iadc)=xkorr/cos(theta13)              tof11(left,i,iadc)=xkorr/cos(theta13)
 c            write(*,*) 'tofl2 left ',i, tof11(left,i,iadc)  
689              adcflagtof(ch11a(i),hb11a(i)) = 1              adcflagtof(ch11a(i),hb11a(i)) = 1
690           endif           endif
 c         if (tof11(right,i,iadc).eq.4095) then  
691           if (adc(ch11b(i),hb11b(i)).eq.4095) then           if (adc(ch11b(i),hb11b(i)).eq.4095) then
692              xkorr = atten(right,11,i,yhelp)              xkorr = atten(right,11,i,yhelp)
693              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
694              tof11(right,i,iadc)=xkorr/cos(theta13)              tof11(right,i,iadc)=xkorr/cos(theta13)
 c            write(*,*) 'tofl2 right ',i, tof11(right,i,iadc)  
695              adcflagtof(ch11b(i),hb11b(i)) = 1              adcflagtof(ch11b(i),hb11b(i)) = 1
696           endif           endif
697         ENDIF         ENDIF
# Line 662  c            write(*,*) 'tofl2 right ',i Line 702  c            write(*,*) 'tofl2 right ',i
702    
703         IF (tof12_i.GT.none_find.AND.abs(xhelp).lt.100) THEN         IF (tof12_i.GT.none_find.AND.abs(xhelp).lt.100) THEN
704           i = tof12_i           i = tof12_i
 c         if (tof12(left,i,iadc).eq.4095) then  
705           if (adc(ch12a(i),hb12a(i)).eq.4095) then           if (adc(ch12a(i),hb12a(i)).eq.4095) then
706              xkorr = atten(left,12,i,xhelp)              xkorr = atten(left,12,i,xhelp)
707              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
708              tof12(left,i,iadc) = xkorr/cos(theta13)              tof12(left,i,iadc) = xkorr/cos(theta13)
709              adcflagtof(ch12a(i),hb12a(i)) = 1              adcflagtof(ch12a(i),hb12a(i)) = 1
710           endif           endif
 c         if (tof12(right,i,iadc).eq.4095) then  
711           if (adc(ch12b(i),hb12b(i)).eq.4095) then           if (adc(ch12b(i),hb12b(i)).eq.4095) then
712              xkorr = atten(right,12,i,xhelp)              xkorr = atten(right,12,i,xhelp)
713              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
714              tof12(right,i,iadc) = xkorr/cos(theta13)              tof12(right,i,iadc) = xkorr/cos(theta13)
715              adcflagtof(ch12b(i),hb12b(i)) = 1              adcflagtof(ch12b(i),hb12b(i)) = 1
716           endif           endif
# Line 686  C-----------------------------S2 ------- Line 724  C-----------------------------S2 -------
724    
725         IF (tof21_i.GT.none_find.AND.abs(xhelp).lt.100) THEN         IF (tof21_i.GT.none_find.AND.abs(xhelp).lt.100) THEN
726           i = tof21_i           i = tof21_i
 c         if (tof21(left,i,iadc).eq.4095) then  
727           if (adc(ch21a(i),hb21a(i)).eq.4095) then           if (adc(ch21a(i),hb21a(i)).eq.4095) then
728              xkorr = atten(left,21,i,xhelp)              xkorr = atten(left,21,i,xhelp)
729              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
730              tof21(left,i,iadc) = xkorr/cos(theta13)              tof21(left,i,iadc) = xkorr/cos(theta13)
731              adcflagtof(ch21a(i),hb21a(i)) = 1              adcflagtof(ch21a(i),hb21a(i)) = 1
732           endif           endif
 c         if (tof21(right,i,iadc).eq.4095) then  
733           if (adc(ch21b(i),hb21b(i)).eq.4095) then           if (adc(ch21b(i),hb21b(i)).eq.4095) then
734              xkorr = atten(right,21,i,xhelp)              xkorr = atten(right,21,i,xhelp)
735              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
736              tof21(right,i,iadc) = xkorr/cos(theta13)              tof21(right,i,iadc) = xkorr/cos(theta13)
737              adcflagtof(ch21b(i),hb21b(i)) = 1              adcflagtof(ch21b(i),hb21b(i)) = 1
738           endif           endif
# Line 709  c         if (tof21(right,i,iadc).eq.409 Line 745  c         if (tof21(right,i,iadc).eq.409
745    
746         IF (tof22_i.GT.none_find.AND.abs(yhelp).lt.100) THEN         IF (tof22_i.GT.none_find.AND.abs(yhelp).lt.100) THEN
747           i = tof22_i           i = tof22_i
 c         if (tof22(left,i,iadc).eq.4095) then  
748           if (adc(ch22a(i),hb22a(i)).eq.4095) then           if (adc(ch22a(i),hb22a(i)).eq.4095) then
749              xkorr = atten(left,22,i,yhelp)              xkorr = atten(left,22,i,yhelp)
750              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
751              tof22(left,i,iadc) = xkorr/cos(theta13)              tof22(left,i,iadc) = xkorr/cos(theta13)
752              adcflagtof(ch22a(i),hb22a(i)) = 1              adcflagtof(ch22a(i),hb22a(i)) = 1
753           endif           endif
 c         if (tof22(right,i,iadc).eq.4095) then  
754           if (adc(ch22b(i),hb22b(i)).eq.4095) then           if (adc(ch22b(i),hb22b(i)).eq.4095) then
755              xkorr = atten(right,22,i,yhelp)              xkorr = atten(right,22,i,yhelp)
756              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
757              tof22(right,i,iadc) = xkorr/cos(theta13)              tof22(right,i,iadc) = xkorr/cos(theta13)
758              adcflagtof(ch22b(i),hb22b(i)) = 1              adcflagtof(ch22b(i),hb22b(i)) = 1
759           endif           endif
# Line 733  C-----------------------------S3 ------- Line 767  C-----------------------------S3 -------
767    
768         IF (tof31_i.GT.none_find.AND.abs(yhelp).lt.100) THEN         IF (tof31_i.GT.none_find.AND.abs(yhelp).lt.100) THEN
769           i = tof31_i           i = tof31_i
 c         if (tof31(left,i,iadc).eq.4095) then  
770           if (adc(ch31a(i),hb31a(i)).eq.4095) then           if (adc(ch31a(i),hb31a(i)).eq.4095) then
771              xkorr = atten(left,31,i,yhelp)              xkorr = atten(left,31,i,yhelp)
772              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
773              tof31(left,i,iadc) = xkorr/cos(theta13)              tof31(left,i,iadc) = xkorr/cos(theta13)
774              adcflagtof(ch31a(i),hb31a(i)) = 1              adcflagtof(ch31a(i),hb31a(i)) = 1
775           endif           endif
 c         if (tof31(right,i,iadc).eq.4095) then  
776           if (adc(ch31b(i),hb31b(i)).eq.4095) then           if (adc(ch31b(i),hb31b(i)).eq.4095) then
777              xkorr = atten(right,31,i,yhelp)              xkorr = atten(right,31,i,yhelp)
778              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
779              tof31(right,i,iadc) = xkorr/cos(theta13)              tof31(right,i,iadc) = xkorr/cos(theta13)
780              adcflagtof(ch31b(i),hb31b(i)) = 1              adcflagtof(ch31b(i),hb31b(i)) = 1
781           endif           endif
# Line 755  c         if (tof31(right,i,iadc).eq.409 Line 787  c         if (tof31(right,i,iadc).eq.409
787    
788         IF (tof32_i.GT.none_find.AND.abs(xhelp).lt.100) THEN         IF (tof32_i.GT.none_find.AND.abs(xhelp).lt.100) THEN
789           i = tof32_i           i = tof32_i
 c         if (tof32(left,i,iadc).eq.4095) then  
790           if (adc(ch32a(i),hb32a(i)).eq.4095) then           if (adc(ch32a(i),hb32a(i)).eq.4095) then
791              xkorr = atten(left,32,i,xhelp)              xkorr = atten(left,32,i,xhelp)
792              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
793              tof32(left,i,iadc) = xkorr/cos(theta13)              tof32(left,i,iadc) = xkorr/cos(theta13)
794              adcflagtof(ch32a(i),hb32a(i)) = 1              adcflagtof(ch32a(i),hb32a(i)) = 1
795           endif           endif
 c         if (tof32(right,i,iadc).eq.4095) then  
796           if (adc(ch32b(i),hb32b(i)).eq.4095) then           if (adc(ch32b(i),hb32b(i)).eq.4095) then
797              xkorr = atten(right,32,i,xhelp)              xkorr = atten(right,32,i,xhelp)
798              xkorr=xkorr/hepratio              if (iz.le.1) xkorr=xkorr/hepratio
799              tof32(right,i,iadc) = xkorr/cos(theta13)              tof32(right,i,iadc) = xkorr/cos(theta13)
800              adcflagtof(ch32b(i),hb32b(i)) = 1              adcflagtof(ch32b(i),hb32b(i)) = 1
801           endif           endif
802         ENDIF         ENDIF
803    
804    
805  C--------------------------------------------------------------------  C-------------------------------------------------------------------
806  C--------------------Time walk correction  -------------------------  C--------------------Time walk correction  -------------------------
807  C--------------------------------------------------------------------  C-------------------------------------------------------------------
808    C-------------------------------------------------------------------
809    C Now there is for each hitted paddle a TDC and ADC value, if the
810    C TDC was < 4095.
811    C There might be also TDC-ADC pairs in paddles not hitted
812    
813    C-------------------------------------------------------------------
814    C If we have multiple paddles hit, so that no artificial ADC value
815    C is created, we set the raw TDC value as "tdc_c"
816    C-------------------------------------------------------------------
817    c
818    c       do i=1,4
819    c         do j=1,12
820    c            tdc_c(i,j) = tdc(i,j)
821    c         enddo
822    c       enddo
823    c
824    C----  Let's correct the raw TDC value with the time walk  ---------
825    
826        DO i=1,8        DO i=1,8
827         xhelp= 0.           if ((tdc(ch11a(i),hb11a(i)).lt.4095).and.
828         xhelp_a = tof11(left,i,iadc)       &             (tof11(left,i,iadc).lt.3786)) THEN
829         xhelp_t = tof11(left,i,itdc)           xhelp = tw11(left,i)/(tof11(left,i,iadc)**0.5)
830  c       if (xhelp_a .eq.0) write (*,*) '11 ',i,xhelp_a           tof11(left,i,itdc) = tof11(left,i,itdc) + xhelp
831         if(xhelp_a<3786) xhelp = tw11(left,i)/sqrt(xhelp_a)           tdc_c(ch11a(i),hb11a(i))=tof11(left,i,itdc)
832         tof11(left,i,itdc) = xhelp_t  + xhelp                                                ENDIF
833         tdc_c(ch11a(i),hb11a(i))=tof11(left,i,itdc)  
834         xhelp_a = tof11(right,i,iadc)           if ((tdc(ch11b(i),hb11b(i)).lt.4095).and.
835         xhelp_t = tof11(right,i,itdc)       &             (tof11(right,i,iadc).lt.3786)) THEN
836         if(xhelp_a<3786) xhelp = tw11(right,i)/sqrt(xhelp_a)           xhelp = tw11(right,i)/(tof11(right,i,iadc)**0.5)
837         tof11(right,i,itdc) = xhelp_t  + xhelp           tof11(right,i,itdc) = tof11(right,i,itdc) + xhelp
838         tdc_c(ch11b(i),hb11b(i))=tof11(right,i,itdc)           tdc_c(ch11b(i),hb11b(i))=tof11(right,i,itdc)
839                                                 ENDIF
840        ENDDO        ENDDO
841    
842    
843        DO i=1,6        DO i=1,6
844         xhelp= 0.           if ((tdc(ch12a(i),hb12a(i)).lt.4095).and.
845         xhelp_a = tof12(left,i,iadc)       &             (tof12(left,i,iadc).lt.3786)) THEN
846         xhelp_t = tof12(left,i,itdc)           xhelp = tw12(left,i)/(tof12(left,i,iadc)**0.5)
847  c       if (xhelp_a .eq.0) write (*,*) '12 ',i,xhelp_a           tof12(left,i,itdc) = tof12(left,i,itdc) + xhelp
848         if(xhelp_a<3786) xhelp = tw12(left,i)/sqrt(xhelp_a)           tdc_c(ch12a(i),hb12a(i))=tof12(left,i,itdc)
849         tof12(left,i,itdc) = xhelp_t  + xhelp                                                ENDIF
850         tdc_c(ch12a(i),hb12a(i))=tof12(left,i,itdc)  
851         xhelp_a = tof12(right,i,iadc)           if ((tdc(ch12b(i),hb12b(i)).lt.4095).and.
852         xhelp_t = tof12(right,i,itdc)       &             (tof12(right,i,iadc).lt.3786)) THEN
853         if(xhelp_a<3786) xhelp = tw12(right,i)/sqrt(xhelp_a)           xhelp = tw12(right,i)/(tof12(right,i,iadc)**0.5)
854         tof12(right,i,itdc) = xhelp_t  + xhelp           tof12(right,i,itdc) = tof12(right,i,itdc) + xhelp
855         tdc_c(ch12b(i),hb12b(i))=tof12(right,i,itdc)           tdc_c(ch12b(i),hb12b(i))=tof12(right,i,itdc)
856                                                 ENDIF
857        ENDDO        ENDDO
858    
859  C----  C----
860        DO i=1,2        DO I=1,2
861         xhelp= 0.           if ((tdc(ch21a(i),hb21a(i)).lt.4095).and.
862         xhelp_a = tof21(left,i,iadc)       &             (tof21(left,i,iadc).lt.3786)) THEN
863         xhelp_t = tof21(left,i,itdc)           xhelp = tw21(left,i)/(tof21(left,i,iadc)**0.5)
864  c       if (xhelp_a .eq.0) write (*,*) '21 ',i,xhelp_a           tof21(left,i,itdc) = tof21(left,i,itdc) + xhelp
865         if(xhelp_a<3786) xhelp = tw21(left,i)/sqrt(xhelp_a)           tdc_c(ch21a(i),hb21a(i))=tof21(left,i,itdc)
866         tof21(left,i,itdc) = xhelp_t  + xhelp                                                ENDIF
867         tdc_c(ch21a(i),hb21a(i))=tof21(left,i,itdc)  
868         xhelp_a = tof21(right,i,iadc)           if ((tdc(ch21b(i),hb21b(i)).lt.4095).and.
869         xhelp_t = tof21(right,i,itdc)       &             (tof21(right,i,iadc).lt.3786)) THEN
870         if(xhelp_a<3786) xhelp = tw21(right,i)/sqrt(xhelp_a)           xhelp = tw21(right,i)/(tof21(right,i,iadc)**0.5)
871         tof21(right,i,itdc) = xhelp_t  + xhelp           tof21(right,i,itdc) = tof21(right,i,itdc) + xhelp
872         tdc_c(ch21b(i),hb21b(i))=tof21(right,i,itdc)           tdc_c(ch21b(i),hb21b(i))=tof21(right,i,itdc)
873        ENDDO                                               ENDIF
874          ENDDO
875        DO i=1,2  
876         xhelp= 0.        DO I=1,2
877         xhelp_a = tof22(left,i,iadc)           if ((tdc(ch22a(i),hb22a(i)).lt.4095).and.
878         xhelp_t = tof22(left,i,itdc)       &             (tof22(left,i,iadc).lt.3786)) THEN
879  c       if (xhelp_a .eq.0) write (*,*) '22 ',i,xhelp_a           xhelp = tw22(left,i)/(tof22(left,i,iadc)**0.5)
880             tof22(left,i,itdc) = tof22(left,i,itdc) + xhelp
881         if(xhelp_a<3786) xhelp = tw22(left,i)/sqrt(xhelp_a)           tdc_c(ch22a(i),hb22a(i))=tof22(left,i,itdc)
882         tof22(left,i,itdc) = xhelp_t  + xhelp                                                ENDIF
883         tdc_c(ch22a(i),hb22a(i))=tof22(left,i,itdc)  
884         xhelp_a = tof22(right,i,iadc)           if ((tdc(ch22b(i),hb22b(i)).lt.4095).and.
885         xhelp_t = tof22(right,i,itdc)       &             (tof22(right,i,iadc).lt.3786)) THEN
886         if(xhelp_a<3786) xhelp = tw22(right,i)/sqrt(xhelp_a)           xhelp = tw22(right,i)/(tof22(right,i,iadc)**0.5)
887         tof22(right,i,itdc) = xhelp_t  + xhelp           tof22(right,i,itdc) = tof22(right,i,itdc) + xhelp
888         tdc_c(ch22b(i),hb22b(i))=tof22(right,i,itdc)           tdc_c(ch22b(i),hb22b(i))=tof22(right,i,itdc)
889                                                 ENDIF
890        ENDDO        ENDDO
 C----  
891    
892        DO i=1,3  C----
893         xhelp= 0.        DO I=1,3
894         xhelp_a = tof31(left,i,iadc)           if ((tdc(ch31a(i),hb31a(i)).lt.4095).and.
895         xhelp_t = tof31(left,i,itdc)       &             (tof31(left,i,iadc).lt.3786)) THEN
896  c       if (xhelp_a .eq.0) write (*,*) '31 ',i,xhelp_a           xhelp = tw31(left,i)/(tof31(left,i,iadc)**0.5)
897             tof31(left,i,itdc) = tof31(left,i,itdc) + xhelp
898         if(xhelp_a<3786) xhelp = tw31(left,i)/sqrt(xhelp_a)           tdc_c(ch31a(i),hb31a(i))=tof31(left,i,itdc)
899         tof31(left,i,itdc) = xhelp_t  + xhelp                                                ENDIF
900         tdc_c(ch31a(i),hb31a(i))=tof31(left,i,itdc)  
901         xhelp_a = tof31(right,i,iadc)           if ((tdc(ch31b(i),hb31b(i)).lt.4095).and.
902         xhelp_t = tof31(right,i,itdc)       &             (tof31(right,i,iadc).lt.3786)) THEN
903         if(xhelp_a<3786) xhelp = tw31(right,i)/sqrt(xhelp_a)           xhelp = tw31(right,i)/(tof31(right,i,iadc)**0.5)
904         tof31(right,i,itdc) = xhelp_t  + xhelp           tof31(right,i,itdc) = tof31(right,i,itdc) + xhelp
905         tdc_c(ch31b(i),hb31b(i))=tof31(right,i,itdc)           tdc_c(ch31b(i),hb31b(i))=tof31(right,i,itdc)
906        ENDDO                                               ENDIF
907          ENDDO
908        DO i=1,3  
909         xhelp= 0.        DO I=1,3
910         xhelp_a = tof32(left,i,iadc)           if ((tdc(ch32a(i),hb32a(i)).lt.4095).and.
911         xhelp_t = tof32(left,i,itdc)       &             (tof32(left,i,iadc).lt.3786)) THEN
912  c       if (xhelp_a .eq.0) write (*,*) '32 ',i,xhelp_a           xhelp = tw32(left,i)/(tof32(left,i,iadc)**0.5)
913             tof32(left,i,itdc) = tof32(left,i,itdc) + xhelp
914         if(xhelp_a<3786) xhelp = tw32(left,i)/sqrt(xhelp_a)           tdc_c(ch32a(i),hb32a(i))=tof32(left,i,itdc)
915         tof32(left,i,itdc) = xhelp_t  + xhelp                                                ENDIF
916         tdc_c(ch32a(i),hb32a(i))=tof32(left,i,itdc)  
917         xhelp_a = tof32(right,i,iadc)           if ((tdc(ch32b(i),hb32b(i)).lt.4095).and.
918         xhelp_t = tof32(right,i,itdc)       &             (tof32(right,i,iadc).lt.3786)) THEN
919         if(xhelp_a<3786) xhelp = tw32(right,i)/sqrt(xhelp_a)           xhelp = tw32(right,i)/(tof32(right,i,iadc)**0.5)
920         tof32(right,i,itdc) = xhelp_t  + xhelp           tof32(right,i,itdc) = tof32(right,i,itdc) + xhelp
921         tdc_c(ch32b(i),hb32b(i))=tof32(right,i,itdc)           tdc_c(ch32b(i),hb32b(i))=tof32(right,i,itdc)
922                                                 ENDIF
923        ENDDO        ENDDO
924            
925    C---------------------------------------------------------------
926    C--- calculate track position in paddle using timing difference
927    C--- now using the time-walk corrected TDC values
928    C---------------------------------------------------------------
929    
930          do i=1,3
931             xtofpos(i)=100.
932             ytofpos(i)=100.
933          enddo
934    
935    C-----------------------------S1 --------------------------------
936    
937          IF (tof11_i.GT.none_find) THEN
938             ytofpos(1)  = ((tof11(1,tof11_i,itdc)-tof11(2,tof11_i,itdc))/2.
939         +        -y_coor_lin11(tof11_i,offset))/y_coor_lin11(tof11_i,slope)
940          endif
941    
942          IF (tof12_i.GT.none_find) THEN
943             xtofpos(1)  = ((tof12(1,tof12_i,itdc)-tof12(2,tof12_i,itdc))/2.
944         +        -x_coor_lin12(tof12_i,offset))/x_coor_lin12(tof12_i,slope)
945          endif
946    
947    
948    C-----------------------------S2 --------------------------------
949    
950          IF (tof21_i.GT.none_find) THEN
951             xtofpos(2) = ((tof21(1,tof21_i,itdc)-tof21(2,tof21_i,itdc))/2.
952         +        -x_coor_lin21(tof21_i,offset))/x_coor_lin21(tof21_i,slope)
953          endif
954    
955          IF (tof22_i.GT.none_find) THEN
956             ytofpos(2) = ((tof22(1,tof22_i,itdc)-tof22(2,tof22_i,itdc))/2.
957         +        -y_coor_lin22(tof22_i,offset))/y_coor_lin22(tof22_i,slope)
958          endif
959          
960    
961    C-----------------------------S3 --------------------------------
962    
963          IF (tof31_i.GT.none_find) THEN
964             ytofpos(3)  = ((tof31(1,tof31_i,itdc)-tof31(2,tof31_i,itdc))/2.
965         +        -y_coor_lin31(tof31_i,offset))/y_coor_lin31(tof31_i,slope)
966          endif
967    
968          IF (tof32_i.GT.none_find) THEN
969             xtofpos(3)  = ((tof32(1,tof32_i,itdc)-tof32(2,tof32_i,itdc))/2.
970         +        -x_coor_lin32(tof32_i,offset))/x_coor_lin32(tof32_i,slope)
971          endif
972    
973    
974    c      do i=1,3
975    c         if (abs(xtofpos(i)).gt.100.) then
976    c            xtofpos(i)=101.
977    c         endif
978    c         if (abs(ytofpos(i)).gt.100.) then
979    c            ytofpos(i)=101.
980    c         endif
981    c      enddo
982    
983    C--  restrict TDC measurements to physical paddle dimensions +/- 10 cm
984    C--  this cut is now stronger than in the old versions
985    
986            if (abs(xtofpos(1)).gt.31.)  xtofpos(1)=101.
987            if (abs(xtofpos(2)).gt.19.)  xtofpos(2)=101.
988            if (abs(xtofpos(3)).gt.19.)  xtofpos(3)=101.
989    
990            if (abs(ytofpos(1)).gt.26.)  ytofpos(1)=101.
991            if (abs(ytofpos(2)).gt.18.)  ytofpos(2)=101.
992            if (abs(ytofpos(3)).gt.18.)  ytofpos(3)=101.
993    
994    
995    C----------------------------------------------------------------------
996    C---------------------  zenith angle theta  ---------------------------
997    C----------------------------------------------------------------------
998    
999          dx=0.
1000          dy=0.
1001          dr=0.
1002          theta13 = 0.
1003    
1004             IF ((tof12_i.GT.none_find).AND.(tof32_i.GT.none_find))
1005         &        dx  = xtofpos(1) - xtofpos(3)
1006             IF ((tof11_i.GT.none_find).AND.(tof31_i.GT.none_find))
1007         &        dy  = ytofpos(1) - ytofpos(3)
1008             dr = sqrt(dx*dx+dy*dy)
1009             theta13 = atan(dr/tofarm13)
1010    
1011    C------------------------------------------------------------------
1012    c      dx=0.
1013    c      dy=0.
1014    c      dr=0.
1015    c      theta12 = 0.
1016    c
1017    c         IF ((tof12_i.GT.none_find).AND.(tof21_i.GT.none_find))
1018    c     &        dx  = xtofpos(1) - xtofpos(2)
1019    c         IF ((tof11_i.GT.none_find).AND.(tof22_i.GT.none_find))
1020    c     &        dy  = ytofpos(1) - ytofpos(2)
1021    c         dr = sqrt(dx*dx+dy*dy)
1022    c         theta12 = atan(dr/tofarm12)
1023    c        
1024    c      dx=0.
1025    c      dy=0.
1026    c      dr=0.
1027    c      theta23 = 0.
1028    c
1029    c         IF ((tof21_i.GT.none_find).AND.(tof32_i.GT.none_find))
1030    c     &        dx  = xtofpos(2) - xtofpos(3)
1031    c         IF ((tof22_i.GT.none_find).AND.(tof31_i.GT.none_find))
1032    c     &        dy  = ytofpos(2) - ytofpos(3)
1033    c         dr = sqrt(dx*dx+dy*dy)
1034    c         theta23 = atan(dr/tofarm23)
1035    c        
1036  C----------------------------------------------------------------------  C----------------------------------------------------------------------
1037  C------------------angle and ADC(x) correction  C------------------angle and ADC(x) correction
1038  C----------------------------------------------------------------------  C----------------------------------------------------------------------
# Line 1044  c            write(90+i,*) xhelp,xkorr Line 1207  c            write(90+i,*) xhelp,xkorr
1207           endif           endif
1208        ENDIF        ENDIF
1209    
   
1210  C--------------------------------------------------------------------  C--------------------------------------------------------------------
1211  C----------------------calculate Beta  ------------------------------  C----------------------calculate Beta  ------------------------------
1212  C--------------------------------------------------------------------  C--------------------------------------------------------------------
# Line 1065  C     S11 - S31 Line 1227  C     S11 - S31
1227           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1228           ihelp=(tof11_i-1)*3+tof31_i           ihelp=(tof11_i-1)*3+tof31_i
1229           c1 = k_S11S31(1,ihelp)           c1 = k_S11S31(1,ihelp)
1230             if (iz.gt.2) c1 = c1 + k1corrA1
1231           c2 = k_S11S31(2,ihelp)           c2 = k_S11S31(2,ihelp)
1232           betatof_a(1) = c2/(cos(theta13)*(ds-c1))           betatof_a(1) = c2/(cos(theta13)*(ds-c1))
1233    
# Line 1093  C     S11 - S32 Line 1256  C     S11 - S32
1256           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1257           ihelp=(tof11_i-1)*3+tof32_i           ihelp=(tof11_i-1)*3+tof32_i
1258           c1 = k_S11S32(1,ihelp)           c1 = k_S11S32(1,ihelp)
1259             if (iz.gt.2) c1 = c1 + k1corrA1
1260           c2 = k_S11S32(2,ihelp)           c2 = k_S11S32(2,ihelp)
1261           betatof_a(2) = c2/(cos(theta13)*(ds-c1))           betatof_a(2) = c2/(cos(theta13)*(ds-c1))
1262    
# Line 1121  C     S12 - S31 Line 1285  C     S12 - S31
1285           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1286           ihelp=(tof12_i-1)*3+tof31_i           ihelp=(tof12_i-1)*3+tof31_i
1287           c1 = k_S12S31(1,ihelp)           c1 = k_S12S31(1,ihelp)
1288             if (iz.gt.2) c1 = c1 + k1corrA1
1289           c2 = k_S12S31(2,ihelp)           c2 = k_S12S31(2,ihelp)
1290           betatof_a(3) = c2/(cos(theta13)*(ds-c1))           betatof_a(3) = c2/(cos(theta13)*(ds-c1))
1291    
# Line 1149  C     S12 - S32 Line 1314  C     S12 - S32
1314           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1315           ihelp=(tof12_i-1)*3+tof32_i           ihelp=(tof12_i-1)*3+tof32_i
1316           c1 = k_S12S32(1,ihelp)           c1 = k_S12S32(1,ihelp)
1317             if (iz.gt.2) c1 = c1 + k1corrA1
1318           c2 = k_S12S32(2,ihelp)           c2 = k_S12S32(2,ihelp)
1319           betatof_a(4) = c2/(cos(theta13)*(ds-c1))           betatof_a(4) = c2/(cos(theta13)*(ds-c1))
1320    
# Line 1177  C     S21 - S31 Line 1343  C     S21 - S31
1343           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1344           ihelp=(tof21_i-1)*3+tof31_i           ihelp=(tof21_i-1)*3+tof31_i
1345           c1 = k_S21S31(1,ihelp)           c1 = k_S21S31(1,ihelp)
1346             if (iz.gt.2) c1 = c1 + k1corrB1
1347           c2 = k_S21S31(2,ihelp)           c2 = k_S21S31(2,ihelp)
1348           betatof_a(5) = c2/(cos(theta13)*(ds-c1))           betatof_a(5) = c2/(cos(theta13)*(ds-c1))
1349    
# Line 1205  C     S21 - S32 Line 1372  C     S21 - S32
1372           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1373           ihelp=(tof21_i-1)*3+tof32_i           ihelp=(tof21_i-1)*3+tof32_i
1374           c1 = k_S21S32(1,ihelp)           c1 = k_S21S32(1,ihelp)
1375             if (iz.gt.2) c1 = c1 + k1corrB1
1376           c2 = k_S21S32(2,ihelp)           c2 = k_S21S32(2,ihelp)
1377           betatof_a(6) = c2/(cos(theta13)*(ds-c1))           betatof_a(6) = c2/(cos(theta13)*(ds-c1))
1378                                        
# Line 1233  C     S22 - S31 Line 1401  C     S22 - S31
1401           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1402           ihelp=(tof22_i-1)*3+tof31_i           ihelp=(tof22_i-1)*3+tof31_i
1403           c1 = k_S22S31(1,ihelp)           c1 = k_S22S31(1,ihelp)
1404             if (iz.gt.2) c1 = c1 + k1corrB1
1405           c2 = k_S22S31(2,ihelp)           c2 = k_S22S31(2,ihelp)
1406           betatof_a(7) = c2/(cos(theta13)*(ds-c1))           betatof_a(7) = c2/(cos(theta13)*(ds-c1))
1407    
# Line 1261  C     S22 - S32 Line 1430  C     S22 - S32
1430           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1431           ihelp=(tof22_i-1)*3+tof32_i           ihelp=(tof22_i-1)*3+tof32_i
1432           c1 = k_S22S32(1,ihelp)           c1 = k_S22S32(1,ihelp)
1433             if (iz.gt.2) c1 = c1 + k1corrB1
1434           c2 = k_S22S32(2,ihelp)           c2 = k_S22S32(2,ihelp)
1435           betatof_a(8) = c2/(cos(theta13)*(ds-c1))           betatof_a(8) = c2/(cos(theta13)*(ds-c1))
1436    
# Line 1289  C     S11 - S21 Line 1459  C     S11 - S21
1459           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1460           ihelp=(tof11_i-1)*2+tof21_i           ihelp=(tof11_i-1)*2+tof21_i
1461           c1 = k_S11S21(1,ihelp)           c1 = k_S11S21(1,ihelp)
1462             if (iz.gt.2) c1 = c1 + k1corrC1
1463           c2 = k_S11S21(2,ihelp)           c2 = k_S11S21(2,ihelp)
1464           betatof_a(9) = c2/(cos(theta13)*(ds-c1))           betatof_a(9) = c2/(cos(theta13)*(ds-c1))
1465    
# Line 1317  C     S11 - S22 Line 1488  C     S11 - S22
1488           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1489           ihelp=(tof11_i-1)*2+tof22_i           ihelp=(tof11_i-1)*2+tof22_i
1490           c1 = k_S11S22(1,ihelp)           c1 = k_S11S22(1,ihelp)
1491             if (iz.gt.2) c1 = c1 + k1corrC1
1492           c2 = k_S11S22(2,ihelp)           c2 = k_S11S22(2,ihelp)
1493           betatof_a(10) = c2/(cos(theta13)*(ds-c1))           betatof_a(10) = c2/(cos(theta13)*(ds-c1))
1494    
# Line 1345  C     S12 - S21 Line 1517  C     S12 - S21
1517           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1518           ihelp=(tof12_i-1)*2+tof21_i           ihelp=(tof12_i-1)*2+tof21_i
1519           c1 = k_S12S21(1,ihelp)           c1 = k_S12S21(1,ihelp)
1520             if (iz.gt.2) c1 = c1 + k1corrC1
1521           c2 = k_S12S21(2,ihelp)           c2 = k_S12S21(2,ihelp)
1522           betatof_a(11) = c2/(cos(theta13)*(ds-c1))           betatof_a(11) = c2/(cos(theta13)*(ds-c1))
1523    
# Line 1373  C     S12 - S22 Line 1546  C     S12 - S22
1546           ds = xhelp1-xhelp2           ds = xhelp1-xhelp2
1547           ihelp=(tof12_i-1)*2+tof22_i           ihelp=(tof12_i-1)*2+tof22_i
1548           c1 = k_S12S22(1,ihelp)           c1 = k_S12S22(1,ihelp)
1549             if (iz.gt.2) c1 = c1 + k1corrC1
1550           c2 = k_S12S22(2,ihelp)           c2 = k_S12S22(2,ihelp)
1551           betatof_a(12) = c2/(cos(theta13)*(ds-c1))           betatof_a(12) = c2/(cos(theta13)*(ds-c1))
1552    
# Line 1393  C-------   Line 1567  C-------  
1567        ENDIF        ENDIF
1568    
1569  C---------------------------------------------------------  C---------------------------------------------------------
1570    C
1571    C      icount=0
1572    C      sw=0.
1573    C      sxw=0.
1574    C      beta_mean=100.
1575    C
1576    C      do i=1,12
1577    C         if ((betatof_a(i).gt.-1.5).and.(betatof_a(i).lt.1.5)) then
1578    C            icount= icount+1
1579    C            if (i.le.4) w_i=1./(0.13**2.)
1580    C            if ((i.ge.5).and.(i.le.8)) w_i=1./(0.16**2.)
1581    C           if (i.ge.9) w_i=1./(0.25**2.)     ! to be checked
1582    C            sxw=sxw + betatof_a(i)*w_i
1583    C            sw =sw + w_i
1584    C         endif
1585    C      enddo
1586    C      
1587    C      if (icount.gt.0) beta_mean=sxw/sw
1588    C      betatof_a(13) = beta_mean
1589    C
1590    
1591        icount=0  C--------  New mean beta  calculation  -----------------------
       sw=0.  
       sxw=0.  
       beta_mean=100.  
1592    
1593        do i=1,12          do i=1,12
1594           if ((betatof_a(i).gt.-1.5).and.(betatof_a(i).lt.1.5)) then           btemp(i) = betatof_a(i)
1595              icount= icount+1          enddo
             if (i.le.4) w_i=1./(0.13**2.)  
             if ((i.ge.5).and.(i.le.8)) w_i=1./(0.16**2.)  
             if (i.ge.9) w_i=1./(0.25**2.)     ! to be checked  
             sxw=sxw + betatof_a(i)*w_i  
             sw =sw + w_i  
          endif  
       enddo  
         
       if (icount.gt.0) beta_mean=sxw/sw  
       betatof_a(13) = beta_mean  
1596    
1597            betatof_a(13)=newbeta(1,btemp,hitvec,10.,10.,20.)
1598    
1599    C--------------------------------------------------------------
1600    C      write(*,*) betatof_a
1601  c      write(*,*) xtofpos  c      write(*,*) xtofpos
1602  c      write(*,*) ytofpos  c      write(*,*) ytofpos
1603  c      write(*,*)'tofl2com beta', betatof_a  c      write(*,*)'tofl2com beta', betatof_a
# Line 1515  c       write(*,*) ix,pc_adc Line 1700  c       write(*,*) ix,pc_adc
1700         end         end
1701    
1702  C------------------------------------------------------------------  C------------------------------------------------------------------
1703    C------------------------------------------------------------------
1704    
1705            function check_charge(theta,hitvec)
1706    
1707            include  'input_tof.txt'
1708            include  'tofcomm.txt'
1709    
1710            real check_charge  
1711            integer hitvec(6)  
1712            REAL CHARGE, theta
1713    
1714    C  upper and lower limits  for the helium selection
1715            REAL A_l(24),A_h(24)
1716            DATA A_l /200,190,300,210,220,200,210,60,60,120,220,
1717         &  120,160,50,300,200,120,250,350,300,350,250,280,300/
1718            DATA A_h /550,490,800,600,650,600,600,260,200,380,
1719         &  620,380,550,200,850,560,400,750,900,800,880,800,750,800/
1720    
1721    C The k1 constants for the beta calculation, only for S1-S3
1722    C k2 constant is taken to be the standard 2D/c
1723            REAL k1(84)
1724            DATA k1 /50,59.3296,28.4328,-26.0818,5.91253,-19.588,
1725         &   -9.26316,24.7544,2.32465,-50.5058,-15.3195,-39.1443,
1726         &   -91.2546,-58.6243,-84.5641,-63.1516,-32.2091,-58.3358,
1727         &   13.8084,45.5322,33.2416,-11.5313,51.3271,75,-14.1141,
1728         &   42.8466,15.1794,-63.6672,-6.07739,-32.164,-41.771,10.5274,
1729         &   -9.46096,-81.7404,-28.783,-52.7167,-127.394,-69.6166,
1730         &   -93.4655,-98.9543,-42.863,-67.8244,-19.3238,31.1221,8.7319,
1731         &   -43.1627,5.55573,-14.4078,-83.4466,-47.4647,-77.8379,
1732         &   -108.222,-75.986,-101.297,-96.0205,-63.1881,-90.1372,
1733         &   -22.7347,8.31409,-19.6912,-7.49008,23.6979,-1.66677,
1734         &   1.81556,34.4668,6.23693,-100,-59.5861,-90.9159,-141.639,
1735         &   -89.2521,-112.881,-130.199,-77.0357,-98.4632,-60.2086,
1736         &   -4.82097,-29.3705,-43.6469,10.5884,-9.31304,-35.3329,
1737         &   25.2514,25.6/
1738    
1739    
1740    
1741            REAL zin(6)
1742            DATA zin /53.74, 53.04, 23.94, 23.44, -23.49, -24.34/
1743    
1744            REAL  c1,c2,xhelp,xhelp1,xhelp2,ds,dist,F
1745            REAL  sw,sxw,beta_mean_tof,w_i
1746            INTEGER  ihelp
1747            INTEGER ipmt(4)
1748            REAL time(4),beta1(4)
1749    
1750            REAL  adca(48), tdca(48)
1751    
1752            REAL  a1,a2
1753            INTEGER jj
1754    
1755    C-----------------------------------------------------------
1756    C--- get data
1757    C-----------------------------------------------------------
1758    
1759             do j=1,8
1760             ih = 1 + 0 +((j-1)*2)
1761             adca(ih)   = adc(ch11a(j),hb11a(j))
1762             adca(ih+1) = adc(ch11b(j),hb11b(j))
1763             tdca(ih)   = tdc(ch11a(j),hb11a(j))
1764             tdca(ih+1) = tdc(ch11b(j),hb11b(j))
1765             enddo
1766    
1767             do j=1,6
1768             ih = 1 + 16+((j-1)*2)
1769             adca(ih)   = adc(ch12a(j),hb12a(j))
1770             adca(ih+1) = adc(ch12b(j),hb12b(j))
1771             tdca(ih)   = tdc(ch12a(j),hb12a(j))
1772             tdca(ih+1) = tdc(ch12b(j),hb12b(j))
1773             enddo
1774    
1775             do j=1,2
1776             ih = 1 + 28+((j-1)*2)
1777             adca(ih)   = adc(ch21a(j),hb21a(j))
1778             adca(ih+1) = adc(ch21b(j),hb21b(j))
1779             tdca(ih)   = tdc(ch21a(j),hb21a(j))
1780             tdca(ih+1) = tdc(ch21b(j),hb21b(j))
1781             enddo
1782    
1783             do j=1,2
1784             ih = 1 + 32+((j-1)*2)
1785             adca(ih)   = adc(ch22a(j),hb22a(j))
1786             adca(ih+1) = adc(ch22b(j),hb22b(j))
1787             tdca(ih)   = tdc(ch22a(j),hb22a(j))
1788             tdca(ih+1) = tdc(ch22b(j),hb22b(j))
1789             enddo
1790    
1791             do j=1,3
1792             ih = 1 + 36+((j-1)*2)
1793             adca(ih)   = adc(ch31a(j),hb31a(j))
1794             adca(ih+1) = adc(ch31b(j),hb31b(j))
1795             tdca(ih)   = tdc(ch31a(j),hb31a(j))
1796             tdca(ih+1) = tdc(ch31b(j),hb31b(j))
1797             enddo
1798    
1799             do j=1,3
1800             ih = 1 + 42+((j-1)*2)
1801             adca(ih)   = adc(ch32a(j),hb32a(j))
1802             adca(ih+1) = adc(ch32b(j),hb32b(j))
1803             tdca(ih)   = tdc(ch32a(j),hb32a(j))
1804             tdca(ih+1) = tdc(ch32b(j),hb32b(j))
1805             enddo
1806    
1807    
1808    c         write(*,*) adca
1809    c         write(*,*) tdca
1810    
1811    
1812    C============   calculate beta and select charge > Z=1   ===============
1813    
1814            ICHARGE=1
1815    
1816    C find hitted paddle by looking for ADC values on both sides
1817    C since we looking for Z>1 this gives decent results
1818    
1819            tof11_i = hitvec(1)-1
1820            tof12_i = hitvec(2)-1
1821            tof21_i = hitvec(3)-1
1822            tof22_i = hitvec(4)-1
1823            tof31_i = hitvec(5)-1
1824            tof32_i = hitvec(6)-1
1825    
1826    c        write(*,*) ' in charge check'
1827    c        write(*,*) theta,tof11_i,tof12_i,tof21_i,tof22_i,tof31_i,tof32_i
1828    
1829    C----------------------------------------------------------------
1830    
1831            beta_help=100.
1832            beta_mean_tof=100.
1833    
1834            do jj=1,4
1835              beta1(jj) = 100.
1836            enddo
1837    
1838    C----------------------------------------------------------------
1839    C---------  S1 - S3 ---------------------------------------------
1840    C----------------------------------------------------------------
1841    
1842    C---------  S11 - S31 -------------------------------------------
1843    
1844            if ((tof11_i.gt.-1).and.(tof31_i.gt.-1)) then
1845    
1846            dist = zin(1) - zin(5)
1847            c2 = (2.*0.01*dist)/(3.E08*50.E-12)
1848            F = 1./cos(theta)
1849    
1850            ipmt(1)   = (tof11_i)*2+1
1851            ipmt(2)   = (tof11_i)*2+2
1852            ipmt(3)   = 36+(tof31_i)*2+1
1853            ipmt(4)   = 36+(tof31_i)*2+2
1854    
1855    c        write(*,*) ipmt
1856    
1857            do jj=1,4
1858               time(jj) = tdca(ipmt(jj))
1859            enddo
1860    
1861    c        write(*,*) time
1862    
1863            if ((time(1).lt.4095).and.(time(2).lt.4095).and.
1864         &     (time(3).lt.4095).and.(time(4).lt.4095)) then
1865             xhelp1 = time(1) + time(2)
1866             xhelp2 = time(3) + time(4)
1867             ds = xhelp1-xhelp2
1868             ihelp=0+(tof11_i)*3+tof31_i
1869             c1 = k1(ihelp+1)
1870             beta1(1) = c2*F/(ds-c1);
1871                                                     endif
1872    c         write(*,*) beta1(1)
1873             endif  ! tof_....
1874    
1875    
1876    C---------  S11 - S32 -------------------------------------------
1877    
1878            if ((tof11_i.gt.-1).and.(tof32_i.gt.-1)) then
1879    
1880            dist = zin(1) - zin(6)
1881            c2 = (2.*0.01*dist)/(3.E08*50.E-12)
1882            F = 1./cos(theta)
1883    
1884            ipmt(1)   = (tof11_i)*2+1
1885            ipmt(2)   = (tof11_i)*2+2
1886            ipmt(3)   = 42+(tof32_i)*2+1
1887            ipmt(4)   = 42+(tof32_i)*2+2
1888    
1889            do jj=1,4
1890               time(jj) = tdca(ipmt(jj))
1891            enddo
1892    
1893            if ((time(1).lt.4095).and.(time(2).lt.4095).and.
1894         &     (time(3).lt.4095).and.(time(4).lt.4095)) then
1895             xhelp1 = time(1) + time(2)
1896             xhelp2 = time(3) + time(4)
1897             ds = xhelp1-xhelp2
1898             ihelp=24+(tof11_i)*3+tof32_i
1899             c1 = k1(ihelp+1)
1900             beta1(2) = c2*F/(ds-c1);
1901                                                     endif
1902             endif  ! tof_....
1903    
1904    
1905    C---------  S12 - S31 -------------------------------------------
1906    
1907            if ((tof12_i.gt.-1).and.(tof31_i.gt.-1)) then
1908    
1909            dist = zin(2) - zin(5)
1910            c2 = (2.*0.01*dist)/(3.E08*50.E-12)
1911            F = 1./cos(theta)
1912    
1913            ipmt(1)   = 16+(tof12_i)*2+1
1914            ipmt(2)   = 16+(tof12_i)*2+2
1915            ipmt(3)   = 36+(tof31_i)*2+1
1916            ipmt(4)   = 36+(tof31_i)*2+2
1917    
1918            do jj=1,4
1919               time(jj) = tdca(ipmt(jj))
1920            enddo
1921    
1922            if ((time(1).lt.4095).and.(time(2).lt.4095).and.
1923         &     (time(3).lt.4095).and.(time(4).lt.4095)) then
1924             xhelp1 = time(1) + time(2)
1925             xhelp2 = time(3) + time(4)
1926             ds = xhelp1-xhelp2
1927             ihelp=48+(tof12_i)*3+tof31_i
1928             c1 = k1(ihelp+1)
1929             beta1(3) = c2*F/(ds-c1);
1930                                                     endif
1931             endif  ! tof_....
1932    
1933    
1934    C---------  S12 - S32 -------------------------------------------
1935    
1936            if ((tof12_i.gt.-1).and.(tof32_i.gt.-1)) then
1937    
1938            dist = zin(2) - zin(6)
1939            c2 = (2.*0.01*dist)/(3.E08*50.E-12)
1940            F = 1./cos(theta)
1941    
1942            ipmt(1)   = 16+(tof12_i)*2+1
1943            ipmt(2)   = 16+(tof12_i)*2+2
1944            ipmt(3)   = 42+(tof32_i)*2+1
1945            ipmt(4)   = 42+(tof32_i)*2+2
1946    
1947            do jj=1,4
1948               time(jj) = tdca(ipmt(jj))
1949            enddo
1950    
1951            if ((time(1).lt.4095).and.(time(2).lt.4095).and.
1952         &     (time(3).lt.4095).and.(time(4).lt.4095)) then
1953             xhelp1 = time(1) + time(2)
1954             xhelp2 = time(3) + time(4)
1955             ds = xhelp1-xhelp2
1956             ihelp=56+(tof12_i)*3+tof32_i
1957             c1 = k1(ihelp+1)
1958             beta1(4) = c2*F/(ds-c1);
1959                                                     endif
1960    
1961             endif  ! tof_....
1962    
1963    c         write(*,*) beta1
1964      
1965    C----  calculate  beta mean, only downward going particles are interesting ----
1966    
1967             sw=0.
1968             sxw=0.
1969             beta_mean_tof=100.
1970    
1971            do jj=1,4
1972            if ((beta1(jj).gt.0.1).and.(beta1(jj).lt.2.0)) then
1973                w_i=1./(0.13*0.13)
1974                sxw=sxw + beta1(jj)*w_i
1975                sw =sw + w_i ;
1976                                                          endif
1977            enddo
1978    
1979            if (sw.gt.0) beta_mean_tof=sxw/sw;
1980    
1981    c        write(*,*) 'beta_mean_tof ',beta_mean_tof
1982    
1983            beta_help = beta_mean_tof  !  pow(beta_mean_tof,1.0) gave best results
1984    
1985    CCCCC        endif  !  if tof11_i > -1 && ...... beta calculation
1986    
1987    C-----------------------  Select charge   --------------------------
1988    
1989           charge=0
1990    
1991           if ((beta_mean_tof.gt.0.2).and.(beta_mean_tof.lt.2.0)) then
1992    
1993            icount1=0
1994            icount2=0
1995            icount3=0
1996    
1997            do jj=0,23
1998            a1 = adca(2*jj+1)
1999            a2 = adca(2*jj+2)
2000            if ((a1.lt.4095).and.(a2.lt.4095)) then
2001            a1 = adca(2*jj+1)*cos(theta)
2002            a2 = adca(2*jj+2)*cos(theta)
2003            xhelp  = 100000.
2004            xhelp1 = 100000.
2005            xhelp = sqrt(a1*a2)  ! geometric mean
2006            xhelp1 = beta_help*xhelp
2007    C if geometric mean multiplied by beta_help is inside/outside helium
2008    C limits, increase counter
2009           if (xhelp1.lt.A_l(jj+1))  icount1=icount1+1
2010           if ((xhelp1.gt.A_l(jj+1)).and.(xhelp1.lt.A_h(jj+1)))
2011         &                           icount2=icount2+1
2012           if (xhelp1.gt.A_h(jj+1))  icount3=icount3+1
2013                                                endif
2014            enddo
2015    
2016    
2017    C  if more than three paddles see the same...
2018    
2019            if (icount1 .gt. 3) charge=1
2020            if (icount2 .gt. 3) charge=2
2021            if (icount3 .gt. 3) charge=3
2022    
2023                                                        endif  ! 0.2<beta<2.0
2024    
2025    C  no beta found? Sum up geometric means of paddles and derive the mean...
2026    
2027           if (beta_mean_tof.eq.100.) then
2028    
2029           xhelp  = 0.
2030           icount = 0
2031    
2032           if (tof11_i.gt.-1) then
2033           jj=tof11_i
2034           a1 = adca(0+2*jj+1)
2035           a2 = adca(0+2*jj+2)
2036           if ((a1.lt.4095).and.(a2.lt.4095)) then
2037           a1 = a1*cos(theta)
2038           a2 = a2*cos(theta)
2039           xhelp = xhelp + sqrt(a1*a2)
2040           icount=icount+1
2041                        endif
2042                        endif
2043    
2044           if (tof12_i.gt.-1) then
2045           jj=tof12_i
2046           a1 = adca(16+2*jj+1)
2047           a2 = adca(16+2*jj+2)
2048           if ((a1.lt.4095).and.(a2.lt.4095)) then
2049           a1 = a1*cos(theta)
2050           a2 = a2*cos(theta)
2051           xhelp = xhelp + sqrt(a1*a2)
2052           icount=icount+1
2053                        endif
2054                        endif
2055    
2056           if (tof21_i.gt.-1) then
2057           jj=tof21_i
2058           a1 = adca(28+2*jj+1)
2059           a2 = adca(28+2*jj+2)
2060           if ((a1.lt.4095).and.(a2.lt.4095)) then
2061           a1 = a1*cos(theta)
2062           a2 = a2*cos(theta)
2063           xhelp = xhelp + sqrt(a1*a2)
2064           icount=icount+1
2065                        endif
2066                        endif
2067    
2068           if (tof22_i.gt.-1) then
2069           jj=tof22_i
2070           a1 = adca(32+2*jj+1)
2071           a2 = adca(32+2*jj+2)
2072           if ((a1.lt.4095).and.(a2.lt.4095)) then
2073           a1 = a1*cos(theta)
2074           a2 = a2*cos(theta)
2075           xhelp = xhelp + sqrt(a1*a2)
2076           icount=icount+1
2077                        endif
2078                        endif
2079    
2080           if (tof31_i.gt.-1) then
2081           jj=tof31_i
2082           a1 = adca(36+2*jj+1)
2083           a2 = adca(36+2*jj+2)
2084           if ((a1.lt.4095).and.(a2.lt.4095)) then
2085           a1 = a1*cos(theta)
2086           a2 = a2*cos(theta)
2087           xhelp = xhelp + sqrt(a1*a2)
2088           icount=icount+1
2089                        endif
2090                        endif
2091    
2092           if (tof32_i.gt.-1) then
2093           jj=tof32_i
2094           a1 = adca(42+2*jj+1)
2095           a2 = adca(42+2*jj+2)
2096           if ((a1.lt.4095).and.(a2.lt.4095)) then
2097           a1 = a1*cos(theta)
2098           a2 = a2*cos(theta)
2099           xhelp = xhelp + sqrt(a1*a2)
2100           icount=icount+1
2101                        endif
2102                        endif
2103    
2104    
2105           if (icount.gt.0) xhelp=xhelp/icount
2106           if ((icount.gt.2).and.(xhelp.gt.1500.)) charge=3
2107    
2108                                      endif  ! beta_mean_tof.eq.100.
2109    
2110    c        write(*,*) 'in function charge: ',charge
2111            check_charge = charge
2112    
2113    
2114            END
2115    
2116    C****************************************************************************
2117    C****************************************************************************
2118    C****************************************************************************
2119    
2120            function newbeta(iflag,b,hitvec,resmax,qualitycut,chi2cut)
2121    
2122            include  'input_tof.txt'
2123            include  'output_tof.txt'
2124            include  'tofcomm.txt'
2125    
2126            REAL newbeta
2127            REAL resmax,qualitycut,chi2cut
2128            REAL w_i(12),w_il(6),quality,res,betachi,beta_mean_inv
2129            REAL sw,sxw,b(12),beta_mean,chi2,xhelp
2130            REAL tdcfl(4,12)
2131    
2132            INTEGER iflag,icount,hitvec(6)
2133    
2134            INTEGER itop(12),ibot(12)
2135            DATA itop /1,1,2,2,3,3,4,4,1,1,2,2/
2136            DATA ibot /5,6,5,6,5,6,5,6,3,4,3,4/
2137    
2138    C====================================================================
2139    
2140            tof11_i = hitvec(1)
2141            tof12_i = hitvec(2)
2142            tof21_i = hitvec(3)
2143            tof22_i = hitvec(4)
2144            tof31_i = hitvec(5)
2145            tof32_i = hitvec(6)
2146    
2147             if (iflag.eq.1) then   ! call from tofl2com
2148             do i=1,4
2149             do j=1,12
2150              tdcfl(i,j) =  tdcflagtof(i,j)
2151             enddo
2152             enddo
2153                            endif
2154    
2155             if (iflag.eq.2) then   ! call from toftrk
2156             do i=1,4
2157             do j=1,12
2158              tdcfl(i,j) =  tdcflag(i,j)
2159             enddo
2160             enddo
2161                            endif
2162    
2163    
2164    C---  Find out ToF layers with artificial TDC values    -------------
2165    
2166            do jj=1,6
2167            w_il(jj) = 1000.
2168            enddo
2169    
2170    
2171            if (tof11_i.gt.0) then
2172            if ((tofmask(ch11a(tof11_i),hb11a(tof11_i)).gt.0).or.
2173         &   (tofmask(ch11b(tof11_i),hb11b(tof11_i)).gt.0)) then
2174            w_il(1)=0
2175            i1=tdcfl(ch11a(tof11_i),hb11a(tof11_i))
2176            i2=tdcfl(ch11b(tof11_i),hb11b(tof11_i))
2177            if ((i1.eq.1).or.(i2.eq.1)) w_il(1) = 1  ! tdcflag
2178                                                          endif
2179                               endif
2180    
2181            if (tof12_i.gt.0) then
2182            if ((tofmask(ch12a(tof12_i),hb12a(tof12_i)).gt.0).or.
2183         &   (tofmask(ch12b(tof12_i),hb12b(tof12_i)).gt.0)) then
2184            w_il(2)=0
2185            i1=tdcfl(ch12a(tof12_i),hb12a(tof12_i))
2186            i2=tdcfl(ch12b(tof12_i),hb12b(tof12_i))
2187            if ((i1.eq.1).or.(i2.eq.1)) w_il(2) = 1  ! tdcflag
2188                                                          endif
2189                               endif
2190    
2191            if (tof21_i.gt.0) then
2192            if ((tofmask(ch21a(tof21_i),hb21a(tof21_i)).gt.0).or.
2193         &   (tofmask(ch21b(tof21_i),hb21b(tof21_i)).gt.0)) then
2194            w_il(3)=0
2195            i1=tdcfl(ch21a(tof21_i),hb21a(tof21_i))
2196            i2=tdcfl(ch21b(tof21_i),hb21b(tof21_i))
2197            if ((i1.eq.1).or.(i2.eq.1)) w_il(3) = 1  ! tdcflag
2198                                                          endif
2199                               endif
2200    
2201            if (tof22_i.gt.0) then
2202            if ((tofmask(ch22a(tof22_i),hb22a(tof22_i)).gt.0).or.
2203         &   (tofmask(ch22b(tof22_i),hb22b(tof22_i)).gt.0)) then
2204            w_il(4)=0
2205            i1=tdcfl(ch22a(tof22_i),hb22a(tof22_i))
2206            i2=tdcfl(ch22b(tof22_i),hb22b(tof22_i))
2207            if ((i1.eq.1).or.(i2.eq.1)) w_il(4) = 1  ! tdcflag
2208                                                          endif
2209                               endif
2210    
2211            if (tof31_i.gt.0) then
2212            if ((tofmask(ch31a(tof31_i),hb11a(tof31_i)).gt.0).or.
2213         &   (tofmask(ch31b(tof31_i),hb31b(tof31_i)).gt.0)) then
2214            w_il(5)=0
2215            i1=tdcfl(ch31a(tof31_i),hb31a(tof31_i))
2216            i2=tdcfl(ch31b(tof31_i),hb31b(tof31_i))
2217            if ((i1.eq.1).or.(i2.eq.1)) w_il(5) = 1  ! tdcflag
2218                                                          endif
2219                               endif
2220    
2221            if (tof32_i.gt.0) then
2222            if ((tofmask(ch32a(tof32_i),hb32a(tof32_i)).gt.0).or.
2223         &   (tofmask(ch32b(tof32_i),hb32b(tof32_i)).gt.0)) then
2224            w_il(6)=0
2225            i1=tdcfl(ch32a(tof32_i),hb32a(tof32_i))
2226            i2=tdcfl(ch32b(tof32_i),hb32b(tof32_i))
2227            if ((i1.eq.1).or.(i2.eq.1)) w_il(6) = 1  ! tdcflag
2228                                                          endif
2229                               endif
2230    
2231    C------------------------------------------------------------------------
2232    C---  Set weights for the 12 measurements using information for top and bottom:
2233    C---  if no measurements: weight = set to very high value=> not used
2234    C---  top or bottom artificial: weight*sqrt(2)
2235    C---  top and bottom artificial: weight*sqrt(2)*sqrt(2)
2236    
2237           DO jj=1,12
2238           if (jj.le.4)           xhelp = 0.11            ! S1-S3
2239           if ((jj.gt.4).and.(jj.le.8)) xhelp = 0.18      ! S2-S3
2240           if (jj.gt.8)           xhelp = 0.28            ! S1-S2
2241           if ((w_il(itop(jj)).eq.1000.).and.(w_il(ibot(jj)).eq.1000.))
2242         &   xhelp = 1.E09
2243           if ((w_il(itop(jj)).eq.1).or.(w_il(ibot(jj)).eq.1.))
2244         &   xhelp = xhelp*1.414
2245           if ((w_il(itop(jj)).eq.1).and.(w_il(ibot(jj)).eq.1.))
2246         &   xhelp = xhelp*2.
2247           w_i(jj) = 1./xhelp
2248           ENDDO
2249    
2250    C========================================================================
2251    C--- Calculate mean beta for the first time -----------------------------
2252    C--- We are using "1/beta" since its error is gaussian ------------------
2253    
2254            icount=0
2255            sw=0.
2256            sxw=0.
2257            beta_mean=100.
2258    
2259            DO jj=1,12
2260            IF ((abs(1./b(jj)).gt.0.1).and.(abs(1./b(jj)).lt.15.)) THEN
2261                icount = icount+1
2262                sxw    = sxw + (1./b(jj))*w_i(jj)*w_i(jj)
2263                sw     = sw + w_i(jj)*w_i(jj)
2264            ENDIF
2265            ENDDO
2266    
2267            if (icount.gt.0) beta_mean=1./(sxw/sw)
2268            beta_mean_inv = 1./beta_mean
2269    
2270      
2271    C--- Calculate beta for the second time, use residuals of the single
2272    C--- measurements to get a chi2 value
2273    
2274            icount  = 0
2275            sw      = 0.
2276            sxw     = 0.
2277            betachi = 100.
2278            chi2    = 0.
2279            quality = 0.
2280    
2281            DO jj=1,12
2282            IF ((abs(1./b(jj)).gt.0.1).and.(abs(1./b(jj)).lt.15.)
2283         &                                .and.(w_i(jj).GT.0.01)) THEN
2284                res    = beta_mean_inv - (1./b(jj)) ;
2285                if (abs(res*w_i(jj)).lt.resmax) THEN
2286                chi2   = chi2 + (res*w_i(jj))**2.
2287                icount = icount+1
2288                sxw    = sxw + (1./b(jj))*w_i(jj)*w_i(jj)
2289                sw     = sw + w_i(jj)*w_i(jj)
2290                                                ENDIF
2291            ENDIF
2292            ENDDO
2293    
2294    c        quality = sw
2295            quality = sqrt(sw)
2296    
2297            if (icount.eq.0) chi2 = 1000.
2298            if (icount.gt.0) chi2 = chi2/(icount)
2299    
2300            if (icount.gt.0) betachi=1./(sxw/sw);
2301    
2302            beta_mean=100.
2303            if ((chi2.lt.chi2cut).and.(quality.gt.qualitycut))
2304         &  beta_mean = betachi
2305            newbeta = beta_mean
2306    
2307            END
2308    
2309    C****************************************************************************
2310    
2311    

Legend:
Removed from v.1.6  
changed lines
  Added in v.1.8

  ViewVC Help
Powered by ViewVC 1.1.23