10 #include <tracking/trackFindingCDC/ca/CellularAutomaton.h>
11 #include <tracking/trackFindingCDC/ca/CellularPathFollower.h>
13 #include <tracking/trackFindingCDC/ca/Path.h>
14 #include <tracking/trackFindingCDC/ca/CellHolder.h>
16 #include <tracking/trackFindingCDC/utilities/StringManipulation.h>
18 #include <framework/core/ModuleParamList.h>
19 #include <framework/logging/Logger.h>
28 namespace TrackFindingCDC {
35 template <
class ACellHolder>
43 static_assert_isCellHolder<ACellHolder>();
50 moduleParamList->
addParameter(prefixed(prefix,
"caMode"),
52 "Mode for the cellular automaton application"
53 "* * 'normal' normal path search for high value paths"
54 "* * 'cells' make path for each individual cell for debugging"
55 "* * 'relations' make path for each individual relation for debugging",
58 moduleParamList->
addParameter(prefixed(prefix,
"minState"),
60 "The minimal accumulated state to follow",
63 moduleParamList->
addParameter(prefixed(prefix,
"minPathLength"),
65 "The minimal path length to that is written to output",
71 void apply(
const std::vector<ACellHolder*>& cellHolders,
73 std::vector<Path<ACellHolder> >& paths)
75 B2ASSERT(
"Expected the relations to be sorted",
76 std::is_sorted(cellHolderRelations.begin(), cellHolderRelations.end()));
80 for (ACellHolder* cellHolder : cellHolders) {
81 paths.push_back({cellHolder});
89 paths.push_back({cellHolderRelation.getFrom(), cellHolderRelation.getTo()});
96 B2WARNING(
"Unrecognised caMode parameter value " <<
m_param_caMode);
104 for (ACellHolder* cellHolder : cellHolders) {
105 cellHolder->unsetAndForwardMaskedFlag();
108 B2DEBUG(25,
"Apply multipass cellular automat");
112 auto lessStartCellState = [
this](ACellHolder * lhs, ACellHolder * rhs) {
128 auto itStartCellHolder =
129 std::max_element(cellHolders.begin(), cellHolders.end(), lessStartCellState);
130 if (itStartCellHolder == cellHolders.end())
break;
131 else if (not(*itStartCellHolder)->getAutomatonCell().hasStartFlag())
break;
132 else if ((*itStartCellHolder)->getAutomatonCell().getCellState() <
m_param_minState)
break;
134 const ACellHolder* highestCellHolder = *itStartCellHolder;
140 if (newPath.empty())
break;
143 for (ACellHolder* cellHolderPtr : newPath) {
144 cellHolderPtr->setAndForwardMaskedFlag();
148 for (ACellHolder* cellHolder : cellHolders) {
149 cellHolder->receiveMaskedFlag();
153 paths.push_back(std::move(newPath));
The Module parameter list class.
Cell used by the cellular automata.
bool hasStartFlag() const
Gets the current state of the start marker flag.
Weight getCellState() const
Getter for the cell state.
bool hasPriorityPathFlag() const
Gets the current state of the priority path marker flag.
Implements the weighted cellular automaton algorithm.
Implements to pick up of the highest value path in neighborhood Following high value paths can be don...
Class to combine the run of the cellular automaton and the repeated path extraction.
CellularAutomaton< ACellHolder > m_cellularAutomaton
The cellular automaton to be used.
int m_param_minPathLength
The minimal path length to write to output.
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix)
Expose the parameters to a module.
Weight m_param_minState
The minimal accumulated state of the paths to follow.
void apply(const std::vector< ACellHolder * > &cellHolders, const std::vector< WeightedRelation< ACellHolder >> &cellHolderRelations, std::vector< Path< ACellHolder > > &paths)
Applies the cellular automaton to the collection and its relations.
CellularPathFollower< ACellHolder > m_cellularPathFollower
The path follower used to extract the path from the graph processed by the cellular automaton.
MultipassCellularPathFinder()
Default constructor also checking the validity of the template arguments.
std::string m_param_caMode
Mode for the cellular automaton application.
Type for two related objects with a weight.
void addParameter(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module list.
Abstract base class for different kinds of events.