LCOV - code coverage report
Current view: top level - src/netwrite - NWWriter_DlrNavteq.h (source / functions) Coverage Total Hit
Test: lcov.info Lines: 100.0 % 1 1
Test Date: 2024-11-22 15:46:21 Functions: - 0 0

            Line data    Source code
       1              : /****************************************************************************/
       2              : // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
       3              : // Copyright (C) 2012-2024 German Aerospace Center (DLR) and others.
       4              : // This program and the accompanying materials are made available under the
       5              : // terms of the Eclipse Public License 2.0 which is available at
       6              : // https://www.eclipse.org/legal/epl-2.0/
       7              : // This Source Code may also be made available under the following Secondary
       8              : // Licenses when the conditions for such availability set forth in the Eclipse
       9              : // Public License 2.0 are satisfied: GNU General Public License, version 2
      10              : // or later which is available at
      11              : // https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
      12              : // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
      13              : /****************************************************************************/
      14              : /// @file    NWWriter_DlrNavteq.h
      15              : /// @author  Jakob Erdmann
      16              : /// @author  Michael Behrisch
      17              : /// @date    26.10.2012
      18              : ///
      19              : // Exporter writing networks using DlrNavteq (Elmar) format
      20              : /****************************************************************************/
      21              : #pragma once
      22              : #include <config.h>
      23              : 
      24              : #include <string>
      25              : #include <map>
      26              : #include <utils/xml/SUMOSAXHandler.h>
      27              : #include <utils/common/UtilExceptions.h>
      28              : 
      29              : 
      30              : // ===========================================================================
      31              : // class declarations
      32              : // ===========================================================================
      33              : class NBEdge;
      34              : class NBEdgeCont;
      35              : class NBNetBuilder;
      36              : class NBNode;
      37              : class NBNodeCont;
      38              : class NBTrafficLightLogicCont;
      39              : class NBTypeCont;
      40              : class OptionsCont;
      41              : 
      42              : 
      43              : // ===========================================================================
      44              : // class definitions
      45              : // ===========================================================================
      46              : /**
      47              :  * @class NWWriter_DlrNavteq
      48              :  * @brief Exporter writing networks using XML (native input) format
      49              :  *
      50              :  */
      51              : class NWWriter_DlrNavteq {
      52              : public:
      53              :     /** @brief Writes the network into XML-files (nodes, edges, connections,
      54              :      *   traffic lights)
      55              :      * @param[in] oc The options to use
      56              :      * @param[in] nb The network builder from which to read data
      57              :      */
      58              :     static void writeNetwork(const OptionsCont& oc, NBNetBuilder& nb);
      59              : 
      60              :     /// @brief get the navteq road class
      61              :     static int getRoadClass(const NBEdge* const edge);
      62              : 
      63              :     /// @brief get the navteq brunnel type
      64              :     static int getBrunnelType(const NBEdge* const edge);
      65              : 
      66              :     /// @brief get the form of way
      67              :     static int getFormOfWay(const NBEdge* const edge);
      68              : 
      69              : private:
      70              :     /** @brief Writes the nodes_unsplitted file
      71              :      * @param[in] oc The options to use
      72              :      * @param[in] nc The node-container from which to read data
      73              :      * @param[in] ec The edge-container from which to read data
      74              :      * @param[out] internalNodes The internal node ids, generated for edges with complex geometry
      75              :      */
      76              :     static void writeNodesUnsplitted(const OptionsCont& oc, const NBNodeCont& nc, const NBEdgeCont& ec, std::map<const NBEdge*, std::string>& internalNodes);
      77              : 
      78              :     /** @brief Writes the links_unsplitted file
      79              :      * @param[in] oc The options to use
      80              :      * @param[in] ec The edge-container from which to read data
      81              :      * @param[int] internalNodes The internal node ids, generated for edges with complex geometry
      82              :      */
      83              :     static void writeLinksUnsplitted(const OptionsCont& oc, const NBEdgeCont& ec, const std::map<const NBEdge*, std::string>& internalNodes);
      84              : 
      85              :     /** @brief Writes the traffic_signals file
      86              :      * @param[in] oc The options to use
      87              :      * @param[in] nc The node-container from which to read data
      88              :      */
      89              :     static void writeTrafficSignals(const OptionsCont& oc, NBNodeCont& nc);
      90              : 
      91              : 
      92              :     /** @brief Writes the prohibited_manoeuvres file
      93              :      * @param[in] oc The options to use
      94              :      * @param[in] nc The node-container from which to read data
      95              :      */
      96              :     static void writeProhibitedManoeuvres(const OptionsCont& oc, const NBNodeCont& nc, const NBEdgeCont& ec);
      97              : 
      98              :     /** @brief Writes the connected_lanes file
      99              :      * @param[in] oc The options to use
     100              :      * @param[in] nc The node-container from which to read data
     101              :      */
     102              :     static void writeConnectedLanes(const OptionsCont& oc, NBNodeCont& nc);
     103              : 
     104              :     /// @brief write header comments (input paramters, date, etc...)
     105              :     static void writeHeader(OutputDevice& device, const OptionsCont& oc);
     106              : 
     107              :     /// @brief build the ascii-bit-vector for column vehicle_type
     108              :     static std::string getAllowedTypes(SVCPermissions permissions);
     109              : 
     110              :     /// @brief get the navteq speed class based on the speed in km/h
     111              :     static int getSpeedCategory(int kph);
     112              : 
     113              :     /// @brief get the SPEED_LIMIT as defined by elmar (upper bound of speed category)
     114              :     static int getSpeedCategoryUpperBound(int kph);
     115              : 
     116              :     /// @brief get the lane number encoding
     117              :     static int getNavteqLaneCode(const int numLanes);
     118              : 
     119              :     /// @brief get the length of the edge when measured up to the junction center
     120              :     static double getGraphLength(const NBEdge* const edge);
     121              : 
     122              :     static std::string getSinglePostalCode(const std::string& zipCode, const std::string edgeID);
     123              : 
     124              :     /// @brief magic value for undefined stuff
     125              :     static const std::string UNDEFINED;
     126              : 
     127              :     /// @brief get edge speed rounded to kmh
     128              :     static inline int speedInKph(double metersPerSecond) {
     129         1151 :         return (int)std::floor(metersPerSecond * 3.6 + 0.5);
     130              :     }
     131              : };
        

Generated by: LCOV version 2.0-1