| 1 | ************************************************************************* | 
| 2 | * | 
| 3 | *     Program reductionflight.f | 
| 4 | * | 
| 5 | *     - reads readraw.f output files: LEVEL0 ntuple, and ped, sig and bad histograms | 
| 6 | *     - decodes raw data (DATATRACKER) using DSP ped, sig and bad values | 
| 7 | *     - looks for clusters information using ped, sig and bad values from | 
| 8 | *     DSP histograms | 
| 9 | *     - fills LEVEL1 ntuple | 
| 10 | * | 
| 11 | ************************************************************************* | 
| 12 |  | 
| 13 | subroutine reductionflight(ierror) | 
| 14 |  | 
| 15 | include 'commontracker.f' | 
| 16 | include 'level0.f' | 
| 17 | include 'level1.f' | 
| 18 | include 'common_reduction.f' | 
| 19 | include 'calib.f' | 
| 20 |  | 
| 21 | data eventn_old/nviews*0/ | 
| 22 |  | 
| 23 | integer ierror | 
| 24 | ierror = 0 | 
| 25 |  | 
| 26 | c$$$      debug = .true. | 
| 27 | c$$$      verbose = .true. | 
| 28 | c$$$      warning = .true. | 
| 29 |  | 
| 30 | *     ////////////////////////// | 
| 31 | *     initialize some parameters | 
| 32 | *     ////////////////////////// | 
| 33 |  | 
| 34 | call init_level1 | 
| 35 |  | 
| 36 | c      debug=.true. | 
| 37 |  | 
| 38 | if(debug)print*,'-- check LEVEL0 status' | 
| 39 |  | 
| 40 | ievco=-1 | 
| 41 | mismatch=0 | 
| 42 | c      good1 = good0 | 
| 43 | c-------------------------------------------------- | 
| 44 | c     check the LEVEL0 event status for missing | 
| 45 | c     sections or DSP alarms | 
| 46 | c     ==> set the variable GOOD1(12) | 
| 47 | c-------------------------------------------------- | 
| 48 | do iv=1,nviews | 
| 49 | if(DSPnumber(iv).gt.0.and.DSPnumber(iv).le.12)then | 
| 50 | c           ------------------------ | 
| 51 | c           GOOD | 
| 52 | c           ------------------------ | 
| 53 | GOOD1(DSPnumber(iv))=0 !OK | 
| 54 | c           ------------------------ | 
| 55 | c           CRC error | 
| 56 | c           ------------------------ | 
| 57 | if(crc(iv).eq.1) then | 
| 58 | c               GOOD1(DSPnumber(iv)) = 2 | 
| 59 | c               GOOD1(DSPnumber(iv)) = GOOD1(DSPnumber(iv)) + 2**1 | 
| 60 | GOOD1(DSPnumber(iv)) = ior(GOOD1(DSPnumber(iv)),2**1) | 
| 61 | 102           format(' * WARNING * Event ',i7,' view',i3 | 
| 62 | $          ,' CRC error') | 
| 63 | if(debug)write(*,102)eventn(1),DSPnumber(iv) | 
| 64 | c               goto 18 !next view | 
| 65 | endif | 
| 66 | c           ------------------------ | 
| 67 | c           online-software alarm | 
| 68 | c           ------------------------ | 
| 69 | if( | 
| 70 | $           fl1(iv).ne.0.or. | 
| 71 | $           fl2(iv).ne.0.or. | 
| 72 | $           fl3(iv).ne.0.or. | 
| 73 | $           fl4(iv).ne.0.or. | 
| 74 | $           fl5(iv).ne.0.or. | 
| 75 | $           fl6(iv).ne.0.or. | 
| 76 | $           fc(iv).ne.0.or. | 
| 77 | $           DATAlength(iv).eq.0.or. | 
| 78 | $           .false.)then | 
| 79 | c               GOOD1(DSPnumber(iv))=3 | 
| 80 | c               GOOD1(DSPnumber(iv)) = GOOD1(DSPnumber(iv)) + 2**2 | 
| 81 | GOOD1(DSPnumber(iv)) = ior(GOOD1(DSPnumber(iv)),2**2) | 
| 82 | 103           format(' * WARNING * Event ',i7,' view',i3 | 
| 83 | $          ,' software alarm') | 
| 84 | if(debug)write(*,103)eventn(1),DSPnumber(iv) | 
| 85 | c               goto 18 | 
| 86 | endif | 
| 87 | c           ------------------------ | 
| 88 | c           DSP-counter jump | 
| 89 | c           ------------------------ | 
| 90 | c     commentato perche` non e` un controllo significativo nel caso in cui | 
| 91 | c     la subroutine venga chiamata per riprocessare l'evento | 
| 92 | c     sostituito con un check dei contatori dei vari dsp | 
| 93 | c$$$            if( | 
| 94 | c$$$     $           eventn_old(iv).ne.0.and. !first event in this file | 
| 95 | c$$$     $           eventn(iv).ne.1.and.     !first event in run | 
| 96 | c$$$     $           good_old(DSPnumber(iv)).ne.0.and. !previous event corrupted | 
| 97 | c$$$     $           .true.)then | 
| 98 | c$$$ | 
| 99 | c$$$               if(eventn(iv).ne.(eventn_old(iv)+1))then | 
| 100 | c$$$c                  GOOD1(DSPnumber(iv))=4 | 
| 101 | c$$$c                  GOOD1(DSPnumber(iv)) = GOOD1(DSPnumber(iv)) + 2**3 | 
| 102 | c$$$                  GOOD1(DSPnumber(iv)) = ior(GOOD1(DSPnumber(iv)),2**3) | 
| 103 | c$$$ 104              format(' * WARNING * Event ',i7,' view',i3 | 
| 104 | c$$$     $          ,' counter jump ',i10,i10) | 
| 105 | c$$$                  if(debug)write(*,104)eventn(1),DSPnumber(iv) | 
| 106 | c$$$     $                 ,eventn_old(iv),eventn(iv)) | 
| 107 | c$$$                  goto 18 | 
| 108 | c$$$               endif | 
| 109 | c$$$ | 
| 110 | c$$$            endif | 
| 111 | c           ------------------------ | 
| 112 | c 18         continue | 
| 113 | c           ------------------------ | 
| 114 | c           DSP-counter | 
| 115 | c           ------------------------ | 
| 116 | if( DSPnumber(iv).ne.0.and.GOOD1(DSPnumber(iv)).ne.1)then | 
| 117 | if(iv.ne.1.and.ievco.ne.-1)then | 
| 118 | if( eventn(iv).ne.ievco )then | 
| 119 | mismatch=1 | 
| 120 | endif | 
| 121 | endif | 
| 122 | ievco = eventn(iv) | 
| 123 | endif | 
| 124 | endif | 
| 125 | enddo | 
| 126 |  | 
| 127 | c      print*,'*** ',(eventn(iv),iv=1,12) | 
| 128 |  | 
| 129 | if(mismatch.eq.1.and.debug) | 
| 130 | $     print*,' * WARNING * DSP counter mismatch: ' | 
| 131 | $     ,(eventn(iv),iv=1,12) | 
| 132 |  | 
| 133 | ngood = 0 | 
| 134 | do iv = 1,nviews | 
| 135 |  | 
| 136 | if(mismatch.eq.1.and.GOOD1(iv).ne.1) | 
| 137 | $        GOOD1(iv)=ior(GOOD1(iv),2**3) | 
| 138 |  | 
| 139 | eventn_old(iv) = eventn(iv) | 
| 140 | good_old(iv)   = good1(iv) | 
| 141 | ngood = ngood + good1(iv) | 
| 142 |  | 
| 143 | enddo | 
| 144 | c$$$      if(verbose.and.ngood.ne.0)print*,'* WARNING * Event ',eventn(1) | 
| 145 | c$$$     $     ,':LEVEL0 event status: ' | 
| 146 | c$$$     $     ,(good1(i),i=1,nviews) | 
| 147 | c-------------------------------------------------- | 
| 148 | c     read the variable DATATRACKER from LEVEL0 | 
| 149 | c     and fill the variable ADC (invertin view 11) | 
| 150 | c-------------------------------------------------- | 
| 151 |  | 
| 152 | if(debug)print*,'-- fill ADC vectors' | 
| 153 |  | 
| 154 | call filladc(iflag) | 
| 155 | if(iflag.ne.0)then | 
| 156 | ierror = 220 | 
| 157 | endif | 
| 158 |  | 
| 159 | c-------------------------------------------------- | 
| 160 | c     computes common noise for each VA1 | 
| 161 | c     (excluding strips with signal, | 
| 162 | c     tagged with the flag CLSTR) | 
| 163 | c-------------------------------------------------- | 
| 164 | if(debug)print*,'-- compute CN' | 
| 165 |  | 
| 166 | do iv=1,nviews | 
| 167 | ima=0 | 
| 168 | do ik=1,nva1_view | 
| 169 | cn(iv,ik)    = 0 | 
| 170 | cnrms(iv,ik) = 0 | 
| 171 | cnn(iv,ik)   = -1 | 
| 172 | iflag = 0 | 
| 173 | mask_vk_ev(iv,ik) = 1 | 
| 174 | call stripmask(iv,ik)      !compute mask(i,j,k), combining VA1-masks | 
| 175 | *           -------------------------------------- | 
| 176 | *           if chip is not masked ---> evaluate CN | 
| 177 | *           -------------------------------------- | 
| 178 | if( mask(iv,ik,1).eq.1 ) then !!!NBNB mask per la striscia 1 !!!!!!!! | 
| 179 | call cncomp(iv,ik,iflag) | 
| 180 | if(iflag.ne.0)then | 
| 181 | ima=ima+1 | 
| 182 | mask_vk_ev(iv,ik)=0 | 
| 183 | ierror = 220 | 
| 184 | endif | 
| 185 | call stripmask(iv,ik) !compute mask(i,j,k), combining VA1-masks | 
| 186 | endif | 
| 187 | enddo | 
| 188 | 100     format(' * WARNING * Event ',i7,' view',i3,': VK MASK ',24i1) | 
| 189 | if(ima.ne.0.and.verbose)write(*,100)eventn(1),iv | 
| 190 | $        ,(mask_vk_ev(iv,ik),ik=1,nva1_view) | 
| 191 | c         if(ima.ne.0)write(*,100)eventn(1),iv | 
| 192 | c     $        ,(mask_vk_ev(iv,ik),ik=1,nva1_view) | 
| 193 | enddo | 
| 194 |  | 
| 195 | cc      call stripmask !compute mask(i,j,k), combining mask_vk_ev and mask_vk | 
| 196 |  | 
| 197 | c--------------------------------------------- | 
| 198 | c     loops on views, VA1 and strips, | 
| 199 | c     and computes strips signals using | 
| 200 | c     badstrip, pedestals, and | 
| 201 | c     sigma informations from histograms | 
| 202 | c--------------------------------------------- | 
| 203 | ind=1                     !clsignal array index | 
| 204 |  | 
| 205 | if(debug)print*,'-- search clusters' | 
| 206 | do iv=1,nviews            !loop on views | 
| 207 | do is=1,nstrips_view    !loop on strips (1) | 
| 208 | if(mod(iv,2).eq.1) then | 
| 209 | C===  > Y view | 
| 210 | c             print*,iv,nvk(is),nst(is),adc(iv,nvk(is),nst(is)) | 
| 211 | c     $            ,cn(iv,nvk(is)) | 
| 212 | c     $            ,pedestal(iv,nvk(is),nst(is)) | 
| 213 | value(is)= -(DBLE(adc(iv,nvk(is),nst(is))) | 
| 214 | $           -cn(iv,nvk(is))-pedestal(iv,nvk(is),nst(is))) | 
| 215 | $           *mask(iv,nvk(is),nst(is)) | 
| 216 | clseedcut(is)=clcuty*sigma(iv,nvk(is),nst(is)) | 
| 217 | $           *mask(iv,nvk(is),nst(is)) | 
| 218 | clinclcut(is)=incuty*sigma(iv,nvk(is),nst(is)) | 
| 219 | $           *mask(iv,nvk(is),nst(is)) | 
| 220 | sat(is)=0 | 
| 221 | if( adc(iv,nvk(is),nst(is)).lt.adc_saty )sat(is)=1 | 
| 222 | else | 
| 223 | C===  > X view | 
| 224 | value(is)= (DBLE(adc(iv,nvk(is),nst(is))) | 
| 225 | $           -cn(iv,nvk(is))-pedestal(iv,nvk(is),nst(is))) | 
| 226 | $           *mask(iv,nvk(is),nst(is)) | 
| 227 | clseedcut(is)=clcutx*sigma(iv,nvk(is),nst(is)) | 
| 228 | $           *mask(iv,nvk(is),nst(is)) | 
| 229 | clinclcut(is)=incutx*sigma(iv,nvk(is),nst(is)) | 
| 230 | $           *mask(iv,nvk(is),nst(is)) | 
| 231 | sat(is)=0 | 
| 232 | if( adc(iv,nvk(is),nst(is)).gt.adc_satx )sat(is)=1 | 
| 233 | endif | 
| 234 | enddo                   !end loop on strips (1) | 
| 235 | call search_cluster(iv) | 
| 236 |  | 
| 237 | if(.not.flag_shower)then | 
| 238 | call save_cluster(iv) | 
| 239 | if(debug)print*,'view ',iv,' #clusters ', nclstr_view | 
| 240 | else | 
| 241 | fshower(iv) = 1 | 
| 242 | c           GOOD1(DSPnumber(iv)) = 11 !AHAHAHAHA ORRORE!! | 
| 243 | c           GOOD1(iv) = 11 | 
| 244 | c           GOOD1(iv) = GOOD1(iv) + 2**5 | 
| 245 | GOOD1(iv) = ior(GOOD1(iv),2**5) | 
| 246 | 101       format(' * WARNING * Event ',i7,' view',i3 | 
| 247 | $          ,' #clusters > ',i5,' --> MASKED') | 
| 248 | if(verbose)write(*,101)eventn(1),iv,nclstrmax_view | 
| 249 | endif | 
| 250 | enddo                     ! end loop on views | 
| 251 | do iv=1,nviews | 
| 252 | do ik=1,nva1_view | 
| 253 | cnev(iv,ik)    = cn(iv,ik) !assigns computed CN to ntuple variables | 
| 254 | cnrmsev(iv,ik) = cnrms(iv,ik) !assigns computed CN to ntuple variables | 
| 255 | cnnev(iv,ik)   = cnn(iv,ik) !assigns computed CN to ntuple variables | 
| 256 | enddo | 
| 257 | enddo | 
| 258 | C--------------------------------------------- | 
| 259 | C     come here if GOOD1=0 | 
| 260 | C     or the event has too many clusters | 
| 261 | C--------------------------------------------- | 
| 262 | 200  continue | 
| 263 |  | 
| 264 | ngood = 0 | 
| 265 | do iv = 1,nviews | 
| 266 | ngood = ngood + good1(iv) | 
| 267 | enddo | 
| 268 | if(verbose.and.ngood.ne.0)print*,'* WARNING * Event ',eventn(1) | 
| 269 | $     ,':LEVEL1 event status: ' | 
| 270 | $     ,(good1(i),i=1,nviews) | 
| 271 | c------------------------------------------------------------------------ | 
| 272 | c | 
| 273 | c     closes files and exits | 
| 274 | c | 
| 275 | c------------------------------------------------------------------------ | 
| 276 | RETURN | 
| 277 | END | 
| 278 |  | 
| 279 | ***...***...***...***...***...***...***...***...***...***...***...***...***...***...***...*** | 
| 280 | * | 
| 281 | * | 
| 282 | * | 
| 283 | * | 
| 284 | * | 
| 285 | * | 
| 286 | * | 
| 287 | * | 
| 288 | * | 
| 289 | ***...***...***...***...***...***...***...***...***...***...***...***...***...***...***...*** | 
| 290 |  | 
| 291 |  | 
| 292 | subroutine init_level1 | 
| 293 |  | 
| 294 | include 'commontracker.f' | 
| 295 | include 'level1.f' | 
| 296 | include 'level0.f' | 
| 297 |  | 
| 298 | c      good1 = 0 | 
| 299 | do iv=1,12 | 
| 300 | good1(iv) = 1 !missing packet | 
| 301 | enddo | 
| 302 | nclstr1 = 0 | 
| 303 | totCLlength = 0 | 
| 304 | do ic=1,nclstrmax | 
| 305 | view(ic) = 0 | 
| 306 | ladder(ic) = 0 | 
| 307 | indstart(ic) = 0 | 
| 308 | indmax(ic) = 0 | 
| 309 | maxs(ic) = 0 | 
| 310 | mult(ic) = 0 | 
| 311 | sgnl(ic) = 0 | 
| 312 | whichtrack(ic) = 0     !assigned @ level2 | 
| 313 |  | 
| 314 | enddo | 
| 315 | do id=1,maxlength         !??? | 
| 316 | clsignal(id) = 0. | 
| 317 | clsigma(id)  = 0. | 
| 318 | cladc(id)    = 0. | 
| 319 | clbad(id)    = 0. | 
| 320 | enddo | 
| 321 | do iv=1,nviews | 
| 322 | c        crc1(iv)=0 | 
| 323 | do ik=1,nva1_view | 
| 324 | cnev(iv,ik) = 0 | 
| 325 | cnnev(iv,ik) = 0 | 
| 326 | enddo | 
| 327 | fshower(iv) = 0 | 
| 328 | enddo | 
| 329 |  | 
| 330 | return | 
| 331 | end | 
| 332 |  | 
| 333 | *---***---***---***---***---***---***---***---*** | 
| 334 | * | 
| 335 | * | 
| 336 | * | 
| 337 | * | 
| 338 | * | 
| 339 | *---***---***---***---***---***---***---***---*** | 
| 340 |  | 
| 341 | subroutine search_cluster(iv) | 
| 342 |  | 
| 343 | include 'commontracker.f' | 
| 344 | include 'level0.f' | 
| 345 | include 'level1.f' | 
| 346 | include 'calib.f' | 
| 347 |  | 
| 348 | include 'common_reduction.f' | 
| 349 |  | 
| 350 |  | 
| 351 | c     local variables | 
| 352 | integer rmax,lmax         !estremi del cluster | 
| 353 | integer rstop,lstop | 
| 354 | integer first,last | 
| 355 | integer fsat,lsat | 
| 356 |  | 
| 357 | external nst | 
| 358 |  | 
| 359 | iseed=-999                !cluster seed index initialization | 
| 360 |  | 
| 361 | inext=-999                !index where to start new cluster search | 
| 362 |  | 
| 363 | flag_shower = .false. | 
| 364 | nclstr_view=0 | 
| 365 |  | 
| 366 | do jl=1,nladders_view              !1..3 !loops on ladders | 
| 367 |  | 
| 368 | first = 1+nstrips_ladder*(jl-1) !1,1025,2049 | 
| 369 | last  = nstrips_ladder*jl       !1024,2048,3072 | 
| 370 |  | 
| 371 | *        X views have 1018 strips instead of 1024 | 
| 372 | if(mod(iv,2).eq.0) then | 
| 373 | first=first+3 | 
| 374 | last=last-3 | 
| 375 | endif | 
| 376 |  | 
| 377 | do is=first,last       !loop on strips in each ladder | 
| 378 |  | 
| 379 | c--------------------------------------------- | 
| 380 | c     new-cluster search starts at index inext | 
| 381 | c--------------------------------------------- | 
| 382 | if(is.lt.inext) goto 220 ! next strip | 
| 383 |  | 
| 384 | if(value(is).gt.clseedcut(is)) then | 
| 385 | c----------------------------------------- | 
| 386 | c     possible SEED... | 
| 387 | c----------------------------------------- | 
| 388 | itemp = is | 
| 389 | fsat = 0         ! first saturated strip | 
| 390 | lsat = 0         ! last saturated strip | 
| 391 | if(itemp.eq.last) goto 230 !estremo... | 
| 392 | c              ------------------------ | 
| 393 | c              search for first maximum | 
| 394 | c              ------------------------ | 
| 395 | do while( | 
| 396 | $                   value(itemp).le.value(itemp+1) | 
| 397 | $              .and.value(itemp+1).gt.clseedcut(itemp+1)) | 
| 398 | itemp = itemp+1 | 
| 399 | if(itemp.eq.last)   goto 230 !stops if reaches last strip | 
| 400 | if(sat(itemp).eq.1) goto 230 !stop if reaches a saturated strip | 
| 401 | enddo            ! of the ladder | 
| 402 | 230           continue | 
| 403 | c              ----------------------------- | 
| 404 | c              check if strips are saturated | 
| 405 | c              ----------------------------- | 
| 406 | if( sat(itemp).eq.1 )then | 
| 407 | fsat = itemp | 
| 408 | lsat = itemp | 
| 409 | if(itemp.eq.last) goto 231 !estremo... | 
| 410 | do while( sat(itemp+1).eq.1 ) | 
| 411 | itemp = itemp+1 | 
| 412 | lsat = itemp | 
| 413 | if(itemp.eq.last)   goto 231 !stops if reaches last strip | 
| 414 | enddo | 
| 415 | endif | 
| 416 | 231           continue | 
| 417 | c--------------------------------------------------------------------------- | 
| 418 | c     fownd SEED!!! | 
| 419 | c     (if there are saturated strips, the cluster is centered in the middle) | 
| 420 | c--------------------------------------------------------------------------- | 
| 421 | if(fsat.eq.0.and.lsat.eq.0)then | 
| 422 | iseed = itemp ! <<< SEED | 
| 423 | else | 
| 424 | iseed = int((lsat+fsat)/2) ! <<< SEED | 
| 425 | c$$$                  print*,'saturated strips ',fsat,lsat,iseed | 
| 426 | c$$$                  print*,'--> ',(value(ii),ii=fsat,lsat) | 
| 427 | endif | 
| 428 | c--------------------------------------------------------------- | 
| 429 | c     after finding a cluster seed, checks also adjacent strips, | 
| 430 | C     and tags the ones exceeding clinclcut | 
| 431 | c--------------------------------------------------------------- | 
| 432 | ir=iseed         !indici destro | 
| 433 | il=iseed         ! e sinistro | 
| 434 |  | 
| 435 | rmax=ir          !estremo destro del cluster | 
| 436 | lmax=il          ! e sinistro | 
| 437 |  | 
| 438 | rstop=0          !initialize flags used to exit from | 
| 439 | lstop=0          ! inclusion loop | 
| 440 |  | 
| 441 | do while(lstop.eq.0.or.rstop.eq.0) !shifts left and right from | 
| 442 |  | 
| 443 |  | 
| 444 | ir=ir+1       !index for right side | 
| 445 | il=il-1       !index for left side | 
| 446 | c------------------------------------------------------------------------ | 
| 447 | c     checks for last or first strip of the ladder | 
| 448 | c------------------------------------------------------------------------ | 
| 449 | if( ir.gt.last  ) rstop = 1 | 
| 450 | if( il.lt.first ) lstop = 1 | 
| 451 |  | 
| 452 | c------------------------------------------------------------------------ | 
| 453 | c     add strips exceeding inclusion cut | 
| 454 | c------------------------------------------------------------------------ | 
| 455 | if( (rmax-lmax+1).ge.nclstrp )goto 210   !exits inclusion loop | 
| 456 |  | 
| 457 | if(rstop.eq.0) then !if right cluster border has not been reached | 
| 458 | if(value(ir).gt.clinclcut(ir)) then | 
| 459 | rmax=ir !include a strip on the right | 
| 460 | else | 
| 461 | rstop=1 !cluster right end | 
| 462 | endif | 
| 463 | endif | 
| 464 |  | 
| 465 | if( (rmax-lmax+1).ge.nclstrp )goto 210   !exits inclusion loop | 
| 466 |  | 
| 467 | if(lstop.eq.0) then !if left cluster border has not been reached | 
| 468 | if(value(il).gt.clinclcut(il)) then | 
| 469 | lmax=il !include a strip on the left | 
| 470 | else | 
| 471 | lstop=1 !cluster left end | 
| 472 | endif | 
| 473 | endif | 
| 474 |  | 
| 475 | c                  if( (rmax-lmax+1).ge.nclstrp )goto 210   !exits inclusion loop | 
| 476 |  | 
| 477 | enddo            !ends strip inclusion loop | 
| 478 | goto 211 | 
| 479 | 210           continue         !jumps here if more than nclstrp have been included | 
| 480 | c               print*,'>>> nclstrp! ' | 
| 481 | 211           continue | 
| 482 | c----------------------------------------- | 
| 483 | c     end of inclusion loop! | 
| 484 | c----------------------------------------- | 
| 485 |  | 
| 486 | c------------------------------------------------------------------------ | 
| 487 | c     adjust the cluster in order to have at least a strip around the seed | 
| 488 | c------------------------------------------------------------------------ | 
| 489 | if(iseed.eq.lmax.and.lmax.ne.first)then | 
| 490 | lmax = lmax-1 | 
| 491 | if( (rmax-lmax+1).gt.nclstrp )rmax=rmax-1 | 
| 492 | endif | 
| 493 | if(iseed.eq.rmax.and.rmax.ne.last )then | 
| 494 | rmax = rmax+1 | 
| 495 | if( (rmax-lmax+1).gt.nclstrp )lmax=lmax+1 | 
| 496 | endif | 
| 497 | c------------------------------------------------------------------------------- | 
| 498 | c     adjust the cluster in order to have at least ANOTHER strip around the seed | 
| 499 | c------------------------------------------------------------------------------- | 
| 500 | c$$$               if(iseed-1.eq.lmax.and.lmax.ne.first)then | 
| 501 | c$$$                  lmax = lmax-1 | 
| 502 | c$$$                  if( (rmax-lmax+1).gt.nclstrp )rmax=rmax-1 | 
| 503 | c$$$               endif | 
| 504 | c$$$               if(iseed+1.eq.rmax.and.rmax.ne.last )then | 
| 505 | c$$$                  rmax = rmax+1 | 
| 506 | c$$$                  if( (rmax-lmax+1).gt.nclstrp )lmax=lmax+1 | 
| 507 | c$$$               endif | 
| 508 | c--------------------------------------------------- | 
| 509 | c     now we have 5 stored-strips around the maximum | 
| 510 | c--------------------------------------------------- | 
| 511 |  | 
| 512 | c------------------------------------------------------------------------ | 
| 513 | c     adjust the cluster in order to store a minimum number of strips | 
| 514 | c------------------------------------------------------------------------ | 
| 515 | do while( (rmax-lmax+1).lt.nclstrpmin ) | 
| 516 |  | 
| 517 | vl = -99999 | 
| 518 | vr = -99999 | 
| 519 | if(lmax-1.ge.first) vl = value(lmax-1) | 
| 520 | if(rmax+1.le.last ) vr = value(rmax+1) | 
| 521 | if(vr.ge.vl) then | 
| 522 | rmax = rmax+1 | 
| 523 | else | 
| 524 | lmax = lmax-1 | 
| 525 | endif | 
| 526 |  | 
| 527 | enddo | 
| 528 |  | 
| 529 | c-------------------------------------------------------- | 
| 530 | c     store cluster info | 
| 531 | c-------------------------------------------------------- | 
| 532 | nclstr_view = nclstr_view + 1 !cluster number | 
| 533 |  | 
| 534 | if(nclstr_view.gt.nclstrmax_view) then !too many clusters for the view: | 
| 535 | c$$$                  if(verbose) print*,'Event ',eventn(1), | 
| 536 | c$$$     $                 ': more than ',nclstrmax_view | 
| 537 | c$$$     $                 ,' clusters on view ',iv | 
| 538 | flag_shower = .true. | 
| 539 | goto 2000 | 
| 540 | endif | 
| 541 |  | 
| 542 | ladder_view(nclstr_view) = nld(iseed,iv) | 
| 543 | maxs_view(nclstr_view)   = iseed | 
| 544 | mult_view(nclstr_view)   = rmax-lmax+1 | 
| 545 | rmax_view(nclstr_view)   = rmax | 
| 546 | lmax_view(nclstr_view)   = lmax | 
| 547 |  | 
| 548 | c$$$               if(rmax-lmax+1.gt.25) | 
| 549 | c$$$     $              print*,'view ',iv | 
| 550 | c$$$     $              ,' cl ',nclstr_view,' mult ',rmax-lmax+1 | 
| 551 | c------------------------------------------------------------------------ | 
| 552 | c     search for a double peak inside the cluster | 
| 553 | c------------------------------------------------------------------------ | 
| 554 | inext = rmax+1   !<< index where to start new-cluster search | 
| 555 |  | 
| 556 | vmax = 0 | 
| 557 | vmin = value(iseed) | 
| 558 | imax = iseed | 
| 559 | imin = iseed | 
| 560 | do iss = max(iseed+1,lsat+1),rmax | 
| 561 | if( value(iss).lt.vmin )then | 
| 562 | if( imax.ne.iseed )goto 221 !found dowble peek | 
| 563 | imin = iss | 
| 564 | vmin = value(iss) | 
| 565 | else | 
| 566 | delta = value(iss) - value(imin) | 
| 567 | cut = sqrt(clinclcut(iss)**2 + clinclcut(imin)**2) | 
| 568 | if( | 
| 569 | $                    delta.gt.cut .and. | 
| 570 | $                    value(iss).gt.clseedcut(iss).and. | 
| 571 | $                    .true.)then | 
| 572 | if( value(iss).gt.vmax )then | 
| 573 | imax = iss | 
| 574 | vmax = value(iss) | 
| 575 | else | 
| 576 | goto 221 !found dowble peek | 
| 577 | endif | 
| 578 | endif | 
| 579 | endif | 
| 580 | enddo | 
| 581 | 221           continue | 
| 582 |  | 
| 583 | if(imax.gt.iseed)then | 
| 584 | inext = imax    !<< index where to start new-cluster search | 
| 585 | c$$$                  print*,'--- double peek ---' | 
| 586 | c$$$                  print*,(value(ii),ii=lmax,rmax) | 
| 587 | c$$$                  print*,'seed ',iseed,' imin ',imin,' imax ',imax | 
| 588 | endif | 
| 589 | c-------------------------------------------------------- | 
| 590 | c | 
| 591 | c-------------------------------------------------------- | 
| 592 | endif               !end possible seed conditio | 
| 593 | 220        continue            !jumps here to skip strips left of last seed | 
| 594 |  | 
| 595 | enddo                  ! end loop on strips | 
| 596 | enddo                     !end loop on ladders | 
| 597 | 2000 continue | 
| 598 | return | 
| 599 | end | 
| 600 |  | 
| 601 |  | 
| 602 | *---***---***---***---***---***---***---***---*** | 
| 603 | * | 
| 604 | * | 
| 605 | * | 
| 606 | * | 
| 607 | * | 
| 608 | *---***---***---***---***---***---***---***---*** | 
| 609 |  | 
| 610 | subroutine save_cluster(iv) | 
| 611 | * | 
| 612 | *     (080/2006 Elena Vannuccini) | 
| 613 | *     Save the clusters view by view | 
| 614 |  | 
| 615 | include 'commontracker.f' | 
| 616 | include 'level1.f' | 
| 617 | include 'calib.f' | 
| 618 | include 'common_reduction.f' | 
| 619 |  | 
| 620 | integer CLlength          !lunghezza in strip del cluster | 
| 621 |  | 
| 622 | do ic=1,nclstr_view | 
| 623 |  | 
| 624 | nclstr1 = nclstr1+1 | 
| 625 | view(nclstr1)   = iv | 
| 626 | ladder(nclstr1) = ladder_view(ic) | 
| 627 | maxs(nclstr1)   = maxs_view(ic) | 
| 628 | mult(nclstr1)   = mult_view(ic) | 
| 629 |  | 
| 630 | c        posizione dell'inizio del cluster nell' array clsignal | 
| 631 | indstart(nclstr1) = ind | 
| 632 | c        posizione del cluster seed nell'array clsignal | 
| 633 | indmax(nclstr1)   = indstart(nclstr1) | 
| 634 | $        +( maxs_view(ic) - lmax_view(ic) ) | 
| 635 |  | 
| 636 | CLlength      = rmax_view(ic) - lmax_view(ic) + 1 !numero di strip salvate | 
| 637 | totCLlength   = totCLlength + CLlength | 
| 638 | sgnl(nclstr1) = 0 | 
| 639 | do j=lmax_view(ic),rmax_view(ic)         !stores sequentially cluter strip values in | 
| 640 |  | 
| 641 | clsignal(ind) = value(j) ! clsignal array | 
| 642 | c$$$            print*,ind,clsignal(ind) | 
| 643 | ivk=nvk(j) | 
| 644 | ist=nst(j) | 
| 645 |  | 
| 646 | clsigma(ind) = sigma(iv,ivk,ist) | 
| 647 | cladc(ind)   = adc(iv,ivk,ist) | 
| 648 | clbad(ind)   = bad(iv,ivk,ist) | 
| 649 | c            clped(ind)   = pedestal(iv,ivk,ist) | 
| 650 |  | 
| 651 | ind=ind+1 | 
| 652 | c     if(value(j).gt.0) | 
| 653 | if(value(j).gt.clinclcut(j)) | 
| 654 | $           sgnl(nclstr1) = sgnl(nclstr1) + value(j) !cluster charge | 
| 655 | enddo | 
| 656 |  | 
| 657 | c$$$         print*,'view ',iv,' -- save_cluster -- nclstr1: ' | 
| 658 | c$$$     $        ,nclstr1,maxs(nclstr1),mult(nclstr1),sgnl(nclstr1) | 
| 659 | c$$$         print*,'----------------------' | 
| 660 |  | 
| 661 | enddo | 
| 662 |  | 
| 663 | return | 
| 664 | end | 
| 665 | *---***---***---***---***---***---***---***---*** | 
| 666 | * | 
| 667 | * | 
| 668 | * | 
| 669 | * | 
| 670 | * | 
| 671 | *---***---***---***---***---***---***---***---*** | 
| 672 |  | 
| 673 |  | 
| 674 | c$$$      subroutine stripmask | 
| 675 | c$$$ | 
| 676 | c$$$*     this routine set va1 and single-strip masks, | 
| 677 | c$$$*     on the basis of the VA1 mask saved in the DB | 
| 678 | c$$$* | 
| 679 | c$$$*     mask(nviews,nva1_view,nstrips_va1) !strip mask | 
| 680 | c$$$*     mask_vk(nviews,nva1_view)          !VA1 mask | 
| 681 | c$$$* | 
| 682 | c$$$      include 'commontracker.f' | 
| 683 | c$$$      include 'level1.f' | 
| 684 | c$$$      include 'common_reduction.f' | 
| 685 | c$$$      include 'calib.f' | 
| 686 | c$$$ | 
| 687 | c$$$*     init mask | 
| 688 | c$$$      do iv=1,nviews | 
| 689 | c$$$         do ivk=1,nva1_view | 
| 690 | c$$$            do is=1,nstrips_va1 | 
| 691 | c$$$c               mask(iv,ivk,is) = mask_vk(iv,ivk) | 
| 692 | c$$$               if( mask_vk(iv,ivk) .ne. -1)then | 
| 693 | c$$$                  mask(iv,ivk,is) = 1 | 
| 694 | c$$$     $                 * mask_vk(iv,ivk)     !from DB | 
| 695 | c$$$     $                 * mask_vk_ev(iv,ivk)  !from <SIG> | 
| 696 | c$$$     $                 * mask_vk_run(iv,ivk) !from CN | 
| 697 | c$$$               else | 
| 698 | c$$$                  mask(iv,ivk,is) = -1 | 
| 699 | c$$$     $                 * mask_vk(iv,ivk)     !from DB | 
| 700 | c$$$     $                 * mask_vk_ev(iv,ivk)  !from CN | 
| 701 | c$$$               endif | 
| 702 | c$$$            enddo | 
| 703 | c$$$         enddo | 
| 704 | c$$$      enddo | 
| 705 | c$$$ | 
| 706 | c$$$ | 
| 707 | c$$$      return | 
| 708 | c$$$      end | 
| 709 |  | 
| 710 | subroutine stripmask(iv,ivk) | 
| 711 |  | 
| 712 | *     ----------------------------------------------- | 
| 713 | *     this routine set va1 and single-strip masks, | 
| 714 | *     on the basis of the VA1 mask saved in the DB | 
| 715 | * | 
| 716 | *     mask(nviews,nva1_view,nstrips_va1) !strip mask | 
| 717 | *     mask_vk(nviews,nva1_view)          !VA1 mask | 
| 718 | *     ----------------------------------------------- | 
| 719 | include 'commontracker.f' | 
| 720 | include 'level1.f' | 
| 721 | include 'common_reduction.f' | 
| 722 | include 'calib.f' | 
| 723 |  | 
| 724 | *     init mask | 
| 725 | do is=1,nstrips_va1 | 
| 726 | *        -------------------------------------------------------- | 
| 727 | *        if VA1-mask from DB is 0 or 1, three masks are combined: | 
| 728 | *        - from DB (a-priori mask) | 
| 729 | *        - run-based (chip declared bad on the basis of <SIG>) | 
| 730 | *        - event-based (failure in CN computation) | 
| 731 | *        -------------------------------------------------------- | 
| 732 | c         print*,iv,ivk | 
| 733 | c     $        ,mask_vk(iv,ivk),mask_vk_ev(iv,ivk),mask_vk_run(iv,ivk) | 
| 734 | if( mask_vk(iv,ivk) .ne. -1)then | 
| 735 | mask(iv,ivk,is) = 1 | 
| 736 | $           * mask_vk(iv,ivk)     !from DB | 
| 737 | $           * mask_vk_ev(iv,ivk)  !from <SIG> | 
| 738 | $           * mask_vk_run(iv,ivk) !from CN | 
| 739 | *        ----------------------------------------------------------- | 
| 740 | *        if VA1-mask from DB is -1 only event-based mask is applied | 
| 741 | *        ----------------------------------------------------------- | 
| 742 | else | 
| 743 | mask(iv,ivk,is) = -1 | 
| 744 | $           * mask_vk(iv,ivk)     !from DB | 
| 745 | $           * mask_vk_ev(iv,ivk)  !from CN | 
| 746 | endif | 
| 747 | enddo | 
| 748 |  | 
| 749 |  | 
| 750 | return | 
| 751 | end |