User Tools

Site Tools


ece6554:project_ballbeam

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
ece6554:project_ballbeam [2019/03/19 19:28] – [Step 3: Nonlinear Adaptive Backstepping] pvelaece6554:project_ballbeam [2024/08/20 21:38] (current) – external edit 127.0.0.1
Line 36: Line 36:
  
 Variables: Variables:
-\begin{equation} +^ Parameter ^ Value ^ 
-\begin{split} +| $m$ | 0.111 kg | 
-    & = 0.111 \\ +| $r$ | 0.015 m | 
-    & = 0.015; \\ +| $g$ | -9.8 m/s$^2$ | 
-    & = -9.8; \\ +| $L$ | 1.0 m | 
-    & = 1.0; \\  % d = 0.03; +| $J_b$ | 9.99e$^{-6}$ | 
-  J_b & = 9.99e^{-6}; +
-\end{split} +
-\end{equation}+
  
 ==== Adding Motor Dynamics==== ==== Adding Motor Dynamics====
Line 52: Line 50:
 \begin{split} \begin{split}
   J_m \ddot \theta & = K \iota - m_b g x \cos(\theta) - \dot \theta \\   J_m \ddot \theta & = K \iota - m_b g x \cos(\theta) - \dot \theta \\
-  \dot \iota & = V - \iota - K_e \dot \theta+  L_m \dot \iota & = V - R_m \iota - K_e \dot \theta
 \end{split}  \end{split} 
 \end{equation}    \end{equation}   
 where $\iota$ is the motor current, $V$ is the motor voltage, and some potential energy coupling from the ball/beam system is included in the motor angle dynamics. where $\iota$ is the motor current, $V$ is the motor voltage, and some potential energy coupling from the ball/beam system is included in the motor angle dynamics.
  
 +Variables:
 +Variables:
 +^ Parameter ^ Value ^
 +| $J_m$ | 0.043 |
 +| $K$ | 4.91 |
 +| $L_m$ | 0.0016 |
 +| $R_m$ | 4.7 |
 +| $K_e$ | 4.77 |
 +
 +Obtained from Wang (2007).
 ==== Stabilization and Tracking ==== ==== Stabilization and Tracking ====
  
 Stabilization of the system would be to some value $(x^*, 0)$ where the ball is on the beam and presumably the beam is not angled. The simplest stabilization would be to some time-varying signal $(x^*(t), \dot x^*(t))$ like a sinusoid or some rsteps like function where the magnitude of $x^*(t)$ is reasonable and time rate of change is likewise reasonably bounded. At this point, you should be able to pick reasonable tracking objectives for demonstrating the outcomes of your controllers, adaptive or otherwise. Stabilization of the system would be to some value $(x^*, 0)$ where the ball is on the beam and presumably the beam is not angled. The simplest stabilization would be to some time-varying signal $(x^*(t), \dot x^*(t))$ like a sinusoid or some rsteps like function where the magnitude of $x^*(t)$ is reasonable and time rate of change is likewise reasonably bounded. At this point, you should be able to pick reasonable tracking objectives for demonstrating the outcomes of your controllers, adaptive or otherwise.
-===== Activities =====+====== Activities ======
 ---------------------- ----------------------
  
-==== Step 1: Baseline Adaptive Systems ==== +===== Step 1: Baseline Adaptive Systems ===== 
-=== Linear Version ===+==== Linear Version ====
  
 Linearize the system about the zero set-point and derive a stabilizing linear controller for the ball-beam system.  Modify the parameters by about 20%, and show how the performance degrades versus knowing the ideal model. Create an adaptive controller that can improve the overall performance of the ball-beam system. Linearize the system about the zero set-point and derive a stabilizing linear controller for the ball-beam system.  Modify the parameters by about 20%, and show how the performance degrades versus knowing the ideal model. Create an adaptive controller that can improve the overall performance of the ball-beam system.
  
-=== Nonlinear Version ===+For this part, please run the versions with linear dynamics and with nonlinear dynamics. That means there will be four instances run based on the binary options of //dynamics// and //adaptive control// Since your control $u(t)$ is $\theta(t)$, you will naturally not have access to $\dot \theta$.  The way around this is to design the system in simulink and use a $d/dt$ block to obtain the derivative of the input for use as $\dot \theta$.  Until you get to the later steps, where the dynamics of $\theta$ are utilized, you'll have to use this particular cheat.
  
-Create a nonlinear adaptive controller that can improve the overall performance of the ball-beam system.+==== Nonlinear Version ====
  
-The nonlinearieties lie in the span of the control. Rewrite the equations so that this is the case and make sure to include the control defect in the equations arising from the sine function. +Create a nonlinear adaptive controller that should improve the overall performance of the ball-beam system. The nonlinearieties lie in the span of the control. Rewrite the equations so that this is the case and make sure to include the control defect in the equations arising from the sine function; basically try to think of the problem as a linear system plus a nonlinear defectProvide the massaged equations of motion. 
-Utilize a model inversion / feedback linearization technique on the true nonlinear system to arrive at a stable controller for the ball-beam system. I am going to request something funny. Add two additional states that will estimate $\theta$ and $\dot \theta$ given a measured input of $\theta = u$, the control.  The estimator equations should be the trivial second order dynamics. These two additional states will be tacked onto the adaptive system and will be used for the nonlinear regression problem associated to the model inversion cancelling term.  The parametrization is known in this case.+ 
 +Utilize a model inversion / feedback linearization technique on the true nonlinear system to arrive at a stable controller for the ball-beam system. For the true dynamics, you will continue to utilize the Simulink model designed in the earlier step. For the nonlinear control terms, you will deny yourself access to the true signals and will have to generate them another way. To be able to do this, I am going to request something funny. Add two additional states that will estimate $\theta$ and $\dot \theta$ given a measured input of $\theta = u$, the control.  The estimator equations should be the trivial second order dynamics. These two additional states will be tacked onto the adaptive system and will be used for the nonlinear regression problem associated to the model inversion cancelling term.  The parametrization is known in this case.
  
 Turn in your form of the equations for this particular case and the associated adaptive control equations. Turn in your form of the equations for this particular case and the associated adaptive control equations.
-Again, compare the perturbed system versus the true system response. +Again, compare the perturbed system versus the true system response. In this case the only binary variable is //adaptive control//, so I would expect to see two different types of runs. These runs should be performed with different types of signals, much like the homework stabilizes to a reference and tracks a target trajectory. Note that there is something of an algebraic loop in the problem as you are using the control to cancel out a nonlinearity **due to the control.**  That means you should not be so aggressive regarding the adaptive gains for the nonlinear cancellations, and you might want to be have a bit more damping than normal for the drift prevention terms.
  
 --------------------------------------- ---------------------------------------
-==== Step 2: Adaptive Backstepping ====+===== Step 2: Full Linear System (An Almost Backstepping Approach) =====
  
-=== Motor Control ===+==== Motor Control: Linear ====
  
-Add in the motor dynamics and have them be linearized around the steady-state. Work out what steady-state should be for a given non-zero target ball position $(x^*, 0)$. Have your trajectories also be relative to this position so that the linearization remains valid.  Work out a good controller for this fifth order system. Remember that you are controlling $x$ via $\theta$ which is controlled through $I$ which has the control $V$.+Add in the motor dynamics and have them be linearized around the steady-state. Work out what steady-state should be for a given non-zero target ball position $(x^*, 0)$ (it should be reasonably located, as in not too far out). Have your trajectories also be relative to this position so that the linearization remains valid.  Work out a good controller for this fifth order system. Remember that you are controlling $x$ via $\theta$ which is controlled through $I$ which has the control $V$.  Provide the $A$ and $B$ matrices.
  
-This linear system is looking a lot like a backstepping control, but where backstepping is usually not applied because the system should be controllable in the linearization. You can try to work out backstepping approach for the linearized dynamics if that seems most sensibleYou should relate to a linear controller though to continue.+This linear system is looking a lot like a backstepping control process, but where backstepping is usually not applied because the system should be controllable in the linearization. Since it is controllable in the linearization, all that is needed is to design stabilizing controller for the fifth order systemBe careful about how quickly things stabilize as the main objective is to properly control the ball, then to control the beam.
  
-=== Adaptive Control ===+==== Linear Adaptive Control ====
  
-Incorporate adaptive control to correct for the unmatched uncertainty. Randomly perturb by about 15% the parameters.+Incorporate adaptive control to correct for the unmatched uncertainty. Randomly perturb by about 15% the parameters.  Since the uncertainty is unmatched, you will have to work out a backstepping type of adaptive control law. The uncertainty hits the $\dot x$, $\dot \theta$, $\iota$ coordinates dynamics. Provide your derivation of the adaptive control law, the final set of equations, and simulations showing it in action. 
 + 
 +=== Tips: De-Coupled then Re-Coupled Adaptive Systems === 
 + 
 +//Tip:// Designing a fifth-order backstepping method is going to be pretty nasty, especially because of the dependency structure of things.  Instead, decouple the system into two parts.  One is the subsystem from Step 1 and the second is the new motor dynamics subsystem.  Design a backstepping controller for the new motor dynamics subsystem independent of the ball subsystem.  You will have to treat the ball signal as an external input in the decoupled system.  Go ahead and do that when synthesizing the backstepping control policy for the motor subsystem.  Get it to work out, then add on the adaptive ball system from Step 1.  This is not 100% correct/ideal, but it is much simpler than attempting a full backstepping design that will end up with lord knows how many differentiated signals. 
 + 
 +//Tip:// When designing the back-stepping type adaptive controller for the three new states, you should identify some candidate $x_1$ dynamics for the ball-beam part to be used in the motor controller. With $x_1$ specified in closed-form, the associated time derivatives can also be computed in closed form.  These should be used as exogenous signals in the linear, back-stepping type adaptive controller.  Later, when combining with the adaptive controller for the ball sub-system, you'll be trying to track the desired adaptive control law for the motor sub-system.
  
 --------------------------------------- ---------------------------------------
-==== Step 3: Nonlinear Adaptive Backstepping ====+===== Step 3: Nonlinear Adaptive Backstepping ====
 + 
 +**This Step should not be done for ECE6554 Spring 2019. Only complete Steps 1 + 2.**
  
 Translate the linear adaptive backstepping strategy to the nonlinear system. Start with the vanilla nonlinear backstepping method, then make it adaptive. Translate the linear adaptive backstepping strategy to the nonlinear system. Start with the vanilla nonlinear backstepping method, then make it adaptive.
  
-=== Nonlinear Model Inversion with Backstepping ===+==== Nonlinear Model Inversion with Backstepping ====
  
 Consider the nonlinearities of the system and identify a backstepping approach to controlling the system. Get the baseline backstepping method working.  It should resemble that of the linear controller from Step 2 but with nonlinear terms. Consider the nonlinearities of the system and identify a backstepping approach to controlling the system. Get the baseline backstepping method working.  It should resemble that of the linear controller from Step 2 but with nonlinear terms.
  
  
-=== Nonlinear Model Inversion with Adaptive Backstepping ==+==== Nonlinear Model Inversion with Adaptive Backstepping ====
  
 Add in adaptation to the backstepping controller, using the same 15% perturbed model. Add in adaptation to the backstepping controller, using the same 15% perturbed model.
Line 107: Line 124:
 ===== References ===== ===== References =====
 ---------------------- ----------------------
 +
 +
 +  * J. Hauser, S. Sastry, P. Kokotovic. "Nonlinear Control via Approximate Input-Output Linearization: The Ball and Beam Example." //IEEE Trans on Automatic Control//, 37(3):392-398, 1992. [[https://ieeexplore.ieee.org/document/119645 | IEEE Xplore]]
 +  * W. Wang. "Control of a Ball and Beam System," MS Thesis, University of Adelaide, 2007. [[ http://data.mecheng.adelaide.edu.au/robotics/projects/2007/BallBeam/Wei_Final_Thesis.pdf | pdf ]]
  
 ------ ------
ece6554/project_ballbeam.1553038106.txt.gz · Last modified: 2024/08/20 21:38 (external edit)