00001 #include "mEmcDefGeom.h"
00002 #include "emlLib.h"
00003
00004 #include "gsl/gsl_math.h"
00005
00006 #include <math.h>
00007
00015 long type_of_call mEmcDefGeom_(
00016 TABLE_HEAD_ST *dEmcGeaParams_h, DEMCGEAPARAMS_ST *dEmcGeaParams ,
00017 TABLE_HEAD_ST *dEmcGeometry_h, DEMCGEOMETRY_ST *dEmcGeometry )
00018 {
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087 #define max1(x,y) ( ( int ) ( (x) > (y) ) ? (x) : (y) )
00088 #define amax1(x,y) ( ( (x) > (y) ) ? (x) : (y) )
00089 #define max(x,y) ( ( (x) > (y) ) ? (x) : (y) )
00090 #define min(x,y) ( ( (x) < (y) ) ? (x) : (y) )
00091
00092 int size;
00093
00094 int pcons1, pcons2;
00095
00096
00097
00098 #define max_chanz 96
00099 #define max_chany 48
00100 #define max_subdet 8
00101 #define max_fields 10
00102
00103
00104 float ra_det[120][max_subdet];
00105
00106
00107
00108
00109
00110
00111
00112
00113
00114
00115
00116 int i_trans[8][2] =
00117 {
00118 1, 0,
00119 2, 0,
00120 3, 0,
00121 4, 0,
00122 5, 0,
00123 6, 0,
00124 0, 7,
00125 0, 8
00126 };
00127
00128 int i_limits[16] = { 72,36,72,36,72,36,72,36,72,36,72,36, 96,48,96,48 };
00129
00130
00131
00132
00133
00134
00135
00136
00137
00138
00139
00140
00141
00142
00143
00144
00145 float emc_geom[max_fields][max_chanz][max_chany][max_subdet];
00146 int i,j,iz,iy,i1;
00147 int ll;
00148 float r_work1;
00149 float r_appx,r_appy,r_appz;
00150 float r_measthe = 0.0;
00151 float r_measphi = 0.0;
00152
00153 float r_sectheta,r_secphi,r_dist,r_distz,r_disty;
00154
00155
00156
00157
00158
00159
00160
00161
00162
00163
00164 int emc_walls = 8;
00165
00166 float emc_cutgam = 0.001;
00167 float emc_cutele = 0.001;
00168 float emc_cutneu = 0.001;
00169 float emc_cuthad = 0.001;
00170 float emc_cutmuo = 0.001;
00171 float ra_sampfrac[23][2] =
00172 {
00173 .0001, .2443, .0002, .2432, .0005, .2313, .0008, .2204,
00174 .0010, .2054, .0012, .1981, .0015, .1889, .0018, .1809,
00175 .0020, .1760, .0022, .1717, .0025, .1650, .0028, .1607,
00176 .0030, .1565, .0040, .1429, .0050, .1307, .0060, .1214,
00177 .0070, .1130, .0080, .1058, .0090, .0993, .0100, .0936,
00178 .0120, .0824, .0150, .0710, .0200, .0576
00179 };
00180
00181 float r_cutgam,r_sampfrac;
00182 int l_automatic_threshold = TRUE;
00183 int ind1,ind2;
00184
00185
00186
00187
00188
00189
00190
00191
00192
00193
00194
00195
00196 float ra_newcalib[4][4] =
00197 {
00198 0.2285, 0.1891, 0.1715, 0.1428,
00199 0.2285, 0.1891, 0.1715, 0.1428,
00200 0.1872, 0.1658, 0.1715, 0.1387,
00201 0.1382, 0.1593, 0.1715, 0.1295
00202 };
00203
00204
00205
00206
00207
00208
00209
00210
00211
00212
00213
00214
00215
00216
00217
00218
00219
00220
00221 float rpos_plus_pbsc = 0.0;
00222 float rpos_plus_pbgl = 0.0;
00223
00224 int istaf;
00225
00226
00227
00228
00229
00230
00231
00232
00233
00234
00235
00236
00237
00238
00239
00240
00241
00242
00243
00244
00245
00246
00247
00248
00249
00250
00251
00252
00253
00254
00255
00256
00257
00258
00259
00260
00261
00262
00263
00264
00265
00266
00267
00268
00269
00270
00271
00272
00273
00274
00275
00276
00277
00278
00279
00280
00281
00282
00283
00284
00285
00286
00287
00288
00289
00290
00291
00292
00293
00294
00295
00296
00297
00298
00299
00300
00301
00302
00303
00304
00305
00306
00307
00308
00309
00310
00311
00312
00313
00314
00315
00316
00317
00318
00319
00320
00321
00322
00323
00324
00325
00326
00327
00328
00329
00330
00331
00332
00333
00334
00335
00336
00337
00338
00339
00340
00341
00342
00343
00344
00345
00346
00347
00348
00349
00350 double d_theta,d_phi,d_work,d_work0,d_work1,d_work2;
00351 double todeg,torad;
00352
00353
00354
00355 torad = M_PI / 180.0;
00356 todeg = 180.0 / M_PI;
00357
00358
00359
00360
00361
00362
00363
00364
00365
00366 if(dEmcGeaParams_h->nok > 0)
00367 {
00368 return(STAFCV_OK);
00369 }
00370
00371
00372 for (ll = 0; ll < sizeof(ra_det)/sizeof(ra_det[0][0]); ll++)
00373 {
00374 *((float *)ra_det + ll) = 0.0;
00375 }
00376
00377
00378
00379
00380
00381
00382
00383 for(j=0;j<8;j++)
00384 {
00385
00386 ra_det[0][j] = 8.0;
00387
00388 ra_det[1][j] = 3.0;
00389
00390 ra_det[2][j] = (float) j+1;
00391 }
00392
00393
00394
00395 for(j=0;j<6;j++){ ra_det[3][j]=1.0;}
00396 for(j=6;j<8;j++){ ra_det[3][j]=2.0;}
00397
00398 ra_det[4][0] = 202.632;
00399 ra_det[4][1] = 180.000;
00400 ra_det[4][2] = 157.368;
00401 ra_det[4][3] = 134.738;
00402 ra_det[4][4] = 45.264;
00403 ra_det[4][5] = 22.632;
00404 ra_det[4][6] = 0.000;
00405 ra_det[4][7] = -22.000;
00406
00407 for(j=0;j<6;j++){ ra_det[5][j]= 510.0;}
00408 for(j=6;j<8;j++){ ra_det[5][j]= 552.64;}
00409
00410 for(j=0;j<6;j++){ ra_det[6][j]= -196.74;}
00411 for(j=6;j<8;j++){ ra_det[6][j]= -193.23;}
00412
00413
00414 if(j>5) {ra_det[5][j] = 543.2;}
00415
00416
00417 ra_det[7][0] = -285.771;
00418 ra_det[7][1] = -96.985;
00419 ra_det[7][2] = 106.738;
00420 ra_det[7][3] = 294.022;
00421 ra_det[7][4] = 294.022;
00422 ra_det[7][5] = 106.738;
00423 ra_det[7][6] = -95.598;
00424 ra_det[7][7] = -291.674;
00425
00426
00427 for(j=0;j<6;j++){ ra_det[8][j]= 38.934;}
00428 for(j=6;j<8;j++){ ra_det[8][j]= 51.200;}
00429
00430 for(j=0;j<6;j++){ ra_det[9][j]= 5.542;}
00431
00432
00433
00434
00435
00436
00437
00438
00439
00440
00441
00442 for(j=6;j<8;j++){ ra_det[9][j]= 4.104;}
00443
00444
00445
00446 for(j=0;j<6;j++){ ra_det[10][j]= 12.0;}
00447 for(j=6;j<8;j++){ ra_det[10][j]= 6.0;}
00448
00449 for(j=0;j<6;j++){ ra_det[11][j]= 12.0;}
00450 for(j=6;j<8;j++){ ra_det[11][j]= 4.0;}
00451
00452 for(j=0;j<6;j++){ ra_det[12][j]= 6.0;}
00453 for(j=6;j<8;j++){ ra_det[12][j]= 16.0;}
00454
00455 for(j=0;j<6;j++){ ra_det[13][j]= 3.0;}
00456 for(j=6;j<8;j++){ ra_det[13][j]= 12.0;}
00457
00458 for(j=0;j<8;j++){ ra_det[14][j]= 0.0;}
00459 for(j=0;j<8;j++){ ra_det[15][j]= 0.0;}
00460 for(j=0;j<8;j++){ ra_det[16][j]= 0.0;}
00461
00462 for(j=0;j<6;j++){ ra_det[17][j]= 881.0;}
00463 for(j=6;j<8;j++){ ra_det[17][j]= 810.0;}
00464
00465 for(j=0;j<8;j++){ ra_det[18][j]= 0.0;}
00466 for(j=0;j<8;j++){ ra_det[19][j]= 0.0;}
00467 for(j=0;j<8;j++){ ra_det[20][j]= 0.0;}
00468
00469 for(j=0;j<8;j++){ ra_det[21][j]= 1.0;}
00470
00471 for ( i = 0; i < 5; i++ )
00472 {
00473 ra_det[22+i][j] = 0.001;
00474 }
00475
00476 for(j=0;j<8;j++){ ra_det[27][j]= 0.0;}
00477 for(j=0;j<8;j++){ ra_det[28][j]= 0.0;}
00478
00479 for(j=0;j<6;j++){ ra_det[29][j]= 510.0;}
00480 for(j=6;j<8;j++){ ra_det[29][j]= 535.0;}
00481
00482 for(j=0;j<6;j++){ ra_det[30][j]= 580.0;}
00483 for(j=6;j<8;j++){ ra_det[30][j]= 605.0;}
00484
00485 for(j=0;j<8;j++){ ra_det[31][j]= 0.07;}
00486
00487 for(j=0;j<8;j++){ ra_det[32][j]= -200.0;}
00488
00489 for(j=0;j<8;j++){ ra_det[33][j]= 200.0;}
00490
00491 for(j=0;j<8;j++){ ra_det[34][j]= 0.1;}
00492
00493 for(j=0;j<6;j++){ ra_det[35][j]= 280.0;}
00494 for(j=6;j<8;j++){ ra_det[35][j]= 460.0;}
00495
00496 for(j=0;j<6;j++){ ra_det[36][j]= 560.0;}
00497 for(j=6;j<8;j++){ ra_det[36][j]= 740.0;}
00498
00499 for(j=0;j<6;j++){ ra_det[37][j]= 0.07;}
00500 for(j=6;j<8;j++){ ra_det[37][j]= 0.07;}
00501
00502 for(j=0;j<8;j++){ ra_det[38][j]= 0.0;}
00503
00504 for(j=0;j<6;j++){ ra_det[39][j]= 0.0327;}
00505 for(j=6;j<8;j++){ ra_det[39][j]= 0.256;}
00506
00507 for(j=0;j<6;j++){ ra_det[40][j]= 1.0e-6;}
00508 for(j=6;j<8;j++){ ra_det[40][j]= 8.0e-6;}
00509
00510 for(j=0;j<8;j++){ ra_det[41][j]= 17.0;}
00511
00512 for(j=0;j<8;j++){ ra_det[42][j]= 345.0;}
00513
00514 for(j=0;j<8;j++){ ra_det[43][j]= 0.01;}
00515
00516 for(j=0;j<8;j++){ ra_det[44][j]= 0.0;}
00517 for(j=0;j<8;j++){ ra_det[45][j]= 0.0;}
00518 for(j=0;j<8;j++){ ra_det[46][j]= 0.0;}
00519 for(j=0;j<8;j++){ ra_det[47][j]= 0.0;}
00520 for(j=0;j<8;j++){ ra_det[48][j]= 0.0;}
00521
00522 for(j=0;j<6;j++){ ra_det[49][j]= 18.0;}
00523 for(j=6;j<8;j++){ ra_det[49][j]= 192.0;}
00524
00525 for(j=0;j<6;j++){ ra_det[50][j]= 144.0;}
00526 for(j=6;j<8;j++){ ra_det[50][j]= 24.0;}
00527
00528 for(j=0;j<8;j++){ ra_det[51][j]= 8.0;}
00529
00530 for(j=0;j<8;j++){ ra_det[52][j]= 3.0;}
00531
00532 for(j=0;j<8;j++){ ra_det[53][j]= 8.0;}
00533
00534 for(j=0;j<8;j++){ ra_det[54][j]= 0.0;}
00535 for(j=0;j<8;j++){ ra_det[55][j]= 0.0;}
00536 for(j=0;j<8;j++){ ra_det[56][j]= 0.0;}
00537 for(j=0;j<8;j++){ ra_det[57][j]= 0.0;}
00538 for(j=0;j<8;j++){ ra_det[58][j]= 0.0;}
00539
00540 for(j=0;j<8;j++){ ra_det[59][j]= 32767.0;}
00541
00542 for(j=0;j<8;j++){ ra_det[60][j]= 62.0;}
00543
00544 for(j=0;j<8;j++){ ra_det[61][j]= 31.0;}
00545
00546 for(j=0;j<8;j++){ ra_det[62][j]= 0.0;}
00547 for(j=0;j<8;j++){ ra_det[63][j]= 0.0;}
00548
00549 for(j=0;j<8;j++){ ra_det[64][j]= 0.001;}
00550 for(j=0;j<8;j++){ ra_det[65][j]= 0.001;}
00551 for(j=0;j<8;j++){ ra_det[66][j]= 0.001;}
00552 for(j=0;j<8;j++){ ra_det[67][j]= 0.001;}
00553 for(j=0;j<8;j++){ ra_det[68][j]= 0.001;}
00554 for ( i = 0; i < 11; i++ )
00555 {
00556 for(j=0;j<6;j++)
00557 if(i<8)
00558 {
00559 ra_det[69+i][j] = 1.0e-4;
00560 }
00561 else
00562 {
00563 ra_det[69+i][j] = 0.0;
00564 }
00565 for(j=6;j<8;j++) ra_det[69+i][j] = 0.0;
00566
00567 }
00568
00569
00570
00571 for ( j = 0; j < emc_walls; j++ )
00572 {
00573
00574
00575 if( ra_det[70][0] == 0.0)
00576 {
00577 l_automatic_threshold = FALSE;
00578 }
00579 if(l_automatic_threshold)
00580 {
00581 r_sampfrac = 0.2285;
00582 ind1 = 0;
00583 ind2 = 0 ;
00584 if(j < 6)
00585 {
00586 if(ra_det[70][j] >= 0.0029) ind2 = 1;
00587 if(ra_det[70][j] >= 0.0049) ind2 = 2;
00588 if(ra_det[70][j] >= 0.0099) ind2 = 3;
00589
00590 if(ra_det[22][j] <= 0.0001) ind1 = 0;
00591 if(ra_det[22][j] > 0.0001 && ra_det[22][j] <= 0.005) ind1 = 1;
00592 if(ra_det[22][j] > 0.005 && ra_det[22][j] <= 0.02) ind1 = 2;
00593 if(ra_det[22][j] > 0.02 && ra_det[22][j] <= 0.1) ind1 = 3;
00594
00595 r_sampfrac = ra_newcalib[ind1][ind2];
00596 }
00597 }
00598 else
00599 {
00600 r_sampfrac = .2443;
00601 r_cutgam = ra_det[22][j];
00602 if(r_cutgam <= ra_sampfrac[0][0] )
00603 {
00604 r_sampfrac = ra_sampfrac[0][1];
00605 }
00606 else
00607 {
00608 if(r_cutgam >= ra_sampfrac[22][0] )
00609 {
00610 r_sampfrac = ra_sampfrac[22][1];
00611 }
00612 else
00613 {
00614
00615 for ( i = 1; i < 22; i++)
00616 {
00617 if(r_cutgam == ra_sampfrac[i][0] )
00618 {
00619 r_sampfrac = ra_sampfrac[i][1];
00620 }
00621 else
00622 {
00623 if ( r_cutgam > ra_sampfrac[i][0] && r_cutgam < ra_sampfrac[i+1][0] )
00624 {
00625 r_sampfrac = ra_sampfrac[i+1][1] +
00626 ( ra_sampfrac[i][1] - ra_sampfrac[i+1][1] ) *
00627 ( ra_sampfrac[i+1][0]-r_cutgam ) /
00628 ( ra_sampfrac[i+1][0] - ra_sampfrac[i][0] );
00629 }
00630 }
00631 }
00632 }
00633 }
00634 }
00635 if(r_sampfrac == 0.0) r_sampfrac = 0.2054;
00636
00637 d_work = ra_det[4][j];
00638 d_work = torad * d_work;
00639 d_work1 = cos(d_work);
00640 d_work2 = sin(d_work);
00641 ra_det[80][j] = d_work1;
00642 ra_det[81][j] = d_work2;
00643
00644 ra_det[82][j] = 200.0;
00645 ra_det[83][j] = 17.0;
00646 ra_det[86][j] = 0.0;
00647 ra_det[87][j] = 1.0;
00648 ra_det[89][j] = 10.0;
00649 ra_det[90][j] = 10.0;
00650 ra_det[91][j] = 3.0;
00651 ra_det[92][j] = 3.0;
00652
00653 ra_det[93][j] = 0.04;
00654
00655 ra_det[94][j] = 3.0;
00656 if(j < 6)
00657 {
00658 ra_det[84][j] = r_sampfrac;
00659
00660
00661
00662
00663
00664
00665
00666
00667
00668 ra_det[84][j] = ra_det[84][j] * 0.87;
00669 ra_det[85][j] = 1500.0;
00670 }
00671 else
00672 {
00673 ra_det[84][j] = 1.0;
00674 ra_det[85][j] = 600.0;
00675 }
00676 if( ra_det[90][j] > 0.0)
00677 {
00678 r_work1 = ra_det[90][j] * log(2.0);
00679 ra_det[92][j] = ra_det[94][j] * r_work1 / (1.0 + r_work1);
00680 }
00681
00682
00683
00684 for ( i = 0; i < 120; i++ )
00685 {
00686 dEmcGeaParams[j].detarray[i] = ra_det[i][j];
00687 }
00688 }
00689
00690 dEmcGeaParams_h->nok = emc_walls;
00691
00692
00693
00694 for (ll = 0; ll < sizeof(emc_geom)/sizeof(emc_geom[0][0][0][0]); ll++)
00695 {
00696 *((float *)emc_geom + ll) = 0.0;
00697 }
00698
00699
00700
00701 for ( i1 = 0; i1 < emc_walls; i1++ )
00702 {
00703 for ( iz = 0; iz < ra_det[10][i1]*ra_det[12][i1]; iz++ )
00704 {
00705 for ( iy = 0; iy < ra_det[11][i1]*ra_det[13][i1]; iy++ )
00706 {
00707
00708
00709
00710 r_appz = ra_det[6][i1] + iz * ra_det[9][i1];
00711
00712
00713
00714
00715
00716
00717
00718 d_work1 = ra_det[80][i1];
00719 d_work = fabs(d_work1);
00720
00721 r_appy = ra_det[7][i1] + iy * ra_det[9][i1] * d_work;
00722
00723
00724
00725
00726
00727
00728
00729
00730 r_appx = ra_det[5][i1] * d_work -
00731 (- (ra_det[11][i1]*ra_det[13][i1] - 1.0)
00732 * ra_det[9][i1] / 2.0
00733 + iy * ra_det[9][i1]) * ra_det[81][i1];
00734
00735 if(i1 > 3) r_appx = - r_appx;
00736 d_work1 = r_appx*r_appx + r_appy*r_appy;
00737 d_work1 = sqrt(d_work1);
00738 d_work2 = r_appz;
00739 d_work0 = r_appx;
00740
00741 if(d_work1 > 0.0)
00742 {
00743
00744 d_work = atan2(d_work1,d_work2);
00745 r_measthe = d_work;
00746 r_measthe = todeg * r_measthe;
00747
00748 d_work = acos(d_work0/d_work1);
00749 r_measphi = d_work;
00750 r_measphi = todeg * r_measphi;
00751
00752 if(r_appy < 0.0) r_measphi = 360.0 - r_measphi;
00753 }
00754
00755
00756 emc_geom[0][iz][iy][i1] = r_appx;
00757 emc_geom[1][iz][iy][i1] = r_appy;
00758 emc_geom[2][iz][iy][i1] = r_appz;
00759 emc_geom[3][iz][iy][i1] = r_measthe;
00760 emc_geom[4][iz][iy][i1] = r_measphi;
00761 d_work1 = r_appx*r_appx + r_appy*r_appy + r_appz*r_appz;
00762 d_work = sqrt(d_work1);
00763 r_work1 = d_work;
00764
00765 emc_geom[5][iz][iy][i1] = r_work1;
00766 emc_geom[6][iz][iy][i1] = r_work1 / 30.0;
00767
00768
00769
00770 emc_geom[7][iz][iy][i1] = ra_det[80][i1];
00771 emc_geom[8][iz][iy][i1] = ra_det[81][i1];
00772 emc_geom[9][iz][iy][i1] = 0.0;
00773
00774
00775
00776 }
00777 }
00778 }
00779
00780
00781
00782
00783
00784
00785
00786 istaf = 0;
00787 for ( i1 = 0; i1 < emc_walls; i1++)
00788 {
00789 for ( iy = 0; iy < max_chany; iy++ )
00790 {
00791 for ( iz = 0; iz < max_chanz; iz++ )
00792 {
00793 if(emc_geom[5][iz][iy][i1] > 0.0)
00794 {
00795 dEmcGeometry[istaf].id = istaf + 1;
00796 dEmcGeometry[istaf].hwkey = 0;
00797 if(i1 < 4)
00798 {
00799 dEmcGeometry[istaf].arm = 0;
00800 dEmcGeometry[istaf].sector = i1;
00801 }
00802 else
00803 {
00804
00805 dEmcGeometry[istaf].arm = 1;
00806 dEmcGeometry[istaf].sector = 7 - i1;
00807 }
00808
00809
00810 if(dEmcGeometry[istaf].arm == 0 && iz <= 71)
00811 {
00812 dEmcGeometry[istaf].ind[0] = 71 - iz;
00813 }
00814 else
00815 {
00816 dEmcGeometry[istaf].ind[0] = iz;
00817 }
00818
00819 dEmcGeometry[istaf].ind[1] = iy;
00820
00821 dEmcGeometry[istaf].swkey =
00822 100000 * dEmcGeometry[istaf].arm +
00823 10000 * dEmcGeometry[istaf].sector +
00824 100 * iy+
00825 iz;
00826
00827
00828 for (i = 0; i < 3; i++)
00829 {
00830 dEmcGeometry[istaf].nomxyz[i] = emc_geom[i][iz][iy][i1];
00831 dEmcGeometry[istaf].actxyz[i] = emc_geom[i][iz][iy][i1];
00832 dEmcGeometry[istaf].nomunitv[i] = emc_geom[7+i][iz][iy][i1];
00833 dEmcGeometry[istaf].actunitv[i] = emc_geom[7+i][iz][iy][i1];
00834 }
00835
00836 dEmcGeometry[istaf].nomtheta = emc_geom[3][iz][iy][i1];
00837 dEmcGeometry[istaf].nomphi = emc_geom[4][iz][iy][i1];
00838 dEmcGeometry[istaf].acttheta = emc_geom[3][iz][iy][i1];
00839 dEmcGeometry[istaf].actphi = emc_geom[4][iz][iy][i1];
00840 dEmcGeometry[istaf].nomdist = emc_geom[5][iz][iy][i1];
00841 dEmcGeometry[istaf].actdist = emc_geom[5][iz][iy][i1];
00842 dEmcGeometry[istaf].nomflash = emc_geom[6][iz][iy][i1];
00843 dEmcGeometry[istaf].actflash = emc_geom[6][iz][iy][i1];
00844
00845
00846
00847
00848
00849
00850
00851 r_dist = ra_det[5][i1];
00852 r_distz = ( iz
00853 - ra_det[10][i1] * ra_det[12][i1] / 2.0)
00854 * ra_det[9][i1];
00855 r_disty = ( iy - ra_det[11][i1] * ra_det[15][i1]
00856 - ra_det[11][i1] * ra_det[13][i1] / 2.0)
00857 * ra_det[9][i1];
00858
00859 d_work1 = r_distz;
00860 d_work2 = r_disty;
00861 d_work = r_dist;
00862 d_theta = atan2(d_work1,d_work);
00863 d_phi = atan2(d_work2,d_work);
00864 d_theta = todeg * d_theta;
00865 d_phi = todeg * d_phi;
00866 r_sectheta = d_theta;
00867 r_secphi = d_phi;
00868 dEmcGeometry[istaf].sectheta = r_sectheta;
00869 dEmcGeometry[istaf].secphi = r_secphi;
00870
00871
00872
00873 istaf = istaf + 1;
00874
00875 }
00876 }
00877 }
00878 }
00879
00880
00881 dEmcGeometry_h->nok = istaf;
00882
00883 return (STAFCV_OK);
00884 }
00885
00886