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/04/20 20:12] – [Step 1: Baseline Adaptive Systems] pvela | ece6554:project_ballbeam [2024/08/20 21:38] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 68: | Line 68: | ||
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. | ||
Line 78: | Line 78: | ||
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 // | 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 // | ||
- | === Nonlinear Version === | + | ==== Nonlinear Version |
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. | 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. | ||
Line 90: | Line 90: | ||
===== Step 2: Full Linear System (An Almost Backstepping Approach) ===== | ===== Step 2: Full Linear System (An Almost Backstepping Approach) ===== | ||
- | === Motor Control: Linear === | + | ==== 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)$ (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. | 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. | ||
Line 96: | Line 96: | ||
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, | 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, | ||
- | === Linear 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. | ||
+ | |||
+ | === 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:// 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.** | **This Step should not be done for ECE6554 Spring 2019. Only complete Steps 1 + 2.** | ||
Line 109: | Line 113: | ||
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. |
ece6554/project_ballbeam.1555805578.txt.gz · Last modified: 2024/08/20 21:38 (external edit)