snake.h 5.48 KB
Newer Older
1 2 3 4 5 6 7 8 9
#pragma once

#include <vector>
#include <string>
#include <array>

#include "snake_geometry.h"

using namespace std;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
10
using namespace snake_geometry;
11 12 13 14 15

namespace snake {

    enum AreaType {MeasurementArea, ServiceArea, Corridor};

16 17 18 19 20 21
    class Area {
    public:
        Area();
        Area(const GeoPoint2DList &gP, AreaType tp);
        Area(const GeoPoint2DList &gP, double alt, size_t l, AreaType tp);

Valentin Platzgummer's avatar
Valentin Platzgummer committed
22
        GeoPoint2DList      geoPolygon;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
23 24 25
        double              altitude;
        size_t              layers;
        AreaType            type;
26 27
    };

Valentin Platzgummer's avatar
Valentin Platzgummer committed
28 29 30
    //========================================================================================
    // Scenario
    //========================================================================================
31 32 33 34
    class Scenario{
    public:
        Scenario();

Valentin Platzgummer's avatar
Valentin Platzgummer committed
35
        bool addArea(Area &area);
36

Valentin Platzgummer's avatar
Valentin Platzgummer committed
37 38 39 40 41 42 43 44 45 46 47
        const Area &getMeasurementArea() const {return _measurementArea;}
        const Area &getServiceArea() const {return _serviceArea;}
        const Area &getCorridor() const {return _corridor;}

        const BoostPolygon &getMeasurementAreaENU() {return _measurementAreaENU;}
        const BoostPolygon &getServiceAreaENU()     {return _serviceAreaENU;}
        const BoostPolygon &getCorridorENU()        {return _corridorENU;}
        const BoostPolygon &getJoineAreaENU()       {return _joinedAreaENU;}
        const GeoPoint3D   &getOrigin()             {return _geoOrigin;}

        const vector<BoostPolygon> &getTilesENU()               {return _tilesENU;}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
48
        const BoostLineString      &getTileCenterPointsENU()    {return _tileCenterPointsENU;}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
49 50
        const min_bbox_rt          &getMeasurementAreaBBoxENU() {return _mAreaBoundingBox;}
        const BoostPoint           &getHomePositonENU()         {return _homePositionENU;}
51

52 53 54 55
        const vector<GeoPoint3DList>    &getTiles()               {return _tiles;}
        const vector<GeoPoint3D>        &getTileCenterPoints()    {return _tileCenterPoints;}
        const GeoPoint3D                &getHomePositon()         {return _homePosition;}

Valentin Platzgummer's avatar
Valentin Platzgummer committed
56
        bool update(double tileWidth, double tileHeight, double minTileArea);
57

Valentin Platzgummer's avatar
Valentin Platzgummer committed
58 59
        string errorString;

60 61 62 63 64 65
    private:
        bool _areas2enu();
        bool _setMeasurementArea(Area &area);
        bool _setServiceArea(Area &area);
        bool _setCorridor(Area &area);
        bool _calculateBoundingBox();
Valentin Platzgummer's avatar
Valentin Platzgummer committed
66
        bool _calculateTiles(double tileWidth, double tileHeight, double minTileArea);
67 68 69 70 71 72
        bool _calculateJoinedArea();

        Area _measurementArea;
        Area _serviceArea;
        Area _corridor;

Valentin Platzgummer's avatar
Valentin Platzgummer committed
73 74 75 76
        BoostPolygon _measurementAreaENU;
        BoostPolygon _serviceAreaENU;
        BoostPolygon _corridorENU;
        BoostPolygon _joinedAreaENU;
77

Valentin Platzgummer's avatar
Valentin Platzgummer committed
78 79
        min_bbox_rt _mAreaBoundingBox;

Valentin Platzgummer's avatar
Valentin Platzgummer committed
80
        vector<BoostPolygon>    _tilesENU;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
81
        BoostLineString         _tileCenterPointsENU;
82

83 84 85
        vector<GeoPoint3DList>    _tiles;
        vector<GeoPoint3D>        _tileCenterPoints;

86
        GeoPoint3D _geoOrigin;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
87
        BoostPoint _homePositionENU;
88 89

        GeoPoint3D _homePosition;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
90 91 92 93 94
    };

    //========================================================================================
    // FlightPlan
    //========================================================================================
95

Valentin Platzgummer's avatar
Valentin Platzgummer committed
96 97 98
    class FlightPlan{
    public:
        FlightPlan();
99

Valentin Platzgummer's avatar
Valentin Platzgummer committed
100 101
        void setScenario(Scenario &scenario)          {_scenario = scenario;}
        void setProgress(vector<int> &progress)       {_progress = progress;}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
102

Valentin Platzgummer's avatar
Valentin Platzgummer committed
103 104 105 106 107
        const Scenario          &getScenario(void)          const {return _scenario;}
        const BoostLineString   &getWaypointsENU(void)      const {return _waypointsENU;}
        const GeoPoint2DList    &getWaypoints(void)         const {return _waypoints;}
        const vector<uint64_t>  &getArrivalPathIdx(void)    const {return _arrivalPathIdx;}
        const vector<uint64_t>  &getReturnPathIdx(void)     const {return _returnPathIdx;}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
108
#ifndef NDEBUG
Valentin Platzgummer's avatar
Valentin Platzgummer committed
109
        const BoostLineString   &getPathVertices(void)      const {return _PathVertices;}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
110
#endif
Valentin Platzgummer's avatar
Valentin Platzgummer committed
111

112 113
        bool                            generate(double lineDistance, double minTransectLength);
        const vector<BoostLineString>  &getTransects() const {return _transects;}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
114 115 116 117

        string errorString;

    private:
Valentin Platzgummer's avatar
Valentin Platzgummer committed
118 119
        // Search Filter to speed up routing.SolveWithParameters(...);
        // Found here: http://www.lia.disi.unibo.it/Staff/MicheleLombardi/or-tools-doc/user_manual/manual/ls/ls_filtering.html
Valentin Platzgummer's avatar
Valentin Platzgummer committed
120
        class SearchFilter;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
121

Valentin Platzgummer's avatar
Valentin Platzgummer committed
122
        struct RoutingDataModel;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
123

Valentin Platzgummer's avatar
Valentin Platzgummer committed
124
        bool _generateTransects(double lineDistance, double minTransectLength);
Valentin Platzgummer's avatar
Valentin Platzgummer committed
125 126 127
        void _generateRoutingModel(const BoostLineString &vertices,
                                   const BoostPolygon &polygonOffset,
                                   size_t n0,
Valentin Platzgummer's avatar
Valentin Platzgummer committed
128
                                   RoutingDataModel &dataModel,
Valentin Platzgummer's avatar
Valentin Platzgummer committed
129 130
                                   Matrix<double> &graph);

Valentin Platzgummer's avatar
Valentin Platzgummer committed
131
        Scenario                                _scenario;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
132
        BoostLineString                         _waypointsENU;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
133
        GeoPoint2DList                          _waypoints;
134
        vector<BoostLineString>                 _transects;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
135
        vector<int>                             _progress;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
136 137
        vector<uint64_t>                        _arrivalPathIdx;
        vector<uint64_t>                        _returnPathIdx;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
138 139 140 141

#ifndef NDEBUG
        BoostLineString                         _PathVertices;
#endif
142
    };
Valentin Platzgummer's avatar
Valentin Platzgummer committed
143 144

    namespace detail {
145
        const double offsetConstant = 0.1; // meter, polygon offset to compenstate for numerical inaccurracies.
Valentin Platzgummer's avatar
Valentin Platzgummer committed
146
    }
147 148
}