|
||||
File indexing completed on 2025-01-19 09:23:24
0001 // This file is part of the Acts project. 0002 // 0003 // Copyright (C) 2024 CERN for the benefit of the Acts project 0004 // 0005 // This Source Code Form is subject to the terms of the Mozilla Public 0006 // License, v. 2.0. If a copy of the MPL was not distributed with this 0007 // file, You can obtain one at http://mozilla.org/MPL/2.0/. 0008 0009 #pragma once 0010 0011 #include "Acts/Definitions/Algebra.hpp" 0012 #include "Acts/Geometry/GeometryContext.hpp" 0013 #include "Acts/Geometry/GeometryHierarchyMap.hpp" 0014 #include "Acts/Material/MaterialInteraction.hpp" 0015 #include "Acts/Material/interface/IAssignmentFinder.hpp" 0016 0017 #include <array> 0018 #include <functional> 0019 #include <optional> 0020 #include <tuple> 0021 #include <vector> 0022 0023 namespace Acts { 0024 0025 class Surface; 0026 0027 namespace MaterialInteractionAssignment { 0028 0029 /// The result struct of the assignment run 0030 struct Result { 0031 /// The assigned material interactions 0032 std::vector<MaterialInteraction> assigned = {}; 0033 /// The unassigned material interactions 0034 std::vector<MaterialInteraction> unassigned = {}; 0035 /// Surfaces without assignment (for empty hit correction) 0036 std::vector<IAssignmentFinder::SurfaceAssignment> unassignedSurfaces = {}; 0037 }; 0038 0039 /// @brief definition of a global veto for assigning material interactions 0040 /// 0041 /// This can be used to restrict the assignment to a specific volume, or 0042 /// exclude certain materials (if one wants), etc. 0043 /// 0044 /// @param materialInteraction is the material interaction to be checked for the veto 0045 /// 0046 /// It will be globally applied, i.e. every single material interaction 0047 /// will have to go through this veto 0048 using GlobalVeto = 0049 std::function<bool(const MaterialInteraction& materialInteraction)>; 0050 0051 /// @brief definition of a local veto on a material interaction 0052 /// 0053 /// This can take already the suggested surface assignment into account 0054 /// return true if the assignment should be vetoed. This can be used for 0055 /// having exclusion rules based on surface information. 0056 /// 0057 /// @param materialInteraction is the material interaction to be checked for the veto 0058 /// @param suggestedAssignment is the suggested assignment: surface, position, direction 0059 using LocalVeto = std::function<bool( 0060 const MaterialInteraction&, 0061 const IAssignmentFinder::SurfaceAssignment& suggestedAssignment)>; 0062 0063 /// @brief definition of possible re-assignments to next surface, this could e.g. 0064 /// be used for respecting pre/post mapping directives that are not fully 0065 /// handled by closest distance matching 0066 /// 0067 /// The provided parameters are the mutable material interaction, the suggested 0068 /// assignment and the next possible assignment, due to the ordered nature of 0069 /// the material interactions, assignment to previous is excluded 0070 /// 0071 /// @param materialInteraction is the material interaction to be checked for the veto 0072 /// @param suggestedAssignment is the suggested assignment: surface, position, direction 0073 /// @param suggestedReAssignment is the suggested assignment: surface, position, direction 0074 /// 0075 /// @note this changes the MaterialInteraction if the re-assignment is accepted 0076 using ReAssignment = std::function<void( 0077 MaterialInteraction& materialInteraction, 0078 const IAssignmentFinder::SurfaceAssignment& suggestedAssignment, 0079 const IAssignmentFinder::SurfaceAssignment& suggestedReAssignment)>; 0080 0081 /// @brief Options for the material interaction matcher 0082 /// The options are used to specify the vetos for the assignment 0083 struct Options { 0084 /// Allow global vetos for the assignment, e.g. restricting 0085 /// the assignment to a specific volume 0086 std::vector<GlobalVeto> globalVetos = {}; 0087 0088 /// Allow specific vetoes for the assignment, e.g. only locally to 0089 /// surface, rest to next mapper (e.g. volume mapper) 0090 GeometryHierarchyMap<LocalVeto> localVetos = {}; 0091 0092 /// Allow re-assignment of the material interaction, e.g. to respect 0093 GeometryHierarchyMap<ReAssignment> reAssignments = {}; 0094 }; 0095 0096 /// @brief Match the material interactions to surfaces intersections while respecting 0097 /// eventual vetos for the assignment 0098 /// 0099 /// @param gctx is the geometry context 0100 /// @param materialInteractions is the vector of material interaction 0101 /// @param intersectedSurfaces are the surfac assignment candidates 0102 /// @param options are the options for the assignment 0103 /// 0104 /// @return a pair of vectors of assigned and unassigned material interactions 0105 Result assign(const GeometryContext& gctx, 0106 const std::vector<MaterialInteraction>& materialInteractions, 0107 const std::vector<IAssignmentFinder::SurfaceAssignment>& 0108 intersectedSurfaces, 0109 const Options& options = Options()); 0110 0111 } // namespace MaterialInteractionAssignment 0112 0113 } // namespace Acts
[ Source navigation ] | [ Diff markup ] | [ Identifier search ] | [ general search ] |
This page was automatically generated by the 2.3.7 LXR engine. The LXR team |