/[PAMELA software]/tof/ground/toftrack_101.tar
ViewVC logotype

Annotation of /tof/ground/toftrack_101.tar

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.1 - (hide annotations) (download) (as text)
Thu Mar 9 12:31:47 2006 UTC (18 years, 10 months ago) by pam-de
Branch point for: v_tag, MAIN
File MIME type: application/x-tar
Initial revision

1 pam-de 1.1 Makefile0000640000076500001440000000156710314237651011406 0ustar mennusers# Fortran flags
2     FC=g77
3     FFLAGS=-fvxt -fno-automatic -Wall -Wno-globals -fbounds-check
4     # C flags
5     CC=gcc
6     CFLAGS=-Wall -O2
7     CFLADJ=-c
8    
9     # used libraries
10     #LIBS=-L/cern/pro/lib -lkernlib -lpacklib -lgraflib -lmathlib -lnsl
11     LIBS= `cernlib kernlib packlib graflib mathlib`
12    
13     template.exe: template-static
14    
15     # this directive links static libraries
16     template-static: template.f trk_level2.f
17     $(FC) $(FFLAGS) template.f -o template.exe $(TRK_GRND)/lib/libtrk.a $(LIBS)
18    
19     # the next directive link dinamyc library (.so)
20     # NB! in order to link dynamically it must be added the library path to
21     # LD_LIBRARY_PATH (in the ./bashrc)
22     template-dynamic: template.f trk_level2.f
23     $(FC) $(FFLAGS) -o template.exe template.f $(LIBS) -L$(TRK_GRND)/lib -ltrk
24    
25     toftrack: toftrack.f trk_level2.f
26     $(FC) $(FFLAGS) toftrack.f -o toftrack.exe $(TRK_GRND)/lib/libtrk.a $(LIBS)
27    
28     clean:
29     rm -f *.o
30     rm -f *.exe
31     rm -f *~
32    
33     README0000664000076500001440000001724410314477647010646 0ustar mennusers
34     1) The ToF software uses the Tracking software V2.00
35     It is assumed that you have created all the directories and the compiling
36     of the three executables "level0.exe", "level1.exe" and "level2.exe"
37     was succesful.
38    
39     2) Copy the file toftrack.tar to the "utilities/template" directory (where
40     the program template.f is located), untar the file toftrack.tar.
41    
42     The following files will be extracted:
43     Makefile (the old Makefile will be overwritten)
44     run-test.sh
45     tofcalib.rz
46     toftrack.f
47     common_tof.f
48     tofroutine.f
49     trk_level2.f (the old trk_level2.f was not correct)
50     common_tofroutine.f
51    
52     3)Create the executable toftrack.exe doing
53     # make toftrack
54    
55     4) The "level*.exe" programs in your working directory were run by doing
56    
57     #./run-test.sh some_filename.txt level0/1/2 &
58    
59     Copy the new "run-test.sh" from the template directory to the working
60     directory. Copy toftrack.exe to the working directory
61     After you have done step 5 (see below) you can run the toftrack software
62     analogue to the command for the level0/1/2 software:
63    
64     #./run-test.sh some_filename.txt toftrack &
65    
66     In the file good_files.tar.gz there is a list of good files from the Roma
67     tests.
68    
69     5) Untar the file tofcalib.tar in your rz-data directory (where the level2
70     and tof rz-files are located). This will create a standard "tofcalib.rz"
71     file plus the calibration files for the Roma data
72     "DW_******_***_tofcalib.rz"
73    
74    
75     ---------------------------------------------------------------------------
76    
77     "tracktof" will read the appropriate level2, tof, and tofcalib file. If
78     there is no tofcalib file for this data run, the standard calibration is
79     used (There will be a message saying "Could not find.... Will use the
80     standard calibration")
81    
82    
83     "tracktof" will create a new rz file DW_******_**_toftrack.rz" combining
84     the level2 data, the (raw) tof data, plus the variables calculated in the
85     tofroutine.
86    
87     The structure looks like this:
88    
89    
90     ******************************************************************
91     * Ntuple ID = 2 Entries = 1185 TOF
92     ******************************************************************
93     * Var numb * Type * Packing * Range * Block * Name *
94     ******************************************************************
95     * 1 * L*4 * 1 * * EVENT * GOOD
96     * 2 * I*4 * * * EVENT * NEV_TRK
97     * 1 * I*4 * * * CPU * PKT_TYPE
98     * 2 * I*4 * * * CPU * PKT_NUM
99     * 3 * I*4 * * * CPU * OBT
100     * 4 * I*4 * * * CPU * WHICH_CALIB
101     * 1 * I*4 * * * TOF * TDCID(12)
102     * 2 * I*4 * * * TOF * EVCOUNT(12)
103     * 3 * I*4 * * * TOF * TDCMASK(12)
104     * 4 * I*4 * * * TOF * ADC(4,12)
105     * 5 * I*4 * * * TOF * TDC(4,12)
106     * 6 * I*4 * * * TOF * TEMP1(12)
107     * 7 * I*4 * * * TOF * TEMP2(12)
108     * 8 * R*4 * * * TOF * BETA(5)
109     * 9 * R*4 * * * TOF * XTOF(3)
110     * 10 * R*4 * * * TOF * YTOF(3)
111     * 11 * R*4 * * * TOF * ADC_C(4,12)
112     * 12 * I*4 * * * TOF * IFLAG(6)
113     * 13 * I*4 * * * TOF * JFLAG(6)
114     * 14 * R*4 * * * TOF * XOUT(3)
115     * 15 * R*4 * * * TOF * YOUT(3)
116     * 1 * I*4 * * * TRIGGER * TRIG_EVCOUNT
117     * 2 * I*4 * * * TRIGGER * PMTPL(3)
118     * 3 * I*4 * * * TRIGGER * TRIGRATE(6)
119     * 4 * I*4 * * * TRIGGER * DLTIME(2)
120     * 5 * I*4 * * * TRIGGER * S4CALCOUNT(2)
121     * 6 * I*4 * * * TRIGGER * PMTCOUNT1(24)
122     * 7 * I*4 * * * TRIGGER * PMTCOUNT2(24)
123     * 8 * I*4 * * * TRIGGER * PATTERNBUSY(3)
124     * 9 * I*4 * * * TRIGGER * PATTERNTRIG(6)
125     * 10 * I*4 * * * TRIGGER * TRIGCONF
126     * 1 * I*4 * * [0,50] * TRACKS * NTRK
127     * 2 * U*4 * 6 * [0,50] * TRACKS * IMAGE(NTRK)
128     * 3 * R*4 * * * TRACKS * XM(6,NTRK)
129     * 4 * R*4 * * * TRACKS * YM(6,NTRK)
130     * 5 * R*4 * * * TRACKS * ZM(6,NTRK)
131     * 6 * R*4 * * * TRACKS * RESX(6,NTRK)
132     * 7 * R*4 * * * TRACKS * RESY(6,NTRK)
133     * 8 * R*4 * * * TRACKS * AL(5,NTRK)
134     * 9 * R*4 * * * TRACKS * COVAL(5,5,NTRK)
135     * 10 * R*4 * * * TRACKS * CHI2(NTRK)
136     * 11 * U*4 * 1 * [0,1] * TRACKS * XGOOD(6,NTRK)
137     * 12 * U*4 * 1 * [0,1] * TRACKS * YGOOD(6,NTRK)
138     * 13 * R*4 * * * TRACKS * XV(6,NTRK)
139     * 14 * R*4 * * * TRACKS * YV(6,NTRK)
140     * 15 * R*4 * * * TRACKS * ZV(6,NTRK)
141     * 16 * R*4 * * * TRACKS * AXV(6,NTRK)
142     * 17 * R*4 * * * TRACKS * AYV(6,NTRK)
143     * 18 * R*4 * * * TRACKS * DEDXP(6,NTRK)
144     * 1 * I*4 * * * SINGLETS * NCLSX(6)
145     * 2 * I*4 * * * SINGLETS * NCLSY(6)
146     ******************************************************************
147     * Block * Entries * Unpacked * Packed * Packing Factor *
148     ******************************************************************
149     * EVENT * 1185 * 8 * 5 * 1.600 *
150     * CPU * 1185 * 16 * 16 * 1.000 *
151     * TOF * 1185 * 932 * 932 * 1.000 *
152     * TRIGGER * 1185 * 288 * 288 * 1.000 *
153     * TRACKS * 1185 * 22004 * Var. * Variable *
154     * SINGLETS * 1185 * 48 * 48 * 1.000 *
155     * Total * --- * 23296 * Var. * Variable *
156     ******************************************************************
157     * Blocks = 6 Variables = 51 Max. Columns = 5824 *
158     ******************************************************************
159    
160    
161    
162     The variables calculated in "TOFROUTINE" are the last ones in the block
163     "TOF":
164    
165    
166     BETA(5): four values (1-4) for beta from S11-S31, S12-S32, S21-S31
167     and S22-S32.
168     if there is no valid signal beta is set to "100".
169     if there are four values for beta, the weighted mean is
170     calculated and put into beta(5). So it is possible for
171     the user to calculate his own mean value by using the
172     single values.
173    
174     XTOF(3): The x-position in the 3 different layers using the ToF
175     timing (So, for the x-coordinate we use S12, S21,S32).
176     If we cannot find a valid timing the value is set to "1000"
177    
178     YTOF(3): The same for y-position using S11, S22,S31
179    
180     ADC_C(4,12): normalized ADC values, the value in the middle of the
181     paddle is set to "1", using the (sometimes poor) attenuation
182     fit curves. The ADC_C matrix is analog to the ADC matrix
183     for the raw data, so one can use the same channel map.
184    
185     IFLAG(6): 6 values for the six layers:
186     "0" if no hit in this layer
187     "-1" if more than one hit
188     otherwise the number of the hitted paddle ("hit" = good
189     TDC values on both sides)
190    
191     JFLAG(6): 6 values for the six layers: coded value to see which
192     strips have valid hits:
193     for i=1 to (number of strips) do
194     if (paddle "i" = hit) then jflag = jflag + 2**(i-1)
195    
196    
197    
198    
199     common_tof.f0000664000076500001440000000125410314004226012242 0ustar mennusers integer tdcid(12),evcount(12)
200     integer tdcmask(12),adc(4,12),tdc(4,12)
201     integer temp1(12),temp2(12)
202     COMMON / tofvar /tdcid,evcount,tdcmask,adc,tdc,temp1,temp2
203    
204     integer*4 trig_evcount
205     integer pmtpl(3), trigrate(6), dltime(2), s4calcount(2)
206     integer pmtcount1(24), pmtcount2(24)
207     integer*4 patternbusy(3)
208     integer patterntrig(6), trigconf
209     COMMON / trig / trig_evcount, pmtpl, trigrate, dltime,
210     & s4calcount, pmtcount1, pmtcount2,
211     & patternbusy, patterntrig, trigconf
212    
213    
214     parameter (ntp_tof=17)
215     parameter (ntp_tofcalib=60)
216    
217     logical good
218     integer nev_trk
219     common / event_tof /good,nev_trk
220     common_tofroutine.f0000664000076500001440000001107510314004226013652 0ustar mennusers* DATA ZTOF/55.,25.,-23/
221     *
222     * TOF data
223     * first index : 1 = A, 2 = B
224     * second index : 1.. number of paddle
225     * third index : 1 = TDC, 2 = ADC
226    
227     c INTEGER tof11(2,8,2),tof12(2,6,2)
228     c INTEGER tof21(2,2,2),tof22(2,2,2)
229     c INTEGER tof31(2,3,2),tof32(2,3,2)
230     REAL tof11(2,8,2),tof12(2,6,2)
231     REAL tof21(2,2,2),tof22(2,2,2)
232     REAL tof31(2,3,2),tof32(2,3,2)
233    
234     c Normalized ADC value
235     REAL adc_c(4,12)
236    
237     c k1 constans for calculation of beta
238     REAL k1_s11s31(24),k1_s12s32(18),k1_S21S31(6),k1_S22S32(6)
239    
240     c middle y (or x) position of the upper and middle ToF-Paddle
241     c to calculate theta-angle without track information
242     REAL tof11_x(8), tof21_y(2), tof31_x(3)
243     REAL tof12_y(6), tof22_x(2), tof32_y(3)
244    
245     c relation of time differences in a tof paddle and the location of the
246     c passage of the particle
247     c first index : 1... number of paddle
248     c second index : 1 = offset, 2 = slope
249     REAL y_coor_lin11(8,2),x_coor_lin12(6,2)
250     REAL x_coor_lin21(2,2),y_coor_lin22(2,2)
251     REAL y_coor_lin31(3,2),x_coor_lin32(3,2)
252    
253     c ADC(x) - correction
254     c first index : 1 = left, 2 = right
255     c second index : 1..8 number of paddle
256     c third index: parameter as follows
257     c left: xkorr=par(1)*exp(-x/par(2))
258     c right:xkorr=par(1)*exp(x/par(2))
259     c then:adc(x,right/left)=adc(x,right/left)/xkorr
260     c normalize to x=0 (middle of paddle)
261     REAL adcx11(2,8,2),adcx12(2,6,2)
262     REAL adcx21(2,2,2),adcx22(2,2,2)
263     REAL adcx31(2,3,2),adcx32(2,3,2)
264    
265    
266     c Time Walk - correction
267     c first index : 1 = left, 2 = right
268     c second index : 1..8 number of paddle
269     REAL tw11(2,8),tw12(2,6)
270     REAL tw21(2,2),tw22(2,2)
271     REAL tw31(2,3),tw32(2,3)
272    
273    
274     c value for status of each PM-data
275     c first index : 1 = left, 2 = right
276     c second index : 1... number of paddle
277     INTEGER tof11_event(2,8),tof12_event(2,6)
278     INTEGER tof21_event(2,2),tof22_event(2,2)
279     INTEGER tof31_event(2,3),tof32_event(2,3)
280    
281     C----
282    
283     INTEGER left,right,top,bot,mid,itdc,iadc
284     INTEGER tdc_ev, adc_ev, none_ev, none_find
285     INTEGER offset, slope
286     INTEGER tof11_i,tof21_i,tof31_i,tof11_j,tof21_j,tof31_j
287     INTEGER tof12_i,tof22_i,tof32_i,tof12_j,tof22_j,tof32_j
288     * REAL adcoff(4,2,52),a,b
289     c REAL delta_x12,delta_y12,delta_x23,delta_y23,delta_x13,delta_y13
290     REAL xtofpos(3),ytofpos(3)
291     REAL xkorr, secure
292     INTEGER i, j, ihelp
293     LOGICAL check
294     REAL theta12,theta13,theta23
295    
296     REAL beta_a(5)
297    
298     INTEGER tof_i_flag(6),tof_j_flag(6)
299    
300    
301     DATA TOFfst / 0/
302    
303     PARAMETER (tofarm23 = 45.)
304     PARAMETER (tofarm13 = 81.)
305     PARAMETER (c2_13=108.) ! = 2.*tofarm13*0.01/(3.E08*50.E-12)
306     PARAMETER (c2_23=60.) ! = 2.*tofarm23*0.01/(3.E08*50.E-12)
307    
308    
309     * S11 8 paddles 33.0 x 5.1 cm
310     * S12 6 paddles 40.8 x 5.5 cm
311     * S21 2 paddles 18.0 x 7.5 cm
312     * S22 2 paddles 15.0 x 9.0 cm
313     * S31 3 paddles 15.0 x 6.0 cm
314     * S32 3 paddles 18.0 x 5.0 cm
315    
316     DATA tof11_x/ -17.85,-12.75,-7.65,-2.55,2.55,7.65,12.75,17.85/
317     DATA tof12_y/ -13.75,-8.25,-2.75,2.75,8.25,13.75/
318     DATA tof21_y/ -3.75,3.75/
319     DATA tof22_x/ -4.5,4.5/
320     DATA tof31_x/ -6.0,0.,6.0/
321     DATA tof32_y/ -5.0,0.0,5.0/
322    
323     integer ch11a(8),hb11a(8),ch11b(8),hb11b(8)
324     integer ch12a(6),hb12a(6),ch12b(6),hb12b(6)
325     integer ch21a(2),hb21a(2),ch21b(2),hb21b(2)
326     integer ch22a(2),hb22a(2),ch22b(2),hb22b(2)
327     integer ch31a(3),hb31a(3),ch31b(3),hb31b(3)
328     integer ch32a(3),hb32a(3),ch32b(3),hb32b(3)
329    
330    
331     data ch11a / 4, 4, 4, 4, 1, 1, 2, 2/
332     data hb11a / 1, 3, 5, 7, 10, 12, 2, 4/
333     data ch11b / 2, 2, 2, 2, 1, 1, 1, 1/
334     data hb11b / 6, 8, 12, 10, 8, 6, 4, 2/
335    
336     data ch12a / 3, 3, 3, 3, 3, 3/
337     data hb12a / 2, 4, 6, 8, 10, 12/
338     data ch12b / 4, 4, 4, 4, 4, 4/
339     data hb12b / 12, 10, 8, 6, 4, 2/
340    
341     data ch21a / 1, 1/
342     data hb21a / 1, 5/
343     data ch21b / 2, 1/
344     data hb21b / 9, 7/
345    
346     data ch22a / 1, 1/
347     data hb22a / 3, 9/
348     data ch22b / 2, 1/
349     data hb22b / 11, 11/
350    
351     data ch31a / 2, 3, 3/
352     data hb31a / 7, 9, 11/
353     data ch31b / 2, 2, 2/
354     data hb31b / 5, 3, 1/
355    
356     data ch32a / 3, 3, 4/
357     data hb32a / 1, 5, 9/
358     data ch32b / 3, 3, 4/
359     data hb32b / 3, 7, 11/
360    
361     common / tofcalc /k1_s11s31,k1_s12s32,k1_S21S31,
362     & k1_S22S32,beta_a,
363     & adcx11,adcx12,adcx21,adcx22,adcx31,adcx32,
364     & tw11,tw12,tw21,tw22,tw31,tw32,
365     & y_coor_lin11,x_coor_lin12,x_coor_lin21,
366     & y_coor_lin22,y_coor_lin31,x_coor_lin32,
367     & xtofpos,ytofpos,adc_c,tof_i_flag,tof_j_flag
368     good_files.tar.gz0000744000076500001440000000325310314506262013203 0ustar mennusers‹ MCí]AŽ7 ܳ_á8)QêyM°N€À—p$ÈëÝ#v«Ö>l CõvW]¶³3³[¨&E‘R²¤iyþáË__ž…$)Õ’žÒŠVëö³ôŸ’Ÿ$©iN%I[_/µÉÓûô°oôüþåùóû÷Oûõ—O¯¼îÏO?þ9â…"uýLéönöW!& ë{¨ýÿÑÿ²š}ø?å»ÿ-Óÿ!pýWÿ·wƒ. ·A%
369     ¨‚æN%­¿& 
370     úâ…O›cÀ™ëÿTÛîÿܪuÿ—LÿG ë/°¬À²ËJ·ì F÷ž®é!òÿÚJK¥ˆçÿ•þÀðt¥§¯ˆ®>Dþ_ï™@ÊÕóÿDÿGÀõGüψÿñ¿à/(ß¾À@+h]@Ym8\‘Éñ_ëæɹ%ÿôºþ{[÷ôìoEDÁýÿq®ÿ}ýïþ/=þ·Äú_†é üo ´.|@œ]Óz”õ¿¨•-þ7ú?®ÿ³¿
371     1®ÿÜø¿zÿMT»ÿ«ÑÿþßÖôkúŠ¬ aÐðÚƵ›‡ 99þ[qÿk*j™õÿ@ #¿pºVÐF§Ÿ.ïäõÿ–ÿ¯þ¯÷…÷¿Òÿöæšþ’pý:FþßýoŒÿèú/Hï¤÷ – „ ¬àÍÃ…<LþŸ[+^ÿ§ÿC0Œ¼ÀÓÞô+7<ný©0û»ÿ?\ôÃäÿ%Iåþ †½YÈ»$ÜÿsóÿÑÿ£Ùªçÿ÷eý€áÿ‚HÏöþëÀEÿ êþO¯¬ÿŶý[W½þ׌ù†é=ÿWLï)¦÷Ó{šÆ³¢S/¨°ƒàmÂ… èÿÅÿ{üo¥$“mþ—õÿ ÷¾02G®}²ÿ·þßVîÀÍÿœÿ Á0½·÷ª"þ+â¿"è+g‚k:Ùÿ[ýõ¿X)îæÿ!èúcþO1ÿ§˜ÿë”Gvœ.ï\ÿïó¿Ýÿ"<ÿ'ÃÞ§Wк€ú¡b*X1¬˜
372     î´€(—+°ÿÿšÿsÚü¿¦"ûù…þ@×ó¿*h- ZA(› ß
373     Üÿûÿ¯åÿEà+œÿ ÄnÙíx¿Nñ(6ýœ®ôÜøÿbþw] lý¿ÜÿÁîte#ï%áú&þK®<ÿ/Ãÿ·ô3RÌ=ý“£+]?h{tÿÏ+ýZ¶þ•d~þocþ׫wLú+&ýµ¡€YaŬ°bVXÛ·o¶€ÞÝW «6ïŸ&Üxx \ÿÉûˆÿ©jóó¿YÿÁðÿfC¢•Sç‡?e'ÏÿŒþ?½§ìÿD×C¿ºÐô—‚‹>ùþ½ÿgÍÿ“ŸÿÃø„aúž½ç4®qª |*œ.ïdÿïõ½ŸûßÏÿ4åþºþÊé«Âõ?Äý_÷ý¿b­ŸÿiÆùŸtý3‚~FÐÏ{¥Ï©²{ï4èš–ƒø_ššÏÿ›1ÿ맆GÁhtÊŠüiàš%ÿOÍ2×ÿ‘žfÿÏ%ÑõŸ|ÿÇØÿ—’sõû„õÿ¸þúA¿"èW$KŠ²áè pº€ÞõM§ø4Á§ >MðiÂiãâþ_–Ùõ¿1ÿ+­úùf<ÿ/]ÿ1ôïTA3(“þ3Âåìÿ½ÿ§Z.µ²þˆaï§/ ¼§÷äèJçÉù*»ÿKÍ~þ·ðüŸ¸þˆÿ¨ÿãþo§Ô@+hÝž ï[ð¾åû÷ý?¸2\†ƒôÿ­þo©¹ÿÙÿ‚áHƒ9¹½w¸èsó±áñþŸBÿ‡ ëM?Á¦Ÿ`Ó„gÜ
374     žq+xÞnô6èVô?W`ö_K|çëË­Šlõ¿Âú_ºþ¨ÿã*à,œÿ¹\éCÔÿ»ÿ“¯ÿïÇ€ÒÿØœ.{œnx4<
375     xÓ÷YáòNÎÿýþÕÿVE óÿ@ {8Ý@·LÁSaÁSaÁ¯-<ümÂÕ;Jü·ÖÔûÿ*óÿ ÷nN¿Áé78ž.ïdÿ{ý¿û¿zýMèÿ {8ü:¸‹rÿ׿©ÿ—Z›Ÿÿk•ý?!pýGÐÇ¥—þe\ú—qéŸÓ
376     ê[ŠcTðÂþCÂÅ9Lü¯m;ÿËXÿ Á0§Á§Üÿ¿ºè“û_ÔÿZj™õ¿@¸þˆÞèÿÅ­`WeE+ ® ÊÊSÞ(\½CÌÿ[ºEèçsÿ?»{·‰<Üé•q§WÆ^y»Ókö×&‚ ‚ ‚ þ#¾A¥´àÈrun-test.sh0000751000076500001440000001003310314240675012052 0ustar mennusers#################################################################
377     # Shell script to run the tracker reduction programs
378     #################################################################
379     #
380     #
381     #
382     #----------------------------------------------------------------
383     #local variables:
384     rawdata_dir='raw-data/'
385     rzdata_dir='rz-test/'
386    
387     if [ -n "$1" -a -n "$2" ] ;then
388    
389     lines=$(grep -n -c $ $1)
390     list=`more $1`
391    
392     #################################################################
393     # ------------------------- LEVEL0 ------------------------------
394     #
395     # This part of the script creates the input to level0.exe and run it,
396     # starting from a txt list of file IDs (format: YYMMDD_XXX).
397     #
398     # Tipical input of level0.exe is as follows:
399     # ../level0.exe << EOF
400     # 5 # N. of downlink to process
401     # raw-data/ # raw-data directory
402     # 050323_011 # 1^ file id
403     # 050324_001 # 2^
404     # 050324_002 # ....
405     # 050324_003 #
406     # 050324_004 #
407     # rz-test/ # output rz directory
408     # 100000 # maximum number of events to be processed
409     # EOF
410     #################################################################
411     if [ $2 = 'level0' ]; then
412     echo $lines > input
413     echo $rawdata_dir >> input
414     for dnlk in $list
415     do
416     echo $dnlk >> input
417     done
418     echo $rzdata_dir >> input
419     echo '100000' >> input
420     ./level0.exe < input > $1-level0
421     # rm -f input
422    
423     #################################################################
424     # ------------------------- LEVEL1 ------------------------------
425     #
426     # This script creates the input to level1.exe and run it
427     # starting from a txt list of file IDs (format: YYMMDD_XXX).
428     #
429     # Tipical input of level1.exe is as follows:
430     # ../level1.exe << EOF
431     # raw-data/ # raw-data directory
432     # 050323_011 # file id
433     # rz-test/ # input/output rz directory
434     # 100000 # maximum number of events to be processed
435     # EOF
436     #################################################################
437     elif [ $2 = 'level1' ]; then
438     if [ -f $1-level1 ];then
439     rm $1-level1
440     fi
441     touch $1-level1
442     for dnlk in $list
443     do
444     ./level1.exe >> $1-level1 <<EOF
445     $rzdata_dir
446     $dnlk
447     100000
448     EOF
449     done
450     #################################################################
451     # ------------------------- LEVEL2 ------------------------------
452     #
453     # This script creates the input to level2.exe and run it
454     # starting from a txt list of file IDs (format: YYMMDD_XXX).
455     #
456     # Tipical input of level1.exe is as follows:
457     # ../level2.exe << EOF
458     # raw-data/ # raw-data directory
459     # 050323_011 # file id
460     # rz-test/ # input/output rz directory
461     # 100000 # maximum number of events to be processed
462     # F # (debug flag)
463     # EOF
464     #################################################################
465     elif [ $2 = 'level2' ]; then
466     if [ -f $1-level2 ];then
467     rm $1-level2
468     fi
469     touch $1-level2
470     for dnlk in $list
471     do
472     ./level2.exe >> $1-level2 <<EOF
473     $rzdata_dir
474     $dnlk
475     100000
476     COG2
477     F
478     EOF
479     done
480     #################################################################
481     # --------------------- TOFTRACK -----------------------------
482     #
483     # This script creates the input to tofsoft.exe and run it
484     # starting from a txt list of file IDs (format: YYMMDD_XXX).
485     #
486     # Typical input of toftrack.exe is as follows:
487     # ../toftrack.exe << EOF
488     # raw-data/ # raw-data directory
489     # 050323_011 # file id
490     # rz-test/ # input/output rz directory
491     # 100000 # maximum number of events to be processed
492     # F # (debug flag)
493     # EOF
494     #################################################################
495     elif [ $2 = 'toftrack' ]; then
496     if [ -f $1-toftrack ];then
497     rm $1-toftrack
498     fi
499     touch $1-toftrack
500     for dnlk in $list
501     do
502     ./toftrack.exe <<EOF
503     $rzdata_dir
504     $dnlk
505     1
506     100000
507     EOF
508     done
509     fi
510     else
511     echo ""
512     echo "USAGE:"
513     echo "./run-test.sh downlink-list-file-name level0/1/2/tofsoft"
514     echo "( ex: ./run-test.sh 050323.txt level0 & )"
515     echo "( ex: ./run-test.sh 050323.txt level1 & )"
516     echo "( ex: ./run-test.sh 050323.txt level2 & )"
517     echo "( ex: ./run-test.sh 050323.txt toftrack & )"
518     echo ""
519     fi
520    
521     tofcalib.rz0000644000076500001440000044000010314241134012066 0ustar mennusersUC—S-- ¡.å¡.åýèx7 8D&(`¥<ðˆ™‹% VÀð¡.åþý<'ù<'õ<'ñ<'í<'é<'å<'á<'Ý<'Ù<'Õ<'Ñ<'Í<'É<'Å<'Á<' ½<'!¹<'"µ<'#±<'$­<'%©<'&¥< ¡.å7¡.å¡.å¡.å ¡.å¡.å¡.å¡.å ¡.å¡.å¡.å¡.å ¡.å¡.å¡.å¡.å ¡.å¡.å¡.å¡.å ¡.å¡.å¡.åû Câ Cá GÜ Gó GòHCONñB
522     \B~õÃB,{ÁÛ…@@Á<£×Án¸RA„£×?ï\)ÂDG®Á„õÃÁø(ö¼ÌÍÂz{›W
523     †aHÂë…ÂQ\AQÂB*ë…Aï33ÁƒÂA͸ÁDzáû ?ç ?æ Cá Gó GñHCONñÂÈšÂ[¸RÂ×
524     à ³3¤ǮÂΣ×ÃÅŸÂÂÅÂÂi\)À…p¤ÁÄ{Â(…A5™šÀθRÁžzáBáHÀä(öû ;ì ;ë ?æ Gó GðHCONñAθRBb\B(ÌÍÁS×
525     AÂ@AG®û 7ñ 7ð ;ë Gó GïHCONñÂQìA«×
526     @áHÂä=qÂhzáÂœ33û 3ö 3õ 7ð Gó GîHCONñÁ˜ÌÍÁ×
527     ÁÎQìÁR¸RÁ÷®Á©
528     =Á9™šÁ\QìÀffÀzáÀë…À£×À£×À(QìÀ*áHÀ%Âû /û /ú 3õ Gó GíHCONñAK…A„õÃ@ÁG®Á²(öÁ×
529     Átõÿê=qÀ(ö¿ü(öÀ¸À¸R¿ü(öû , +ÿ /ú Gó GìHCONñA­33AF=q¿Ã×
530     ¿Â\û ( ( +ÿ Gó GëHCONñÁÕë…Â7®¿ìÌÍ¿ÁG®û $
531     $ ( Gó Gê HCONñÁ³33Â&p¤ÂÌÍÀ[…Àz=qÀ`£×û   $  Gó Gé
532     HCONñ?Ë…@j=qÁ°záÀVffÀn{ÀhQìû    Gó Gè HCONñû    Gó Gç HCONñû    Gó Gæ HCONñû # "  Gó GåHCONñû ( ' " Gó GäHCONñû - , ' Gó GãHCONñû 2 1 , Gó GâHCONñB…úáBgzáBA®Bg=qB—p¤Bx£×BŒk…B€\)Bz{Bˆ¸B¨Ç®B33B¢¸BCG®B.£×A“33A%G®A2\A%p¤A'…Ap¤AzáA A ÌÍA ®A4A{@èA(ö@ÐõÃA G®@µp¤û 7 6 1 Gó GáHCONñBõÃB33BÂA홚BHBv¸RAù™šBM¸B<B®B ÌÍBÂA33A£×A=qAffARáHA0õÃADzáA\(öA+33A™šAXQìA”\û ü< ü; 6 Gó GàHCONñB²ffB«W
533     B6(öB‘£×AÌÌÍAË™šBpë…A«…û øA ø@ ü; Gó GßHCONñBH{B@QìBŒ€Bƒ³3Eª&A½×
534     A»G®AÊÌÍû ôF ôE ø@ Gó GÞHCONñBñ³3BÀ#×B¹k…B£uÃB‘(öB¾{@Æff@ᙚ@´ÌÍ@­¸@ºáH@¾ffû ðK ðJ ôE Gó GÝHCONñB”Š=B¥=qBªáHBÉ€BÈõÃBœ¸RA
535     áH@ºáH@¸Qì@ÝÂ@êáH@θR. WÁ ãN ïV H‰ H¢ I- IF IÑ Iê Ju JŽ K K2 K½ KÖ La Lz M M M© M NM Nf Nñ O
536     O• O® P9 PR PÝ Pö Q Qš R% R> RÉ Râ Sm S† T T* Tµ TÎ UY Ur Uý Wî ðK H HHNAM€" /,-ü£ê ôF I4 I3HNAM€" -)-ü£ö øA IØ I×HNAM€" +
537     &-ü¤ ü< J| J{HNAM€" )
538     #-ü¤
539      7 K KHNAM€" ' -ü¤ 2 KÄ KÃHNAM€" %"-ü¤* - Lh LgHNAM€" $-ü£¶ ( M M HNAM€" #-ü£¾ # M° M¯HNAM€" "-ü£Æ  NT NSHNAM€" ! -ü£Ê  Nø N÷HNAM€"   -ü£Î  Oœ O›HNAM€"  -ü£Ú  P@ P?HNAM€" 
540     -ü¤J $
541     Pä PãHNAM€"   -ü¤R ( Qˆ Q‡HNAM€"  -ü¤Z , R, R+HNAM€"  -ü¤^ /û RÐ RÏHNAM€" -ü¤b 3ö St SsHNAM€" -ü¤n 7ñ T THNAM€B
542     -ü¤~ ;ì T¼ T»HNAM€B -ü¤† ?ç U` U_HNAM€B -ü¤Ž Câ W¢ W¡HNAM€B -ü¤¢¥ ãQ WÁ I4HBLK  TOFADC32¥ ãÝ H WÁ IØHBLK  TOFADC31¥ äi I4 WÁ J|HBLK  TOFADC22¥ äõ IØ WÁ K HBLK  TOFADC21¥ å J| WÁ KÄHBLK  TOFADC12¥ æ K WÁ LhHBLK  TOFADC11¥ æ™ KÄ WÁ M HBLK  TOFTW32 ¥ ç% Lh WÁ M°HBLK  TOFTW31 ¥ ç± M WÁ NTHBLK  TOFTW22 ¥ è= M° WÁ Nø HBLK  TOFTW21 ¥ èÉ NT WÁ Oœ HBLK  TOFTW12 ¥ éU Nø WÁ P@ HBLK  TOFTW11 ¥ éá Oœ WÁ Pä
543     HBLK  TOFLIN32¥ êm P@ WÁ Qˆ HBLK  TOFLIN31¥ êù Pä WÁ R,HBLK  TOFLIN22¥ ë… Qˆ WÁ RÐHBLK  TOFLIN21¥ ì R, WÁ StHBLK  TOFLIN12¥ ì RÐ WÁ THBLK  TOFLIN11¥ í) St WÁ T¼HBLK  TOFK1D ¥ íµ T WÁ U`HBLK  TOFK1C ¥ îA T¼ WÁ W¢HBLK  TOFK1B  WÁ W½HREA€ WÁ W¾HINT€ÿÿÿèÿÿÿîÿÿÿúÿÿÿúÿÿÿøÿÿÿþÿÿÿúÿÿÿþÿÿÿþÿÿÿþÿÿÿþÿÿÿþÿÿÿýÿÿÿþÿÿÿýÿÿÿþÿÿÿþÿÿÿøÿÿÿþÿÿÿúÿÿÿþÿÿÿþÿÿÿþÿÿÿþÿÿÿþÿÿÿýÿÿÿþÿÿÿýÿÿÿþÿÿÿøÿÿÿþÿÿÿþÿÿÿúÿÿÿþÿÿÿþÿÿÿþÿÿÿþÿÿÿþÿÿÿþÿÿÿþÿÿÿþÿÿÿýÿÿÿþÿÿÿþÿÿÿýÿÿÿþ WÁ W¿HCHA€K1_S11S31 K1_S12S32 K1_S21S31 K1_S22S32 X_COOR_LIN11Y_COOR_LIN12Y_COOR_LIN21X_COOR_LIN22Y_COOR_LIN31X_COOR_LIN32TW11TW12TW21TW22TW31TW32ADCX11 ADCX12 ADCX21 ADCX22 ADCX31 ADCX32 ¥ îÍ U` WÁ WÀHBLK  TOFK1A ¥ H Uþ Vˆ W W¢ \ \<HIDT $ñ1/"< //Wntuple TOF CALIB HNAM€" /,-ü£ê ôF I4 I3HNAM€" -)-ü£ö øA IØ I×HNAM€" +
544     &-ü¤ ü< J| J{HNAM€" )
545     #-ü¤
546      7 K KHNAM€" ' -ü¤ 2 KÄ KÃHNAM€" %"-ü¤* - Lh LgHNAM€" $-ü£¶ ( M M HNAM€" #-ü£¾ # M° M¯HNAM€" "-ü£Æ  NT NSHNAM€" ! -ü£Ê  Nø N÷HNAM€"   -ü£Î  Oœ O›HNAM€"  -ü£Ú  P@ P?HNAM€" 
547     -ü¤J $
548     Pä PãHNAM€"   -ü¤R ( Qˆ Q‡HNAM€"  -ü¤Ztofroutine.f0000664000076500001440000006721310321442276012320 0ustar mennusers SUBROUTINE TOFROUTINE(XOUT,YOUT,ALPHA)
549    
550     C------------------------------------------------
551     C W. Menn
552     C
553     C Version 1.00 August 2005
554     C Version 1.01 7-oct-2005
555     C changed initialization values of xtofpos and ytofpos to "100."
556     C if the calculated values are unphysical (> +/- 100), then they
557     C are set to "101." to avoid problems in the attenuation calculation
558     C------------------------------------------------
559    
560    
561     include 'common_tofroutine.f'
562     include 'common_tof.f'
563    
564     c =======================================
565     c variables for tracking routine
566     c =======================================
567     parameter(NPOINT_MAX=100)
568     REAL XOUT(NPOINT_MAX),YOUT(NPOINT_MAX)
569     REAL ALPHA(5)
570    
571    
572     * ******************************************************************
573     * eventcounter
574     c write(*,*) '--- in beta.f ----'
575    
576    
577     * amplitude has to be 'secure' higher than pedestal for an adc event
578     secure = 2.
579    
580     xtop = 1000.0
581     xmid = 1000.0
582     xbot = 1000.0
583    
584     offset = 1
585     slope = 2
586     top = 1
587     mid = 2
588     bot = 3
589     left = 1
590     right = 2
591     none_ev = 0
592     none_find = 0
593     tdc_ev = 1
594     adc_ev = 1
595     itdc = 1
596     iadc = 2
597    
598     do i=1,5
599     beta_a(i) = 1000.
600     enddo
601    
602     do i=1,4
603     do j=1,12
604     adc_c(i,j) = 1000.
605     enddo
606     enddo
607    
608    
609     c the calibration files are read in the main program from xxx_tofcalib.rz
610    
611     IF (TOFfst.EQ.0) THEN
612     TOFfst = 1
613    
614     write(*,*) 'Calibration Data'
615     write(*,*) 'K1 data '
616     write(*,*) 'S11-S31'
617     DO i = 1,24
618     write(*,*) i,k1_S11S31(i)
619     ENDDO
620    
621     write(*,*) 'S12-S32'
622     DO i = 1,18
623     write (*,*) i,k1_S12S32(i)
624     ENDDO
625    
626     write(*,*) 'S21-S31'
627     DO i = 1,6
628     write(*,*) i,k1_S21S31(i)
629     ENDDO
630    
631     write(*,*) 'S22-S32'
632     DO i = 1,6
633     write (*,*) i,k1_S22S32(i)
634     ENDDO
635    
636    
637     C--- use TDC-difference to calculate incident point
638    
639     write(*,*) 'X-Y-Lin Coordinates'
640     DO i = 1, 8
641     write(*,*) i,y_coor_lin11(i,1),y_coor_lin11(i,2)
642     ENDDO
643     DO i = 1, 6
644     write(*,*) i,x_coor_lin12(i,1),x_coor_lin12(i,2)
645     ENDDO
646     DO i = 1, 2
647     write(*,*) i,x_coor_lin21(i,1),x_coor_lin21(i,2)
648     ENDDO
649     DO i = 1, 2
650     write(*,*) i,y_coor_lin22(i,1),y_coor_lin22(i,2)
651     ENDDO
652     DO i = 1, 3
653     write(*,*) i,y_coor_lin31(i,1),y_coor_lin31(i,2)
654     ENDDO
655     DO i = 1, 3
656     write(*,*) i,x_coor_lin32(i,1),x_coor_lin32(i,2)
657     ENDDO
658    
659     c---------- Time Walk
660    
661     write(*,*) 'Time Walk'
662     DO i = 1,8
663     write(*,*) i,tw11(left,i), tw11(right,i)
664     ENDDO
665     DO i = 1,6
666     write(*,*) i,tw12(left,i), tw12(right,i)
667     ENDDO
668     DO i = 1,2
669     write(*,*) i,tw21(left,i), tw21(right,i)
670     ENDDO
671     DO i = 1,2
672     write(*,*) i,tw22(left,i), tw22(right,i)
673     ENDDO
674     DO i = 1,3
675     write(*,*) i,tw31(left,i), tw31(right,i)
676     ENDDO
677     DO i = 1,3
678     write(*,*) i,tw32(left,i), tw32(right,i)
679     ENDDO
680    
681     c---------- ADC map
682     c read ADC correction file
683    
684     write(*,*) 'ADC Map'
685     write(*,*) 'ADC Map 1'
686     DO i = 1,8
687     write(*,*) (adcx11(left,i,j),j=1,2)
688     write(*,*) (adcx11(right,i,j),j=1,2)
689     ENDDO
690     DO i = 1,6
691     write(*,*) (adcx12(left,i,j),j=1,2)
692     write(*,*) (adcx12(right,i,j),j=1,2)
693     ENDDO
694    
695     write(*,*) 'ADC map 2'
696     DO i = 1,2
697     write(*,*) (adcx21(left,i,j),j=1,2)
698     write(*,*) (adcx21(right,i,j),j=1,2)
699     ENDDO
700     DO i = 1,2
701     write(*,*) (adcx22(left,i,j),j=1,2)
702     write(*,*) (adcx22(right,i,j),j=1,2)
703     ENDDO
704    
705     write(*,*) 'ADC map 3'
706     DO i = 1,3
707     write(*,*) (adcx31(left,i,j),j=1,2)
708     write(*,*) (adcx31(right,i,j),j=1,2)
709     ENDDO
710     DO i = 1,3
711     write(*,*) (adcx32(left,i,j),j=1,2)
712     write(*,*) (adcx32(right,i,j),j=1,2)
713     ENDDO
714    
715     ENDIF
716     c end of reading parameter files
717    
718     c------------------------- get ToF data --------------------------------
719    
720     c put the adc and tdc values from ntuple into tofxx(i,j,k) variables
721    
722     do j=1,8
723     tof11(1,j,2) = adc(ch11a(j),hb11a(j))
724     tof11(2,j,2) = adc(ch11b(j),hb11b(j))
725     tof11(1,j,1) = tdc(ch11a(j),hb11a(j))
726     tof11(2,j,1) = tdc(ch11b(j),hb11b(j))
727     c write(*,*) j,adc(ch11a(j),hb11a(j)),adc(ch11b(j),hb11b(j))
728     enddo
729    
730     do j=1,6
731     tof12(1,j,2) = adc(ch12a(j),hb12a(j))
732     tof12(2,j,2) = adc(ch12b(j),hb12b(j))
733     tof12(1,j,1) = tdc(ch12a(j),hb12a(j))
734     tof12(2,j,1) = tdc(ch12b(j),hb12b(j))
735     enddo
736    
737     do j=1,2
738     tof21(1,j,2) = adc(ch21a(j),hb21a(j))
739     tof21(2,j,2) = adc(ch21b(j),hb21b(j))
740     tof21(1,j,1) = tdc(ch21a(j),hb21a(j))
741     tof21(2,j,1) = tdc(ch21b(j),hb21b(j))
742     enddo
743    
744     do j=1,2
745     tof22(1,j,2) = adc(ch22a(j),hb22a(j))
746     tof22(2,j,2) = adc(ch22b(j),hb22b(j))
747     tof22(1,j,1) = tdc(ch22a(j),hb22a(j))
748     tof22(2,j,1) = tdc(ch22b(j),hb22b(j))
749     enddo
750    
751     do j=1,3
752     tof31(1,j,2) = adc(ch31a(j),hb31a(j))
753     tof31(2,j,2) = adc(ch31b(j),hb31b(j))
754     tof31(1,j,1) = tdc(ch31a(j),hb31a(j))
755     tof31(2,j,1) = tdc(ch31b(j),hb31b(j))
756     enddo
757    
758     do j=1,3
759     tof32(1,j,2) = adc(ch32a(j),hb32a(j))
760     tof32(2,j,2) = adc(ch32b(j),hb32b(j))
761     tof32(1,j,1) = tdc(ch32a(j),hb32a(j))
762     tof32(2,j,1) = tdc(ch32b(j),hb32b(j))
763     enddo
764    
765     C----------------------------------------------------------------------
766    
767     DO i = 1,8
768     if (abs(tof11(1,i,itdc)).gt.10000.) tof11(1,i,itdc)= 10000.
769     if (abs(tof11(2,i,itdc)).gt.10000.) tof11(2,i,itdc)= 10000.
770     if (abs(tof11(1,i,iadc)).gt.10000.) tof11(1,i,iadc)= 10000.
771     if (abs(tof11(2,i,iadc)).gt.10000.) tof11(2,i,iadc)= 10000.
772     ENDDO
773    
774     DO i = 1,6
775     if (abs(tof12(1,i,itdc)).gt.10000.) tof12(1,i,itdc)= 10000.
776     if (abs(tof12(2,i,itdc)).gt.10000.) tof12(2,i,itdc)= 10000.
777     if (abs(tof12(1,i,iadc)).gt.10000.) tof12(1,i,iadc)= 10000.
778     if (abs(tof12(2,i,iadc)).gt.10000.) tof12(2,i,iadc)= 10000.
779     ENDDO
780    
781    
782     DO i = 1,2
783     if (abs(tof21(1,i,itdc)).gt.10000.) tof21(1,i,itdc)= 10000.
784     if (abs(tof21(2,i,itdc)).gt.10000.) tof21(2,i,itdc)= 10000.
785     if (abs(tof21(1,i,iadc)).gt.10000.) tof21(1,i,iadc)= 10000.
786     if (abs(tof21(2,i,iadc)).gt.10000.) tof21(2,i,iadc)= 10000.
787     ENDDO
788    
789     DO i = 1,2
790     if (abs(tof22(1,i,itdc)).gt.10000.) tof22(1,i,itdc)= 10000.
791     if (abs(tof22(2,i,itdc)).gt.10000.) tof22(2,i,itdc)= 10000.
792     if (abs(tof22(1,i,iadc)).gt.10000.) tof22(1,i,iadc)= 10000.
793     if (abs(tof22(2,i,iadc)).gt.10000.) tof22(2,i,iadc)= 10000.
794     ENDDO
795    
796     DO i = 1,3
797     if (abs(tof31(1,i,itdc)).gt.10000.) tof31(1,i,itdc)= 10000.
798     if (abs(tof31(2,i,itdc)).gt.10000.) tof31(2,i,itdc)= 10000.
799     if (abs(tof31(1,i,iadc)).gt.10000.) tof31(1,i,iadc)= 10000.
800     if (abs(tof31(2,i,iadc)).gt.10000.) tof31(2,i,iadc)= 10000.
801     ENDDO
802    
803     DO i = 1,3
804     if (abs(tof32(1,i,itdc)).gt.10000.) tof32(1,i,itdc)= 10000.
805     if (abs(tof32(2,i,itdc)).gt.10000.) tof32(2,i,itdc)= 10000.
806     if (abs(tof32(1,i,iadc)).gt.10000.) tof32(1,i,iadc)= 10000.
807     if (abs(tof32(2,i,iadc)).gt.10000.) tof32(2,i,iadc)= 10000.
808     ENDDO
809    
810     C----------------------------------------------------------------
811     C------------ Check Paddles for hits -----------------------
812     C----------------------------------------------------------------
813    
814     C upper tof S11
815     DO i = 1,8
816     DO j = 1,2
817     tof11_event(j,i) = none_ev
818     IF ((tof11(j,i,itdc).LT.2000).AND.(tof11(j,i,itdc).GT.100))
819     + tof11_event(j,i) = tof11_event(j,i) + tdc_ev
820     IF ((tof11(j,i,iadc).GT.secure).AND.
821     + (tof11(j,i,iadc).LT.4095))
822     + tof11_event(j,i) = tof11_event(j,i) + adc_ev
823     ENDDO
824     ENDDO
825    
826     c find single paddle in upper tof with tdc and adc signal
827     tof11_i = none_find
828     tof11_j = none_find
829     check = .TRUE.
830     DO i = 1, 8
831     IF ((tof11_event(left,i).GE.1).AND.(tof11_event(right,i).GE.1))
832     + THEN
833     c check if an other paddle has also an event - then set flag
834     tof11_j = tof11_j + 2**(i-1)
835     IF (check.EQV..TRUE.) THEN
836     IF (tof11_i.EQ.none_find) THEN
837     tof11_i = i
838     ELSE
839     tof11_i = -1
840     check = .FALSE.
841     ENDIF
842     ENDIF
843     ENDIF
844     ENDDO
845    
846    
847     C upper tof S12
848     DO i = 1,6
849     DO j = 1,2
850     tof12_event(j,i) = none_ev
851     IF ((tof12(j,i,itdc).LT.2000).AND.(tof12(j,i,itdc).GT.100))
852     + tof12_event(j,i) = tof12_event(j,i) + tdc_ev
853     IF ((tof12(j,i,iadc).GT.secure).AND.
854     + (tof12(j,i,iadc).LT.4095))
855     + tof12_event(j,i) = tof12_event(j,i) + adc_ev
856     ENDDO
857     ENDDO
858    
859     c find single paddle in upper tof with tdc and adc signal
860     tof12_i = none_find
861     tof12_j = none_find
862     check = .TRUE.
863     DO i = 1, 6
864     IF ((tof12_event(left,i).GE.1).AND.(tof12_event(right,i).GE.1))
865     + THEN
866     c check if an other paddle has also an event - then set flag
867     tof12_j = tof12_j + 2**(i-1)
868     IF (check.EQV..TRUE.) THEN
869     IF (tof12_i.EQ.none_find) THEN
870     tof12_i = i
871     ELSE
872     tof12_i = -1
873     check = .FALSE.
874     ENDIF
875     ENDIF
876     ENDIF
877     ENDDO
878    
879    
880     C middle tof S21
881     DO i = 1,2
882     DO j = 1,2
883     tof21_event(j,i) = none_ev
884     IF ((tof21(j,i,itdc).LT.2000).AND.(tof21(j,i,itdc).GT.100))
885     + tof21_event(j,i) = tof21_event(j,i) + tdc_ev
886     IF ((tof21(j,i,iadc).GT.secure).AND.
887     + (tof21(j,i,iadc).LT.4095))
888     + tof21_event(j,i) = tof21_event(j,i) + adc_ev
889     ENDDO
890     ENDDO
891    
892     c find single paddle in upper tof with tdc and adc signal
893     tof21_i = none_find
894     tof21_j = none_find
895     check = .TRUE.
896     DO i = 1, 2
897     IF ((tof21_event(left,i).GE.1).AND.(tof21_event(right,i).GE.1))
898     + THEN
899     c check if an other paddle has also an event - then set flag
900     tof21_j = tof21_j + 2**(i-1)
901     IF (check.EQV..TRUE.) THEN
902     IF (tof21_i.EQ.none_find) THEN
903     tof21_i = i
904     ELSE
905     tof21_i = -1
906     check = .FALSE.
907     ENDIF
908     ENDIF
909     ENDIF
910     ENDDO
911    
912     C middle tof S22
913     DO i = 1,2
914     DO j = 1,2
915     tof22_event(j,i) = none_ev
916     IF ((tof22(j,i,itdc).LT.2000).AND.(tof22(j,i,itdc).GT.100))
917     + tof22_event(j,i) = tof22_event(j,i) + tdc_ev
918     IF ((tof22(j,i,iadc).GT.secure).AND.
919     + (tof22(j,i,iadc).LT.4095))
920     + tof22_event(j,i) = tof22_event(j,i) + adc_ev
921     ENDDO
922     ENDDO
923    
924     c find single paddle in upper tof with tdc and adc signal
925     tof22_i = none_find
926     tof22_j = none_find
927     check = .TRUE.
928     DO i = 1, 2
929     IF ((tof22_event(left,i).GE.1).AND.(tof22_event(right,i).GE.1))
930     + THEN
931     c check if an other paddle has also an event - then set flag
932     tof22_j = tof22_j + 2**(i-1)
933     IF (check.EQV..TRUE.) THEN
934     IF (tof22_i.EQ.none_find) THEN
935     tof22_i = i
936     ELSE
937     tof22_i = -1
938     check = .FALSE.
939     ENDIF
940     ENDIF
941     ENDIF
942     ENDDO
943    
944    
945     C bottom tof S31
946     DO i = 1,3
947     DO j = 1,2
948     tof31_event(j,i) = none_ev
949     IF ((tof31(j,i,itdc).LT.2000).AND.(tof31(j,i,itdc).GT.100))
950     + tof31_event(j,i) = tof31_event(j,i) + tdc_ev
951     IF ((tof31(j,i,iadc).GT.secure).AND.
952     + (tof31(j,i,iadc).LT.4095))
953     + tof31_event(j,i) = tof31_event(j,i) + adc_ev
954     ENDDO
955     ENDDO
956    
957     c find single paddle in upper tof with tdc and adc signal
958     tof31_i = none_find
959     tof31_j = none_find
960     check = .TRUE.
961     DO i = 1, 3
962     IF ((tof31_event(left,i).GE.1).AND.(tof31_event(right,i).GE.1))
963     + THEN
964     c check if an other paddle has also an event - then set flag
965     tof31_j = tof31_j + 2**(i-1)
966     IF (check.EQV..TRUE.) THEN
967     IF (tof31_i.EQ.none_find) THEN
968     tof31_i = i
969     ELSE
970     tof31_i = -1
971     check = .FALSE.
972     ENDIF
973     ENDIF
974     ENDIF
975     ENDDO
976    
977     C bottom tof S32
978     DO i = 1,3
979     DO j = 1,2
980     tof32_event(j,i) = none_ev
981     IF ((tof32(j,i,itdc).LT.2000).AND.(tof32(j,i,itdc).GT.100))
982     + tof32_event(j,i) = tof32_event(j,i) + tdc_ev
983     IF ((tof32(j,i,iadc).GT.secure).AND.
984     + (tof32(j,i,iadc).LT.4095))
985     + tof32_event(j,i) = tof32_event(j,i) + adc_ev
986     ENDDO
987     ENDDO
988    
989     c find single paddle in upper tof with tdc and adc signal
990     tof32_i = none_find
991     tof32_j = none_find
992     check = .TRUE.
993     DO i = 1, 3
994     IF ((tof32_event(left,i).GE.1).AND.(tof32_event(right,i).GE.1))
995     + THEN
996     c check if an other paddle has also an event - then set flag
997     tof32_j = tof32_j + 2**(i-1)
998     IF (check.EQV..TRUE.) THEN
999     IF (tof32_i.EQ.none_find) THEN
1000     tof32_i = i
1001     ELSE
1002     tof32_i = -1
1003     check = .FALSE.
1004     ENDIF
1005     ENDIF
1006     ENDIF
1007     ENDDO
1008    
1009     do i=1,6
1010     tof_i_flag(i)=0
1011     tof_j_flag(i)=0
1012     enddo
1013    
1014     tof_i_flag(1)=tof11_i
1015     tof_i_flag(2)=tof12_i
1016     tof_i_flag(3)=tof21_i
1017     tof_i_flag(4)=tof22_i
1018     tof_i_flag(5)=tof31_i
1019     tof_i_flag(6)=tof32_i
1020    
1021     tof_j_flag(1)=tof11_j
1022     tof_j_flag(2)=tof12_j
1023     tof_j_flag(3)=tof21_j
1024     tof_j_flag(4)=tof22_j
1025     tof_j_flag(5)=tof31_j
1026     tof_j_flag(6)=tof32_j
1027    
1028     C--------------------------------------------------------------------
1029     C-------------------- Time walk correction -------------------------
1030     C--------------------------------------------------------------------
1031    
1032     IF (tof11_i.GT.none_find) THEN
1033     tof11(left,tof11_i,itdc) = tof11(left,tof11_i,itdc) +
1034     + tw11(left,tof11_i)/sqrt(tof11(left,tof11_i,iadc))
1035     tof11(right,tof11_i,itdc) = tof11(right,tof11_i,itdc) +
1036     + tw11(right,tof11_i)/sqrt(tof11(right,tof11_i,iadc))
1037     ENDIF
1038    
1039    
1040     IF (tof12_i.GT.none_find) THEN
1041     tof12(left,tof12_i,itdc) = tof12(left,tof12_i,itdc) +
1042     + tw12(left,tof12_i)/sqrt(tof12(left,tof12_i,iadc))
1043     tof12(right,tof12_i,itdc) = tof12(right,tof12_i,itdc) +
1044     + tw12(right,tof12_i)/sqrt(tof12(right,tof12_i,iadc))
1045     ENDIF
1046    
1047     IF (tof21_i.GT.none_find) THEN
1048     tof21(left,tof21_i,itdc) = tof21(left,tof21_i,itdc) +
1049     + tw21(left,tof21_i)/sqrt(tof21(left,tof21_i,iadc))
1050     tof21(right,tof21_i,itdc) = tof21(right,tof21_i,itdc) +
1051     + tw21(right,tof21_i)/sqrt(tof21(right,tof21_i,iadc))
1052     ENDIF
1053     IF (tof22_i.GT.none_find) THEN
1054     tof22(left,tof22_i,itdc) = tof22(left,tof22_i,itdc) +
1055     + tw22(left,tof22_i)/sqrt(tof22(left,tof22_i,iadc))
1056     tof22(right,tof22_i,itdc) = tof22(right,tof22_i,itdc) +
1057     + tw22(right,tof22_i)/sqrt(tof22(right,tof22_i,iadc))
1058     ENDIF
1059    
1060     IF (tof31_i.GT.none_find) THEN
1061     tof31(left,tof31_i,itdc) = tof31(left,tof31_i,itdc) +
1062     + tw31(left,tof31_i)/sqrt(tof31(left,tof31_i,iadc))
1063     tof31(right,tof31_i,itdc) = tof31(right,tof31_i,itdc) +
1064     + tw31(right,tof31_i)/sqrt(tof31(right,tof31_i,iadc))
1065     ENDIF
1066    
1067     IF (tof32_i.GT.none_find) THEN
1068     tof32(left,tof32_i,itdc) = tof32(left,tof32_i,itdc) +
1069     + tw32(left,tof32_i)/sqrt(tof32(left,tof32_i,iadc))
1070     tof32(right,tof32_i,itdc) = tof32(right,tof32_i,itdc) +
1071     + tw32(right,tof32_i)/sqrt(tof32(right,tof32_i,iadc))
1072     ENDIF
1073    
1074    
1075     C------------------------------------------------------------------
1076     C--- calculate track position in paddle using timing difference
1077     C------------------------------------------------------------------
1078    
1079     do i=1,3
1080     xtofpos(i)=100.
1081     ytofpos(i)=100.
1082     enddo
1083     C----------------------------- S1 --------------------------------
1084    
1085     IF (tof11_i.GT.none_find) THEN
1086     ytofpos(1) = ((tof11(1,tof11_i,itdc)-tof11(2,tof11_i,itdc))/2.
1087     + - y_coor_lin11(tof11_i,offset))/y_coor_lin11(tof11_i,slope)
1088     endif
1089    
1090     IF (tof12_i.GT.none_find) THEN
1091     xtofpos(1) = ((tof12(1,tof12_i,itdc)-tof12(2,tof12_i,itdc))/2.
1092     + - x_coor_lin12(tof12_i,offset))/x_coor_lin12(tof12_i,slope)
1093     endif
1094    
1095    
1096     C----------------------------- S2 --------------------------------
1097    
1098     IF (tof21_i.GT.none_find) THEN
1099     xtofpos(2) = ((tof21(1,tof21_i,itdc)-tof21(2,tof21_i,itdc))/2.
1100     + - x_coor_lin21(tof21_i,offset))/x_coor_lin21(tof21_i,slope)
1101     endif
1102    
1103     IF (tof22_i.GT.none_find) THEN
1104     ytofpos(2) = ((tof22(1,tof22_i,itdc)-tof22(2,tof22_i,itdc))/2.
1105     + - y_coor_lin22(tof22_i,offset))/y_coor_lin22(tof22_i,slope)
1106     endif
1107    
1108    
1109     C----------------------------- S3 --------------------------------
1110    
1111     IF (tof31_i.GT.none_find) THEN
1112     ytofpos(3) = ((tof31(1,tof31_i,itdc)-tof31(2,tof31_i,itdc))/2.
1113     + - y_coor_lin31(tof31_i,offset))/y_coor_lin31(tof31_i,slope)
1114     c write(*,*) '31',tof31(1,tof31_i,itdc),tof31(2,tof31_i,itdc),
1115     c + y_coor_lin31(tof31_i,offset),y_coor_lin31(tof31_i,slope),
1116     c + ytofpos(3)
1117     endif
1118    
1119     IF (tof32_i.GT.none_find) THEN
1120     xtofpos(3) = ((tof32(1,tof32_i,itdc)-tof32(2,tof32_i,itdc))/2.
1121     + - x_coor_lin32(tof32_i,offset))/x_coor_lin32(tof32_i,slope)
1122     c write(*,*) '32',tof32(1,tof32_i,itdc),tof32(2,tof32_i,itdc),
1123     c + x_coor_lin32(tof32_i,offset),x_coor_lin32(tof32_i,slope),
1124     c + xtofpos(3)
1125     endif
1126    
1127    
1128     do i=1,3
1129     if (abs(xtofpos(i)).gt.100.) then
1130     xtofpos(i)=101.
1131     endif
1132     if (abs(ytofpos(i)).gt.100.) then
1133     ytofpos(i)=101.
1134     endif
1135     enddo
1136    
1137    
1138     C----------------------------------------------------------------------
1139     C-------------------- Corrections on ADC-data -------------------------
1140     C--------------------- zenith angle theta ---------------------------
1141     C----------------------------------------------------------------------
1142    
1143     C if we have a good track use tracking information
1144    
1145     dx=0.
1146     dy=0.
1147     dr=0.
1148     theta13 = 0.
1149    
1150     if (xout(1).lt.100.) then
1151     dx = xout(1)-xout(3)
1152     dy = yout(1)-yout(3)
1153     dr = sqrt(dx*dx+dy*dy)
1154     theta13 = atan(dr/tofarm13)
1155     else
1156     IF ((tof12_i.GT.none_find).AND.(tof32_i.GT.none_find))
1157     & dx = xtofpos(1) - xtofpos(3)
1158     IF ((tof11_i.GT.none_find).AND.(tof31_i.GT.none_find))
1159     & dy = ytofpos(1) - ytofpos(3)
1160     dr = sqrt(dx*dx+dy*dy)
1161     theta13 = atan(dr/tofarm13)
1162     endif
1163    
1164    
1165     C----------------------------------------------------------------------
1166     C------------------ angle and ADC(x) correction
1167     C----------------------------------------------------------------------
1168     C----------------------------- S1 --------------------------------
1169    
1170     yhelp=1000.
1171     if (yout(1).lt.100.) then
1172     yhelp=yout(1)
1173     else
1174     yhelp=ytofpos(1)
1175     endif
1176    
1177    
1178     IF (tof11_i.GT.none_find.AND.yhelp.lt.100) THEN
1179    
1180     i = tof11_i
1181     xdummy=tof11(left,i,iadc)
1182     tof11(left,i,iadc) = tof11(left,i,iadc)*cos(theta13)
1183     if (tof11(left,i,iadc).lt.1000) then
1184     xkorr=adcx11(left,i,1)*exp(-yhelp/adcx11(left,i,2))
1185     xkorr0=adcx11(left,i,1)
1186     adc_c(ch11a(i),hb11a(i))=tof11(left,i,iadc)/xkorr
1187     endif
1188    
1189     tof11(right,i,iadc) = tof11(right,i,iadc)*cos(theta13)
1190     if (tof11(right,i,iadc).lt.1000) then
1191     xkorr=adcx11(right,i,1)*exp(yhelp/adcx11(right,i,2))
1192     xkorr0=adcx11(right,i,1)
1193     adc_c(ch11b(i),hb11b(i))=tof11(right,i,iadc)/xkorr
1194     endif
1195     ENDIF
1196    
1197    
1198     xhelp=1000.
1199     if (xout(1).lt.100.) then
1200     xhelp=xout(1)
1201     else
1202     xhelp=xtofpos(1)
1203     endif
1204    
1205    
1206     IF (tof12_i.GT.none_find.AND.xhelp.lt.100) THEN
1207    
1208     i = tof12_i
1209     tof12(left,i,iadc) = tof12(left,i,iadc)*cos(theta13)
1210     if (tof12(left,i,iadc).lt.1000) then
1211     xkorr=adcx12(left,i,1)*exp(-xhelp/adcx12(left,i,2))
1212     xkorr0=adcx12(left,i,1)
1213     adc_c(ch12a(i),hb12a(i))=tof12(left,i,iadc)/xkorr
1214     endif
1215    
1216     tof12(right,i,iadc) = tof12(right,i,iadc)*cos(theta13)
1217     if (tof12(right,i,iadc).lt.1000) then
1218     xkorr=adcx12(right,i,1)*exp(xhelp/adcx12(right,i,2))
1219     xkorr0=adcx12(right,i,1)
1220     adc_c(ch12b(i),hb12b(i))=tof12(right,i,iadc)/xkorr
1221     endif
1222     ENDIF
1223    
1224     C----------------------------- S2 --------------------------------
1225    
1226     xhelp=1000.
1227     if (xout(2).lt.100.) then
1228     xhelp=xout(2)
1229     else
1230     xhelp=xtofpos(2)
1231     endif
1232    
1233     IF (tof21_i.GT.none_find.AND.xhelp.lt.100) THEN
1234    
1235     i = tof21_i
1236     tof21(left,i,iadc) = tof21(left,i,iadc)*cos(theta13)
1237     if (tof21(left,i,iadc).lt.1000) then
1238     xkorr=adcx21(left,i,1)*exp(-xhelp/adcx21(left,i,2))
1239     xkorr0=adcx21(left,i,1)
1240     adc_c(ch21a(i),hb21a(i))=tof21(left,i,iadc)/xkorr
1241     endif
1242    
1243     tof21(right,i,iadc) = tof21(right,i,iadc)*cos(theta13)
1244     if (tof21(right,i,iadc).lt.1000) then
1245     xkorr=adcx21(right,i,1)*exp(xhelp/adcx21(right,i,2))
1246     xkorr0=adcx21(right,i,1)
1247     adc_c(ch21b(i),hb21b(i))=tof21(right,i,iadc)/xkorr
1248     endif
1249     ENDIF
1250    
1251     yhelp=1000.
1252     if (yout(2).lt.100.) then
1253     yhelp=yout(2)
1254     else
1255     yhelp=ytofpos(2)
1256     endif
1257    
1258     IF (tof22_i.GT.none_find.AND.yhelp.lt.100) THEN
1259    
1260     i = tof22_i
1261     tof22(left,i,iadc) = tof22(left,i,iadc)*cos(theta13)
1262     if (tof22(left,i,iadc).lt.1000) then
1263     xkorr=adcx22(left,i,1)*exp(-yhelp/adcx22(left,i,2))
1264     xkorr0=adcx22(left,i,1)
1265     adc_c(ch22a(i),hb22a(i))=tof22(left,i,iadc)/xkorr
1266     endif
1267    
1268     tof22(right,i,iadc) = tof22(right,i,iadc)*cos(theta13)
1269     if (tof22(right,i,iadc).lt.1000) then
1270     xkorr=adcx22(right,i,1)*exp(yhelp/adcx22(right,i,2))
1271     xkorr0=adcx22(right,i,1)
1272     adc_c(ch22b(i),hb22b(i))=tof22(right,i,iadc)/xkorr
1273     endif
1274     ENDIF
1275    
1276     C----------------------------- S3 --------------------------------
1277    
1278     yhelp=1000.
1279     if (yout(3).lt.100.) then
1280     yhelp=yout(3)
1281     else
1282     yhelp=ytofpos(3)
1283     endif
1284    
1285     IF (tof31_i.GT.none_find.AND.yhelp.lt.100) THEN
1286    
1287     i = tof31_i
1288     tof31(left,i,iadc) = tof31(left,i,iadc)*cos(theta13)
1289     if (tof31(left,i,iadc).lt.1000) then
1290     xkorr=adcx31(left,i,1)*exp(-yhelp/adcx31(left,i,2))
1291     xkorr0=adcx31(left,i,1)
1292     adc_c(ch31a(i),hb31a(i))=tof31(left,i,iadc)/xkorr
1293     endif
1294    
1295     tof31(right,i,iadc) = tof31(right,i,iadc)*cos(theta13)
1296     if (tof31(right,i,iadc).lt.1000) then
1297     xkorr=adcx31(right,i,1)*exp(yhelp/adcx31(right,i,2))
1298     xkorr0=adcx31(right,i,1)
1299     adc_c(ch31b(i),hb31b(i))=tof31(right,i,iadc)/xkorr
1300     endif
1301     ENDIF
1302    
1303     xhelp=1000.
1304     if (xout(3).lt.100.) then
1305     xhelp=xout(3)
1306     else
1307     xhelp=xtofpos(3)
1308     endif
1309    
1310     IF (tof32_i.GT.none_find.AND.xhelp.lt.100) THEN
1311    
1312     i = tof32_i
1313     tof32(left,i,iadc) = tof32(left,i,iadc)*cos(theta13)
1314     if (tof32(left,i,iadc).lt.1000) then
1315     xkorr=adcx32(left,i,1)*exp(-xhelp/adcx32(left,i,2))
1316     xkorr0=adcx32(left,i,1)
1317     adc_c(ch32a(i),hb32a(i))=tof32(left,i,iadc)/xkorr
1318     endif
1319    
1320     tof32(right,i,iadc) = tof32(right,i,iadc)*cos(theta13)
1321     if (tof32(right,i,iadc).lt.1000) then
1322     xkorr=adcx32(right,i,1)*exp(xhelp/adcx32(right,i,2))
1323     xkorr0=adcx32(right,i,1)
1324     adc_c(ch32b(i),hb32b(i))=tof32(right,i,iadc)/xkorr
1325     endif
1326     ENDIF
1327    
1328     C-----------------------------------------------------------------------
1329     C---------------------- calculate Beta ------------------------------
1330     C-----------------------------------------------------------------------
1331     C------------------- difference of sums ---------------------------
1332     C
1333     C DS = (t1+t2) - t3+t4)
1334     C DS = c1 + c2/beta*cos(theta)
1335     C c2 = 2d/c gives c2 = 2d/(c*TDCresolution) TDC=50ps/channel
1336     C => c2_23 = 60 for 0.45 m c2_13 = 109 for 0.81 m
1337    
1338     C S11 - S31
1339     IF (tof11_i.GT.none_find.AND.tof31_i.GT.none_find) THEN
1340     xhelp1 = tof11(1,tof11_i,itdc)+tof11(2,tof11_i,itdc)
1341     xhelp2 = tof31(1,tof31_i,itdc)+tof31(2,tof31_i,itdc)
1342     ds = xhelp1-xhelp2
1343     ihelp=(tof11_i-1)*3+tof31_i
1344     c1 = k1_S11S31(ihelp)
1345     beta_a(1) = c2_13/(cos(theta13)*(ds-c1))
1346     ENDIF
1347    
1348     C S12 - S32
1349     IF (tof12_i.GT.none_find.AND.tof32_i.GT.none_find) THEN
1350     xhelp1 = tof12(1,tof12_i,itdc)+tof12(2,tof12_i,itdc)
1351     xhelp2 = tof32(1,tof32_i,itdc)+tof32(2,tof32_i,itdc)
1352     ds = xhelp1-xhelp2
1353     ihelp=(tof12_i-1)*3+tof32_i
1354     c1 = k1_S12S32(ihelp)
1355     beta_a(2) = c2_13/(cos(theta13)*(ds-c1))
1356     ENDIF
1357    
1358    
1359     C S21 - S31
1360     IF (tof21_i.GT.none_find.AND.tof31_i.GT.none_find) THEN
1361     xhelp1 = tof21(1,tof21_i,itdc)+tof21(2,tof21_i,itdc)
1362     xhelp2 = tof31(1,tof31_i,itdc)+tof31(2,tof31_i,itdc)
1363     ds = xhelp1-xhelp2
1364     ihelp=(tof21_i-1)*3+tof31_i
1365     c1 = k1_S21S31(ihelp)
1366     beta_a(3) = c2_23/(cos(theta13)*(ds-c1))
1367     ENDIF
1368    
1369     C S22 - S32
1370     IF (tof22_i.GT.none_find.AND.tof32_i.GT.none_find) THEN
1371     xhelp1 = tof22(1,tof22_i,itdc)+tof22(2,tof22_i,itdc)
1372     xhelp2 = tof32(1,tof32_i,itdc)+tof32(2,tof32_i,itdc)
1373     ds = xhelp1-xhelp2
1374     ihelp=(tof22_i-1)*3+tof32_i
1375     c1 = k1_S22S32(ihelp)
1376     beta_a(4) = c2_23/(cos(theta13)*(ds-c1))
1377     ENDIF
1378    
1379     C-------
1380    
1381     icount=0
1382     sw=0.
1383     sxw=0.
1384     beta_mean=100.
1385    
1386     do i=1,4
1387     if ((beta_a(i).gt.0.4).and.(beta_a(i).lt.1.5)) then
1388     icount= icount+1
1389     if (i.le.2) w_i=1./(0.13**2.)
1390     if (i.ge.3) w_i=1./(0.16**2.)
1391     sxw=sxw + beta_a(i)*w_i
1392     sw =sw + w_i
1393     endif
1394     enddo
1395     if (icount.eq.4) beta_mean=sxw/sw
1396     beta_a(5) = beta_mean
1397    
1398    
1399     c ERROR MESSAGES
1400     100 continue
1401     *
1402     RETURN
1403     END
1404    
1405     toftrack.f0000775000076500001440000004000510321444754011733 0ustar mennusersC------------------------------------------------
1406     PROGRAM TOFTRACK
1407     C------------------------------------------------
1408     C W. Menn
1409     C
1410     C Based on the "template" progran from Elena Vannuccini
1411     C
1412     C Version 1.00 August 2005
1413     C Version 1.01 07-oct-2005: Some bugs found
1414     C - new rz file must be named "***_toftrack.rz'
1415     C - booking of the EVENT and CPU blocks changed according
1416     C to Elena's "book_level2" routine
1417     C
1418     C------------------------------------------------
1419    
1420     include 'trk_level2.f'
1421     include 'common_tofroutine.f'
1422     include 'common_tof.f'
1423    
1424     c----- HBOOK
1425     INTEGER HMEM
1426     parameter (NWPAWC=8500000)
1427     common/PAWC/HMEM(NWPAWC)
1428    
1429     parameter (ntp_level2=22)
1430     parameter (ntp_new=2)
1431    
1432     c------------------------------------------------------------------------
1433     c local variables
1434     c------------------------------------------------------------------------
1435     character*74 data_file !data file name
1436     character*74 tof_file !tofdata file name
1437     character*74 data_dir !data directory
1438     character*74 data_file_level2
1439     character*74 data_file_tof
1440     character*74 data_file_tofcalib
1441     character*74 data_file_new
1442    
1443     parameter (lun_data_level2=72) !data file id number
1444    
1445     c------------------------------------------------------------------
1446     COMMON/QUEST/IQUEST(100)
1447    
1448     C------------------------------------------------------------------
1449     c =======================================
1450     c variables for tracking routine
1451     c =======================================
1452     parameter(NPOINT_MAX=100)
1453     DOUBLE PRECISION ZIN(NPOINT_MAX)
1454     DOUBLE PRECISION XOUT1(NPOINT_MAX),YOUT1(NPOINT_MAX)
1455     REAL XOUT(NPOINT_MAX),YOUT(NPOINT_MAX)
1456     DOUBLE PRECISION AL_P(5)
1457     REAL XFIT(6),YFIT(6),ZFIT(6),ALPHA(5),XGOOD1(6),YGOOD1(6)
1458     c =======================================
1459    
1460     c define TOF Z-coordinates
1461     parameter (NPTOF=3)
1462     REAL ZTOF(NPTOF)
1463     c DATA ZTOF/55.,25.,-23/ !NB!!! from TOP to BOTTOM
1464     DATA ZTOF/53.4,23.9,-23.4/ !Stockholm 29.9.2005
1465    
1466     c------------------------------------------------------------------------
1467     C
1468     CHARACTER*100 name
1469     C
1470    
1471     INTEGER lrec, openntuple
1472     INTEGER istat, ierr, icycle
1473     PARAMETER (lrec=4096)
1474    
1475    
1476     integer patterntrig1(6)
1477     real chi
1478    
1479     character*35 block1,block2
1480    
1481     C-------------------------------------------------------------------------
1482     c
1483     c HBOOK initialization
1484     c
1485     c------------------------------------------------------------------------
1486    
1487     call HLIMIT(NWPAWC)
1488    
1489     C HERE A PATH where you can write!
1490     C
1491     c print *
1492     c print *,'File saved in: ',name
1493     C
1494     C CHANGE here (hbname and hbnt if you want another ntuple id number
1495     C
1496    
1497     111 format(a)
1498     print*,'data dir:'
1499     read(*,111)data_dir
1500     c read(*,*)data_dir
1501     print*,data_dir
1502     print*,'tof file?'
1503     print*,'(without estention: output_YYMMDD_XXX )'
1504     read(*,*)tof_file
1505    
1506     print*,tof_file
1507     print*,' '
1508    
1509     print*,'first event:'
1510     read(*,*) minevent
1511     print*,minevent
1512     c print*,' '
1513    
1514     print*,'number of events to be analysed'
1515     read(*,*) ntotev
1516     print*,ntotev
1517    
1518    
1519     c------------------------------------------------------------------------
1520     c--------------- open ToF rz file
1521     c------------------------------------------------------------------------
1522    
1523     print*,
1524     $ data_dir(1:LNBLNK(data_dir))//tof_file(1:LNBLNK(tof_file))
1525    
1526    
1527     505 format(a,'DW_',a,'_tof.rz')
1528     write(data_file_tof,505)
1529     $ data_dir(1:LNBLNK(data_dir))
1530     $ ,tof_file(1:LNBLNK(tof_file))
1531     print*,'__________ opening TOF rz file __________'
1532     print*,data_file_tof
1533    
1534    
1535     call HROPEN(59,
1536     $ 'EVENT',data_file_tof,'QP',4096,istat) !opens rz
1537    
1538    
1539     if(istat.ne.0) stop
1540     print*,' '
1541     print*,'reading TOF n-tuple...'
1542     call HRIN(ntp_tof,9999,0)
1543     CALL HBNAME(ntp_tof,' ',0,'$CLEAR')
1544     CALL HBNAME(ntp_tof,'EVENT',good,'$SET')
1545     CALL HBNAME(ntp_tof,'TRIGGER',trig_evcount,'$SET')
1546     CALL HBNAME(ntp_tof,'TOF',tdcid,'$SET')
1547     call HPRNTU(ntp_tof)
1548     call HNOENT(ntp_tof,iemax0)
1549     write(*,*) 'Number of events ToF ',iemax0
1550    
1551    
1552     c------------------------------------------------------------------------
1553     c--------------- open ToF calib rz file
1554     c------------------------------------------------------------------------
1555    
1556     print*,
1557     $ data_dir(1:LNBLNK(data_dir))//tof_file(1:LNBLNK(tof_file))
1558    
1559     506 format(a,'DW_',a,'_tofcalib.rz')
1560     write(data_file_tofcalib,506)
1561     $ data_dir(1:LNBLNK(data_dir))
1562     $ ,tof_file(1:LNBLNK(tof_file))
1563     print*,'__________ opening TOF calib rz file __________'
1564     print*,data_file_tofcalib
1565    
1566     CALL HROPEN(59,'TOF K1A',data_file_tofcalib,'QP',4096,istat)
1567    
1568     if (istat.ne.0) then ! check if HROPEN was OK
1569     write(*,*) 'Can''t open correct ToF calibration File !!!'
1570     write(*,*) 'Will use standard file tofcalib.rz !!!'
1571     507 format(a,'tofcalib.rz')
1572     write(data_file_tofcalib,507)
1573     $ data_dir(1:LNBLNK(data_dir))
1574     print*,'__________ opening TOF calib rz file __________'
1575     print*,data_file_tofcalib
1576    
1577     CALL HROPEN(59,'TOF K1A',data_file_tofcalib,'QP',4096,istat)
1578     endif
1579    
1580     print*,' reading TOF CALIB n-tuple...'
1581    
1582     call HRIN(ntp_tofcalib,9999,0)
1583    
1584     call HBNAME(ntp_tofcalib,' ',0,'$CLEAR')
1585    
1586     call HBNAME(ntp_tofcalib,'TOFK1A',k1_s11s31,'$SET')
1587     call HBNAME(ntp_tofcalib,'TOFK1B',k1_s12s32,'$SET')
1588     call HBNAME(ntp_tofcalib,'TOFK1C',k1_s21s31,'$SET')
1589     call HBNAME(ntp_tofcalib,'TOFK1D',k1_s22s32,'$SET')
1590    
1591     call HBNAME(ntp_tofcalib,'TOFLIN11',y_coor_lin11,'$SET')
1592     call HBNAME(ntp_tofcalib,'TOFLIN12',x_coor_lin12,'$SET')
1593     call HBNAME(ntp_tofcalib,'TOFLIN21',x_coor_lin21,'$SET')
1594     call HBNAME(ntp_tofcalib,'TOFLIN22',y_coor_lin22,'$SET')
1595     call HBNAME(ntp_tofcalib,'TOFLIN31',y_coor_lin31,'$SET')
1596     call HBNAME(ntp_tofcalib,'TOFLIN32',x_coor_lin32,'$SET')
1597    
1598     call HBNAME(ntp_tofcalib,'TOFTW11',tw11,'$SET')
1599     call HBNAME(ntp_tofcalib,'TOFTW12',tw12,'$SET')
1600     call HBNAME(ntp_tofcalib,'TOFTW21',tw21,'$SET')
1601     call HBNAME(ntp_tofcalib,'TOFTW22',tw22,'$SET')
1602     call HBNAME(ntp_tofcalib,'TOFTW31',tw31,'$SET')
1603     call HBNAME(ntp_tofcalib,'TOFTW32',tw32,'$SET')
1604    
1605     call HBNAME(ntp_tofcalib,'TOFADC11',adcx11,'$SET')
1606     call HBNAME(ntp_tofcalib,'TOFADC12',adcx12,'$SET')
1607     call HBNAME(ntp_tofcalib,'TOFADC21',adcx21,'$SET')
1608     call HBNAME(ntp_tofcalib,'TOFADC22',adcx22,'$SET')
1609     call HBNAME(ntp_tofcalib,'TOFADC31',adcx31,'$SET')
1610     call HBNAME(ntp_tofcalib,'TOFADC32',adcx32,'$SET')
1611    
1612     call HPRNTU(ntp_tofcalib)
1613    
1614     call HNOENT(ntp_tofcalib,iemax_cal)
1615     c write(*,*) 'Number of Events CALIB ',iemax_cal
1616    
1617     do iev=1,iemax_cal
1618     call HGNT(ntp_tofcalib,iev,ierr) !reads an event
1619     enddo
1620    
1621     call hrout(ntp_tofcalib,icycle,' ')
1622     call hrend('TOF K1A')
1623     close(0)
1624    
1625    
1626    
1627     c------------------------------------------------------------------------
1628     c--------------- open Track Level2 rz file
1629     c------------------------------------------------------------------------
1630    
1631     data_file=tof_file
1632     print*,'data dir:'
1633     c read(*,111)data_dir
1634     print*,data_dir
1635     c print*,'data file?'
1636     c print*,'(without estention: output_YYMMDD_XXX )'
1637     c read(*,*)data_file
1638    
1639     print*,'data_file:'
1640     print*,data_file
1641     print*,' '
1642    
1643     print*,
1644     $ data_dir(1:LNBLNK(data_dir))//data_file(1:LNBLNK(data_file))
1645    
1646     c------------------------------------------------------------------------
1647     504 format(a,'DW_',a,'_level2.rz')
1648     write(data_file_level2,504)
1649     $ data_dir(1:LNBLNK(data_dir))
1650     $ ,data_file(1:LNBLNK(data_file))
1651     print*,'__________ opening LEVEL2 rz file __________'
1652     print*,data_file_level2
1653     print*,'__________ opening LEVEL2 rz file __________'
1654     print*,data_file_level2
1655     IQUEST(10)=65000
1656     call HROPEN(lun_data_level2,
1657     $ 'LEVEL2',data_file_level2,'QP',4096,istat) !opens rz
1658     if(istat.ne.0) goto 19
1659     print*,'reading LEVEL2 n-tuple...'
1660     call HRIN(ntp_level2,9999,0)
1661    
1662     * -----------------------------------------------
1663     CALL HBNAME(ntp_level2,' ',0,'$CLEAR')
1664     CALL HBNAME(ntp_level2,'EVENT',GOOD2,'$SET')
1665     CALL HBNAME(ntp_level2,'CPU',pkt_type,'$SET')
1666     CALL HBNAME(ntp_level2,'TRACKS',ntrk,'$SET')
1667     CALL HBNAME(ntp_level2,'SINGLETS',nclsx,'$SET')
1668     * -----------------------------------------------
1669    
1670     call HPRNTU(ntp_level2)
1671     call HNOENT(ntp_level2,iemax2)
1672    
1673     write(*,*) 'Number of events LEVEL2 ',iemax2
1674     print*,'ok'
1675     print*,' '
1676    
1677    
1678    
1679     c------------------------------------------------------------------------
1680     c read magnetic field map
1681     c------------------------------------------------------------------------
1682     c
1683     c =======================
1684    
1685    
1686     c read magnetic field map
1687     c =======================
1688     c
1689     c------------------------------------------------------------------------
1690     print*,'- read magnetic field map'
1691     print*,' '
1692     call read_B
1693     print*,' '
1694    
1695     c print*,' '
1696     c print*,'- read magnetic field map'
1697     c print*,' '
1698     c call read_B_2maps
1699     c
1700    
1701    
1702     c------------------------------------------------------------------------
1703     c open new RZ file
1704     c------------------------------------------------------------------------
1705    
1706     503 format(a,'DW_',a,'_toftrack.rz')
1707     write(data_file_new,503)
1708     $ data_dir(1:LNBLNK(data_dir))
1709     $ ,data_file(1:LNBLNK(data_file))
1710     print*,'__________ opening NEW rz file __________'
1711     print*,data_file_new
1712    
1713    
1714     call HROPEN(10,'TEST',data_file_new,'NP',4096,istat) !opens rz
1715    
1716     call HBNT(ntp_new,'TOF',' ')
1717    
1718    
1719     c call HBNAME(ntp_new,'EVENT',good,'GOOD:L,NEV_TRK:I')
1720    
1721     call HBNAME(ntp_new,'EVENT',good2,'GOOD2:L,NEV2:I')
1722    
1723    
1724     c call HBNAME(ntp_new,'CPU',pkt_type
1725     c $ ,'PKT_TYPE:I
1726     c $ ,PKT_NUM:I
1727     c $ ,OBT:I
1728     c $ ,WHICH_CALIB:I')
1729    
1730     call HBNAME(ntp_new,'CPU',pkt_type
1731     $ ,'PKT_TYPE:I::[0,50]
1732     $ ,PKT_NUM:I
1733     $ ,OBT:I
1734     $ ,WHICH_CALIB:I::[0,50]')
1735    
1736    
1737    
1738     call HBNAME(ntp_new,'TOF',tdcid
1739     $ ,'TDCID(12):I
1740     $ ,EVCOUNT(12):I
1741     $ ,TDCMASK(12):I
1742     $ ,ADC(4,12):I
1743     $ ,TDC(4,12):I
1744     $ ,TEMP1(12):I
1745     $ ,TEMP2(12):I')
1746    
1747     call HBNAME(ntp_new,'TOF',beta_a,'BETA(5)')
1748     call HBNAME(ntp_new,'TOF',xtofpos,'XTOF(3)')
1749     call HBNAME(ntp_new,'TOF',ytofpos,'YTOF(3)')
1750     call HBNAME(ntp_new,'TOF',adc_c,'ADC_C(4,12)')
1751     call HBNAME(ntp_new,'TOF',tof_i_flag,'IFLAG(6)')
1752     call HBNAME(ntp_new,'TOF',tof_j_flag,'JFLAG(6)')
1753    
1754     call HBNAME(ntp_new,'TOF',xout,'XOUT(3)')
1755     call HBNAME(ntp_new,'TOF',yout,'YOUT(3)')
1756    
1757    
1758     call HBNAME(ntp_new,'TRIGGER',trig_evcount
1759     $ ,'TRIG_EVCOUNT:I
1760     $ ,PMTPL(3):I
1761     $ ,TRIGRATE(6):I
1762     $ ,DLTIME(2):I
1763     $ ,S4CALCOUNT(2):I
1764     $ ,PMTCOUNT1(24):I
1765     $ ,PMTCOUNT2(24):I
1766     $ ,PATTERNBUSY(3):I
1767     $ ,PATTERNTRIG(6):I
1768     $ ,TRIGCONF:I')
1769    
1770    
1771     417 format('NTRK:I::[0,',I4,']')
1772     418 format(',IMAGE(NTRK):I::[0,',I4,']')
1773     write(block1,417)NTRKMAX
1774     write(block2,418)NTRKMAX
1775     call HBNAME(ntp_new,'TRACKS',NTRK,
1776     $ block1//
1777     $ block2//'
1778     $ ,XM(6,NTRK):R
1779     $ ,YM(6,NTRK):R
1780     $ ,ZM(6,NTRK):R
1781     $ ,RESX(6,NTRK):R
1782     $ ,RESY(6,NTRK):R
1783     $ ,AL(5,NTRK):R
1784     $ ,COVAL(5,5,NTRK):R
1785     $ ,CHI2(NTRK):R
1786     $ ,XGOOD(6,NTRK):I::[0,1]
1787     $ ,YGOOD(6,NTRK):I::[0,1]
1788     $ ,XV(6,NTRK):R
1789     $ ,YV(6,NTRK):R
1790     $ ,ZV(6,NTRK):R
1791     $ ,AXV(6,NTRK):R
1792     $ ,AYV(6,NTRK):R
1793     $ ,DEDXP(6,NTRK):R
1794     $ ')
1795     call HBNAME(ntp_new,'SINGLETS',nclsx,
1796     $ 'NCLSX(6):I,NCLSY(6):I')
1797    
1798    
1799     call HPRNTU(ntp_new)
1800    
1801     c------------------------------------------------------------------------
1802    
1803     call HCDIR('//LEVEL2',' ')
1804    
1805     c------------------------------------------------------------------------
1806     c start loop on events
1807     c------------------------------------------------------------------------
1808    
1809     maxevent=minevent+ntotev
1810     igoodevent=0
1811    
1812     c do iev = 1,iemax0
1813     do iev = minevent,MIN(iemax0,maxevent) !loop on events
1814     Call Hcdir('//EVENT',' ')
1815     Call Hgnt(ntp_tof,iev,Ierr)
1816    
1817     do i=1,6
1818     patterntrig1(i) = patterntrig(i)
1819     enddo
1820    
1821     * ----------------------------------------------
1822     Call Hcdir('//LEVEL2',' ')
1823     call HGNT(ntp_level2,iev,ierr) !reads an event
1824    
1825     if(ierr.ne.0) goto 21
1826     * ----------------------------------------------
1827    
1828     do i=1,nptof
1829     xout(i)=1000.
1830     yout(i)=1000.
1831     enddo
1832     do i=1,5
1833     ALPHA(i) = 1000.
1834     enddo
1835     do i=1,6
1836     XFIT(i) = 1000.
1837     YFIT(i) = 1000.
1838     ZFIT(i) = 1000.
1839     XGOOD1(i) = 1000.
1840     YGOOD1(i) = 1000.
1841     enddo
1842    
1843     chi = 1000.
1844    
1845     *=======> INSTERT HERE YOUR CODE
1846    
1847     * ---- example ----
1848     * write(*,*) 'GOOD2 ',good2
1849     * if(GOOD2)then
1850     if(NTRK.ne.0)then
1851     print*,'Event ',iev,' # tracks ',ntrk
1852     if(ntrk.eq.1)then
1853    
1854     chi = CHI2(1)
1855     do i=1,5
1856     ALPHA(i) = AL(i,1)
1857     enddo
1858     do i=1,6
1859     XFIT(i) = XV(i,1)
1860     YFIT(i) = YV(i,1)
1861     ZFIT(i) = ZV(i,1)
1862     XGOOD1(i)=XGOOD(i,1)
1863     YGOOD1(i)=YGOOD(i,1)
1864     enddo
1865    
1866     igoodevent = igoodevent+1
1867     * assigned input parameters for track routine
1868     * 1) Z-coordinates where the trajectory is evaluated
1869     do itof=1,NPTOF
1870     ZIN(itof) = ZTOF(itof)
1871     enddo
1872     * 2) track status vector
1873     do i=1,5
1874     AL_P(i) = AL(i,1)
1875     enddo
1876     * -------- *** tracking routine *** --------
1877     call track(NPTOF,ZIN,XOUT1,YOUT1,AL_P,IFAIL)
1878     * ------------------------------------------
1879     do itof=1,NPTOF
1880     XOUT(itof)=XOUT1(itof)
1881     YOUT(itof)=YOUT1(itof)
1882     enddo
1883    
1884     do itof=1,NPTOF
1885     c print*,' ',itof,ZIN(itof),XOUT(itof),YOUT(itof)
1886     enddo
1887     endif
1888     else
1889     print*,'Event ',iev,' *** BAD ***'
1890     endif
1891    
1892    
1893     call tofroutine(xout,yout,alpha)
1894    
1895    
1896     c--------------------- fill new rz file -----------------------------
1897    
1898     call HFNT(2)
1899    
1900     enddo !end loop on events
1901     GOTO 9000 !got to end
1902    
1903     c------------------------------------------------------------------------
1904     c
1905     c data file opening error
1906     c
1907     c------------------------------------------------------------------------
1908     19 continue
1909    
1910     print*,' '
1911     print*,'ERROR OPENING DATA FILE: ',data_file
1912     print*,' '
1913     print*,' '
1914    
1915     goto 9000 !the end
1916    
1917     c------------------------------------------------------------------------
1918     c
1919     c level2 ntuple event reading error
1920     c
1921     c------------------------------------------------------------------------
1922    
1923     21 continue
1924    
1925     print*,' '
1926     print*,'ERROR WHILE READING LEVEL2 NTUPLE, AT EVENT
1927     $ : ',iev
1928     print*,' '
1929     print*,' '
1930    
1931     goto 9000 !the end
1932    
1933     c------------------------------------------------------------------------
1934     c
1935     c closes files and exits
1936     c
1937     c------------------------------------------------------------------------
1938    
1939     9000 continue
1940    
1941     write(*,*) 'Good Events ',igoodevent
1942    
1943    
1944     c--------------------------------------------------------------
1945    
1946     call HCDIR('//EVENT',' ')
1947     CALL HROUT(0,icycle,' ')
1948     call HREND('EVENT')
1949     close(0)
1950    
1951     call HCDIR('//LEVEL2',' ')
1952     call HREND('level2')
1953     close(lun_data_level2)
1954    
1955    
1956     call HPRNTU(2)
1957     call HCDIR('//TEST',' ')
1958     CALL HROUT(0,icycle,' ')
1959     call HREND('TEST')
1960     close(0)
1961    
1962     STOP
1963     END
1964    
1965    
1966     include 'tofroutine.f'
1967    
1968     trk_level2.f0000644000076500001440000000607310314004227012156 0ustar mennusers*************************************************************************
1969     *
1970     * Common level2.f
1971     *
1972     * contains LEVEL2 ntuple variables definitions
1973     *
1974     *
1975     *************************************************************************
1976    
1977     PARAMETER (NTRKMAX=50) !ncloyz_max*ncloxz_max)
1978    
1979     c EVENT block:
1980     * -----------------------------------------------------------
1981     logical good2 !flag to mark good or noise events
1982     integer nev2 !level2 event number
1983     common/level2/good2,nev2
1984    
1985     c CPU block (only for ground data):
1986     * -----------------------------------------------------------
1987     integer pkt_type !CPU packet type identifier. see http://people.roma2.infn.it/~cpu/HB_list.txt
1988     c 0x12 --> calibration board 0
1989     c 0x13 --> calibration board 1
1990     c 0x10 --> event
1991     c 0x30 --> full event for calib special
1992     c 0x83 --> tracker ALARM (control register)
1993     integer pkt_num !CPU packet number
1994     integer obt !CPU on-board time
1995     integer which_calib !calibration file identifier. see DW_DATE_NUM_calib.txt file
1996     common/level2_cpu/pkt_type,pkt_num,obt,which_calib
1997    
1998    
1999     * -----------------------------------------------------------
2000     * Common to store TRACK info
2001     * All the variables have a dimention equal to the number of
2002     * found tracks
2003     * -----------------------------------------------------------
2004     c TRACK PARAMETERS
2005     integer ntrk !# identified tracks
2006     integer image !flag to tag track-images
2007     real al !track state vector
2008     integer xgood !mask of used planes
2009     integer ygood !*
2010     real xm !me asured points
2011     real ym !*
2012     real zm !*
2013     real resx !spatial resolution
2014     real resy !*
2015     real chi2 !chi2
2016     real xv !calculated points
2017     real yv !*
2018     real zv !*
2019     real axv !calculated angles (deg)
2020     real ayv !*
2021     real dedxp
2022     common/level2_tracks/
2023     $ ntrk
2024     $ ,image(NTRKMAX)
2025     $ ,xm(6,NTRKMAX)
2026     $ ,ym(6,NTRKMAX)
2027     $ ,zm(6,NTRKMAX)
2028     $ ,resx(6,NTRKMAX)
2029     $ ,resy(6,NTRKMAX)
2030     $ ,al(5,NTRKMAX)
2031     $ ,chi2(NTRKMAX)
2032     $ ,xgood(6,NTRKMAX)
2033     $ ,ygood(6,NTRKMAX)
2034     $ ,xv(6,NTRKMAX)
2035     $ ,yv(6,NTRKMAX)
2036     $ ,zv(6,NTRKMAX)
2037     $ ,axv(6,NTRKMAX)
2038     $ ,ayv(6,NTRKMAX)
2039     $ ,dedxp(6,NTRKMAX)
2040     * -----------------------------------------------------------
2041     * Common to store SINGLET info
2042     * (clusters not associated with any track)
2043     * -----------------------------------------------------------
2044     integer nclsx !# unassociated clusters per plane X views
2045     integer nclsy ! " " " " Y views
2046     common/level2_singlets/
2047     $ nclsx(6),nclsy(6)
2048    
2049    

  ViewVC Help
Powered by ViewVC 1.1.23