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

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

#include "snake_geometry.h"

9 10 11 12
#include "ortools/constraint_solver/routing.h"
#include "ortools/constraint_solver/routing_enums.pb.h"
#include "ortools/constraint_solver/routing_index_manager.h"
#include "ortools/constraint_solver/routing_parameters.h"
Valentin Platzgummer's avatar
Valentin Platzgummer committed
13

14
using namespace std;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
15
using namespace snake_geometry;
16

Valentin Platzgummer's avatar
Valentin Platzgummer committed
17 18
using namespace operations_research;

19 20 21 22 23
namespace snake {

    enum AreaType {MeasurementArea, ServiceArea, Corridor};

    struct Area {
Valentin Platzgummer's avatar
Valentin Platzgummer committed
24
        GeoPoint2DList      geoPolygon;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
25 26 27
        double              altitude;
        size_t              layers;
        AreaType            type;
28 29
    };

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

Valentin Platzgummer's avatar
Valentin Platzgummer committed
37
        bool addArea(Area &area);
38

Valentin Platzgummer's avatar
Valentin Platzgummer committed
39 40 41 42 43 44 45 46 47 48 49
        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
50
        const BoostLineString      &getTileCenterPointsENU()    {return _tileCenterPointsENU;}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
51 52
        const min_bbox_rt          &getMeasurementAreaBBoxENU() {return _mAreaBoundingBox;}
        const BoostPoint           &getHomePositonENU()         {return _homePositionENU;}
53 54 55

        bool defined(double tileWidth, double tileHeight, double minTileArea);

Valentin Platzgummer's avatar
Valentin Platzgummer committed
56 57
        string errorString;

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

        Area _measurementArea;
        Area _serviceArea;
        Area _corridor;

Valentin Platzgummer's avatar
Valentin Platzgummer committed
71 72 73 74
        BoostPolygon _measurementAreaENU;
        BoostPolygon _serviceAreaENU;
        BoostPolygon _corridorENU;
        BoostPolygon _joinedAreaENU;
75

Valentin Platzgummer's avatar
Valentin Platzgummer committed
76 77
        min_bbox_rt _mAreaBoundingBox;

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

        GeoPoint3D _geoOrigin;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
82 83 84 85 86 87
        BoostPoint _homePositionENU;
    };

    //========================================================================================
    // FlightPlan
    //========================================================================================
88

Valentin Platzgummer's avatar
Valentin Platzgummer committed
89 90 91
    class FlightPlan{
    public:
        FlightPlan();
92

Valentin Platzgummer's avatar
Valentin Platzgummer committed
93 94 95
        void setScenario(const Scenario &scenario)          {_scenario = scenario;}
        void setProgress(const vector<int8_t> &progress)    {_progress = progress;}

Valentin Platzgummer's avatar
Valentin Platzgummer committed
96 97 98 99 100
        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
101
#ifndef NDEBUG
Valentin Platzgummer's avatar
Valentin Platzgummer committed
102
        const BoostLineString   &getPathVertices(void)      const {return _PathVertices;}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
103
#endif
Valentin Platzgummer's avatar
Valentin Platzgummer committed
104

105 106
        bool                            generate(double lineDistance, double minTransectLength);
        const vector<BoostLineString>  &getTransects() const {return _transects;}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
107 108 109 110

        string errorString;

    private:
Valentin Platzgummer's avatar
Valentin Platzgummer committed
111 112 113 114 115 116 117 118 119 120 121 122
        // 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
        class SearchFilter : public LocalSearchFilter{

        };

        typedef struct{
            Matrix<int64_t>                 distanceMatrix;
            long                            numVehicles;
            RoutingIndexManager::NodeIndex  depot;
        }RoutingDataModel_t;

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

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

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

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