diff --git a/.nojekyll b/.nojekyll
index d4c7d3f..5820e42 100644
--- a/.nojekyll
+++ b/.nojekyll
@@ -1 +1 @@
-2a85fde5
\ No newline at end of file
+465962d1
\ No newline at end of file
diff --git a/classes_PWA 7.html b/classes_PWA 7.html
new file mode 100644
index 0000000..9c84379
--- /dev/null
+++ b/classes_PWA 7.html
@@ -0,0 +1,1190 @@
+
+
This is a subclass of switched systems where the functions on the right-hand side of the differential equations are affine functions of the state. For some (historical) reason these systems are also called piecewise linear (PWL).
+
We are going to reformulate such systems as switched systems with state-driven switching.
+
First, we consider the autonomous case, that is, systems without inputs:
+\dot{\bm x}
+=
+\begin{cases}
+\bm A_1 \bm x + \bm b_1, & \mathrm{if}\, \bm H_1 \bm x + \bm g_1 \leq 0,\\
+\vdots\\
+\bm A_m \bm x + \bm b_m, & \mathrm{if}\, \bm H_m \bm x + \bm g_m \leq 0.
+\end{cases}
+
+
The nonautonomous case of systems with inputs is then:
+\dot{\bm x}
+=
+\begin{cases}
+\bm A_1 \bm x + \bm B_1 u + \bm c_1, & \mathrm{if}\, \bm H_1 \bm x + \bm g_1 \leq 0,\\
+\vdots\\
+\bm A_m \bm x + \bm B_m + \bm c_m, & \mathrm{if}\, \bm H_m \bm x + \bm g_m \leq 0.
+\end{cases}
+
+
+
Example 1 (Linear system with saturated linear state feedback) In this example we consider a linear system with a saturated linear state feedback as in Fig 1.
+
+
+
+
The state equations for the close-loop system are
+\dot{\bm x} = \bm A\bm x + \bm b \,\mathrm{sat}(v), \quad v = \bm k^T \bm x,
+ which can be reformulated as a piecewise affine system
+\dot{\bm x} =
+\begin{cases}
+\bm A \bm x - \bm b, & \mathrm{if}\, \bm x \in \mathcal{X}_1,\\
+(\bm A + \bm b \bm k^\top )\bm x, & \mathrm{if}\, \bm x \in \mathcal{X}_2,\\
+\bm A \bm x + \bm b, & \mathrm{if}\, \bm x \in \mathcal{X}_3,\\
+\end{cases}
+ where the partitioning of the space of control inputs is shown in Fig 2.
+
+
+
+
Expressed in the state space, the partitioning is
+\begin{aligned}
+\mathcal{X}_1 &= \{\bm x \mid \bm H_1\bm x + g_1 \leq 0\},\\
+\mathcal{X}_2 &= \{\bm x \mid \bm H_2\bm x + \bm g_2 \leq 0\},\\
+\mathcal{X}_3 &= \{\bm x \mid \bm H_3\bm x + g_3 \leq 0\},
+\end{aligned}
+ where
+\begin{aligned}
+\bm H_1 &= \bm k^\top, \quad g_1 = 1,\\
+\bm H_2 &= \begin{bmatrix}-\bm k^\top\\\bm k^\top\end{bmatrix}, \quad \bm g_2 = \begin{bmatrix}-1\\-1\end{bmatrix},\\
+\bm H_3 &= -\bm k^\top, \quad g_3 = 1.
+\end{aligned}
+
+
+
+
Approximation of nonlinear systems
+
While the example with the saturated linear state feedback can be modelled as a PWA system exactly, there are many practical cases, in which the system is not exactly PWA affine but we want to approximate it as such.
+
+
Example 2 (Nonlinear system approximated by a PWA system) Consider the following nonlinear system
+\begin{bmatrix}
+\dot x_1\\\dot x_2
+\end{bmatrix}
+=
+\begin{bmatrix}
+x_2\\
+-x_2 |x_2| - x_1 (1+x_1^2)
+\end{bmatrix}
+
+
Our task is to approximate this system by a PWA system. Equivalently, we need to find a PWA approximation for the right-hand side function.
Switched systems are modelled by first-order differential (state) equations with multiple right-hand sides, that is,
+
+\dot{\bm x} = \bm f_q(\bm x), \qquad q \in \{1,2, \ldots, m\},
+\tag{1} where m right-hand sides are possible and the lower index q determines which right-hand side function is “active” at a given moment.
+
The question is, what dictates the evolution of the integer variable q? In other words, what drives the switching? It turns out that the switching can be time-driven or state-driven.
+
In both cases, the right-hand sides can also depend the control input \bm u.
+
Major results for switched systems have been achieved without the need to refer to the framework of hybrid systems. But now that we have built such general framework, it turns out useful to view switched systems as a special class of hybrid systems. The aspects in which they are special will be discussed in the following, but here let us state that in contrast to full hybrid systems, switched systems are a bit less rich on the discrete side.
+
+
Time-driven
+
The evolution of the state variable complies with the following model \dot{\bm x} = \bm f_{q(t)}(\bm x), where q(t) is some function of time. The values of q(t) can be under our control or beyond our control, deterministic or stochastic.
+
A hybrid automaton for a time-driven switched system is shown in Fig 1.
+
+
+
+
The transition from one mode to another is triggered by the integer variable q(t) attaining the appropriate value.
+
Since the switching signal is unrelated to the (continuous) state of the system, the invariant of the two modes are usually covering the whole state space \mathcal X.
+
+
+
State-dependent switching
+
The model is
+\dot{\bm x}
+=
+\begin{cases}
+\bm f_1(\bm x), & \mathrm{if}\, \bm x \in \mathcal{X}_1,\\
+\vdots\\
+\bm f_m(\bm x), & \mathrm{if}\, \bm x \in \mathcal{X}_m.
+\end{cases}
+
+
Let’s consider just two domains \mathcal X_1 and \mathcal X_2. A hybrid automaton for a state-driven switched system is shown in Fig 2.
+
+
+
+
The transition to the other mode is triggered by the continuous state of the system crossing the boundary between the two domains. The boundary is defined by the function s(\bm x) (called switching function), which is zero on the boundary, see the Fig 3.
+
+
+
+
Through examples we now illustrate the possible behaviors of the system when the flow transverses the boundary, when it pulls away from the boundary, and when it pushes towards the boundary.
+
+
Example 1 (The flow transverses the boundary) We consider the two right-hand sides of the state equation
+\bm f_1(\bm x) = \begin{bmatrix}1\\ x_1^2 + 2x_2^2\end{bmatrix}
+ and
+\bm f_2(\bm x) = \begin{bmatrix}1\\ 2x_1^2+3x_2^2-2\end{bmatrix}
+ and the switching function
+s(x_1,x_2) = (x_1+0.05)^2 + (x_2+0.15)^2 - 1.
+
+
The state portrait that also shows the switching function is generated using the following code.
The state portrait also shows a particular initial state \bm x_0 using a blue dot. Note that the projection of both vector fields \mathbf f_1 and \mathbf f_2 evaluated at \bm x_0 onto the normal (the gradient) of the switching function at \bm x_0 is positive, that is
+\left.\left(\nabla s\right)^\top \bm f_1\right|_{\bm x_0} \geq 0, \quad \left.\left(\nabla s\right)^\top \bm f_2\right|_{\bm x_0} \geq 0.
+
+
This is consistent with the observation that the flow goes through the boundary.
+
We can also plot a particular solution of the ODE using the following code.
Strictly speaking, this solution does not satisfy the differential equation on the boundary of the two domains (the derivative of x_2 does not exist there). This is visually recognized in the above plot as the sharp corner in the solution. But other than that, the solution is perfectly “reasonable” – for a while the system evolves according to one state equations, then at one particular moment the system starts evolving according to another state equation. That is it. Not much more to see here.
+
+
+
Example 2 (The flow pulls away from the boundary) We now consider another pair of the right-hand sides.
+\bm f_1(\bm x) = \begin{bmatrix}-1\\ x_1^2 + 2x_2^2\end{bmatrix}
+ and
+\bm f_2(\bm x) = \begin{bmatrix}1\\ 2x_1^2+3x_2^2-2\end{bmatrix}.
+
+
The switching function is the same as in the previous example.
We focus on the blue dot again. The projections of the two vector fields onto the normal of the switching function satisfy
+\left.\left(\nabla s\right)^\top \bm f_1\right|_{\bm x_0} \leq 0, \quad \left.\left(\nabla s\right)^\top \bm f_2\right|_{\bm x_0} \geq 0.
+
+
The only interpretation of this situation is that a unique solution does not start at \bm x_0. Again, not much more to see here.
+
+
+
Example 3 (The flow pushes towards the boundary) And one last pair of the right-hand sides:
+\bm f_1(\bm x) = \begin{bmatrix}1\\ x_1^2 + 2x_2^2\end{bmatrix}
+ and
+\bm f_2(\bm x) = \begin{bmatrix}-1\\ 2x_1^2+3x_2^2-2\end{bmatrix}.
+
The projections of the two vector fields onto the normal of the switching function satisfy
+\left.\left(\nabla s\right)^\top \bm f_1\right|_{\bm x_0} \geq 0, \quad \left.\left(\nabla s\right)^\top \bm f_2\right|_{\bm x_0} \leq 0.
+
+
But this is interesting! Once the trajectory hits the switching curve and tries to penetrate it futher, it is pushed back to the switching curve. As it tries to penetrate it further, it is pushed back to the switching curve again. And so on. But then, how does the state evolve from \bm x_0?
+
Hint: solve the ODE numerically with some finite step size. The solution will exhibit zig-zagging or chattering along the switching curve, away from the blue point. Now, keep shrinking the step size. The solution will ultimately “slide” smoothly along the switching curve. Perhaps this was your guess. One thing should worry you, however: such “sliding” solution satisfies neither of the two state equations!
+
We will make this more rigorous in a moment, but right now we just wanted to tease the intuition.
+
+
+
+
Conditions for existence and uniqueness of solutions of ODE
+
In order to analyze the situations such as the previous example, we need to recapitulate some elementary facts about the existence and uniqueness of solutions of ordinary differential equations (ODEs). And then we are going to add some new stuff.
+
Consider the ODE
+
\dot x(t) = f(x(t),t).
+
We ask the following two questions:
+
+
Under which conditions does a solution exists?
+
Under which conditions is the solution unique?
+
+
To answer both, the function f() must be analyzed.
+
But before we answer the two questions, we must ask another one that is even more fundamental:
+
+
What does it mean that a function x(t) is a solution of the the ODE?
+
+
However trivial this question may seem, an answer can escalate rather quickly – there are actually several concepts of a solution of an ordinary differential equation.
+
+
Classical solution (Peano, also Cauchy-Peano)
+
We assume that f(x(t),t) is continuous with respect to both x and t. Then existence of a solution is guaranteed locally (on some finite interval), but uniqueness is not.
+
+
+
+
+
+
+Not guaranteed does not mean impossible
+
+
+
+
Uniqueness is not not excluded in all cases, it is just that it is not guaranteed.
+
+
+
A solution is guaranteed to be continuously differentiable ( x\in\mathrm C^1 ). Such function x(t) satisfies the ODE \dot x(t) = f(x(t),t) \; \forall t, that is why such solution is called classical.
+
+
Example 4 An example of a solution that exists only on a finite interval is
+ \dot x(t) = x^2(t),\; x(0) = 1,
+
+for which the solution is x(t) = \frac{1}{1-t} . The solution blows up at t=1 .
+
+
+
Example 5 An example of nonuniqueness is provided by \dot x(t) = \sqrt{x(t)}, \; x(0) = 0.
+
One possible solution is x(t) = \frac{1}{4}t^2. Another is x(t) = 0. Yet another example is x(t) = \frac{1}{4}(t-t_0)^2. It is related to the Leaky bucket example.
+
+
+
+
Strenghtening the requirement of continuity (Pickard-Lindelöf)
+
Since continuity of f(x(t),t) was not enough to guarantee uniqueness, we need to impose a stricter condition on f(). Namely, we impose a stricter condition on f() with respect to x – Lipschitz continuity, while we still require that the function be continuous with respect to t.
+
Now it is not only existence but also uniqueness of a solution that is guaranteed.
+
+
+
+
+
+
+Uniqueness not guaranteed does not mean it is impossible
+
+
+
+
Similarly as with Peano conditions, here too the condition is not necessary, it is just sufficient – even if the function f is not Lipschitz continuous, there may exist a unique solution.
+
+
+
Since the condition is stricter than mere continuity, whatever goodies hold here too. In particular, the solution is guaranteed to be continuously differentiable.
+
If the function is only locally Lipschitz, the solution is guaranteed on some finite interval. If the function is (globally) Lipschitz, the solution is guaranteed on an unbounded interval.
+
+
+
Extending the set of solutions (Carathéodory)
+
In contrast with the classical solution, we can allow the solution x(t) to fail to satisfy the ODE at some isolated points in time. This is called Carathéodory (or extended) solution.
+
Carathéodory solution x(t) is more than just continuous (even more than uniformly continuous) but less than contiuously differentiable (aka \mathcal C^1) – it is absolutely continuous. Absolutely continuous function is a solution of the integral equation (indeed, an equation) x(t) = x(t_0) + \int_{t_0}^t f(x(\tau),\tau)\mathrm{d}\tau,
+where we use Lebesgue integral (instead of Riemann).
+
Having referred to absolute continuity and Lebesgue integral, the discussion could quickly become rather technical. But all we want to say is that f can be “some kind of discontinuous” with respect to t. In particular, it must be measurable wrt t, which again seems to start escalating… But it suffices to say that it includes the case when f(x,t) is piecewise continuous with respect to t (sampled data control with ZOH).
+
Needles to say that for a continuous f, solutions x are just classical (smooth).
+
If the function f is discontinuous with respect to x, some more concepts of a solution need to be invoked so that existence and uniqueness can be analyzed.
+
+
Example 6 (Some more examples of nonexistence and nonuniqueness of solutions) The system with a discontinuous RHS
+\begin{aligned}
+\dot x_1 &= -2x_1 - 2x_2\operatorname*{sgn(x_1)},\\
+\dot x_2 &= x_2 + 4x_1\operatorname*{sgn(x_1)}
+\end{aligned}
+ can be reformulated as a switched system
+\begin{aligned}
+\dot{\bm x} &= \begin{bmatrix}-2 & 2\\-4 & 1\end{bmatrix}\begin{bmatrix}x_1\\ x_2\end{bmatrix}, \quad s(\bm x)\leq 0\\
+\dot{\bm x} &= \begin{bmatrix}-2 & -2\\4 & 1\end{bmatrix}\begin{bmatrix}x_1\\ x_2\end{bmatrix}, \quad s(\bm x)> 0,
+\end{aligned}
+ where the switching function is s(\bm x) = x_1.
The previous example provided yet another illustration of a phenomenon of sliding, or a sliding mode. We say that there is an attractive sliding mode at \bm x_\mathrm{s}, if there is a trajectory that ends at \bm x_\mathrm{s}, but no trajectory that starts at \bm x_\mathrm{s}.
+
+
+
Generalized solutions (Filippov)
+
It is now high time to introduce yet another concept of a solution. A concept that will make it possible to model the sliding mode dynamics in a more rigorous way. Remember that when the state \bm x(t) slides along the boundary, it qualifies as a solution to neither of the two state equations in any sense we have discussed so far. But now comes the concept of Fillipov solution.
+
\bm x() is a Filippov solution on [t_0,t_1] if for almost all t
+\dot{\bm{x}}(t) \in \overline{\operatorname*{co}}\{\mathbf f(\bm x(t),t)\},
+ where \overline{\operatorname*{co}} denotes the (closed) convex hull.
+
+
Example 7 Consider the model in the previous example. The switching surface, along which the solution slides, is given by \mathcal{S}^+ = \{\bm x \mid x_1=0 \land x_2\geq 0\}.
Note, however, that not all the weights keep the solution on \mathcal S^+. We must impose some restriction, namely that \dot x_1 = 0 for \bm x(t) \in \mathcal S^+. This leads to
+\alpha_1(t) [-2x_1 + 2x_2] + \alpha_2(t) [-2x_1 - 2x_2] = 0
+
+
Combining this with \alpha_1(t) + \alpha_2(t) = 1 gives
+\alpha_1(t) = \alpha_2(t) = 1/2,
+ which in this simple case perhaps agrees with our intuition (the average of the two vector fields).
+
The dynamics on the sliding mode is modelled by
+\dot x_1 = 0, \quad \dot x_2 = x_2, \quad \bm x \in \mathcal{S}^+.
+
+
+
+
+
+
+
+
+Possible nonuniqueness on intersection of boundaries
+
Concise (short and yet sufficient for our purposes) introduction to (linear) complementarity problems and systems is in [1]. Besides describing the idea of complementarity in dynamical systems, it also shows how it is related to other modeling frameworks for hybrid dynamical systems. More detailed and yet very accessible introduction is in the thesis [2]. Condensed treatment is in the papers [3] and [4].
+
A readable introduction to the Extended Linear Complementarity Problem is in [5] (it is also freely available as a technical report).
+
The topics of complementarity constraints in dynamical systems and optimization is still being actively researched. A recent publication on QP optimization with complementarity constraints (LCQP) is [6].
+
Numerical methods for nonsmooth dynamical systems that are based on complementary constraints (and implemented in SICONOS software) are comprehensively presented in [7].
W. P. M. H. Heemels, B. De Schutter, and A. Bemporad, “Equivalence of hybrid dynamical models,”Automatica, vol. 37, no. 7, pp. 1085–1091, Jul. 2001, doi: 10.1016/S0005-1098(01)00059-0.
W. P. M. H. Heemels, J. M. Schumacher, and S. Weiland, “Linear Complementarity Systems,”SIAM Journal on Applied Mathematics, vol. 60, no. 4, pp. 1234–1269, Jan. 2000, doi: 10.1137/S0036139997325199.
+
+
+
[4]
A. J. van der Schaft and J. M. Schumacher, “Complementarity modeling of hybrid systems,”IEEE Transactions on Automatic Control, vol. 43, no. 4, pp. 483–490, Apr. 1998, doi: 10.1109/9.664151.
+
+
+
[5]
B. De Schutter and B. De Moor, “The Extended Linear Complementarity Problem and the Modeling and Analysis of Hybrid Systems,” in Hybrid Systems V, P. Antsaklis, M. Lemmon, W. Kohn, A. Nerode, and S. Sastry, Eds., in Lecture Notes in Computer Science. Berlin, Heidelberg: Springer, 1999, pp. 70–85. doi: 10.1007/3-540-49163-5_4.
+
+
+
[6]
J. Hall, A. Nurkanovic, F. Messerer, and M. Diehl, “LCQPow – A Solver for Linear Complementarity Quadratic Programs.” arXiv, Nov. 2022. Accessed: Dec. 03, 2022. [Online]. Available: http://arxiv.org/abs/2211.16341
+
+
+
[7]
V. Acary and B. Brogliato, Numerical Methods for Nonsmooth Dynamical Systems: Applications in Mechanics and Electronics. in Lecture Notes in Applied and Computational Mechanics, no. 35. Berlin Heidelberg: Springer, 2008. Available: https://doi.org/10.1007/978-3-540-75392-6
┌ Warning: Found `resolution` in the theme when creating a `Scene`. The `resolution` keyword for `Scene`s and `Figure`s has been deprecated. Use `Figure(; size = ...` or `Scene(; size = ...)` instead, which better reflects that this is a unitless size and not a pixel resolution. The key could also come from `set_theme!` calls or related theming functions.
+└ @ Makie ~/.julia/packages/Makie/pFPBw/src/scenes.jl:238
Example continued: how fast does the solution approach the origin?
+
+
Let’s use the 1-norm \|\bm x\|_1 = |x_1| + |x_2| to measure how far the trajectory is from the origin.
+
How fast does the trajectory converge to the origin? That, is
+\frac{\mathrm d}{\mathrm dt}\|\bm x\|_1 = ?
+
+
Consider each quadrant separately. Let’s start in the first (upper right) quadrant, that is, x_1>0 and x_2>0, and therefore |x_1| = x_1, \;|x_2| = x_2, and therefore
Instead solving the above nasty equations, introduce new variables u_1 and u_2 as the outcomes of the \operatorname{sign} functions:
+\begin{aligned}
+{\color{blue} x_{1,k+1}} &= x_{1,k} + h (-{\color{blue}u_{1}} + 2 {\color{blue}u_{2}})\\
+{\color{blue} x_{2,k+1}} &= x_{1,k} + h (-2{\color{blue}u_{1}} - {\color{blue}u_{2}})
+\end{aligned}
+
+
But now we have to enforce the relation between \bm u and \bm x_{k+1}.
+
Recall the standard definition of the \operatorname{sign} function:
+\operatorname{sign}(x) = \begin{cases}
+1 & x>0\\
+0 & x=0\\
+-1 & x<0
+\end{cases}
+
+
Change the definition to a set-valued function
+\begin{cases}
+\operatorname{sign}(x) = 1 & x>0\\
+\operatorname{sign}(x) \in [-1,1] & x=0\\
+\operatorname{sign}(x) = -1 & x<0
+\end{cases}
+
+
Accordingly, set the relation between \bm u and \bm x
+\begin{cases}
+u_1 = 1 & x_1>0\\
+u_1 \in [-1,1] & x_1=0\\
+u_1 = -1 & x_1<0
+\end{cases}
+ and
+\begin{cases}
+u_2 = 1 & x_2>0\\
+u_2 \in [-1,1] & x_2=0\\
+u_2 = -1 & x_2<0
+\end{cases}
+
How does the set of states from which the next state is zero look like?
+\begin{aligned}
+-\begin{bmatrix}
+-1 & 2 \\
+-2 & -1
+\end{bmatrix}^{-1}
+\begin{bmatrix}
+x_{1,k}\\
+x_{2,k}
+\end{bmatrix}
+&= h
+\begin{bmatrix}
+{\color{blue}u_{1}}\\
+{\color{blue}u_{2}}
+\end{bmatrix}\\
+-1 \leq {\color{blue} u_1} \leq 1, \quad -1 &\leq {\color{blue} u_2} \leq 1
+\end{aligned}
+