# Design Criteria to Architect Continuous Experimentation for Self-Driving   Vehicles

**Authors:** Federico Giaimo, Christian Berger

arXiv: 1705.05170 · 2017-06-13

## TL;DR

This paper explores design criteria and architectural strategies to enable continuous experimentation in self-driving vehicle software, facilitating ongoing software evolution in complex cyber-physical systems.

## Contribution

It introduces specific design requirements and a deployment process for self-driving car software architecture to support continuous experimentation.

## Key findings

- Proposed a set of design criteria for continuous experimentation
- Described a software architecture tailored for self-driving vehicles
- Outlined a development and deployment process for ongoing software updates

## Abstract

The software powering today's vehicles surpasses mechatronics as the dominating engineering challenge due to its fast evolving and innovative nature. In addition, the software and system architecture for upcoming vehicles with automated driving functionality is already processing ~750MB/s - corresponding to over 180 simultaneous 4K-video streams from popular video-on-demand services. Hence, self-driving cars will run so much software to resemble "small data centers on wheels" rather than just transportation vehicles. Continuous Integration, Deployment, and Experimentation have been successfully adopted for software-only products as enabling methodology for feedback-based software development. For example, a popular search engine conducts ~250 experiments each day to improve the software based on its users' behavior. This work investigates design criteria for the software architecture and the corresponding software development and deployment process for complex cyber-physical systems, with the goal of enabling Continuous Experimentation as a way to achieve continuous software evolution. Our research involved reviewing related literature on the topic to extract relevant design requirements. The study is concluded by describing the software development and deployment process and software architecture adopted by our self-driving vehicle laboratory, both based on the extracted criteria.

## Full text

_Full body text omitted from this summary view._ Fetch the complete paper as Markdown: https://tomesphere.com/paper/1705.05170/full.md

## Figures

2 figures with captions in the complete paper: https://tomesphere.com/paper/1705.05170/full.md

## References

21 references — full list in the complete paper: https://tomesphere.com/paper/1705.05170/full.md

---
Source: https://tomesphere.com/paper/1705.05170