Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/src/utils/router/EffortCalculator.h
169678 views
1
/****************************************************************************/
2
// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3
// Copyright (C) 2001-2025 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 EffortCalculator.h
15
/// @author Michael Behrisch
16
/// @date 2018-08-21
17
///
18
// The EffortCalculator is an interface for additional edge effort calculators
19
/****************************************************************************/
20
#pragma once
21
#include <config.h>
22
23
#include <utils/common/Parameterised.h>
24
25
26
// ===========================================================================
27
// class definitions
28
// ===========================================================================
29
/// @brief the effort calculator interface
30
class EffortCalculator {
31
public:
32
/// @brief empty destructor
33
virtual ~EffortCalculator() {}
34
35
/** Pass the set of all edges in the routing query to the effortCalculator **/
36
virtual void init(const std::vector<std::string>& edges) = 0;
37
38
/** Add information about stops **/
39
virtual void addStop(const int stopEdge, const Parameterised& params) = 0;
40
41
/** Return the effort of a given edge **/
42
virtual double getEffort(const int numericalID) const = 0;
43
44
/** Update the effort of the edge **/
45
virtual void update(const int edge, const int prev, const double length) = 0;
46
47
/** Set the effort of the first edge in the query to zero **/
48
virtual void setInitialState(const int edge) = 0;
49
50
/** basic output facility to inform about effort at this edge **/
51
virtual std::string output(const int edge) const = 0;
52
53
};
54
55