Skip to main content

HIVE is a mobility services research platform developed by the Mobility and Advanced Powertrains (MBAP) group at the National Renewable Energy Laboratory in Golden, Colorado, USA.

Project description

drawing

Highly
Integrated
Vehicle
Ecosystem

HIVE™ is an open-source mobility services research platform developed by the Mobility, Behavior, and Advanced Powertrains (MBAP) group at the National Renewable Energy Laboratory in Golden, Colorado, USA.

HIVE supports researchers who explore Electric Vehicle (EV) fleet control, Electric Vehicle Supply Equipment (EVSE) siting, and fleet composition problems, and is designed for ease-of-use, scalability, and co-simulation. Out-of-the-box, it provides a baseline set of algorithms for fleet dispatch, but provides a testbed for exploring alternatives from leading research in model-predictive control (MPC) and deep reinforcement learning. HIVE is designed to integrate with vehicle power and energy grid power models in real-time for accurate, high-fidelity energy estimation over arbitrary road networks and demand scenarios.

Installation

HIVE depends on a Python installation [3.7, 3.8, 3.9, 3.10] and the pip package manager ( python.org. In our installation example we use conda | miniconda for managing a HIVE Python environment.

via pip

> pip install nrel.hive

build from source

Via conda, create a dedicated 'hive' Python environment:

> conda create -n hive python=3.8 
> conda activate hive

to run tests, also install pytest:

> pip install pytest

to load hive as a command line application along with all dependencies into your conda environment:

> git clone https://github.com/NREL/hive.git
> cd hive
> pip install -e .

Run HIVE

run a test of hive using a built-in scenario:

> hive denver_demo.yaml

if you want the program to use a file outside of this location, provide a valid path:

> hive some_other_directory/my_scenario.yaml

Built-In Scenarios

The following built-in scenario files come out-of-the-box, and available directly by name:

scenario description
denver_demo.yaml default demo scenario with 20 vehicles and 2.5k requests synthesized with uniform time/location sampling
denver_rl_toy.yaml extremely simple scenario for testing RL
denver_demo_constrained_charging.yaml default scenario with limited charging supply
denver_demo_fleets.yaml default scenario with two competing TNC fleets
manhattan.yaml larger test scenario with 200 vehicles and 20k requests sampled from the NY Taxi Dataset

Scenario configuration

Scenarios are run by reading a YAML file describing the parameters of the simulation. The files list all scenario-specific parameters but can fall back to defaults set here.

Scenario YAML files organize a list of resource files to use as input. If a file resource is listed which doesn't resolve to a local file path, HIVE will search for a default resource here. By default, HIVE expects file resources stored in a directory matching their resource type. For example, using the default Denver scenario:

...
input:
  vehicles_file: denver_demo_vehicles.csv  # vehicles/denver_demo_vehicles.csv
  requests_file: denver_demo_requests.csv  # requests/denver_demo_requests.csv
  bases_file: denver_demo_bases.csv        # bases/denver_demo_bases.csv
...

For a description of file contents and schemas, please read our technical report. Example scenario and resource data can be found here.

Global configuration

Some values are set by a global configuration file with filename .hive.yaml. The defaults are set in the repo here. If you want to override any entries in this file, you can create a new one by the same name .hive.yaml and place it in your working directory or a parent directory. Hive will also check your base user directory for this file (aka ~/.hive.yaml). This can be useful if you would like to reduce the output files or change the default output base directory (for example, to something like ~/hive/output).

Dependencies

HIVE attempts to rely on as few dependencies as possible. For the most part, these dependencies are obvious choices from the open-source Python analysis ecosystem:

  • scipy (bipartite matching optimization)
  • numpy (linear interpolation of energy lookup tables)
  • pandas (file IO)
  • networkx (underlying network model)
  • pyyaml
  • tqdm (command line progress bars)

Beyond these, HIVE uses Uber H3, a geospatial index which HIVE uses for positioning and search, and MagicStack Immutables, which provides the implementation of an immutable Map to replace the standard Python Dict type. The Returns library provides Python-approximations for functional containers. Links provided here:

Developer documentation

Documentation can be found here.

Why HIVE?

When the Mobility, Behavior, and Advanced Powertrains group began looking to answer questions related to fleet sizing, charging infrastructure, and dynamic energy pricing, we could not find a simulator which was right-sized for our research questions. Most modern models for mobility services have a large barrier-to-entry due to the complex interactions of mode choice, economics, and model tuning required to use the leading micro and mesoscopic transportation models (BEAM, POLARIS, MATSim, SUMO, AMoDeus, etc.). Additionally, they have heavyweight technical infrastructure demands where deployment of these models requires a specialized team. HIVE attempts to fill a gap for researchers seeking to study the economic and energy impacts of autonomous ride hail fleets by providing the following feature set:

  • agent-based model (ABM)
  • data-driven control interfaces for Model-Predicted Control and Reinforcement Learning research
  • easy integration/co-simulation (can be called alongside other software tools)
  • dynamic dispatch, trip energy, routing, and economics
  • simple to define/share scenarios via configuration files and simulation snapshots
  • 100% Python (v 3.7) code with a small(ish) set of dependencies and well-documented code

HIVE is not a fully-featured Activity-Based Model, does not simulate all vehicles on the network, and does not simulate congestion. It also assumes demand is fixed. If these assumptions are too strong for your research question, then one of the other mesoscopic models capable of ridehail simulation may be a more appropriate fit. The following (opinionated) chart attempts to compare features of HIVE against LBNL's BEAM and ANL's POLARIS models.

feature HIVE BEAM POLARIS
Agent-Based Ridehail Model :honeybee: :red_car: :train:
Designed for large-scale inputs :honeybee: :red_car: :train:
Integrates with NREL energy models :honeybee: :red_car: :train:
Charging infrastructure & charge events :honeybee: :red_car: :train:
Service pricing and income model :honeybee: :red_car: :train:
Data-driven ridehail dispatcher :honeybee:
Does not require socio-demographic data :honeybee:
Built-in example scenario :honeybee: :red_car:
Written entirely in Python, installed via pip :honeybee:
Activity-Based Demand Model :red_car: :train:
Dynamic demand using behavioral models :red_car: :train:
Robust assignment of population demographics :red_car: :train:
Supports broad set of travel modes :red_car: :train:
Endogenous traffic congestion modeling :red_car: :train:

Looking at a default scenario

Map of Denver Downtown

Running HIVE takes one argument, which is a configuration file. Hive comes packaged with a demo scenario for Downtown Denver, located at hive/resources/scenarios/denver_demo.yaml. This file names the inputs and the configuration Parameters for running HIVE.

the Denver demo scenario is configured to log output to a folder named denver_demo_outputs which is also tagged with a timestamp. These output files can be parsed by Pandas (for Pandas > 0.19.0):

import pandas as pd
# log files store JSON rows, like a document store
output_file = "~/hive/output/denver_demo_2021-02-08_11-00-07/state.log"
pd.read_json(output_file, lines=True)

By default, these outputs are generated:

file name file type description
<config>.yaml YAML the input configuration serialized (can be read back by HIVE)
run.log text console log output
event.log JSON rows events that occur, such as vehicle movement, pickup + dropoff events, etc
instruction.log JSON rows instructions sent from dispatcher to drivers
state.log JSON rows entity states at every time step
station_capacities.csv CSV energy load capacity for each station
summary_stats.json JSON summary stats as displayed in run.log but in JSON format
time_step_stats_{$FLEET all}.csv CSV

Running this scenario should also feed some logging into the console. First, HIVE announces where it is loading configuration from (1). It then dumps the global and scenario configuration to the console (2). Finally, after around 65 lines, it begins running the simulation with a progress bar (3). After, it prints the summary stats to the console and exits (4).

INFO
         ##     ##  ####  ##     ##  #######
         ##     ##   ##   ##     ##  ##
         #########   ##   ##     ##  ######
         ##     ##   ##    ##   ##   ##
         ##     ##  ####     ###     #######

                         .' '.            __
                .        .   .           (__\_
                 .         .         . -{{_(|8)
                   ' .  . ' ' .  . '     (__/

/Users/nreinick/dev/repos/hive/nrel/hive/resources/scenarios/denver_downtown/denver_demo.yaml
INFO     global hive configuration loaded from /Users/nreinick/dev/repos/hive/nrel/hive/resources/defaults/.hive.yaml
INFO       global_settings_file_path: /Users/nreinick/dev/repos/hive/nrel/hive/resources/defaults/.hive.yaml
INFO       output_base_directory: .
INFO       local_parallelism: 1
INFO       local_parallelism_timeout_sec: 60
INFO       log_run: True
INFO       log_events: True
INFO       log_states: True
INFO       log_instructions: True
INFO       log_stats: True
INFO       log_level: INFO
INFO       log_sim_config: {<ReportType.INSTRUCTION: 8>, <ReportType.VEHICLE_STATE: 2>, <ReportType.DRIVER_SCHEDULE_EVENT: 13>,
         <ReportType.DRIVER_STATE: 3>, <ReportType.VEHICLE_CHARGE_EVENT: 9>, <ReportType.CANCEL_REQUEST_EVENT: 7>,
         <ReportType.DROPOFF_REQUEST_EVENT: 6>, <ReportType.STATION_LOAD_EVENT: 11>, <ReportType.VEHICLE_MOVE_EVENT: 10>,
         <ReportType.REFUEL_SEARCH_EVENT: 12>, <ReportType.STATION_STATE: 1>, <ReportType.PICKUP_REQUEST_EVENT: 5>,
         <ReportType.ADD_REQUEST_EVENT: 4>}
INFO       log_station_capacities: True
INFO       log_time_step_stats: True
INFO       log_fleet_time_step_stats: True
INFO       lazy_file_reading: False
INFO       wkt_x_y_ordering: True
INFO     output directory set to /Users/nreinick/dev/repos/hive/nrel/hive/resources/scenarios/denver_downtown
INFO     hive config loaded from /Users/nreinick/dev/repos/hive/nrel/hive/resources/scenarios/denver_downtown/denver_demo.yaml
INFO
         dispatcher:
           base_charging_range_km_threshold: 100
           charging_range_km_soft_threshold: 50
           charging_range_km_threshold: 20
           charging_search_type: nearest_shortest_queue
           default_update_interval_seconds: 600
           ideal_fastcharge_soc_limit: 0.8
           idle_time_out_seconds: 1800
           matching_range_km_threshold: 20
           max_search_radius_km: 100.0
           valid_dispatch_states:
           - Idle
           - Repositioning
         input:
           bases_file: denver_demo_bases.csv
           charging_price_file: denver_charging_prices_by_geoid.csv
           demand_forecast_file: denver_demand.csv
           geofence_file: downtown_denver.geojson
           mechatronics_file: mechatronics.yaml
           rate_structure_file: rate_structure.csv
           requests_file: denver_demo_requests.csv
           road_network_file: downtown_denver_network.json
           stations_file: denver_demo_stations.csv
           vehicles_file: denver_demo_vehicles.csv
         network:
           default_speed_kmph: 40.0
           network_type: osm_network
         sim:
           end_time: '1970-01-02T00:00:00'
           request_cancel_time_seconds: 600
           schedule_type: time_range
           sim_h3_resolution: 15
           sim_h3_search_resolution: 7
           sim_name: denver_demo
           start_time: '1970-01-01T00:00:00'
           timestep_duration_seconds: 60

INFO     creating run log at denver_demo_2022-10-27_16-36-43/run.log with log level INFO
INFO     running denver_demo for time 1970-01-01T00:00:00 to 1970-01-02T00:00:00:
100%|██████████████████████████████████████████████████████████████████████████████████████| 1440/1440 [00:09<00:00, 144.72it/s]
INFO     done! time elapsed: 9.97 seconds
INFO     96.84 %         Requests Served
                        Summary Stats
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━┓
┃ Stat                                         ┃ Value      ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━┩
│ Mean Final SOC                               │ 51.1%      │
│ Requests Served                              │ 96.84%     │
│ Time in State Idle                           │ 28.03%     │
│ Time in State DispatchBase                   │ 0.07%      │
│ Time in State DispatchTrip                   │ 20.89%     │
│ Time in State ChargingBase                   │ 3.62%      │
│ Time in State ServicingTrip                  │ 27.51%     │
│ Time in State ReserveBase                    │ 15.3%      │
│ Time in State DispatchStation                │ 0.29%      │
│ Time in State ChargingStation                │ 4.3%       │
│ Time in State Repositioning                  │ 0.0%       │
│ Total Kilometers Traveled                    │ 8032.26 km │
│ Kilometers Traveled in State DispatchBase    │ 11.41 km   │
│ Kilometers Traveled in State DispatchTrip    │ 3304.36 km │
│ Kilometers Traveled in State ServicingTrip   │ 4665.25 km │
│ Kilometers Traveled in State DispatchStation │ 50.54 km   │
│ Kilometers Traveled in State Repositioning   │ 0.69 km    │
│ Station Revenue                              │ $ 196.72   │
│ Fleet Revenue                                │ $ 12017.56 │
└──────────────────────────────────────────────┴────────────┘
INFO     summary stats written to denver_demo_2022-10-27_16-36-43/summary_stats.json
INFO     time step stats written to denver_demo_2022-10-27_16-36-43/time_step_stats_all.csv

Roadmap

Updated October, 2022

HIVE intends to implement the following features in the near-term:

  • Time-varying network speeds
  • Integration into vehicle powertrain, grid energy, smart charging models
  • Ridehail Pooling
  • Improved network modeling (turn costs, signal costs)
  • Support for wiring in choice models
  • Baseline multi-objective dispatcher

Citation

If you have found HIVE useful for your research, please cite our technical report as follows:

@techreport{fitzgerald2021highly,
  title={The Highly Integrated Vehicle Ecosystem (HIVE): A Platform for Managing the Operations of On-Demand Vehicle Fleets},
  author={Fitzgerald, Robert and Reinicke, Nicholas and Moniot, Matthew},
  year={2021},
  institution={National Renewable Energy Lab.(NREL), Golden, CO (United States)}
}

Notice

Copyright © 2022 Alliance for Sustainable Energy, LLC, Inc. All Rights Reserved

This computer software was produced by Alliance for Sustainable Energy, LLC under Contract No. DE-AC36-08GO28308 with the U.S. Department of Energy. For 5 years from the date permission to assert copyright was obtained, the Government is granted for itself and others acting on its behalf a nonexclusive, paid-up, irrevocable worldwide license in this software to reproduce, prepare derivative works, and perform publicly and display publicly, by or on behalf of the Government. There is provision for the possible extension of the term of this license. Subsequent to that period or any extension granted, the Government is granted for itself and others acting on its behalf a nonexclusive, paid-up, irrevocable worldwide license in this software to reproduce, prepare derivative works, distribute copies to the public, perform publicly and display publicly, and to permit others to do so. The specific term of the license can be identified by inquiry made to Contractor or DOE. NEITHER ALLIANCE FOR SUSTAINABLE ENERGY, LLC, THE UNITED STATES NOR THE UNITED STATES DEPARTMENT OF ENERGY, NOR ANY OF THEIR EMPLOYEES, MAKES ANY WARRANTY, EXPRESS OR IMPLIED, OR ASSUMES ANY LEGAL LIABILITY OR RESPONSIBILITY FOR THE ACCURACY, COMPLETENESS, OR USEFULNESS OF ANY DATA, APPARATUS, PRODUCT, OR PROCESS DISCLOSED, OR REPRESENTS THAT ITS USE WOULD NOT INFRINGE PRIVATELY OWNED RIGHTS.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nrel.hive-1.1.0.tar.gz (1.0 MB view hashes)

Uploaded Source

Built Distribution

nrel.hive-1.1.0-py3-none-any.whl (1.1 MB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page