ece6554:project_ballbeam
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
ece6554:project_ballbeam [2019/03/19 20:26] – [References] pvela | ece6554: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 | |
- | m & = 0.111 \\ | + | | $r$ | 0.015 m | |
- | | + | | $g$ | -9.8 m/s$^2$ | |
- | g & = -9.8; \\ | + | | $L$ | 1.0 m | |
- | L & = 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 \\ | ||
- | | + | |
\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, | 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, | ||
- | ===== 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. | Linearize the system about the zero set-point and derive a stabilizing linear controller for 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 // |
- | Create a nonlinear adaptive controller that can 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. Provide the massaged equations of motion. | + | ==== Nonlinear Version ==== |
- | Utilize a model inversion / feedback linearization technique on the true nonlinear system to arrive at a stable controller for the ball-beam system. 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. | + | 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 defect. Provide 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. 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. | ||
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.** |
--------------------------------------- | --------------------------------------- | ||
- | ==== Step 2: Full Linear System (An Almost Backstepping Approach) ==== | + | ===== 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. | + | 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. |
- | 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. | + | This linear system is looking a lot like a backstepping control |
- | === Adaptive Control === | + | ==== Linear |
- | 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. | ||
+ | |||
+ | //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, | ||
--------------------------------------- | --------------------------------------- | ||
- | ==== 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. | Consider the nonlinearities of the system and identify a backstepping approach to controlling the system. Get the baseline backstepping method working. | ||
- | === 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 108: | Line 126: | ||
- | * J. Hauser, S. Sastry, P. Kokotovic. " | + | * J. Hauser, S. Sastry, P. Kokotovic. " |
+ | * W. Wang. " | ||
------ | ------ |
ece6554/project_ballbeam.1553041602.txt.gz · Last modified: 2024/08/20 21:38 (external edit)