All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
FittedRangeBuilder.h
1 // Copyright eeGeo Ltd (2012-2014), All Rights Reserved
2 
3 #pragma once
4 
5 #include "Types.h"
6 #include "Routes.h"
7 #include "Streaming.h"
8 #include "FittedRangeForRoad.h"
9 #include "ConformerSolution.h"
10 #include <vector>
11 
12 namespace Eegeo
13 {
14  namespace Routes
15  {
16  namespace Fitting
17  {
18  namespace NavGraphConforming
19  {
21  {
22  public:
24  const std::vector<ConformerSolution>& conformerSolutions);
25 
26  void Create(SelectedRoadRepository& selectedRoadRepository, std::vector<FittedRangeForRoad>& out_fittedRanges);
27 
28  private:
29  struct MutableFittedRange
30  {
31  std::vector<const Candidate*> solution;
32  const NavGraphRoadFittingInfo* roadFittingInfo;
33  bool clipAtStart;
34  bool clipAtEnd;
35  bool isConformed;
36  bool isClosed;
37 
38  MutableFittedRange()
39  : roadFittingInfo(NULL)
40  , clipAtStart(false)
41  , clipAtEnd(false)
42  , isConformed(false)
43  , isClosed(false)
44  {
45 
46  }
47  };
48 
49  void Start(const Candidate& firstCandidate, bool clipAtStart);
50 
51  bool CanExtend(const Candidate& candidate) const;
52 
53  void Extend(const Candidate& candidate);
54 
55  void Reset();
56 
57  void BuildMutableFittedRanges(const std::vector<const Candidate*>& inputSolution, SelectedRoadRepository& selectedRoadRepository, std::vector<MutableFittedRange>& out_fittedRanges);
58 
59 
60  const Streaming::MortonKey& m_key;
61  const std::vector<ConformerSolution>& m_conformerSolutions;
62 
63  MutableFittedRange m_current;
64  };
65  }
66  }
67  }
68 }