Hybrid system

A hybrid system is a dynamical system that exhibits both continuous and discrete dynamic behavior – a system that can both flow (described by a differential equation) and jump (described by a state machine or automaton). Often, the term "hybrid dynamical system" is used, to distinguish over hybrid systems such as those that combine neural nets and fuzzy logic, or electrical and mechanical drivelines. A hybrid system has the benefit of encompassing a larger class of systems within its structure, allowing for more flexibility in modeling dynamic phenomena.

In general, the state of a hybrid system is defined by the values of the continuous variables and a discrete mode. The state changes either continuously, according to a flow condition, or discretely according to a control graph. Continuous flow is permitted as long as so-called invariants hold, while discrete transitions can occur as soon as given jump conditions are satisfied. Discrete transitions may be associated with events.

Examples
Hybrid systems have been used to model several cyber-physical systems, including physical systems with impact, logic-dynamic controllers, and even Internet congestion.

Bouncing ball
A canonical example of a hybrid system is the bouncing ball, a physical system with impact. Here, the ball (thought of as a point-mass) is dropped from an initial height and bounces off the ground, dissipating its energy with each bounce. The ball exhibits continuous dynamics between each bounce; however, as the ball impacts the ground, its velocity undergoes a discrete change modeled after an inelastic collision. A mathematical description of the bouncing ball follows. Let $$x_1$$ be the height of the ball and $$x_2$$ be the velocity of the ball. A hybrid system describing the ball is as follows:

When $$x \in C = \{x_1 > 0\}$$, flow is governed by $$ \dot{x}_1 = x_2, \dot{x}_2 = -g $$, where $$g$$ is the acceleration due to gravity. These equations state that when the ball is above ground, it is being drawn to the ground by gravity.

When $$x \in D = \{x_1 = 0\}$$, jumps are governed by $$ x_1^+ = x_1, x_2^+ = -\gamma x_2 $$, where $$0 < \gamma < 1$$ is a dissipation factor. This is saying that when the height of the ball is zero (it has impacted the ground), its velocity is reversed and decreased by a factor of $$\gamma$$. Effectively, this describes the nature of the inelastic collision.

The bouncing ball is an especially interesting hybrid system, as it exhibits Zeno behavior. Zeno behavior has a strict mathematical definition, but can be described informally as the system making an infinite number of jumps in a finite amount of time. In this example, each time the ball bounces it loses energy, making the subsequent jumps (impacts with the ground) closer and closer together in time.

It is noteworthy that the dynamical model is complete if and only if one adds the contact force between the ground and the ball. Indeed, without forces, one cannot properly define the bouncing ball and the model is, from a mechanical point of view, meaningless. The simplest contact model that represents the interactions between the ball and the ground, is the complementarity relation between the force and the distance (the gap) between the ball and the ground. This is written as $$ 0 \leq \lambda \perp x_1 \geq 0. $$ Such a contact model does not incorporate magnetic forces, nor gluing effects. When the complementarity relations are in, one can continue to integrate the system after the impacts have accumulated and vanished: the equilibrium of the system is well-defined as the static equilibrium of the ball on the ground, under the action of gravity compensated by the contact force $$\lambda$$. One also notices from basic convex analysis that the complementarity relation can equivalently be rewritten as the inclusion into a normal cone, so that the bouncing ball dynamics is a differential inclusion into a normal cone to a convex set. See Chapters 1, 2 and 3 in Acary-Brogliato's book cited below (Springer LNACM 35, 2008). See also the other references on non-smooth mechanics.

Hybrid systems verification
There are approaches to automatically proving properties of hybrid systems (e.g., some of the tools mentioned below). Common techniques for proving safety of hybrid systems are computation of reachable sets, abstraction refinement, and barrier certificates.

Most verification tasks are undecidable, making general verification algorithms impossible. Instead, the tools are analyzed for their capabilities on benchmark problems. A possible theoretical characterization of this is algorithms that succeed with hybrid systems verification in all robust cases implying that many problems for hybrid systems, while undecidable, are at least quasi-decidable.

Other modeling approaches
Two basic hybrid system modeling approaches can be classified, an implicit and an explicit one. The explicit approach is often represented by a hybrid automaton, a hybrid program or a hybrid Petri net. The implicit approach is often represented by guarded equations to result in systems of differential algebraic equations (DAEs) where the active equations may change, for example by means of a hybrid bond graph.

As a unified simulation approach for hybrid system analysis, there is a method based on DEVS formalism in which integrators for differential equations are quantized into atomic DEVS models. These methods generate traces of system behaviors in discrete event system manner which are different from discrete time systems. Detailed of this approach can be found in references [Kofman2004] [CF2006] [Nutaro2010] and the software tool PowerDEVS.

Simulation

 * HyEQ Toolbox: Hybrid system solver for MATLAB and Simulink
 * PowerDEVS: General-purpose tool for DEVS (Discrete Event System) modeling and simulation oriented to the simulation of hybrid systems

Reachability

 * Ariadne: C++ library for (numerically rigorous) reachability analysis of nonlinear hybrid systems
 * CORA: A MATLAB Toolbox for reachability analysis of cyber-physical systems, including hybrid systems
 * Flow*: A tool for reachability analysis of nonlinear hybrid systems
 * HyCreate: A tool for overapproximating reachability of hybrid automata
 * HyPro: C++ library for state set representations for hybrid systems reachability analysis
 * JuliaReach: A toolbox for set-based reachability

Temporal Logic and Other Verification

 * C2E2: Nonlinear hybrid system verifier
 * HyTech: Model checker for hybrid systems
 * HSolver: Verification tool for hybrid systems
 * KeYmaera: Theorem prover for hybrid systems
 * PHAVer: Polyhedral hybrid automaton verifier
 * S-TaLiRo: MATLAB toolbox for verification of hybrid systems with respect to temporal logic specifications

Other

 * SCOTS: Tool for the synthesis of correct-by-construction controllers for hybrid systems
 * SpaceEx: State-space explorer