10 #include <tracking/trackFindingCDC/findlets/base/Findlet.h> 
   12 #include <tracking/trackFindingCDC/numerics/WithWeight.h> 
   13 #include <tracking/trackFindingCDC/utilities/WeightedRelation.h> 
   14 #include <tracking/trackFindingCDC/utilities/Range.h> 
   16 #include <framework/logging/Logger.h> 
   26   class ModuleParamList;
 
   27   namespace TrackFindingCDC {
 
   51     template <
class AStateRejecter, 
class AState, 
class AResult = std::vector<const AState*>>
 
   53       : 
public Findlet<const AState* const, const WeightedRelation<AState>, AResult> {
 
   78       void apply(
const std::vector<const AState*>& seededStates,
 
   80                  std::vector<AResult>& results) 
override;
 
   86                         std::vector<AResult>& results);
 
   93     template <
class AStateRejecter, 
class AState, 
class AResult>
 
   95       const std::vector<const AState*>& seededStates,
 
   97       std::vector<AResult>& results)
 
   99       std::vector<const AState*> path;
 
  100       for (
const AState* state : seededStates) {
 
  101         B2DEBUG(25, 
"Starting with new seed...");
 
  102         path.push_back(state);
 
  103         traverseTree(path, stateRelations, results);
 
  105         B2DEBUG(25, 
"... finished with seed");
 
  107       assert(path.empty());
 
  110     template <
class AStateRejecter, 
class AState, 
class AResult>
 
  112       std::vector<const AState*>& path,
 
  114       std::vector<AResult>& results)
 
  118       const AState* currentState = path.back();
 
  120         std::equal_range(stateRelations.begin(), stateRelations.end(), currentState);
 
  122       std::vector<WithWeight<AState*>> childStates;
 
  124         AState* childState = continuation.getTo();
 
  125         Weight weight = continuation.getWeight();
 
  126         childStates.push_back({childState, weight});
 
  131       const std::vector<const AState*>& constPath = path;
 
  132       m_stateRejecter.apply(constPath, childStates);
 
  134       if (childStates.empty()) {
 
  135         B2DEBUG(25, 
"Terminating this route, as there are no possible child states.");
 
  136         results.emplace_back(path);
 
  141       B2DEBUG(25, 
"Having found " << childStates.size() << 
" child states.");
 
  143         if (std::count(path.begin(), path.end(), childState)) {
 
  148         path.push_back(childState);
 
  149         traverseTree(path, stateRelations, results);
 
The Module parameter list class.
void addProcessingSignalListener(ProcessingSignalListener *psl)
Register a processing signal listener to be notified.
Interface for a minimal algorithm part that wants to expose some parameters to a module.
Type for two related objects with a weight.
General implementation of a tree search algorithm using a given classes as state and results and one ...
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix) final
Expose the parameters of the subfindlet.
AStateRejecter m_stateRejecter
State rejecter to decide which available continuations should be traversed next.
void apply(const std::vector< const AState * > &seededStates, const std::vector< WeightedRelation< AState >> &stateRelations, std::vector< AResult > &results) override
Main function of this findlet: traverse a tree starting from a given seed states.
void traverseTree(std::vector< const AState * > &path, const std::vector< WeightedRelation< AState >> &stateRelations, std::vector< AResult > &results)
Implementation of the traverseTree function.
WeightedTreeTraversal()
Construct this findlet and add the subfindlet as listener.
A mixin class to attach a weight to an object.
Abstract base class for different kinds of events.