10 #include <analysis/variables/FEIVariables.h> 
   13 #include <analysis/VariableManager/Manager.h> 
   15 #include <analysis/dataobjects/Particle.h> 
   16 #include <mdst/dataobjects/MCParticle.h> 
   17 #include <framework/datastore/StoreArray.h> 
   18 #include <framework/logging/Logger.h> 
   32     int mostcommonBTagIndex(
const Particle* part)
 
   34       std::map <int, int> tag_candidates;
 
   35       const std::vector<const Particle*>& fsp_tag = part->getFinalStateDaughters();
 
   36       for (
const Particle* fsp : fsp_tag) {
 
   37         const MCParticle* mc_fsp = fsp->getMCParticle();
 
   39           int tag_index = finddescendant(mc_fsp);
 
   40           if (tag_candidates.find(tag_index) == tag_candidates.end()) {
 
   41             tag_candidates[tag_index] = 1;
 
   43             tag_candidates[tag_index]++;
 
   50       for (
const auto& [key, value] : tag_candidates) {
 
   58     int finddescendant(
const MCParticle* mcpart)
 
   60       const MCParticle* i_mcpart = mcpart;
 
   62         auto* i_mcpart_mother = i_mcpart->getMother();
 
   63         if (i_mcpart_mother) {
 
   64           std::vector<int> B_PDG = {511, 521};
 
   65           auto result = std::find(std::begin(B_PDG), std::end(B_PDG), abs(i_mcpart_mother->getPDG()));
 
   66           if (result != std::end(B_PDG)) {
 
   67             return i_mcpart_mother->getArrayIndex();
 
   69           i_mcpart = i_mcpart_mother;
 
   76     std::vector<int> truthFSPTag(
int BTag_index)
 
   78       StoreArray<MCParticle> MC_Particle_list;
 
   79       std::vector<int> fsp_truth_index;
 
   80       for (
const MCParticle& iMCParticle : MC_Particle_list) {
 
   84           fsp_truth_index.push_back(iMCParticle.getArrayIndex());
 
   87       return fsp_truth_index;
 
   89     double percentageMissingParticlesBTag(
const Particle* part)
 
   91       int index = mostcommonBTagIndex(part);
 
   95         std::vector<int> fsp_FEI_index;
 
   96         const std::vector<const Particle*>& fsp_tag = part->getFinalStateDaughters();
 
   97         for (
const Particle* fsp : fsp_tag) {
 
   98           const MCParticle* mc_fsp = fsp->getMCParticle();
 
  100             int tag_index = finddescendant(mc_fsp);
 
  101             if (tag_index == index) {
 
  102               fsp_FEI_index.push_back(mc_fsp->getArrayIndex());
 
  106         std::vector<int> diff;
 
  107         std::vector<int> fsp_truth_index = truthFSPTag(index);
 
  108         std::sort(fsp_truth_index.begin(), fsp_truth_index.end());
 
  109         std::sort(fsp_FEI_index.begin(), fsp_FEI_index.end());
 
  110         std::set_difference(fsp_truth_index.begin(), fsp_truth_index.end(), fsp_FEI_index.begin(), fsp_FEI_index.end(), std::inserter(diff,
 
  112         return double(diff.size()) / double(fsp_truth_index.size());
 
  115     double percentageWrongParticlesBTag(
const Particle* part)
 
  117       int index = mostcommonBTagIndex(part);
 
  121         const std::vector<const Particle*>& fsp_tag = part->getFinalStateDaughters();
 
  123         for (
const Particle* fsp : fsp_tag) {
 
  124           const MCParticle* mc_fsp = fsp->getMCParticle();
 
  126             int tag_index = finddescendant(mc_fsp);
 
  127             if (tag_index != index) {
 
  132         return double(wrong_FEI) / double(truthFSPTag(index).size());
 
  135     VARIABLE_GROUP(
"FEIVariables");
 
  136     REGISTER_VARIABLE(
"mostcommonBTagIndex", mostcommonBTagIndex,
 
  137                       "By giving e.g. a FEI B meson candidate the B meson index on generator level is determined, where most reconstructed particles can be assigned to. If no B meson found on generator level -1 is returned.");
 
  138     REGISTER_VARIABLE(
"percentageMissingParticlesBTag", percentageMissingParticlesBTag,
 
  139                       "Get the percentage of missing particles by using the mostcommonBTagIndex. So the number of particles not reconstructed by e.g. the FEI are determined and divided by the number of generated particles using the given index of the B meson. If no B meson found on generator level -1 is returned.");
 
  140     REGISTER_VARIABLE(
"percentageWrongParticlesBTag", percentageWrongParticlesBTag,
 
  141                       "Get the percentage of wrong particles by using the mostcommonBTagIndex. In this context wrong means that the reconstructed particles originated from the other B meson. The absolute number is divided by the total number of generated FSP from the given B meson index. If no B meson found on generator level -1 is returned.");
 
@ c_IsFSRPhoton
bit 7: Particle is from finial state radiation
@ c_IsPHOTOSPhoton
bit 8: Particle is an radiative photon from PHOTOS
@ c_StableInGenerator
bit 1: Particle is stable, i.e., not decaying in the generator.
@ c_IsISRPhoton
bit 6: Particle is from initial state radiation
Abstract base class for different kinds of events.