Presentation is loading. Please wait.

Presentation is loading. Please wait.

Basilio Bona DAUIN – Politecnico di Torino

Similar presentations


Presentation on theme: "Basilio Bona DAUIN – Politecnico di Torino"— Presentation transcript:

1 Basilio Bona DAUIN – Politecnico di Torino
28/04/2017 ROBOTICS 01PEEQW Basilio Bona DAUIN – Politecnico di Torino di 23

2 Mobile & Service Robotics Kinematics
28/04/2017 Mobile & Service Robotics Kinematics di 23

3 Fundamental problems in mobile robotics
28/04/2017 Fundamental problems in mobile robotics Locomotion: how the robot moves in the environment Perception: how the robot perceives the environment Mapping: how to build the map of the environment Localization: where is the robot wrt the map Representation: how the robot organizes the knowledge about the environment Path planning/action planning: what the robot shall do to go from here to there; what are the actions to be performed to complete a specified task Supervision and control: how are the command to actuators generated to perform simple or complex tasks. How to generate tasks Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW di 23

4 Kinematics robot kinematics depends on the adopted locomotion stuctures Almost all mobile robots are underactuated, i.e., they have less actuators (and the relative control signals) that is less than the number of degrees of freedom of the structure Various wheels arrangements exist Each one has a different kinematic model We will study the following structures Differential drive robots Bicycle-like robots And a brief introduction to quadcopters Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

5 Examples of underactuated structures
A car has two actuators, thrust and steer, and moves in a 2D space (3dof) A fixed-wing aircraft has four actuators, forward thrust, ailerons, elevator and rudder, and moves in a 3D space (6dof) A helicopter has four actuators: thrust vector magnitude and direction from the main rotor, and yaw moment from the tail rotor, and moves in a 3D space (6dof) A quadcopter has four actuators, the four rotor thrusts , and moves in a 3D space (6dof) A ship has three actuators: two propellers on parallel axes and one rudder, and moves in a 2D space (3dof) Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

6 Instantaneous Curvature Centre (ICC)
The wheel axes meet in a common point called ICC If an ICC exists, each wheel rotates without slippage ICC Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

7 ICC ? wheels slip = skid steering
If an ICC does not exist, the wheel motion occurs with slippage ? wheels slip = skid steering Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

8 Kinematics of a wheeled robot (aka rover)
the steering angle is the angle between the velocity vector and the steered wheel direction is equivalent to the angle between the normal to the velocity vector and the steered wheel rotation axis the robot pose is the position and the orientation (with respect to some give inertial axis) Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

9 Kinematics Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

10 Kinematics – Fixed wheel
The kinematic model represents a rover frame with a generic active non-steering wheel, located at a given position, with a local orientation The kinematic equations describe the relations and constraints between the wheel angular velocity and the angular velocity of the frame given constants Linear velocity of the wheel at the contact point with the plane Angular velocity of the wheel Angular velocity of the robot Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

11 Kinematic constraints
To avoid slippage the tangential velocity at the wheel contact point, due to the rover rotation around its center, must be equal to the advance velocity of the wheel Hypothesis In the wheel reference frame we have Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

12 Differential Drive (DD) Rover
Left wheel, active, non steering Passive support (castor, omniwheel) Right wheel, active, non steering Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

13 Differential Drive Rover
Left wheel Right wheel Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

14 Differential Drive Kinematics
ICC Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

15 Differential Drive Kinematics
ICC Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

16 Differential Drive Kinematics
ICC Consider the generic time instant Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

17 Differential Drive Kinematics
after Turn left Turn right before Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

18 Differential Drive Kinematics
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

19 Differential Drive Kinematics
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

20 Differential Drive Kinematics
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

21 Differential Drive Kinematics
Considering the sampled time equations and assuming constant values during the time interval Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

22 Differential Drive Kinematics
Approximation when sampling period is small (A) Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

23 Differential Drive Kinematics
EULER APPROXIMATION Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

24 Differential Drive Kinematics
RUNGE-KUTTA APPROXIMATION Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

25 Differential Drive Kinematics
EXACT INTEGRATION (B) (A) and (B) are the same Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

26 Differential Drive Kinematics
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

27 Path Planning Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

28 2D Path Planning free space obstacles final pose final pose
initial pose initial pose Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

29 F I 3D Path Planning Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

30 arcs of zero radius represent turn-in-place maneuvers
Path Planning A robot path from pose A to pose B can always be decomposed into a series of arcs of different radius arcs of zero radius represent turn-in-place maneuvers arcs of infinite radius represents straight line maneuvers Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

31 Path Planning Driving a vehicle to a goal (no orientation specified)
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

32 Path Planning Driving a vehicle to a goal (orientation specified)
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

33 Path Planning Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

34 Path Planning Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

35 Unicycle Unicycle is the simplest example of a wheeled robot. It consists of a single actuated steering wheel  is the steering velocity states/coordinates control commands (underactuated) Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

36 Unicycle motion Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

37 Unicycle-like robot (polar coordinates)
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

38 Bicycle-like robot NON HOLONOMIC CONSTRAINT steering angle orientation
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

39 Bicycle equations 1 1) 2) 1’) Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

40 Bicycle equations 2 Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

41 Bicycle equations 3 Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

42 Bicycle equations 5 Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

43 Bicycle vs unicycle motion
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

44 Quadcopters Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

45 Quadcopter model Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

46 Quadcopter equations Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

47 Quadcopter equations Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

48 Quadcopter equations Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

49 Quadcopter equations Basilio Bona - DAUIN - PoliTo
ROBOTICS 01PEEQW

50 Odometry Odometry is the estimation of the successive robot poses based on the wheel motion. Wheel angles are measured and used for pose computation Odometric errors increase with the distance covered, and are due to many causes, e.g. Imperfect knowledge of the wheels geometry Unknown contact points: in the ideal DD robot there are two geometric contact points between wheels and ground. In real robots the wheels are several centimeters wide and the actual contact points are undefined Slippage of the wheel wrt the terrain Errors can be compensated sensing the environment around the robot and comparing it with known data (maps, etc.) Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

51 Odometry Errors Estimated path based only on odometry Desired path Map
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

52 Visual odometry Visual odometry is the estimation of the robot poses based only on the acquisition of successive images of the environment Stereo visual odometry uses two cameras to estimate the ego-motion of a camera by tracking features in a video sequence. If the camera system is calibrated then the full 3D Euclidean geometry can be reconstructed Using a single camera, the reconstruction is up to an unknown scale factor A RGB-D (Kinect or similar) camera can be used Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

53 Other important problems that must be addressed
Mapping: how to build environment maps (geometrical vs semantic maps) Localization: where am I in the map? Simultaneous Localization and Mapping (SLAM): build a map and at the same time localize the robot in the map while moving Path planning: the definition of an “optimal” geometric path in the environment from A to B, and avoid obstacles Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

54 Path Planning – A map is given
Path planning algorithm: it computes which route to take, from the initial to the final pose, based on the current internal representation of the terrain possibly considering a “cost function” (minimum time, minimum energy, maximum comfort, etc.) Complete path generation: the path is created as a sequence of successive moves from the initial pose to the final one Motion planning: is the execution of the above defined theoretical route; it translates the plan from the internal representation to the physical movement of the wheels Next move selection: at each step, the algorithm must decide which way to move next. An efficient dynamic implementation is required Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

55 Introduction to AI Robotics (MIT Press)
Path Planning Where am I going? Mission planning What’s the best way there? Path planning Where have I been? Map making Where am I? Localization Navigation Carto- grapher Mission Planner deliberative Behaviors How am I going to get there? reactive Introduction to AI Robotics (MIT Press) Robin Murphy 2000 Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

56 Path Planning B A Mobile obstacles Fixed obstacles Velocity
Acceleration constraints Velocity Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

57 Which commands shall I give to the rover?
Path Planning Which commands shall I give to the rover? Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

58 Path Planning B Final pose Path B Path A A Initial pose
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

59 Motion Planning B Move 3:rotation Final pose Move 2: go straight
Initial pose Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

60 Non-holonomic constraints
Non-holonomic constraints limit the possible incremental movements in the configuration space of the robot Robots with differential drive move on a circular trajectory and cannot move sideways Omni-wheel robots can move sideways Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

61 Holonomic vs. Non-Holonomic
Non-holonomic constraints reduce the control space with respect to the current configuration (e.g., moving sideways is impossible) Holonomic constraints reduce the configuration space Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

62 Academic year 2010/11 by Prof. Alessandro De Luca
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

63 Academic year 2010/11 by Prof. Alessandro De Luca
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

64 Academic year 2010/11 by Prof. Alessandro De Luca
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW

65 Academic year 2010/11 by Prof. Alessandro De Luca
Basilio Bona - DAUIN - PoliTo ROBOTICS 01PEEQW


Download ppt "Basilio Bona DAUIN – Politecnico di Torino"

Similar presentations


Ads by Google