Autonomous Mobile Robot Design

Similar documents
Dr Ian R. Manchester Dr Ian R. Manchester AMME 3500 : Review

João P. Hespanha. January 16, 2009

Autonomous Mobile Robot Design

Outline. Classical Control. Lecture 1

Contents. PART I METHODS AND CONCEPTS 2. Transfer Function Approach Frequency Domain Representations... 42

Contents. 1 State-Space Linear Systems 5. 2 Linearization Causality, Time Invariance, and Linearity 31

Video 5.1 Vijay Kumar and Ani Hsieh

Learn2Control Laboratory

Feedback Control of Linear SISO systems. Process Dynamics and Control

Control Systems. Design of State Feedback Control.

State Regulator. Advanced Control. design of controllers using pole placement and LQ design rules

AMME3500: System Dynamics & Control

Linear State Feedback Controller Design

Linear System Theory. Wonhee Kim Lecture 1. March 7, 2018

Control Systems I. Lecture 7: Feedback and the Root Locus method. Readings: Jacopo Tani. Institute for Dynamic Systems and Control D-MAVT ETH Zürich

Controls Problems for Qualifying Exam - Spring 2014

Control Systems Lab - SC4070 Control techniques

Dynamic Response. Assoc. Prof. Enver Tatlicioglu. Department of Electrical & Electronics Engineering Izmir Institute of Technology.

Topic # Feedback Control Systems

Course Outline. Higher Order Poles: Example. Higher Order Poles. Amme 3500 : System Dynamics & Control. State Space Design. 1 G(s) = s(s + 2)(s +10)

CYBER EXPLORATION LABORATORY EXPERIMENTS

ẋ n = f n (x 1,...,x n,u 1,...,u m ) (5) y 1 = g 1 (x 1,...,x n,u 1,...,u m ) (6) y p = g p (x 1,...,x n,u 1,...,u m ) (7)

Digital Control Engineering Analysis and Design

Dr Ian R. Manchester Dr Ian R. Manchester AMME 3500 : Root Locus

ELEC4631 s Lecture 2: Dynamic Control Systems 7 March Overview of dynamic control systems

Control Systems I. Lecture 6: Poles and Zeros. Readings: Emilio Frazzoli. Institute for Dynamic Systems and Control D-MAVT ETH Zürich

Return Difference Function and Closed-Loop Roots Single-Input/Single-Output Control Systems

MECH 6091 Flight Control Systems Final Course Project

Analysis and Synthesis of Single-Input Single-Output Control Systems

Chapter 7 Control. Part Classical Control. Mobile Robotics - Prof Alonzo Kelly, CMU RI

LQR, Kalman Filter, and LQG. Postgraduate Course, M.Sc. Electrical Engineering Department College of Engineering University of Salahaddin

Control Systems I Lecture 10: System Specifications

R a) Compare open loop and closed loop control systems. b) Clearly bring out, from basics, Force-current and Force-Voltage analogies.

Lecture 5: Linear Systems. Transfer functions. Frequency Domain Analysis. Basic Control Design.

Table of Laplacetransform

Topic # Feedback Control

CDS 110b: Lecture 2-1 Linear Quadratic Regulators

Answers to multiple choice questions

DESIGN AND DEVELOPMENT OF THE LQR OPTIMAL CONTROLLER FOR THE UNMANNED AERIAL VEHICLE

ECSE 4962 Control Systems Design. A Brief Tutorial on Control Design

Mech 6091 Flight Control System Course Project. Team Member: Bai, Jing Cui, Yi Wang, Xiaoli

Übersetzungshilfe / Translation aid (English) To be returned at the end of the exam!

Control Systems II. ETH, MAVT, IDSC, Lecture 4 17/03/2017. G. Ducard

Overview of the Seminar Topic

State Space Control D R. T A R E K A. T U T U N J I

Topic # Feedback Control Systems

Design Methods for Control Systems

Lecture 9. Introduction to Kalman Filtering. Linear Quadratic Gaussian Control (LQG) G. Hovland 2004

Advanced Aerospace Control. Marco Lovera Dipartimento di Scienze e Tecnologie Aerospaziali, Politecnico di Milano

CHAPTER 1 Basic Concepts of Control System. CHAPTER 6 Hydraulic Control System

1 An Overview and Brief History of Feedback Control 1. 2 Dynamic Models 23. Contents. Preface. xiii

Index. Index. More information. in this web service Cambridge University Press

Process Modelling, Identification, and Control

Chapter 2 Review of Linear and Nonlinear Controller Designs

Course roadmap. Step response for 2nd-order system. Step response for 2nd-order system

Modeling and Control Overview


EL2520 Control Theory and Practice

ESC794: Special Topics: Model Predictive Control

MASSACHUSETTS INSTITUTE OF TECHNOLOGY Department of Mechanical Engineering 2.04A Systems and Controls Spring 2013

Inverted Pendulum: State-Space Methods for Controller Design

Lecture plan: Control Systems II, IDSC, 2017

AA/EE/ME 548: Problem Session Notes #5

Analysis of Discrete-Time Systems

EE C128 / ME C134 Final Exam Fall 2014

ECE317 : Feedback and Control

KINGS COLLEGE OF ENGINEERING DEPARTMENT OF ELECTRONICS AND COMMUNICATION ENGINEERING

Control Systems I. Lecture 5: Transfer Functions. Readings: Emilio Frazzoli. Institute for Dynamic Systems and Control D-MAVT ETH Zürich

Quadrotor Modeling and Control

Control of Manufacturing Processes

Richiami di Controlli Automatici

Here represents the impulse (or delta) function. is an diagonal matrix of intensities, and is an diagonal matrix of intensities.

Aircraft Stability & Control

MODERN CONTROL DESIGN

Exam. 135 minutes + 15 minutes reading time

Homework 7 - Solutions

Problem Set 4 Solution 1

Process Control & Instrumentation (CH 3040)

Analysis of Discrete-Time Systems

EE C128 / ME C134 Feedback Control Systems

Time Response of Systems

Introduction to Feedback Control

ECEn 483 / ME 431 Case Studies. Randal W. Beard Brigham Young University

(b) A unity feedback system is characterized by the transfer function. Design a suitable compensator to meet the following specifications:

Automatic Control II Computer exercise 3. LQG Design

Positioning Servo Design Example

EE C128 / ME C134 Fall 2014 HW 8 - Solutions. HW 8 - Solutions

Control of Mobile Robots

Control Systems I. Lecture 2: Modeling. Suggested Readings: Åström & Murray Ch. 2-3, Guzzella Ch Emilio Frazzoli

INTRODUCTION TO DIGITAL CONTROL

ECE317 : Feedback and Control

Systems Analysis and Control

D(s) G(s) A control system design definition

FATIMA MICHAEL COLLEGE OF ENGINEERING & TECHNOLOGY

Problem Value Score Total 100/105

A Comparative Study on Automatic Flight Control for small UAV

Dr Ian R. Manchester

Lecture 2: Discrete-time Linear Quadratic Optimal Control

Robot Dynamics - Rotary Wing UAS: Control of a Quadrotor

MAE 142 Homework #5 Due Friday, March 13, 2009

Transcription:

Autonomous Mobile Robot Design Topic: Guidance and Control Introduction and PID Loops Dr. Kostas Alexis (CSE)

Autonomous Robot Challenges How do I control where to go?

Autonomous Mobile Robot Design Topic: Basic principles and prerequisites for control Dr. Kostas Alexis (CSE)

What is it all about? Control theory is an interdisciplinary branch of engineering and mathematics that deals with the behavior of dynamical systems with inputs, and how their behavior is modified by feedback.

What is it all about? Control theory is an interdisciplinary branch of engineering and mathematics that deals with the behavior of dynamical systems with inputs, and how their behavior is modified by feedback. To do that in a systematic way, we should develop a model-based approach on control synthesis.

1. Modeling of Dynamic Systems Generic form of dynamic system: x is the state vector, u is the input vector. Generic linear state space form: And given specific output vector:

State Space Representation Generic linear (time invariant) state space form: A is the system matrix (nxn), B is the input matrix (nxp), C is the output matrix (qxn), D is the feedforward matrix (qxp). In general a MIMO system (Multi-Input, Multi-Output) In fact a Linear Time Invariant system (LTI). More complex representations exist.

Transfer Function Representation Linear time invariant can be represented in the frequency domain using the Laplace Transform. Laplace Transform: Transfer function form to represent Single Input Single Output (SISO) relationships: And equivalently: p 1 p n correspond to the poles and z 1 z m to the zeros.

State Space to Transfer Function Transformation from state space to transfer function: Possibly leads to multiple transfer functions

Dynamic system example System ordinary differential equation: Or in state space form: Or in transfer function form:

2. Analysis of Dynamic Systems Time-Domain Response of an LTI system Frequency-Domain Response of an LTI system Stability of an LTI system

Time-Domain Response The time response of a linear dynamic system consists of the sum of the transient response which depends on the initial conditions and the steadystate response which depends on the system input. These correspond to the free (homogeneous or zero input) and the forced (inhomogeneous or non-zero input) solutions of the governing differential equations respectively.

Frequency-Domain Response All the examples presented in this tutorial are modeled by linear constant coefficient differential equations and are thus linear time-invariant (LTI). LTI systems have the extremely important property that if the input to the system is sinusoidal, then the steady-state output will also be sinusoidal at the same frequency but in general with different magnitude and phase. These magnitude and phase differences as a function of frequency comprise the frequency response of the system. The frequency response of a system can be found from the transfer function in the following way: create a vector of frequencies (varying between zero or "DC" to infinity) and compute the value of the plant transfer function at those frequencies. If G(s) is the open-loop transfer function of a system and ω is the frequency vector, we then plot G(jω) versus ω. Since G(jω) is a complex number, we can plot both its magnitude and phase (the Bode Plot) or its position in the complex plane (the Nyquist Diagram). Both methods display the same information in different ways.

Stability Bounded Input Bounded Output (BIBO) sense: a system is stable if the output remains bounded for all bounded (finite) inputs. Practically, this means that the system will not blow up while in operation. Using transfer functions: the system is stable if ALL of the poles are in the left complex plane. If any of them is on the right then the system is unstable. If any of them has zero real component, the system is critically stable.

Stability Bounded Input Bounded Output (BIBO) sense: a system is stable if the output remains bounded for all bounded (finite) inputs. Practically, this means that the system will not blow up while in operation. Using transfer functions: the system is stable if ALL of the poles are in the left complex plane. If any of them is on the right then the system is unstable. If any of them has zero real component, the system is critically stable. Stable region

Stability Bounded Input Bounded Output (BIBO) sense: a system is stable if the output remains bounded for all bounded (finite) inputs. Practically, this means that the system will not blow up while in operation. Using transfer functions: the system is stable if ALL of the poles are in the left complex plane. If any of them is on the right then the system is unstable. If any of them has zero real component, the system is critically stable. Unstable region

Stability Bounded Input Bounded Output (BIBO) sense: a system is stable if the output remains bounded for all bounded (finite) inputs. Practically, this means that the system will not blow up while in operation. Using transfer functions: the system is stable if ALL of the poles are in the left complex plane. If any of them is on the right then the system is unstable. If any of them has zero real component, the system is critically stable. Critical stability

Stability Bounded Input Bounded Output (BIBO) sense: a system is stable if the output remains bounded for all bounded (finite) inputs. Practically, this means that the system will not blow up while in operation. Using transfer functions: the system is stable if ALL of the poles are in the left complex plane. If any of them is on the right then the system is unstable. If any of them has zero real component, the system is critically stable. Stable region oscillations No oscillations oscillations

1 st Order Systems First order system representation: With pole a, time constant τ and dcgain k dc Time constant is the value that the system reaches 63% of its steady-state value.

2 nd Order Systems First order system representation: Or in transfer function form: dcgain: damping ratio: (if ζ < 1 system is underdamped) natural frequency: poles/zeros:

2 nd Order Systems Pole map

2 nd Order Systems Time response

3. The Root Locus Method Consider a transfer function and a gain K: The closed-loop transfer function takes the form: Thus the closed-loop poles are the solutions of: And if we write: Then the poles are the solutions of:

Root Locus Method example Consider the transfer function:

Root Locus Method example Consider the transfer function: Use a single-gain Controller (K):

Root Locus Method example Consider the transfer function: Root locus for a gain K:

5. State Space Control Consider the system: How do we define observability? How do we define controllability? How do we design a simple controller to tune the dynamic response as desired? To place the poles where desired?

State Space system Stability Consider the system: Stability: The system is stable if the eigenvalues of matrix A are all with negative real part.

State Space system Observability Consider the system: Observability: The system is observable if the initial state x 0 can be determined from the system output, y(t), over some finite time t 0 < t < t f. For LTI systems, a system is observable if the observability matrix is of full rank.

Rank of a Matrix The rank of a matrix A is the dimension of the vector space generated (or spanned) by its columns. This is the same as the dimension of the space spanned by its rows. Rank row = Rank column It is a measure of the "nondegenerateness" of the system of linear equations and linear transformation encoded by A. 1 2 1 2 3 1 3 5 0

Rank of a Matrix The rank of a matrix A is the dimension of the vector space generated (or spanned) by its columns. This is the same as the dimension of the space spanned by its rows. Rank row = Rank column It is a measure of the "nondegenerateness" of the system of linear equations and linear transformation encoded by A. 1 2 1 2 3 1 3 5 0 Rank = 2

State Space system Controllability Consider the system: Controllability: A system is controllable if there exists a control input, u(t), that transfers any state of the system to zero in finite time. For LTI systems, a system is controllable if the controllability matrix is of full rank.

Pole Placement Consider the system: Then the following structure is correct:

Pole Placement Assuming zero reference: The state space equations of the closed loop system take the form: The pole placement techniques is about how to find the gain matrix K such that the poles of the closed-loop system go to desired locations. This is under the assumption of an LTI system and infinite actuator dynamic range and bandwidth.

Autonomous Mobile Robot Design Topic: PID Flight Control for Multirotors Dr. Kostas Alexis (CSE)

MAV Dynamics To append the forces and moments we need to combine their formulation with Next step: append the MAV forces and moments

MAV Dynamics MAV forces in the body frame: Moments in the body frame:

MAV Dynamics MAV forces in the body frame: Moments in the body frame:

Control System Block Diagram There are simpler

Control System Block Diagram Simplified loop

Controlling a Multirotor along the x-axis Assume a single-axis case. The system has to coordinate its pitching motion and thrust to move to the desired point ahead of its axis. Roll is considered to be zero, yaw is considered to be constant. No initial velocity. No motion is expressed in any other axis. A system of only two degrees of freedom.

Controlling a Multirotor along the x-axis Simplified linear dynamics

Controlling a Multirotor along the x-axis Explanation of translation model

Controlling a Multirotor along the x-axis Simplified linear dynamics How does this system behave?

Controlling a Multirotor along the x-axis

Controlling a Multirotor along the x-axis

Controlling a Multirotor along the x-axis Simplified linear dynamics How to control this system? Most common way: use of PD controllers

Controlling a Multirotor along the x-axis Decoupled Control Structure

Controlling a Multirotor along the x-axis Decoupled Control Structure How to select the PD gains?

A mini introduction to PID Control PID = Proportional-Integral-Derivative feedback control It corresponds to one of the most commonly used controllers used in industry. It's success is based on its capacity to efficiently and robustly control a variety of processes and dynamic systems, while having an extremely simple structure and intuitive tuning procedures. Not comparable in performance with modern control strategies, but still the most common starting point How to select the PD gains?

Controlling a Multirotor along the x-axis MATLAB Implementation

Controlling a Multirotor along the x-axis MATLAB Implementation

Controlling a Multirotor along the x-axis

Controlling a Multirotor along the x-axis MATLAB Implementation

Controlling a Multirotor along the x-axis

Controlling a Multirotor along the x-axis MATLAB Implementation

Controlling a Multirotor along the x-axis

Real-life Limitations The control margins of the aerial vehicle have limits and therefore the PID controller has to be designed account for these constraints. The integral term needs special caution due to the often critically stable or unstable characteristics expressed by unmanned aircraft. With the exception of hover/or trimmed-flight, an aerial vehicle is a nonlinear system. As the PID is controller, it naturally cannot maintain an equally good behavior for the full flight envelope of the system. A variety of techniques such as Gain scheduling are employed to deal with this fact.

Autonomous Mobile Robot Design Topic: LQR Flight Control for Multirotors Dr. Kostas Alexis (CSE)

Controlling a Multirotor along the x-axis Assume a single-axis multirotor. The system has to coordinate its pitching motion and thrust to move to the desired point ahead of its axis. Roll is considered to be zero, yaw is considered to be constant. No initial velocity. No motion is expressed in any other axis. A system of only two degrees of freedom.

Controlling a Multirotor along the x-axis Simplified linear dynamics How does this system behave?

Optimal Model-Based Control Use model knowledge to design optimal control behaviors. The employed model must be simultaneously sufficiently accurate but also simple enough to enable efficient control computation. Optimal control can support linear and nonlinear systems as well as systems subject to state, output and input constraints. Further extensions (e.g. for hybrid systems) also exist. Established method for unconstrained linear systems regulation: Linear Quadratic Regulator (LQR) Generalization: Linear Quadratic Gaussian (LQG) control

Linear Quadratic Regulator Consider the system and suppose we want to design state feedback control u=fx to stabilize the system. The design of F is a trade-off between the transit response and the control effort. The optimal control approach to this design trade-off is to define the performance index (cost functional): and search for the control u=fx that minimizes this index. Q is an nxm symmetric positive semidefinite matrix and R is an mxm symmetric positive definite matrix.

Linear Quadratic Regulator The matrix Q can be written as Q=M T M, where M is a pxn matrix, with p n. With this representation: Where z=mx can be viewed as a controlled input. Optimal Control Problem: Find u(t)=fx(t) to maximize J subject to the model: Since J is defined by an integral over, the first question we need to address is: Under what conditions will J exist and be finite?

Write J as: Linear Quadratic Regulator is a monotonically increasing function of t f. Hence, as either converges to a finite limit or diverges to infinity. Under what conditions will be finite?

Linear Quadratic Regulator Recall that (A,B) is stabilizable if the uncontrollable eigenvalues of A, if any, have negative real parts. Notice that (A,B) is stabilizable if (A,B) is controllable or Definition: (A,C) is detectable if the observable eigenvalues of A, if any, have negative real parts. Lemma 1: Suppose (A,B) is stabilizable, (A,M) is detectable, where Q=M T M, and u(t)=fx(t). Then, J is finite for every if and only if:

Remarks: Linear Quadratic Regulator The need for (A,B) to be stabilizable is clear, for otherwise there would be no F such that: To see why detectability of (A,M) is needed, consider: (A,B) is controllable, but (A,M) is not detectable The control is clearly optimal and results in a finite J but it does not stabilize the system because

Linear Quadratic Regulator Lemma 2: For any stabilizing control u(t)=fx(t), the cost given by: where W is a symmetric positive semidefinite matrix that satisfies the Lyapunov equation: Remark: The control u(t)=fx(t) is stabilizing if:

Linear Quadratic Regulator Theorem: Consider the system: and the performance index: where Q=M T M, R is symmetric and positive definite, (A,B) is stabilizable, and (A,M) is detectable. The optimal control is: where P is the symmetric positive semidefinite solution of the Algebraic Riccati Equation (ARE):

Remarks: Linear Quadratic Regulator Since the control is stabilizing: The control is optimal among all square integratable signals u(t), not just among u(t)=fx(t) The Ricatti equation can have multiple solutions, but only one of them is positive semidefinite.

Linear Quadratic Regulator Typical penalty matrices selection: t si is the desired settling time of xi x imax is a constraint on x i u imax is a constraint on u i ρ is chosen to tradeoff regulation versus control effort

Linear Quadratic Regulator LQR Loop (F=K)

MATLAB Design Example Recall:

MATLAB Design Example

MATLAB Design Example

MATLAB Design Example [K,S,e] = dlqr(a,b,q,r,n)

MATLAB Design Example

MATLAB Design Example

MATLAB Design Example

MATLAB Design Example

MATLAB Design Example

MATLAB Aircraft Pitch Example For a step reference of 0.2 radians, the design criteria are the following. 1. Overshoot less than 10% 2. Rise time less than 2 seconds 3. Settling time less than 10 seconds 4. Steady-state error less than 2%

MATLAB Aircraft Pitch Example For a step reference of 0.2 radians, the design criteria are the following. 1. Overshoot less than 10% 2. Rise time less than 2 seconds 3. Settling time less than 10 seconds 4. Steady-state error less than 2%

MATLAB Aircraft Pitch Example

MATLAB Aircraft Pitch Example

MATLAB Aircraft Pitch Example

MATLAB Aircraft Pitch Example

MATLAB Aircraft Pitch Example

MATLAB Aircraft Pitch Example

MATLAB Aircraft Pitch Example

Code Examples and Tasks https://github.com/unrarl/autonomous_mobile_robot_design_course/tree/master/ma tlab/control-systems/gain-scheduled-three-loop-aircraftautopilot https://github.com/unrarl/autonomous_mobile_robot_design_course/tree/master/ma tlab/control-systems/lqr https://github.com/unrarl/autonomous_mobile_robot_design_course/tree/master/ma tlab/control-systems/pid-cruise-control https://github.com/unrarl/autonomous_mobile_robot_design_course/tree/master/ma tlab/control-systems/pid

How does this apply to my project? To control the state of the robot and make it follow the desired trajectory.

Find out more http://www.kostasalexis.com/pid-control.html http://www.kostasalexis.com/lqr-control.html http://www.kostasalexis.com/linear-model-predictive-control.html http://ctms.engin.umich.edu/ctms/index.php?example=invertedpendulum &section=controlstatespace http://www.kostasalexis.com/literature-and-links.html

Thank you! Please ask your question!