@@ -77,6 +77,8 @@ struct DileptonPolarization {
7777 ConfigurableAxis ConfOccupancyBins{" ConfOccupancyBins" , {VARIABLE_WIDTH, -1 , 1e+10 }, " Mixing bins - occupancy" };
7878 Configurable<int > cfgPolarizationFrame{" cfgPolarizationFrame" , 0 , " frame of polarization. 0:CS, 1:HX, else:FATAL" };
7979 Configurable<bool > cfgUseAbs{" cfgUseAbs" , false , " flag to use absolute value for cos_theta and phi" }; // this is to increase statistics per bin.
80+ Configurable<bool > cfgDoULS{" cfgDoULS" , true , " flag to perform ULS pairing" };
81+ Configurable<bool > cfgDoLS{" cfgDoLS" , true , " flag to perform LS pairing" };
8082
8183 ConfigurableAxis ConfMllBins{"ConfMllBins", {VARIABLE_WIDTH, 0.00, 0.01, 0.02, 0.03, 0.04, 0.05, 0.06, 0.07, 0.08, 0.09, 0.10, 0.11, 0.12, 0.13, 0.14, 0.15, 0.16, 0.17, 0.18, 0.19, 0.20, 0.21, 0.22, 0.23, 0.24, 0.25, 0.26, 0.27, 0.28, 0.29, 0.30, 0.31, 0.32, 0.33, 0.34, 0.35, 0.36, 0.37, 0.38, 0.39, 0.40, 0.41, 0.42, 0.43, 0.44, 0.45, 0.46, 0.47, 0.48, 0.49, 0.50, 0.51, 0.52, 0.53, 0.54, 0.55, 0.56, 0.57, 0.58, 0.59, 0.60, 0.61, 0.62, 0.63, 0.64, 0.65, 0.66, 0.67, 0.68, 0.69, 0.70, 0.71, 0.72, 0.73, 0.74, 0.75, 0.76, 0.77, 0.78, 0.79, 0.80, 0.81, 0.82, 0.83, 0.84, 0.85, 0.86, 0.87, 0.88, 0.89, 0.90, 0.91, 0.92, 0.93, 0.94, 0.95, 0.96, 0.97, 0.98, 0.99, 1.00, 1.01, 1.02, 1.03, 1.04, 1.05, 1.06, 1.07, 1.08, 1.09, 1.10, 1.11, 1.12, 1.13, 1.14, 1.15, 1.16, 1.17, 1.18, 1.19, 1.20, 1.30, 1.40, 1.50, 1.60, 1.70, 1.80, 1.90, 2.00, 2.10, 2.20, 2.30, 2.40, 2.50, 2.60, 2.70, 2.75, 2.80, 2.85, 2.90, 2.95, 3.00, 3.05, 3.10, 3.15, 3.20, 3.25, 3.30, 3.35, 3.40, 3.45, 3.50, 3.55, 3.60, 3.65, 3.70, 3.75, 3.80, 3.85, 3.90, 3.95, 4.00, 4.5, 5.0, 5.5, 6.0, 6.5, 7.0, 7.5, 8.00, 8.10, 8.20, 8.30, 8.40, 8.50, 8.60, 8.70, 8.80, 8.90, 9.00, 9.10, 9.20, 9.30, 9.40, 9.50, 9.60, 9.70, 9.80, 9.90, 10.00, 10.10, 10.20, 10.30, 10.40, 10.50, 10.60, 10.70, 10.80, 10.90, 11.00, 11.1, 11.2, 11.3, 11.4, 11.50, 11.6, 11.7, 11.8, 11.9, 12.0}, "mll bins for output histograms"};
8284 ConfigurableAxis ConfPtllBins{" ConfPtllBins" , {VARIABLE_WIDTH, 0.00 , 0.10 , 0.20 , 0.30 , 0.40 , 0.50 , 0.60 , 0.70 , 0.80 , 0.90 , 1.00 , 1.10 , 1.20 , 1.30 , 1.40 , 1.50 , 1.60 , 1.70 , 1.80 , 1.90 , 2.00 , 2.50 , 3.00 , 3.50 , 4.00 , 4.50 , 5.00 , 6.00 , 7.00 , 8.00 , 9.00 , 10.00 }, " pTll bins for output histograms" };
@@ -374,11 +376,12 @@ struct DileptonPolarization {
374376 const AxisSpec axis_phi{ConfPolarizationPhiBins, Form (" #varphi^{%s} (rad.)" , frameName.data ())};
375377 const AxisSpec axis_quadmom{ConfPolarizationQuadMomBins, Form (" #frac{3 cos^{2}(#theta^{%s}) -1}{2}" , frameName.data ())};
376378 fRegistry .add (" Pair/same/uls/hs" , " dilepton" , kTHnSparseD , {axis_mass, axis_pt, axis_dca, axis_y, axis_cos_theta, axis_phi, axis_quadmom}, true );
377- fRegistry .add (" Pair/same/uls/hEta" , " #eta_{ll}" , kTH1D , {{2000 , -10 , 10 }}, true );
378379
379380 fRegistry .addClone (" Pair/same/uls/" , " Pair/same/lspp/" );
380381 fRegistry .addClone (" Pair/same/uls/" , " Pair/same/lsmm/" );
381382 fRegistry .addClone (" Pair/same/" , " Pair/mix/" );
383+ fRegistry .add (" Pair/same/uls/hEta" , " #eta_{ll}" , kTH1D , {{2000 , -10 , 10 }}, true );
384+ fRegistry .add (" Pair/mix/uls/hBeta" , " #beta for Lorentz boost;#beta_{same};(#beta_{mix} - #beta_{same})/#beta_{same}" , kTH2D , {{100 , 0 , 1 }, {200 , -0.2 , 0.2 }}, true );
382385 }
383386
384387 template <int ev_id, typename TCollision, typename TDilepton>
@@ -493,6 +496,7 @@ struct DileptonPolarization {
493496 phiPol = std::fabs (phiPol);
494497 }
495498 fRegistry .fill (HIST (" Pair/mix/" ) + HIST (pair_sign_types[signType]) + HIST (" hs" ), empair1.mass (), empair1.pt (), empair1.getPairDCA (), empair1.rapidity (), cos_thetaPol, phiPol, quadmom, weight);
499+ fRegistry .fill (HIST (" Pair/mix/" ) + HIST (pair_sign_types[signType]) + HIST (" hBeta" ), empair1.p () / empair1.e (), (empair2.p () / empair2.e () - empair1.p () / empair1.e ()) / (empair1.p () / empair1.e ()));
496500 }
497501 }
498502
@@ -518,6 +522,7 @@ struct DileptonPolarization {
518522 phiPol = std::fabs (phiPol);
519523 }
520524 fRegistry .fill (HIST (" Pair/mix/" ) + HIST (pair_sign_types[signType]) + HIST (" hs" ), empair2.mass (), empair2.pt (), empair2.getPairDCA (), empair2.rapidity (), cos_thetaPol, phiPol, quadmom, weight);
525+ fRegistry .fill (HIST (" Pair/mix/" ) + HIST (pair_sign_types[signType]) + HIST (" hBeta" ), empair2.p () / empair2.e (), (empair1.p () / empair1.e () - empair2.p () / empair2.e ()) / (empair2.p () / empair2.e ()));
521526 }
522527 }
523528
@@ -612,31 +617,34 @@ struct DileptonPolarization {
612617 // LOGF(info, "collision.globalIndex() = %d, dileptons_uls_per_coll.size() = %d, dileptons_lspp_per_coll.size() = %d, dileptons_lsmm_per_coll.size() = %d", collision.globalIndex(), dileptons_uls_per_coll.size(), dileptons_lspp_per_coll.size(), dileptons_lsmm_per_coll.size());
613618
614619 int nuls = 0 , nlspp = 0 , nlsmm = 0 ;
615- for (const auto & dilepton : dileptons_uls_per_coll) { // ULS
616- bool is_pair_ok = fillPairInfo<0 >(collision, dilepton);
617- if (is_pair_ok) {
618- nuls++;
620+ if (cfgDoULS) {
621+ for (const auto & dilepton : dileptons_uls_per_coll) { // ULS
622+ bool is_pair_ok = fillPairInfo<0 >(collision, dilepton);
623+ if (is_pair_ok) {
624+ nuls++;
625+ }
619626 }
620627 }
621- for (const auto & dilepton : dileptons_lspp_per_coll) { // LS++
622- bool is_pair_ok = fillPairInfo<0 >(collision, dilepton);
623- if (is_pair_ok) {
624- nlspp++;
628+
629+ if (cfgDoLS) {
630+ for (const auto & dilepton : dileptons_lspp_per_coll) { // LS++
631+ bool is_pair_ok = fillPairInfo<0 >(collision, dilepton);
632+ if (is_pair_ok) {
633+ nlspp++;
634+ }
625635 }
626- }
627- for ( const auto & dilepton : dileptons_lsmm_per_coll) { // LS--
628- bool is_pair_ok = fillPairInfo< 0 >(collision, dilepton);
629- if (is_pair_ok) {
630- nlsmm++;
636+ for ( const auto & dilepton : dileptons_lsmm_per_coll) { // LS--
637+ bool is_pair_ok = fillPairInfo< 0 >(collision, dilepton);
638+ if (is_pair_ok) {
639+ nlsmm++;
640+ }
631641 }
632642 }
633643
634644 if (!cfgDoMix || !(nuls > 0 || nlspp > 0 || nlsmm > 0 )) {
635645 continue ;
636646 }
637647
638- // LOGF(info, "collision.globalIndex() = %d, collision.posZ() = %f, centrality = %f, ep2 = %f, collision.ft0cOccupancyInTimeRange() = %f, zbin = %d, centbin = %d, epbin = %d, occbin = %d", collision.globalIndex(), collision.posZ(), centrality, ep2, collision.ft0cOccupancyInTimeRange(), zbin, centbin, epbin, occbin);
639-
640648 auto key_bin = std::make_tuple (zbin, centbin, epbin, occbin);
641649 auto key_df_collision = std::make_pair (ndf, collision.globalIndex ()); // this gives the current event.
642650
@@ -657,13 +665,18 @@ struct DileptonPolarization {
657665 auto collisionIds_in_mixing_pool = emh_pair_uls->GetCollisionIdsFromEventPool (key_bin);
658666 LOGF (info, " iz = %d, icent = %d, iep = %d, iocc = %d, collisionIds_in_mixing_pool.size() = %d" , iz, icent, iep, iocc, collisionIds_in_mixing_pool.size ());
659667
660- fillMixedPairInfo<0 >(collisionIds_in_mixing_pool, emh_pair_uls);
661- fillMixedPairInfo<1 >(collisionIds_in_mixing_pool, emh_pair_lspp);
662- fillMixedPairInfo<2 >(collisionIds_in_mixing_pool, emh_pair_lsmm);
663- }
664- }
665- }
666- }
668+ if (cfgDoULS) {
669+ fillMixedPairInfo<0 >(collisionIds_in_mixing_pool, emh_pair_uls);
670+ }
671+ if (cfgDoLS) {
672+ fillMixedPairInfo<1 >(collisionIds_in_mixing_pool, emh_pair_lspp);
673+ fillMixedPairInfo<2 >(collisionIds_in_mixing_pool, emh_pair_lsmm);
674+ }
675+
676+ } // end of iocc loop
677+ } // end of iep loop
678+ } // end of icent loop
679+ } // end of iz loop
667680
668681 delete emh_pair_uls;
669682 emh_pair_uls = 0x0 ;
0 commit comments