/* This file is part of MAUS: http://micewww.pp.rl.ac.uk/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 . */ #include "src/common_cpp/JsonCppProcessors/SciFiHelicalPRTrackProcessor.hh" namespace MAUS { SciFiHelicalPRTrackProcessor::SciFiHelicalPRTrackProcessor() : _double_array_proc(new DoubleProcessor) { RegisterValueBranch("tracker", &_int_proc, &SciFiHelicalPRTrack::get_tracker, &SciFiHelicalPRTrack::set_tracker, true); RegisterValueBranch("charge", &_int_proc, &SciFiHelicalPRTrack::SciFiBasePRTrack::get_charge, &SciFiHelicalPRTrack::SciFiBasePRTrack::set_charge, true); RegisterValueBranch("dsdz", &_double_proc, &SciFiHelicalPRTrack::get_dsdz, &SciFiHelicalPRTrack::set_dsdz, true); RegisterValueBranch("R", &_double_proc, &SciFiHelicalPRTrack::get_R, &SciFiHelicalPRTrack::set_R, true); RegisterValueBranch("line_sz_c", &_double_proc, &SciFiHelicalPRTrack::get_line_sz_c, &SciFiHelicalPRTrack::set_line_sz_c, true); RegisterValueBranch("line_sz_chisq", &_double_proc, &SciFiHelicalPRTrack::get_line_sz_chisq, &SciFiHelicalPRTrack::set_line_sz_chisq, true); RegisterValueBranch("line_sz_ndf", &_int_proc, &SciFiHelicalPRTrack::get_line_sz_ndf, &SciFiHelicalPRTrack::set_line_sz_ndf, false); RegisterValueBranch("circle_x0", &_double_proc, &SciFiHelicalPRTrack::get_circle_x0, &SciFiHelicalPRTrack::set_circle_x0, true); RegisterValueBranch("circle_y0", &_double_proc, &SciFiHelicalPRTrack::get_circle_y0, &SciFiHelicalPRTrack::set_circle_y0, true); RegisterValueBranch("circle_chisq", &_double_proc, &SciFiHelicalPRTrack::get_circle_chisq, &SciFiHelicalPRTrack::set_circle_chisq, true); RegisterValueBranch("circle_ndf", &_int_proc, &SciFiHelicalPRTrack::get_circle_ndf, &SciFiHelicalPRTrack::set_circle_ndf, false); RegisterValueBranch("chi_squared", &_double_proc, &SciFiHelicalPRTrack::get_chi_squared, &SciFiHelicalPRTrack::set_chi_squared, false); RegisterValueBranch("ndf", &_int_proc, &SciFiHelicalPRTrack::get_ndf, &SciFiHelicalPRTrack::set_ndf, false); RegisterValueBranch("alg_used_circle", &_int_proc, &SciFiHelicalPRTrack::get_alg_used_circle, &SciFiHelicalPRTrack::set_alg_used_circle, false); RegisterValueBranch("alg_used_longitudinal", &_int_proc, &SciFiHelicalPRTrack::get_alg_used_longitudinal, &SciFiHelicalPRTrack::set_alg_used_longitudinal, false); RegisterValueBranch("alg_used_full", &_int_proc, &SciFiHelicalPRTrack::get_alg_used_full, &SciFiHelicalPRTrack::set_alg_used_full, false); RegisterValueBranch("phi0", &_double_proc, &SciFiHelicalPRTrack::get_phi0, &SciFiHelicalPRTrack::set_phi0, false); RegisterValueBranch("point_spread", &_double_proc, &SciFiHelicalPRTrack::get_point_spread, &SciFiHelicalPRTrack::set_point_spread, false); RegisterValueBranch("pos0", &_threevector_proc, &SciFiHelicalPRTrack::get_pos0, &SciFiHelicalPRTrack::set_pos0, false); RegisterValueBranch("phi", &_double_array_proc, &SciFiHelicalPRTrack::get_phi, &SciFiHelicalPRTrack::set_phi, false); RegisterTRefArray("spacepoints", &_spoint_tref_proc, &SciFiHelicalPRTrack::get_spacepoints, &SciFiHelicalPRTrack::set_spacepoints, true); RegisterValueBranch("reference_position", &_threevector_proc, &SciFiHelicalPRTrack::get_reference_position, &SciFiHelicalPRTrack::set_reference_position, false); RegisterValueBranch("reference_momentum", &_threevector_proc, &SciFiHelicalPRTrack::get_reference_momentum, &SciFiHelicalPRTrack::set_reference_momentum, false); } } // ~namespace MAUS