LCOV - code coverage report
Current view: top level - src/utils/common - NamedRTree.h (source / functions) Coverage Total Hit
Test: lcov.info Lines: 100.0 % 19 19
Test Date: 2025-01-02 15:43:51 Functions: 80.0 % 5 4

            Line data    Source code
       1              : /****************************************************************************/
       2              : // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
       3              : // Copyright (C) 2008-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    NamedRTree.h
      15              : /// @author  Daniel Krajzewicz
      16              : /// @author  Jakob Erdmann
      17              : /// @author  Michael Behrisch
      18              : /// @date    27.10.2008
      19              : ///
      20              : // A RT-tree for efficient storing of SUMO's Named objects
      21              : /****************************************************************************/
      22              : #pragma once
      23              : #include <config.h>
      24              : #include <set>
      25              : #include <foreign/rtree/RTree.h>
      26              : #include <utils/common/Named.h>
      27              : 
      28              : 
      29              : // specialized implementation for speedup and avoiding warnings
      30              : #define NAMED_RTREE_QUAL RTree<Named*, Named, float, 2, Named::StoringVisitor>
      31              : 
      32              : template<>
      33              : inline float NAMED_RTREE_QUAL::RectSphericalVolume(Rect* a_rect) {
      34              :     ASSERT(a_rect);
      35      5087720 :     const float extent0 = a_rect->m_max[0] - a_rect->m_min[0];
      36      5087720 :     const float extent1 = a_rect->m_max[1] - a_rect->m_min[1];
      37      3288230 :     return .78539816f * (extent0 * extent0 + extent1 * extent1);
      38              : }
      39              : 
      40              : template<>
      41              : inline NAMED_RTREE_QUAL::Rect NAMED_RTREE_QUAL::CombineRect(Rect* a_rectA, Rect* a_rectB) {
      42              :     ASSERT(a_rectA && a_rectB);
      43              :     Rect newRect;
      44      4634995 :     newRect.m_min[0] = rtree_min(a_rectA->m_min[0], a_rectB->m_min[0]);
      45      4634995 :     newRect.m_max[0] = rtree_max(a_rectA->m_max[0], a_rectB->m_max[0]);
      46      4634995 :     newRect.m_min[1] = rtree_min(a_rectA->m_min[1], a_rectB->m_min[1]);
      47      4634995 :     newRect.m_max[1] = rtree_max(a_rectA->m_max[1], a_rectB->m_max[1]);
      48              :     return newRect;
      49              : }
      50              : 
      51              : // ===========================================================================
      52              : // class definitions
      53              : // ===========================================================================
      54              : /** @class NamedRTree
      55              :  * @brief A RT-tree for efficient storing of SUMO's Named objects
      56              :  *
      57              :  * This class specialises the used RT-tree implementation from "rttree.h".
      58              :  * It stores names of "Named"-objects.
      59              :  * @see Named
      60              :  */
      61              : class NamedRTree : private NAMED_RTREE_QUAL {
      62              : public:
      63              :     /// @brief Constructor
      64       183452 :     NamedRTree() : NAMED_RTREE_QUAL(&Named::addTo) {
      65              :     }
      66              : 
      67              : 
      68              :     /// @brief Destructor
      69          251 :     ~NamedRTree() {
      70       140172 :     }
      71              : 
      72              : 
      73              :     /** @brief Insert entry
      74              :      * @param a_min Min of bounding rect
      75              :      * @param a_max Max of bounding rect
      76              :      * @param a_data The instance of a Named-object to add (the ID is added)
      77              :      * @see RTree::Insert
      78              :      */
      79        10013 :     void Insert(const float a_min[2], const float a_max[2], Named* const& a_data) {
      80       282123 :         NAMED_RTREE_QUAL::Insert(a_min, a_max, a_data);
      81       280911 :     }
      82              : 
      83              : 
      84              :     /** @brief Remove entry
      85              :      * @param a_min Min of bounding rect
      86              :      * @param a_max Max of bounding rect
      87              :      * @param a_data The instance of a Named-object to remove
      88              :      * @see RTree::Remove
      89              :      */
      90           10 :     void Remove(const float a_min[2], const float a_max[2], Named* const& a_data) {
      91        11377 :         NAMED_RTREE_QUAL::Remove(a_min, a_max, a_data);
      92           10 :     }
      93              : 
      94              : 
      95              :     /** @brief Remove all enrties
      96              :      * @see RTree::RemoveAll
      97              :      */
      98              :     void RemoveAll() {
      99        40282 :         NAMED_RTREE_QUAL::RemoveAll();
     100              :     }
     101              : 
     102              : 
     103              :     /** @brief Find all within search rectangle
     104              :      * @param a_min Min of search bounding rect
     105              :      * @param a_max Max of search bounding rect
     106              :      * @param a_searchResult Search result array.  Caller should set grow size. Function will reset, not append to array.
     107              :      * @param a_resultCallback Callback function to return result.  Callback should return 'true' to continue searching
     108              :      * @param a_context User context to pass as parameter to a_resultCallback
     109              :      * @return Returns the number of entries found
     110              :      * @see RTree::Search
     111              :      */
     112         2584 :     int Search(const float a_min[2], const float a_max[2], const Named::StoringVisitor& c) const {
     113       227143 :         return NAMED_RTREE_QUAL::Search(a_min, a_max, c);
     114              :     }
     115              : 
     116              : 
     117              : };
        

Generated by: LCOV version 2.0-1