Repo created
This commit is contained in:
parent
4af19165ec
commit
68073add76
12458 changed files with 12350765 additions and 2 deletions
41
tools/track_analyzing/track_analyzer/crossroad_checker.hpp
Normal file
41
tools/track_analyzing/track_analyzer/crossroad_checker.hpp
Normal file
|
|
@ -0,0 +1,41 @@
|
|||
#pragma once
|
||||
|
||||
#include "routing/geometry.hpp"
|
||||
#include "routing/index_graph.hpp"
|
||||
#include "routing/segment.hpp"
|
||||
|
||||
#include "base/stl_helpers.hpp"
|
||||
|
||||
#include <array>
|
||||
#include <string>
|
||||
|
||||
namespace routing
|
||||
{
|
||||
class IsCrossroadChecker
|
||||
{
|
||||
public:
|
||||
enum class Type
|
||||
{
|
||||
TurnFromSmallerToBigger,
|
||||
TurnFromBiggerToSmaller,
|
||||
IntersectionWithBig,
|
||||
Count
|
||||
};
|
||||
|
||||
using CrossroadInfo = std::array<size_t, base::Underlying(Type::Count)>;
|
||||
|
||||
IsCrossroadChecker(IndexGraph & indexGraph, Geometry & geometry) : m_indexGraph(indexGraph), m_geometry(geometry) {}
|
||||
/// \brief Compares two segments by their highway type to find if there was a crossroad between them.
|
||||
/// Check if current segment is a joint to find and find all intersections with other roads.
|
||||
Type operator()(Segment const & current, Segment const & next) const;
|
||||
|
||||
static void MergeCrossroads(Type from, CrossroadInfo & to);
|
||||
static void MergeCrossroads(IsCrossroadChecker::CrossroadInfo const & from, IsCrossroadChecker::CrossroadInfo & to);
|
||||
|
||||
private:
|
||||
IndexGraph & m_indexGraph;
|
||||
Geometry & m_geometry;
|
||||
};
|
||||
|
||||
std::string DebugPrint(IsCrossroadChecker::Type type);
|
||||
} // namespace routing
|
||||
Loading…
Add table
Add a link
Reference in a new issue