Jump to content

Cushioned Oscillation: Difference between revisions

From mintOC
MaxWolff (talk | contribs)
Resetting an oscillating object in shortest time
 
 
(24 intermediate revisions by 4 users not shown)
Line 1: Line 1:
The Cushioned Oscillation is a simplified model of time optimal "stopping" of an oscillating object attached to a spring by applying a control and moving it back into the relaxed position and no velocity.
{{Dimensions
|nd        = 1
|nx        = 2
|nu        = 1
|nc        = 2
|nre      = 4
}}The Cushioned Oscillation is a simplified model of time optimal "stopping" of an oscillating object attached to a spring by applying a control and moving it back into the relaxed position and zero velocity.


== Model formulation ==  
== Model formulation ==  
Line 5: Line 11:
An object with mass <math> m </math> is attached to a spring with stiffness constant <math> c </math>.
An object with mass <math> m </math> is attached to a spring with stiffness constant <math> c </math>.


If the resetting spring force is proportional to the deviation <math>x=x(t)</math>, an oscillation induced by an external force <math>u(t)</math> satisfies:
If the resetting spring force is proportional to the deviation <math>x=x(t)</math>, an oscillation, induced by an external force <math>u(t)</math>, satisfies:




Line 12: Line 18:


where <math>x(t)</math> denotes the deviation to the relaxed position and <math> v(t)=\dot x (t) </math> the velocity of the oscillating object.
where <math>x(t)</math> denotes the deviation to the relaxed position and <math> v(t)=\dot x (t) </math> the velocity of the oscillating object.


Through external force, the object has been put into an initial state :
Through external force, the object has been put into an initial state :


<math>(x(0),v(0)) = (x_0,v_0)</math>
<math>(x(0),v(0)) = (x_0,v_0)</math>


The goal is to reset position and velocity of the object as fast as possible, meaning:
The goal is to reset position and velocity of the object as fast as possible, meaning:


 
<math>(x(t\mathrm{f}),v(t_\mathrm{f})) = (0,0)</math>,
<math>(x(t_f),v(t_f)) = (0,0)</math>,
 
 


with the objective function:
with the objective function:


<math>\min\limits_{t_\mathrm{f}} t_\mathrm{f}</math>


<math>\min\limits_{t_f} t_f</math>
== Optimal Control Problem Formulation ==
 
 
== Optimal Control Problem (OCP) Formulation ==


The above results in the following OCP  
The above results in the following OCP  


<math> \begin{array}{llll}


<math> \begin{array}{llr}
\min\limits_{x,v,u,t_\mathrm{f}}  & t_\mathrm{f} & & \\  
\min\limits_{x,v,u,t_f}  & t_f\\
 
s.t. & \dot x (t) = v(t), & \forall t \in [0,t_f]\\
 
& \dot v (t)= \frac{1}{m}(u(t) - cx(t)), & \forall t \in [0,t_f]\\
\\
                                                   
& x(0)=x_0,\\
 
& v(0)=v_0,\\
 
& x(t_f)=0,\\


& v(t_f)=0,\\
s.t. & \dot x & =  v,\\


& \dot v & =  \frac{1}{m}(u - c \cdot x),\\
\\
\\
& -u_{mm} \le u(t) \le u_{mm}, & \forall t \in [0,t_f]\\
& x(0) & =  x_0,\\
 
& v(0) & =  v_0,\\
 
& x(t_\mathrm{f}) & =  0,\\
& v(t_\mathrm{f}) & =  0,\\
& |u| & \le  u_\mathrm{mm}.\\
  \end{array}</math>
  \end{array}</math>
Line 64: Line 53:
== Parameters and Reference Solution ==
== Parameters and Reference Solution ==


The following parameters were used, to create the reference solution below, with an almost optimal final time <math> t_\mathrm{f} = 8.98 s</math>:


The following parameters were used, to create the reference solution below, with an almost optimal final time <math> t_f = 16.66 s</math>:
<math> m=5, </math>
 
<math> m=10, </math>
 
<math> c=10, </math>
<math> c=10, </math>
<math> x_0=2, </math>
<math> x_0=2, </math>
<math> v_0=5, </math>
<math> v_0=5, </math>
<math> u_\mathrm{mm}=5.</math>


<math> u_{mm}=5</math>
== Reference Solution ==


<gallery caption="Reference solution plots" widths="180px" heights="140px" perrow="1">
Image:Ref_sol_plot_cushioned_oscillation_m5.png| States and Controls
</gallery>


The OCP was solved within MATLAB R2015b, using the TOMLAB Optimization Package. PROPT reformulates such problems with the direct collocation approach (n=80 collocation points) and automatically finds a suiting solver included in the TOMLAB Optimization Package (in this case, SNOPT was used).


<gallery caption="Reference solution plots" widths="180px" heights="140px" perrow="1">
== Source Code ==
Image:ref_sol_plot_cushioned_oscillation.png| States and Controls
</gallery>


The OCP was solved within MATLAB R2015b, using the TOMLAB Optimization Package. PROPT reformulates such problems with the direct collocation approache and automatically finds a suiting solver included in the TOMLAB Optimization Package (in this case, SNOPT was used).
* A MATLAB script using [[:Category:TomDyn/PROPT | PROPT]] can be found in: [[Cushioned Oscillation (PROPT)]]


== References ==


[[Category:OCP]]
[[Category:MIOCP]]
[[Category:Bang bang]]
[[Category:ODE model]]
[[Category: Minimum time]]

Latest revision as of 13:26, 19 February 2026

Cushioned Oscillation
State dimension: 1
Differential states: 2
Continuous control functions: 1
Path constraints: 2
Interior point equalities: 4

The Cushioned Oscillation is a simplified model of time optimal "stopping" of an oscillating object attached to a spring by applying a control and moving it back into the relaxed position and zero velocity.

Model formulation

An object with mass m is attached to a spring with stiffness constant c.

If the resetting spring force is proportional to the deviation x=x(t), an oscillation, induced by an external force u(t), satisfies:


mv˙(t)+cx(t)=u(t) (which is equivalent to v˙(t)=1m(u(t)cx(t)))


where x(t) denotes the deviation to the relaxed position and v(t)=x˙(t) the velocity of the oscillating object.

Through external force, the object has been put into an initial state :

(x(0),v(0))=(x0,v0)

The goal is to reset position and velocity of the object as fast as possible, meaning:

(x(tf),v(tf))=(0,0),

with the objective function:

mintftf

Optimal Control Problem Formulation

The above results in the following OCP

minx,v,u,tftfs.t.x˙=v,v˙=1m(ucx),x(0)=x0,v(0)=v0,x(tf)=0,v(tf)=0,|u|umm.

Parameters and Reference Solution

The following parameters were used, to create the reference solution below, with an almost optimal final time tf=8.98s:

m=5, c=10, x0=2, v0=5, umm=5.

Reference Solution

The OCP was solved within MATLAB R2015b, using the TOMLAB Optimization Package. PROPT reformulates such problems with the direct collocation approach (n=80 collocation points) and automatically finds a suiting solver included in the TOMLAB Optimization Package (in this case, SNOPT was used).

Source Code

References