This MATSim module (or extension) simulates dynamic ride-sharing (DRS), i.e. it enables car drivers to pick up other agents, share a ride with them in the same vehicle, and drop them off before continuing their own trip.
In more detail DRS can be defined as follows:
- Drivers using a private car pick up riders for a part of their trip
- The driver's trip is part of the daily routine (not an additional trip with the sole purpose of picking up a rider)
- Driver and rider are not necessarily acquaintances
- Matching is facilitated through a platform (e.g. app) on a trip-by-trip basis (which defines the dynamic part of the DRS acronym)
Related Work:
Often passengers in cars have been incorporated as ride
agents
teleported from one activity location to another using car travel times
and without being matched with other agents (e.g. Ziemke et al (2019)).
While this approach suffices for private ride-sharing,
it fails to represent the potential for DRS where non-acquaintances share rides to reach similar destinations.
Wang et al (2017) conducted previous endeavors to model DRS in MATSim,
employing the dvrp
module (source code).
Their approach involved introducing a dynamic agent alongside the standard population agent during simulation iterations,
specifically chosen when the leg's mode is ride share driver.
The implemented DRS has the following additional properties / restrictions:
- A maximum of one rider is allowed per DRS trip
- Pickup and dropoff of the rider takes place directly at the rider's activity locations
- Matching of drivers and riders is done before the start of each day (no spontaneous requests during the day or during the trip),
i.e. in the
replanning
phase of the MATSim loop beforemobsim
. In comparison to Wang et al (2017) this approach reduces complexity and avoids waiting time for the rider, since with thedvrp
module only allows a rider to request a ride when he already wants to depart.
New modes of transport
drsDriver
drsRider
New person attribute
Agents require the a priori attribute drsAffinity
that determines if they are potential driver, rider, both or no DRS user.
drsAffinity
must be set for each person to eitherdriverOrRider
driverOnly
riderOnly
none
In more detail, DRS is integrated into the MATSim loop as follows:
In case of using SubtourModeChoice
replanning:
The drs modes must be added via the regular SubtourModeChoice
config group.
Then PermissibleModesCalculatorForDrs
takes care to remove drs for agents that don't want it using their drsAffinity
.
Then requests are collected and matched based on origin, destination, departure time and detour time.
The riders' acceptance of deviations to their desired departure time can be controlled with the DRS config parameter riderDepartureTimeAdjustmentSeconds
.
The matching algorithm ensures that all rider legs for an agent are matched (or none).
Then agents' plans are adjusted. This entails adding pickup and dropoff activities at the riders' origins and destinations to the plans of matched drivers. For matched riders the departure time is adjusted if necessary.
Finally, the conflict resolver switches to a valid plan for agents whose plan contains unmatched rider legs.
Each matched driver proceeds to the specified pickup point to collect the assigned rider.
The DRS config parameter pickupWaitingSeconds
determines how long a driver waits for a delayed rider before proceeding.
Subsequently, the driver transports the rider to the designated dropoff point.
Concurrently, matched riders await the arrival of their driver for pickup and subsequently for dropoff at the predetermined locations.
Note, that to successfully simulate DRS it is necessary to kickstart the pool of potential drivers. Before the first iteration all agents that can potentially act as a driver are assigned a copy of their original plan with as many driver legs as possible. This avoids the problem of riders not finding a match.
Adjustments to the agents' plans are reverted.
Releases and snapshots are available on repo.matsim.org.
To include the DRS module in your maven project,
add the MATSim repo and the following dependency to your pom.xml
:
<repositories>
<repository>
<id>matsim</id>
<url>https://repo.matsim.org/repository/matsim/</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>at.ac.ait.matsim</groupId>
<artifactId>matsim-drs</artifactId>
<version>VERSION</version>
</dependency>
</dependencies>
The DRS module's major version corresponds to the MATSim version it is compatible with.
Note
network.xml
is assumed to use a meter-based coordinate reference system.
If this is not the case take meter and kilometre in the parameter names (and output such as pkm) with a grain of salt.
config_drs.xml serves as a complete example on how to configure a DRS scenario.
Note, that other modules must be configured in a specific way as well, e.g. qsim
.
List of all parameters:
Costs
carAndDrsDailyMonetaryConstant
: Daily price for car usage including when using the private car as drsDriver. If specified here do not additionaly specify it in planCalcScore.scoringParameters.modeParams.dailyMonetaryConstant - otherwise it will be counted twice (typically negative)driverProfitPerKm
: The amount of money per kilometre the driver gains for a rider (typically positive)- Note, that for the drsRider's costs there is no parameter,
because this should be set in
planCalcScore.modeParams.monetaryDistanceRate
(typically negative)
Matching Algorithm
maxMatchingDistanceMeters
: Maximum euclidean distance between requests to be considered by the matching algorithm, i.e. if both the distance between two requests' origin and destination location are closer than the given value they are potential matches. The default value is good for urban areas. For large areas with sparsely distributed population and low drs share, you may consider using a larger value.maxPossibleCandidates
: Limits the number of possible riders requests considered for a driver during the matching process. Used to speed up computations, values 20 to 40 make a good trade-off between computational speed and quality of results. To turn off this feature specify a sufficiently big number (not recommended).minDriverLegMeters
: minimum length of legs (routed with the drsDriver mode) to be considered for the drs driver mode. 0 means no minimum.minRiderLegMeters
minimum length of legs (routed with the drsDriver mode) to be considered for the drs ride mode. 0 means no minimum.timeSegmentLengthSeconds
: The duration of the time segments used in time segment registers of riders requests. To avoid scenarios where a driver and a rider departure time are close, but cross a segment boundary, candidate requests are taken not only from the current segment but also from the one before and after.
Simulation / Plan Adjustment
pickupWaitingSeconds
The amount of time the driver is expected to wait until the rider enters the vehicle.riderDepartureTimeAdjustmentSeconds
The amount of time the riders are willing to adjust their departure times. During the matching process, the arrival of driver to pick-up point is checked whether it is within the rider departure time +- the riderDepartureTimeAdjustment.
The main method of RunSimpleDrsExample takes only the config file as an input in order to run.
- It automatically adds
drsDriver
mode as an allowed mode to all car links. - It automatically kick-starts all potential
drsDriver
agents, i.e. with an accordingdrsAffinity
+ car + license availability, with adrsDriver
plan.
This should assure, that at the beginning of the simulation many drivers are present and "starvation" of the people choosing rider mode is avoided.
(MATSim guarantees to try out / score all un-scored plans of an agent - see RandomUnscoredPlanSelector
-
before a different plan is selected e.g. via SelectPlanExpBeta
).
The drs modes must be added via the regular SubtourModeChoice
config group.
Then the PermissibleModesCalculatorForDrs
takes care to remove drs for agents that don't want it using their drsAffinity
.
The following output files are additionally created in the MATSim output directory:
drs_replanning_stats.csv/png
: evolution of the number of DRS requests and matchesdrs_replanning_trips_[un]matched.csv
: details of all matched and unmatched trips of the last iterationdrs_sim_stats.csv
: evolution of the actual drs simulation, e.g. nr of stuck riders (similar to experienced plans)drs_vkt_stats.csv/png
: evolution of distribution of vehicle kilometres traveled by motorized individual transport between- DRS travel, i.e. parts of a DRS driver's trip with an actual rider
- before and after DRS, i.e. parts of a DRS driver's trip to the pickup point / after dropping off the rider
- individual travel, i.e. regular non-DRS car trips or unmatched DRS driver trips
- Only one rider is supported per driver's trip (but a driver may take different riders along on different trips).
- If a
drsDriver
can not pick up adrsRider
because it is not there it will still make the detour to the dropoff place. A future improvement is to optimize the drivers' route on the fly in such cases - Unmatched drivers and riders even after reaching equilibrium account for 6% and 0.3% respectively for our Upper Austria model. Ideally that should be 0.
- Improve the matching algorithm
- Option for predefined pickup points (instead of door-to-door)
- Use sociodemographic attributes in the matching algorithm, not only for scoring
- Avoid local optimums (and implement a more complex optimization algorithm)
Reference publications
- Müller, J., Nassar, E., Straub, M., Chou, A. T. M., 2024. Integrating Dynamic Ride-Sharing into an Agent-Based Traffic Simulation: A Sensitivity Analysis. 103rd Annual Meeting of the Transportation Research Board
- Nassar, E., 2023. Integrating Dynamic Ride-Sharing in MATSim. Master’s thesis. Technical University Munich.
Related
- Wang, B., Liang, H., Hörl, S., Ciari, F., 2017. Dynamic ride sharing implementation and analysis in matsim. hEART 2017.
- Ziemke, D., Kaddoura, I., Nagel, K., 2019. The matsim open berlin scenario: A multimodal agent-based transport simulation scenario based on synthetic demand modeling and open data. Procedia computer science 151, 870–877.
The DRS module is GPL-2.0-or-later licensed for maximum compatibility with MATSim.
This work was developed by Eyad Nassar for his master's thesis (Nassar, 2023) with support of Markus Straub and Johannes Müller.
It is part of the lead project DOMINO, which was promoted and financed within the framework of the RTI programme Mobility of the Future by the Federal Ministry for Climate Protection, Environment, Energy, Mobility, Innovation and Technology (BMK) and handled by the Austrian Research Promotion Agency (FFG) under grant 3300226.
If you have any questions, remarks, or collaboration ideas, please get in touch:
either via GitHub or via email to markus.straub
or johannes.mueller
(both at ait.ac.at
).