Randal W. Beard, Timothy W. McLain Cammy Peterson Marc Killpack James Usevitch
Hardcopy available on Amazon
PDF Version of Book - A PDF version of the book is available at this link. - When typos are found, they will be fixed and the most recent version of the book will be posted here. - Please send typos and other suggestions to [email protected].
(Under construction) The following lecture materials are included as a resource for instructors. The slides closely follow the book. We welcome suggestions on how these slides might be improved.
Chapter | PDF Slides | Powerpoint | Last Modified |
---|---|---|---|
Chapter 1 - Introduction | chapter1.pdf | chapter1.pptx | Sept 2019 |
Chapter 2 - Kinetic Energy | chapter2.pdf | chapter2.pptx | Sept 2021 |
Chapter 3 - Euler Lagrange | chapter3.pdf | chapter3.pptx | Sept 2021 |
Equations of Motion + Physics Engine | eom.pdf | eom.pptx | Jan 2023 |
Chapter 4 - Linearization | chapter4.pdf | chapter4.pptx | Sept 2021 |
Chapter 5 - Transfer Function Models | chapter5.pdf | chapter5.pptx | Jan 2023 |
Chapter 6 - State Space Models | chapter6.pdf | chapter6.pptx | Jan 2023 |
Chapter 7 - Second Order Systems | chapter7.pdf | chapter7.pptx | Jan 2023 |
Chapter 8 - Second Order Design | chapter8.pdf | chapter8.pptx | Jan 2023 |
Chapter 9 - Integrators | chapter9.pdf | chapter9.pptx | Feb 2023 |
Chapter 10 - Digital PID | chapter10.pdf | chapter10.pptx | Feb 2023 |
Chapter 11 - Full State Feedback | chapter11.pdf | chapter11.pptx | Feb 2023 |
Chapter 12 - Full State with Integrators | chapter12.pdf | chapter12.pptx | Feb 2023 |
Chapter 13 - Observers | chapter13.pdf | chapter13.pptx | March 2023 |
Chapter 14 - Disturbance Observers | chapter14.pdf | chapter14.pptx | March 2023 |
Chapter 15 - Frequency Response | chapter15.pdf | chapter15.pptx | March 2023 |
Chapter 16 - Frequency Specifications | chapter16.pdf | chapter16.pptx | March 2023 |
Chapter 17 - Robustness Margins | chapter17.pdf | chapter17.pptx | April 2023 |
Chapter 18 - Compensator Design | chapter18.pdf | chapter18.pptx | Nov 2021 |
This GitHub account contains complete Python solutions to the three design problems presented in the book. We will be actively maintaining the Python solutions.
Matlab and Simulink solutions are also available upon request.
Note that homework solutions may need to be slightly altered to fit the current semester's code. For example, in Winter 2024, the code base was altered so that the dataplotter
function needed to have its reference signals thrown in at the end of the list of declared variables instead of in the middle, as in previous years.
The lab description and assignments are described in the hummingbird lab manual, which can be accessed below. The manual will be updated as needed. See the Learning Suite copy if there is a discrepancy.
Template files for the hummingbird simulation are contained in the GitHub directory "_hummingbird_sim."
Template files for the hummingbird hardware lab are contained in the GitHub directory "_hummingbird_lab."
You will want to install an IDE. We recommend either:
If Pycharm is chosen, see the following link for information on how to get a free JetBrains license through BYU.
See the Controls setup PDF found in this repo (Setting_Up_Controlbook_Code_and_Python_Environment_for_ME_EN_431___EC_EN_483.pdf
) for how to set everything up.
For TAs and teachers: The LateX project folder has also been included for easy editing later.
Note that if PyCharm was downloaded instead of VS Code, the section on downloading VSCode in Controls_code_setup.pdf
can be skipped.
See this link for a great introduction from BYU ACME's program.
More Python tutorial can be found on the main ACME website.
This section can be skipped if you followed Setting_Up_Controlbook_Code_and_Python_Environment_for_ME_EN_431___EC_EN_483.pdf
The following python packages will need to be installed for this class:
- numpy
- slipy
- matplotlib
- control
- pyqtgraph
- pyqt6
- pyopengl
In linux or macos, you can install a python package using the command
pip3 install name_of_package
If you are using Pycharm, the following options are available:
- Open Settings>Project:python>Python Interpreter. Make sure that the latest python interpreter is selected at the top, and then click "+" do add a package and search for the needed package. For example:
- Alternatively, you may use this requirements file to download all the necessary dependencies.
To install these dependencies, simply use the command:
pip3 install -r requirements.txt
NOTE: Pycharm sets up a virtual environment for you, so if you are using Pycharm, instructions on venv can be skipped.
The Jupyter notebooks in this repository were developed by Dr. Robert Leishman at Air Force Institute of Technology.
They are designed to be run in google colab.
The Final Exam is a comprehensive coding final.
A practice final, created by Dr. Beard in Winter 2020 and updated in Winter 2023, is found in this repository.
There is no answer key available to students or TAs for this practice final.
The final exam is almost exactly like the practice exam and so we hope that giving you a similar exam will help you study for the final. If you can figure out how to do the practice exam, you will do just fine on the final.
- Case Study E: Once PD control and Full State Feedback are implemented, it will be tempted to think that the reason that the code is breaking is because of tuning gains. Rest assured, even on case study E, that the problem is not with tuning gains. Modifying the gains only tweaks how the system performs, not whether or not it performs at all.
On that note, if you are having issues with Case Study E (which is the hardest case study to implement in this class), review the answer keys to Chapter 4 and Chapter 6 for all 6 systems and you will realize that Case Study E is the only Case study to completely implement the following:
- equilibrium state xe
- equilibrium force Fe
- feedback linearization (with both of these)
Make sure you know the difference between these 3 terms.
And again, review the answer keys to chapters 4 and 6.
- "If number 1 is true, why are my rise times and zeta values different from the answer key? How did they find those rise times and zetas?" This is a legitimate question that has baffled many students who have not only used the correct equations to find their starting rise times and omegas, but also took the extra time to not simply assume that ζ (zeta) = 0.707 and ω = 2.2/tr . Some answer keys show ζ = 0.95.
The short answer? Tuning.
The long answer? After a system is working with the ζ and tr values one would naturally assume, based on the problem description, repetitively halving tr values will slowly increase the speed at which the system arrives at the reference point, which may be desired in some systems. Additionally, ζ (the variable in charge of dampening power) may be increased somewhat if one desires to make the system arrive at the reference point faster, or simply make the plot look nicer.
Once your system is working, following this process will help you get the tuning paramemters you see in the answer keys.
- Mixing Array for Case Study F: The mixing array for Force and Torque in Case Study F might be slighty off, depending on class branch:
unmixing = np.array([[1.0, 1.0], [-d, d]]) # converts fl and fr (LR) to force and torque (FT)
where it should be:
unmixing = np.array([[1.0, 1.0], [d, -d]]) # converts fl and fr (LR) to force and torque (FT)
-
Dynamics of Mechanical Systems: Make sure to read the dynamic system correctly! Know which variable is in reference to which. For example, is φ in reference to the Y axis or in reference to θ? How does that change the dynamics?
-
Sympy and other symbolic solvers: There are several symbolic solvers in Python such as Sympy that are usually allowed on tests. Learning these libraries can be helpful. See
_B_pendulum/python/hw03_pendulum_solving_for_state_variable_form.py
for an example. -
Block Diagrams: We use block diagrams to represent a controls system in terms of its input variables, desired signal (reference), and output variables. Be familiar with both modified and unmodified systems, and how to do the math to solve for the output of the system in any scenario.
-
Laplace Transformations: Some may have forgotten from their Differential Equations class how to do Laplace Transformations. Review what they are and how to solve them if you feel you have forgotten them.
-
Dataplotter helper file: Different versions of the class use different versions of the dataplotter helper file that creates simulations for each case study. The most recent versions require their
update
function to place theref
variable last, since it has a default value. The answer keys do not reflect this. That's on purpose: aside from the pain of constantly updating answer keys, it has commonly been the job of the student to incorporate the answer key to their own system and homework to see what they could do better. Indeed, some answer keys are inpdf
form instead ofpy
format to force the student to read code line by line.
So, if you have dataplotter.update
errors, consider moving the ref
variable to be the last variable.
-
Case study similarities: Case Study A is similar in initial setup to Case Study D. Case Study B is similar in setup to Case Study E. Case Study F is almost like a combination of Case Study D and Case Study E in one system. That being said, each system has different dynamics, linearization properties, and parameter requirements. Make sure you understand each system individually, and that you go beyond simply copy-pasting code from one system to another.
-
Switching positive and minus signs: Whether on a test, a homework problem, or a line of code, the most pervasive error may be switching positive and minus signs. Don't be one of those people who makes that mistake!
-
What is a state? Different robotics and controls applications have different states. Know what variables belong in the system state for this class, and which do not.
-
"Why do point masses note have a moment of inertia in this class?" From Wikipedia (see link to the article here), "Point mass M at a distance r from the axis of rotation. ... A point mass does not have a moment of inertia around its own axis, but using the parallel axis theorem a moment of inertia around a distant axis of rotation is achieved."
-
"The book says that for the controllability matrix to be square, the system needs to be single input. It also says that for the observability matrix to be square, the system needs to be single output. We can't do that for a lot of our systems, and so we use place from the control library. We can't use the control library on tests. How would we do that on a test?" In general, the controllability and observability matrices are not square for MIMO systems. You can still check the rank of the controllability / observability matrices, but you won't be asked to apply Ackermann's formula to a MIMO (Multiple Input, Multiple Output) system. As shown in class, it only applys to SISO (Single Input, Single Output) systems.
-
"I don't understand what a Lagrangian is and why it is what it is. Can you help me understand?" Here is a video explaining the history and proof of Lagrangians: https://www.youtube.com/watch?v=Q10_srZ-pbs
-
"I don't have much background in Python. Am I really able to do this class?" Yes! You will need to learn different features of
numpy
andsympy
, among other libraries, but have patience, and you will get this! You've got this!
There is also a playground.py
file included for experimenting with Python code.
- "With all of the homework solution files we get, there are just too many files! How do I organize everything I am trying to put in my
controlbook
folder?" In the past, code for each case study homework was organized into individual folders within the case study's python folder. This was accomplished by something like this to the top of the Python simulation script:
import os, sys
from pathlib import Path
num_directories_up = 1
sys.path.insert(0, os.fspath(Path(__file__).parents[num_directories_up])) # add parent directory
Then, some complained about the folder structure, and the whole thing was removed.
If you want to have a folder structure like that to organize your homework files, feel free to use the above lines of code.