Algorithmic Improvisation
Daniel J. Fremont
EECS Department, University of California, Berkeley
Technical Report No. UCB/EECS-2019-133
August 27, 2019
http://www2.eecs.berkeley.edu/Pubs/TechRpts/2019/EECS-2019-133.pdf
The increasing use of autonomy for safety-critical tasks, from operating power grids to driving cars, has led to an acute need for reliable and secure systems. The ideal approach to obtaining rigorous reliability guarantees is to automatically construct systems from formal specifications using <em>correct-by-construction synthesis</em>. A new dimension in this area is the synthesis of <em>randomized</em> systems, which, as we show in this thesis, enables a broad range of new applications in safe autonomy and other fields. This is because randomness can provide several crucial benefits to a system, including <em>robustness</em>, <em>variety</em>, and <em>unpredictability</em>. For example, a robot following a random route can be harder for an adversary to intercept, making the system more secure; a synthetic data generator for a machine learning algorithm can use randomness to produce diverse training data, making the ML model more robust. The key question, then, is <em>how can we automatically synthesize a system with random behavior but formal guarantees?</em> This thesis proposes a theory of <em>algorithmic improvisation</em> enabling the correct-by-construction synthesis of randomized systems, and explores its applications to safe autonomy.
The first part of the thesis studies the theory of algorithmic improvisation in depth. We begin by introducing the core computational problem of <em>control improvisation (CI)</em>, which requires constructing an <em>improviser</em>, a randomized algorithm generating sequences of symbols subject to hard, soft, and randomness constraints. We develop a general approach to building improvisers, instantiate it to obtain efficient synthesis algorithms in some cases, and prove hardness results for others. Next, we generalize CI to the <em>reactive control improvisation (RCI)</em> problem, which allows us to synthesize <em>open</em> systems that interact with an adversarial environment. We again give efficient algorithms for constructing <em>improvising strategies</em> in some useful cases, and hardness results in others. Finally, we investigate <em>language-based improvisation</em>, using a probabilistic programming language (PPL) to provide greater control over the distribution of the improviser. We design a <em>domain-specific PPL</em>, Scenic, for defining distributions over <em>scenes</em>, configurations of physical objects and agents. Scenic significantly decreases the effort required to specify the complex environments of systems like self-driving cars.
In the second part of the thesis, we demonstrate how algorithmic improvisation can help with the design, analysis, and testing of autonomous systems. First, we show how to synthesize <em>randomized planners for mobile robots</em>, for example a patrolling security robot which uses randomness to make its route less predictable while still guaranteeing safety. Next, we study using algorithmic improvisation to create <em>human models</em> with realistic stochasticity and tunable behavior, a vital prerequisite for the design of a system which interacts with people. Finally, we propose a methodology for using language-based improvisation to train, test, and debug cyber-physical systems like autonomous cars by <em>generating synthetic data</em> from customizable distributions. We apply our methodology to an industrial neural network, finding bugs in the system, eliminating them through retraining, and boosting the performance of the network beyond what could be achieved with prior techniques by using Scenic to design training sets in a more intelligent way.
In summary, algorithmic improvisation is a mathematical framework for synthesizing randomized systems satisfying formal specifications. It has already proved useful in a wide range of fields, including robotics, cyber-physical systems, computer music, and machine learning, and shows promise in a variety of further applications to the design of secure and dependable systems.
Advisors: Sanjit Seshia
BibTeX citation:
@phdthesis{Fremont:EECS-2019-133, Author= {Fremont, Daniel J.}, Title= {Algorithmic Improvisation}, School= {EECS Department, University of California, Berkeley}, Year= {2019}, Month= {Aug}, Url= {http://www2.eecs.berkeley.edu/Pubs/TechRpts/2019/EECS-2019-133.html}, Number= {UCB/EECS-2019-133}, Abstract= {The increasing use of autonomy for safety-critical tasks, from operating power grids to driving cars, has led to an acute need for reliable and secure systems. The ideal approach to obtaining rigorous reliability guarantees is to automatically construct systems from formal specifications using <em>correct-by-construction synthesis</em>. A new dimension in this area is the synthesis of <em>randomized</em> systems, which, as we show in this thesis, enables a broad range of new applications in safe autonomy and other fields. This is because randomness can provide several crucial benefits to a system, including <em>robustness</em>, <em>variety</em>, and <em>unpredictability</em>. For example, a robot following a random route can be harder for an adversary to intercept, making the system more secure; a synthetic data generator for a machine learning algorithm can use randomness to produce diverse training data, making the ML model more robust. The key question, then, is <em>how can we automatically synthesize a system with random behavior but formal guarantees?</em> This thesis proposes a theory of <em>algorithmic improvisation</em> enabling the correct-by-construction synthesis of randomized systems, and explores its applications to safe autonomy. The first part of the thesis studies the theory of algorithmic improvisation in depth. We begin by introducing the core computational problem of <em>control improvisation (CI)</em>, which requires constructing an <em>improviser</em>, a randomized algorithm generating sequences of symbols subject to hard, soft, and randomness constraints. We develop a general approach to building improvisers, instantiate it to obtain efficient synthesis algorithms in some cases, and prove hardness results for others. Next, we generalize CI to the <em>reactive control improvisation (RCI)</em> problem, which allows us to synthesize <em>open</em> systems that interact with an adversarial environment. We again give efficient algorithms for constructing <em>improvising strategies</em> in some useful cases, and hardness results in others. Finally, we investigate <em>language-based improvisation</em>, using a probabilistic programming language (PPL) to provide greater control over the distribution of the improviser. We design a <em>domain-specific PPL</em>, Scenic, for defining distributions over <em>scenes</em>, configurations of physical objects and agents. Scenic significantly decreases the effort required to specify the complex environments of systems like self-driving cars. In the second part of the thesis, we demonstrate how algorithmic improvisation can help with the design, analysis, and testing of autonomous systems. First, we show how to synthesize <em>randomized planners for mobile robots</em>, for example a patrolling security robot which uses randomness to make its route less predictable while still guaranteeing safety. Next, we study using algorithmic improvisation to create <em>human models</em> with realistic stochasticity and tunable behavior, a vital prerequisite for the design of a system which interacts with people. Finally, we propose a methodology for using language-based improvisation to train, test, and debug cyber-physical systems like autonomous cars by <em>generating synthetic data</em> from customizable distributions. We apply our methodology to an industrial neural network, finding bugs in the system, eliminating them through retraining, and boosting the performance of the network beyond what could be achieved with prior techniques by using Scenic to design training sets in a more intelligent way. In summary, algorithmic improvisation is a mathematical framework for synthesizing randomized systems satisfying formal specifications. It has already proved useful in a wide range of fields, including robotics, cyber-physical systems, computer music, and machine learning, and shows promise in a variety of further applications to the design of secure and dependable systems.}, }
EndNote citation:
%0 Thesis %A Fremont, Daniel J. %T Algorithmic Improvisation %I EECS Department, University of California, Berkeley %D 2019 %8 August 27 %@ UCB/EECS-2019-133 %U http://www2.eecs.berkeley.edu/Pubs/TechRpts/2019/EECS-2019-133.html %F Fremont:EECS-2019-133