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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.8 - (show annotations) (download)
Mon Aug 20 16:07:16 2007 UTC (17 years, 5 months ago) by pam-fi
Branch: MAIN
CVS Tags: v5r00, v4r00, v10RED, v9r00, v9r01, v10REDr01, v6r01, v6r00, HEAD
Changes since 1.7: +41 -24 lines
missing-image bug fixed + other changes

1 *************************************************************************
2 *
3 * Subroutine read_B.f
4 *
5 * it calls the subroutines which read the magnetic field maps for
6 * the PAMELA spectrometer
7 *
8 * needs:
9 * - ./read_B_inner.f inner map reading subroutine
10 * - ./read_B_outer.f outer map reading subroutine
11 *
12 * to be called before ./inter_B.f (interpolation subroutine)
13 *
14 *************************************************************************
15
16 c$$$ subroutine readB(cpath)
17 c$$$ include 'common_c2f.f'
18 c$$$
19 c$$$ LOGICAL DEBUG
20 c$$$ LOGICAL VERBOSE
21 c$$$ LOGICAL WARNING
22 c$$$ COMMON/DBG/DEBUG,VERBOSE,WARNING
23 c$$$ SAVE/DBG/
24 c$$$
25 c$$$ character*256 cpath
26 c$$$ character*256 ppath
27 c$$$
28 c$$$
29 c$$$ b_error=0
30 c$$$ ppath=''
31 c$$$
32 c$$$ la=256
33 c$$$ do i=1,256
34 c$$$ if(cpath(i:i).eq.'/')la=i
35 c$$$ enddo
36 c$$$ ppath=cpath(1:la)
37 c$$$
38 c$$$ b_path = ppath
39 c$$$ b_pathlen = la
40 c$$$
41 c$$$ if(DEBUG)print*,'Field loaded: ',b_loaded
42 c$$$ if(b_loaded.eq.0)then
43 c$$$
44 c$$$c call the subroutine which reads the maps of the measurements taken
45 c$$$c inside the magnetic cavity
46 c$$$ call readBinner(ppath)
47 c$$$ if(b_error.eq.1)return
48 c$$$
49 c$$$c call the subroutine which reads the maps of the measurements taken
50 c$$$c outside the magnetic cavity
51 c$$$ call readBouter(ppath)
52 c$$$ if(b_error.eq.1)return
53 c$$$
54 c$$$ b_loaded = 1
55 c$$$ endif
56 c$$$
57 c$$$ return
58 c$$$ end
59 subroutine readB
60 include 'common_c2f.f'
61
62 c$$$ LOGICAL DEBUG
63 c$$$ LOGICAL VERBOSE
64 c$$$ LOGICAL WARNING
65 c$$$ COMMON/DBG/DEBUG,VERBOSE,WARNING
66 c$$$ SAVE/DBG/
67 INTEGER DEBUG
68 INTEGER VERBOSE
69 INTEGER WARNING
70 COMMON/dbg/DEBUG,VERBOSE,WARNING
71 SAVE/dbg/
72
73
74
75 c$$$ character*256 cpath
76 character*256 ppath
77
78
79 c2f_error=0
80
81 ppath=c2f_path(1:c2f_pathlen)
82
83
84 c VERBOSE=.true.
85
86 c call the subroutine which reads the maps of the measurements taken
87 c inside the magnetic cavity
88 call readBinner(ppath)
89 if(c2f_error.eq.1)return
90
91 c call the subroutine which reads the maps of the measurements taken
92 c outside the magnetic cavity
93 call readBouter(ppath)
94 if(c2f_error.eq.1)return
95
96
97 return
98 end
99
100 ************************************************************
101
102
103 *************************************************************************
104 *
105 * Subroutine readBinner
106 *
107 * it reads from rz files the two magnetic field maps taken inside the
108 * spectrometer cavity and fills the variables in common_B_inner.f
109 *
110 * needs:
111 * - common_B.f common file for the inner magnetic field map
112 * - .rz map files in ./ containing coordinates of measured points, Bx, By
113 * and Bz components + errors
114 *
115 * output variables: (see common_B_inner.f)
116 * - px#(nx,3) with #=1,2 for the 2 maps
117 * - py#(ny,3)
118 * - pz#(nz,3)
119 * - b#(nx,ny,nz,3)
120 *
121 *************************************************************************
122
123 subroutine readBinner(path)
124
125 c implicit double precision (a-h,o-z)
126 include 'common_B.f'
127 include 'common_c2f.f'
128
129 c$$$ LOGICAL DEBUG
130 c$$$ LOGICAL VERBOSE
131 c$$$ LOGICAL WARNING
132 c$$$ COMMON/DBG/DEBUG,VERBOSE,WARNING
133 c$$$ SAVE/DBG/
134 INTEGER DEBUG
135 INTEGER VERBOSE
136 INTEGER WARNING
137 COMMON/dbg/DEBUG,VERBOSE,WARNING
138 SAVE/dbg/
139
140 character*256 path
141
142 C
143 REAL hmemor(10000000)
144 integer Iquest(100)
145 COMMON /pawc/hmemor
146 save /pawc/
147 C
148 Common /QUEST/ Iquest
149 save /quest/
150
151
152 c------------------------------------------------------------------------
153 c
154 c local variables
155 c
156 c------------------------------------------------------------------------
157
158 character*64 Bmap_file !magnetic field file name
159 parameter (lun_Bmap_file=66) !magnetic field map file id number
160
161 parameter (ntpl_Bmap=20) !ntuple identifier
162
163 REAL PFX(3),FX,DFX, !Bx field component coordinates in m, value and error in T
164 $ PFY(3),FY,DFY
165 $ ,PFZ(3),FZ,DFZ
166 INTEGER INDEX(3) !point index
167
168 COMMON /PAWCR4/ INDEX,PFX,FX,DFX,PFY,FY,DFY,PFZ,FZ,DFZ
169
170
171 CALL HLIMIT(10000000)
172 C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
173 C largest RZ file: IQUEST(10) records x LREC words x 4 byte
174 C with the following settings: 65000 x 4096 x 4 = 1G
175 C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
176
177 c permette di ottenere ntuple funzionanti nonostante
178 c il messaggio dei 64K di RZOUT
179 Iquest(10) = 512000
180 c------------------------------------------------------------------------
181 c
182 c *** FIRST MAP ***
183 c
184 c------------------------------------------------------------------------
185
186 c------------------------------------------------------------------------
187 c
188 c initialization and map file opening
189 c
190 c------------------------------------------------------------------------
191
192 c print*,' '
193 c print*,' '
194
195 Bmap_file='measure_n3_290302.rz'
196
197 c opens magnetic field map first file
198 c if(b_debug.eq.1)print *
199 if(VERBOSE.EQ.1)print *
200 $ ,path(1:LNBLNK(path))//Bmap_file
201 call HROPEN
202 $ (lun_Bmap_file,'Bmap'
203 $ ,path(1:LNBLNK(path))//Bmap_file
204 $ ,'P',1024,istat)
205 if(istat.ne.0) goto 21
206
207
208 call HRIN(ntpl_Bmap,9999,0) !puts B map ntuple in memory
209
210 c call HPRNTU(ntpl_Bmap)
211 call HBNAME(ntpl_Bmap,' ',0,'$CLEAR')
212 call HBNAME(ntpl_Bmap,'INDEX',index,'$SET')
213 call HBNAME(ntpl_Bmap,'BX',pfx,'$SET')
214 call HBNAME(ntpl_Bmap,'BY',pfy,'$SET')
215 call HBNAME(ntpl_Bmap,'BZ',pfz,'$SET')
216
217
218 c------------------------------------------------------------------------
219 c
220 c reads events and fills variables
221 c
222 c------------------------------------------------------------------------
223
224 call HNOENT(ntpl_Bmap,iemax) !number of events
225
226 c initializes measurement grid edges
227 do ic=1,3
228 px1max(ic)=0.
229 px1min(ic)=0.
230 py1max(ic)=0.
231 py1min(ic)=0.
232 pz1max(ic)=0.
233 pz1min(ic)=0.
234 enddo
235
236
237 do iev=1,iemax !event loop
238
239 call HGNT(ntpl_Bmap,iev,ierr) !reads event
240 if(ierr.ne.0) goto 22
241
242 c the output consists of matrices for coordinates, B components values
243 c and errors:
244 c e.g. px1(4,2) = X coordinate of the point with index = 4 along X,
245 c in which By (=2) component has been measured
246 c e.g. b1(3,23,4,1) = Bx (=1) component value, measured in the point with
247 c indexes = 3,23,4 along X, Y and Z
248
249 c Bx component
250 px1(index(1),1) = pfx(1)
251 if(px1(index(1),1).lt.px1min(1)) px1min(1)=px1(index(1),1)
252 if(px1(index(1),1).gt.px1max(1)) px1max(1)=px1(index(1),1)
253 py1(index(2),1) = pfx(2)
254 if(py1(index(2),1).lt.py1min(1)) py1min(1)=py1(index(2),1)
255 if(py1(index(2),1).gt.py1max(1)) py1max(1)=py1(index(2),1)
256 pz1(index(3),1) = pfx(3)
257 if(pz1(index(3),1).lt.pz1min(1)) pz1min(1)=pz1(index(3),1)
258 if(pz1(index(3),1).gt.pz1max(1)) pz1max(1)=pz1(index(3),1)
259
260 b1(index(1),index(2),index(3),1) = fx
261
262
263 c By component
264 px1(index(1),2) = pfy(1)
265 if(px1(index(1),2).lt.px1min(2)) px1min(2)=px1(index(1),2)
266 if(px1(index(1),2).gt.px1max(2)) px1max(2)=px1(index(1),2)
267 py1(index(2),2) = pfy(2)
268 if(py1(index(2),2).lt.py1min(2)) py1min(2)=py1(index(2),2)
269 if(py1(index(2),2).gt.py1max(2)) py1max(2)=py1(index(2),2)
270 pz1(index(3),2) = pfy(3)
271 if(pz1(index(3),2).lt.pz1min(2)) pz1min(2)=pz1(index(3),2)
272 if(pz1(index(3),2).gt.pz1max(2)) pz1max(2)=pz1(index(3),2)
273
274 b1(index(1),index(2),index(3),2) = fy
275
276
277 c Bz component
278 px1(index(1),3) = pfz(1)
279 if(px1(index(1),3).lt.px1min(3)) px1min(3)=px1(index(1),3)
280 if(px1(index(1),3).gt.px1max(3)) px1max(3)=px1(index(1),3)
281 py1(index(2),3) = pfz(2)
282 if(py1(index(2),3).lt.py1min(3)) py1min(3)=py1(index(2),3)
283 if(py1(index(2),3).gt.py1max(3)) py1max(3)=py1(index(2),3)
284 pz1(index(3),3) = pfz(3)
285 if(pz1(index(3),3).lt.pz1min(3)) pz1min(3)=pz1(index(3),3)
286 if(pz1(index(3),3).gt.pz1max(3)) pz1max(3)=pz1(index(3),3)
287
288 b1(index(1),index(2),index(3),3) = fz
289
290 enddo
291
292 c------------------------------------------------------------------------
293 c
294 c closes files
295 c
296 c------------------------------------------------------------------------
297
298 call HREND('Bmap')
299 close(lun_Bmap_file)
300 c$$$ cmd2='rm -f '
301 c$$$ $ //Bmap_file(1:LNBLNK(Bmap_file))
302 c$$$ call system(cmd2)
303 c$$$
304
305
306 c------------------------------------------------------------------------
307 c
308 c *** SECOND MAP ***
309 c
310 c------------------------------------------------------------------------
311
312 c------------------------------------------------------------------------
313 c
314 c initialization and map file opening
315 c
316 c------------------------------------------------------------------------
317
318 c print*,' '
319 c print*,' '
320
321 Bmap_file='measure_n4_110402_corrected.rz'
322 c opens magnetic field map first file
323 c if(b_debug.eq.1)print * !,'Opening file: '
324 if(VERBOSE.EQ.1)print * !,'Opening file: '
325 $ ,path(1:LNBLNK(path))//Bmap_file
326 call HROPEN
327 $ (lun_Bmap_file,'Bmap'
328 $ ,path(1:LNBLNK(path))//Bmap_file
329 $ ,'P',1024,istat)
330 if(istat.ne.0) goto 21
331
332
333 call HRIN(ntpl_Bmap,9999,0) !puts B map ntuple in memory
334
335 c call HPRNTU(ntpl_Bmap)
336 call HBNAME(ntpl_Bmap,' ',0,'$CLEAR')
337 call HBNAME(ntpl_Bmap,'INDEX',index,'$SET')
338 call HBNAME(ntpl_Bmap,'BX',pfx,'$SET')
339 call HBNAME(ntpl_Bmap,'BY',pfy,'$SET')
340 call HBNAME(ntpl_Bmap,'BZ',pfz,'$SET')
341
342
343 c------------------------------------------------------------------------
344 c
345 c reads events and fills variables
346 c
347 c------------------------------------------------------------------------
348
349 call HNOENT(ntpl_Bmap,iemax) !number of events
350
351 c print*,'iemax ',iemax
352
353 do ic=1,3 !grid edges
354 px2max(ic)=0.
355 px2min(ic)=0.
356 py2max(ic)=0.
357 py2min(ic)=0.
358 pz2max(ic)=0.
359 pz2min(ic)=0.
360 enddo
361
362
363 do iev=1,iemax !event loop
364
365 call HGNT(ntpl_Bmap,iev,ierr) !reads event
366 if(ierr.ne.0) goto 22
367
368 c the output consists of matrices for coordinates, B components values
369 c and errors:
370 c e.g. px(4,2) = X coordinate of the point with index = 4 along X,
371 c in which By (=2) component has been measured
372 c e.g. b(3,23,4,1) = Bx (=1) component value, measured in the point with
373 c indexes = 3,23,4 along X, Y and Z
374
375 c Bx component
376 px2(index(1),1) = pfx(1)
377 if(px2(index(1),1).lt.px2min(1)) px2min(1)=px2(index(1),1)
378 if(px2(index(1),1).gt.px2max(1)) px2max(1)=px2(index(1),1)
379 py2(index(2),1) = pfx(2)
380 if(py2(index(2),1).lt.py2min(1)) py2min(1)=py2(index(2),1)
381 if(py2(index(2),1).gt.py2max(1)) py2max(1)=py2(index(2),1)
382 pz2(index(3),1) = pfx(3)
383 if(pz2(index(3),1).lt.pz2min(1)) pz2min(1)=pz2(index(3),1)
384 if(pz2(index(3),1).gt.pz2max(1)) pz2max(1)=pz2(index(3),1)
385
386 b2(index(1),index(2),index(3),1) = fx
387
388
389 c By component
390 px2(index(1),2) = pfy(1)
391 if(px2(index(1),2).lt.px2min(2)) px2min(2)=px2(index(1),2)
392 if(px2(index(1),2).gt.px2max(2)) px2max(2)=px2(index(1),2)
393 py2(index(2),2) = pfy(2)
394 if(py2(index(2),2).lt.py2min(2)) py2min(2)=py2(index(2),2)
395 if(py2(index(2),2).gt.py2max(2)) py2max(2)=py2(index(2),2)
396 pz2(index(3),2) = pfy(3)
397 if(pz2(index(3),2).lt.pz2min(2)) pz2min(2)=pz2(index(3),2)
398 if(pz2(index(3),2).gt.pz2max(2)) pz2max(2)=pz2(index(3),2)
399
400 b2(index(1),index(2),index(3),2) = fy
401
402
403 c Bz component
404 px2(index(1),3) = pfz(1)
405 if(px2(index(1),3).lt.px2min(3)) px2min(3)=px2(index(1),3)
406 if(px2(index(1),3).gt.px2max(3)) px2max(3)=px2(index(1),3)
407 py2(index(2),3) = pfz(2)
408 if(py2(index(2),3).lt.py2min(3)) py2min(3)=py2(index(2),3)
409 if(py2(index(2),3).gt.py2max(3)) py2max(3)=py2(index(2),3)
410 pz2(index(3),3) = pfz(3)
411 if(pz2(index(3),3).lt.pz2min(3)) pz2min(3)=pz2(index(3),3)
412 if(pz2(index(3),3).gt.pz2max(3)) pz2max(3)=pz2(index(3),3)
413
414 b2(index(1),index(2),index(3),3) = fz
415
416 enddo
417
418 c------------------------------------------------------------------------
419 c
420 c closes files
421 c
422 c------------------------------------------------------------------------
423
424 call HREND('Bmap')
425 close(lun_Bmap_file)
426
427 c------------------------------------------------------------------------
428 c
429 c no error exit
430 c
431 c------------------------------------------------------------------------
432
433 goto 9000 !happy ending
434
435 c------------------------------------------------------------------------
436 c
437 c magnetic field map file opening error
438 c
439 c------------------------------------------------------------------------
440
441 21 continue
442
443 c2f_error = 1
444 c if(b_debug.eq.1)
445 if(DEBUG.EQ.1)
446 $ print*
447 $ ,'read_B_inner: ERROR OPENING MAGNETIC FIELD MAP FILE: '
448 $ ,Bmap_file
449
450 goto 9000 !the end
451
452
453 c------------------------------------------------------------------------
454 c
455 c ntuple event reading error
456 c
457 c------------------------------------------------------------------------
458
459 22 continue
460
461 c2f_error = 1
462 c if(b_debug.eq.1.eq.1)
463 if(DEBUG.EQ.1)
464 $ print*,'read_B_inner: ERROR WHILE READING NTUPLE, at entry
465 $ : ',iev
466
467 goto 9000 !the end
468
469
470 c------------------------------------------------------------------------
471 c
472 c exit
473 c
474 c------------------------------------------------------------------------
475
476 9000 continue
477
478 return
479 end
480 *************************************************************************
481 *
482 * Subroutine readBouter
483 *
484 * it reads from rz files the two magnetic field maps taken inside the
485 * spectrometer cavity and fills the variables in common_B_inner.f
486 *
487 * needs:
488 * - common_B_outer.f common file for the outer magnetic field map
489 * - .rz map files in ./ containing coordinates of measured points, Bx, By
490 * and Bz components + errors
491 *
492 * output variables: (see common_B_outer.f)
493 * - pxo(nx,3)
494 * - pyo(ny,3)
495 * - pzo(nz,3)
496 * - bo(nx,ny,nz,3)
497 *
498 *************************************************************************
499
500 subroutine readBouter(path)
501
502 c implicit double precision (a-h,o-z)
503 include 'common_B.f'
504 include 'common_c2f.f'
505 C
506 c$$$ LOGICAL DEBUG
507 c$$$ LOGICAL VERBOSE
508 c$$$ LOGICAL WARNING
509 c$$$ COMMON/DBG/DEBUG,VERBOSE,WARNING
510 c$$$ SAVE/DBG/
511 INTEGER DEBUG
512 INTEGER VERBOSE
513 INTEGER WARNING
514 COMMON/dbg/DEBUG,VERBOSE,WARNING
515 SAVE/dbg/
516
517 character*256 path
518
519 REAL hmemor(10000000)
520 integer Iquest(100)
521 COMMON /pawc/hmemor
522 save /pawc/
523 C
524 Common /QUEST/ Iquest
525 save /quest/
526
527
528
529 c------------------------------------------------------------------------
530 c
531 c local variables
532 c
533 c------------------------------------------------------------------------
534
535 character*64 Bmap_file !magnetic field file name
536 parameter (lun_Bmap_file=66) !magnetic field map file id number
537
538 parameter (ntpl_Bmap=20) !ntuple identifier
539
540 REAL PFX(3),FX,DFX, !Bx field component coordinates in m, value and error in T
541 $ PFY(3),FY,DFY
542 $ ,PFZ(3),FZ,DFZ
543 INTEGER INDEX(3) !point index
544
545 COMMON /PAWCR4/ INDEX,PFX,FX,DFX,PFY,FY,DFY,PFZ,FZ,DFZ
546
547
548 c print*,'Calling HLIMIT'
549 CALL HLIMIT(10000000)
550 C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
551 C largest RZ file: IQUEST(10) records x LREC words x 4 byte
552 C with the following settings: 65000 x 4096 x 4 = 1G
553 C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
554
555 c permette di ottenere ntuple funzionanti nonostante
556 c il messaggio dei 64K di RZOUT
557 Iquest(10) = 512000
558 c------------------------------------------------------------------------
559 c
560 c *** FIRST MAP ***
561 c
562 c------------------------------------------------------------------------
563
564 c------------------------------------------------------------------------
565 c
566 c initialization and map file opening
567 c
568 c------------------------------------------------------------------------
569
570 c print*,' '
571 c print*,' '
572
573 Bmap_file='External_top_map_n4_150402.rz'
574
575 c opens magnetic field map first file
576 c if(b_debug.eq.1)print *
577 if(VERBOSE.EQ.1)print *
578 $ ,path(1:LNBLNK(path))//Bmap_file
579 call HROPEN
580 $ (lun_Bmap_file,'Bmap'
581 $ ,path(1:LNBLNK(path))//Bmap_file
582 $ ,'P',1024,istat)
583 if(istat.ne.0) goto 21
584
585
586 call HRIN(ntpl_Bmap,9999,0) !puts B map ntuple in memory
587
588 c call HPRNTU(ntpl_Bmap)
589 call HBNAME(ntpl_Bmap,' ',0,'$CLEAR')
590 call HBNAME(ntpl_Bmap,'INDEX',index,'$SET')
591 call HBNAME(ntpl_Bmap,'BX',pfx,'$SET')
592 call HBNAME(ntpl_Bmap,'BY',pfy,'$SET')
593 call HBNAME(ntpl_Bmap,'BZ',pfz,'$SET')
594
595
596 c------------------------------------------------------------------------
597 c
598 c reads events and fills variables
599 c
600 c------------------------------------------------------------------------
601
602 call HNOENT(ntpl_Bmap,iemax) !number of events
603
604 c initializes measurement grid edges
605 do ic=1,3
606 poxmax(ic)=0.
607 poxmin(ic)=0.
608 poymax(ic)=0.
609 poymin(ic)=0.
610 pozmax(ic)=0.
611 pozmin(ic)=0.
612 enddo
613
614
615 do iev=1,iemax !event loop
616
617 call HGNT(ntpl_Bmap,iev,ierr) !reads event
618 if(ierr.ne.0) goto 22
619
620 c the output consists of matrices for coordinates, B components values
621 c and errors:
622 c e.g. px1(4,2) = X coordinate of the point with index = 4 along X,
623 c in which By (=2) component has been measured
624 c e.g. b1(3,23,4,1) = Bx (=1) component value, measured in the point with
625 c indexes = 3,23,4 along X, Y and Z
626
627 c Bx component
628 pox(index(1),1) = pfx(1)
629 if(pox(index(1),1).lt.poxmin(1)) poxmin(1)=pox(index(1),1)
630 if(pox(index(1),1).gt.poxmax(1)) poxmax(1)=pox(index(1),1)
631 poy(index(2),1) = pfx(2)
632 if(poy(index(2),1).lt.poymin(1)) poymin(1)=poy(index(2),1)
633 if(poy(index(2),1).gt.poymax(1)) poymax(1)=poy(index(2),1)
634 poz(index(3),1) = pfx(3)
635 if(poz(index(3),1).lt.pozmin(1)) pozmin(1)=poz(index(3),1)
636 if(poz(index(3),1).gt.pozmax(1)) pozmax(1)=poz(index(3),1)
637
638 bo(index(1),index(2),index(3),1) = fx
639
640
641 c By component
642 pox(index(1),2) = pfy(1)
643 if(pox(index(1),2).lt.poxmin(2)) poxmin(2)=pox(index(1),2)
644 if(pox(index(1),2).gt.poxmax(2)) poxmax(2)=pox(index(1),2)
645 poy(index(2),2) = pfy(2)
646 if(poy(index(2),2).lt.poymin(2)) poymin(2)=poy(index(2),2)
647 if(poy(index(2),2).gt.poymax(2)) poymax(2)=poy(index(2),2)
648 poz(index(3),2) = pfy(3)
649 if(poz(index(3),2).lt.pozmin(2)) pozmin(2)=poz(index(3),2)
650 if(poz(index(3),2).gt.pozmax(2)) pozmax(2)=poz(index(3),2)
651
652 bo(index(1),index(2),index(3),2) = fy
653
654
655 c Bz component
656 pox(index(1),3) = pfz(1)
657 if(pox(index(1),3).lt.poxmin(3)) poxmin(3)=pox(index(1),3)
658 if(pox(index(1),3).gt.poxmax(3)) poxmax(3)=pox(index(1),3)
659 poy(index(2),3) = pfz(2)
660 if(poy(index(2),3).lt.poymin(3)) poymin(3)=poy(index(2),3)
661 if(poy(index(2),3).gt.poymax(3)) poymax(3)=poy(index(2),3)
662 poz(index(3),3) = pfz(3)
663 if(poz(index(3),3).lt.pozmin(3)) pozmin(3)=poz(index(3),3)
664 if(poz(index(3),3).gt.pozmax(3)) pozmax(3)=poz(index(3),3)
665
666 bo(index(1),index(2),index(3),3) = fz
667
668 enddo
669
670
671 c------------------------------------------------------------------------
672 c
673 c closes files
674 c
675 c------------------------------------------------------------------------
676
677 call HREND('Bmap')
678 close(lun_Bmap_file)
679
680
681 c------------------------------------------------------------------------
682 c
683 c no error exit
684 c
685 c------------------------------------------------------------------------
686
687 goto 9000 !happy ending
688
689 c------------------------------------------------------------------------
690 c
691 c magnetic field map file opening error
692 c
693 c------------------------------------------------------------------------
694
695 21 continue
696
697 c2f_error = 1
698 c if(b_debug.eq.1)
699 if(DEBUG.EQ.1)
700 $ print*
701 $ ,'read_B_inner: ERROR OPENING MAGNETIC FIELD MAP FILE: '
702 $ ,Bmap_file
703
704 goto 9000 !the end
705
706
707 c------------------------------------------------------------------------
708 c
709 c ntuple evevent reading error
710 c
711 c------------------------------------------------------------------------
712
713 22 continue
714
715 c2f_error = 1
716 c if(b_debug.eq.1)
717 if(DEBUG.EQ.1)
718 $ print*
719 $ ,'read_B_inner: ERROR WHILE READING NTUPLE, at event
720 $ : ',iev
721
722 goto 9000 !the end
723
724
725 c------------------------------------------------------------------------
726 c
727 c exit
728 c
729 c------------------------------------------------------------------------
730
731 9000 continue
732
733 return
734 end
735

  ViewVC Help
Powered by ViewVC 1.1.23