/* This file is part of MAUS: http:// micewww.pp.rl.ac.uk:8080/projects/maus * * MAUS is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * MAUS is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with MAUS. If not, see . */ /* Author: Peter Lane */ #include "Recon/Global/Particle.hh" #include "src/common_cpp/DataStructure/Global/ReconEnums.hh" #include "Utils/Squeak.hh" namespace MAUS { namespace recon { namespace global { using MAUS::DataStructure::Global::PID; Particle::Particle() { AddParticleDefinition(MAUS::DataStructure::Global::kNoPID, "none", 0., 0); AddParticleDefinition(MAUS::DataStructure::Global::kEMinus, "e-", 0.510998910, -1); AddParticleDefinition(MAUS::DataStructure::Global::kElectronNeutrino, "electron neutrino", 1.9e-6, 0); AddParticleDefinition(MAUS::DataStructure::Global::kMuMinus, "mu-", 105.6583668, -1); AddParticleDefinition(MAUS::DataStructure::Global::kMuonNeutrino, "muon neutrino", 1.9e-6, 0); AddParticleDefinition(MAUS::DataStructure::Global::kPhoton, "photon", 0., -1); AddParticleDefinition(MAUS::DataStructure::Global::kPi0, "pi0", 134.9766, 0); AddParticleDefinition(MAUS::DataStructure::Global::kPiPlus, "pi+", 139.57018, +1); AddParticleDefinition(MAUS::DataStructure::Global::kKPlus, "K+", 493.667, +1); AddParticleDefinition(MAUS::DataStructure::Global::kNeutron, "neutron", 939.56536, 0); AddParticleDefinition(MAUS::DataStructure::Global::kProton, "proton", 938.271996, +1); AddParticleDefinition(MAUS::DataStructure::Global::kDeuterium, "deuterium", 1876.1239, 0); AddParticleDefinition(MAUS::DataStructure::Global::kTritium, "tritium", 2809.432, 0); AddParticleDefinition(MAUS::DataStructure::Global::kHelium3, "3He", 2809.41346, 0); AddParticleDefinition(MAUS::DataStructure::Global::kHelium4, "4He", 3728.4001, 0); AddParticleDefinition(MAUS::DataStructure::Global::kKLong, "K0L", 497.614, 0); AddParticleDefinition(MAUS::DataStructure::Global::kKShort, "K0S", 497.614, 0); AddParticleDefinition(MAUS::DataStructure::Global::kK0, "K0", 497.614, 0); AddParticleDefinition(MAUS::DataStructure::Global::kLambda, "lambda", 1115.683, 0); AddParticleDefinition(MAUS::DataStructure::Global::kEPlus, "e+", 0.510998910, +1); AddParticleDefinition(MAUS::DataStructure::Global::kElectronAntineutrino, "electron antineutrino", 0., 0); AddParticleDefinition(MAUS::DataStructure::Global::kMuPlus, "mu+", 105.6583668, +1); AddParticleDefinition(MAUS::DataStructure::Global::kMuonAntineutrino, "muon antineutrino", 0., 0); AddParticleDefinition(MAUS::DataStructure::Global::kPiMinus, "pi-", 139.57018, -1); AddParticleDefinition(MAUS::DataStructure::Global::kKMinus, "K-", 493.667, -1); AddParticleDefinition(MAUS::DataStructure::Global::kAntineutron, "antineutron", 939.56536, 0); AddParticleDefinition(MAUS::DataStructure::Global::kAntiproton, "antiproton", 938.271996, -1); AddParticleDefinition(MAUS::DataStructure::Global::kAntilambda, "antilambda", 1115.683, 0); } Particle::~Particle() { } const Particle & Particle::GetInstance() { return Particle::kSingleton; } std::string Particle::GetName(MAUS::DataStructure::Global::PID id) const { return names_.find(id)->second; } double Particle::GetMass(MAUS::DataStructure::Global::PID id) const { return masses_.find(id)->second; } int Particle::GetCharge(MAUS::DataStructure::Global::PID id) const { return charges_.find(id)->second; } const Particle Particle::kSingleton = Particle(); void Particle::AddParticleDefinition(MAUS::DataStructure::Global::PID pid, std::string name, double mass, int charge) { names_.insert( std::pair(pid, name)); masses_.insert( std::pair(pid, mass)); charges_.insert( std::pair(pid, charge)); } } // namespace global } // namespace recon } // namespace MAUS