Roadrunner: Simulating Traffic with Mapbox, Redis, and Kubernetes

Remember “Snowpocalypse”? About 10 years ago, Atlanta faced a surprising blizzard that brought the city to a standstill. What started as a normal workday turned into a city-wide parking lot as everyone tried to leave work simultaneously. This event inspired Roadrunner, an open-source application designed to simulate exactly this kind of scenario.

Roadrunner leverages the power of Mapbox for generating realistic driving routes and Redis for efficient data sharing across multiple server instances. Imagine simulating thousands of cars attempting to navigate Atlanta’s roads during a sudden snowstorm – that’s the kind of problem Roadrunner is built to tackle.

How Roadrunner Works

Roadrunner simulates vehicles driving between two points using real-world directions from Mapbox. It accurately reflects the expected speed limits and travel times, providing a realistic simulation of traffic flow.

Here’s a breakdown of the key components:

  • Roadrunner server: This is the engine of the simulation, generating traffic data based on Mapbox routes and storing it efficiently using Redis. It also utilizes Java Topology Suite (JTS) and Proj4j to handle complex geospatial calculations and coordinate conversions, ensuring accurate positioning of vehicles as they move along their routes.
  • Roadrunner viewer: This provides a visual representation of the simulation, allowing you to observe the traffic patterns and identify potential bottlenecks or problem areas.  It also allows you to “jump” into a vehicle to see what a driver would see.
  • Roadrunner k8s orchestration: This component facilitates deployment and management of Roadrunner using Terraform, enabling scalability and efficient resource utilization.
Roadrunner Viewer Home page
Roadrunner Viewer Home page
Roadrunner Viewer Driver page
Roadrunner Viewer Driver page

Current Development and Future Plans

Roadrunner is still in its early stages, but development continues to add capabilities. Currently, vehicles don’t interact with each other, but that’s about to change. We’re working on enabling interactions between nearby vehicles by ensuring they run on the same node, paving the way for more complex and realistic simulations.

We’re also developing autoscaling functionality based on real-time traffic load within each node. A metrics endpoint is already in place, providing crucial data on execution times to inform the autoscaling process.

Licensing

Roadrunner is open source, but we’re still finalizing the specific licensing details. While MIT License is a strong contender, we need to ensure it aligns with the licensing requirements of included packages like JTS and Proj4j. We’ll provide a definitive update on licensing soon.

Get Involved

Roadrunner is an ongoing project with ambitious goals. We welcome contributions and feedback from the open-source community. Check out the GitHub repositories to explore the code, contribute new features, or report issues.

Links:

Leave a Reply