Abstract
This research deals with mobile robot SLAM algorithm based on extended kalman filter. To enhance a accuracy of robot pose, one more extended kalman filter is used in a rough surface environment. The robot has uncertain kinematic model due to a caterpillar. When the robot drives on irregular surface, it's heading can be corrupted. We propose a method to correct uncertain robot pose using one more extended kalman filter through simulation results.
Introduction
It is a basic and essential ability to recognize exactly unknown environment for intelligent autonomous mobile robot system. However, this problem has not been solved yet even though there were many researches, because robot must not only estimate own position exactly to get accurate map, but also construct accurate map to estimate exactly own position. In other words, that is the chicken-or-egg relationship. The relation between localization and mapping is a consequence of how errors in the robot's sensor readings are corrupted by error in robot's pose. As the robot moves, its pose estimate is corrupted by motion noise. The percieved locations of obstacles in the environment are corrupted by both measurement noise and the error in the estimated pose of the robot. However unlike measurement noise, error in the robot's pose will have a systematic effect on the error in the map. In general, this effect can be stated more plainly. As a result, the true map cannot be estimated without also estimating the true pose of robot.
A robot can be classified by drive method. The most general method that is used to a robot is a differential type using two wheels. For the residue, there are omnidirectinal wheel, caterpillar, four drive wheel. The differential type using two wheel is one the easiest type to make a motion model and consider motin error compare with others type of robot, but it is constrained an environment to drive. We assume that the drive type of robot is a caterpillar type in this simulations. The caterpillar type robot can implement SLAM in a rough surface environment compare with a differential wheel type robot. However because of the nature of a caterpillar, the friction surface is wide, slip, ambiguity of kinematic analysis, we can not make its motion model easily. Also when the robot drives on a rough surface road, as its heading is corrupted, estimation of robot's pose has difficulty.
This paper introduces a useful method for correcting robot pose by using one more extended kalman fiter. The robot implements SLAM based on the extended kalman filter, one more extended kalman fiter is used to supplment uncertain robot pose due to unreliable robot's kinematic property and to correct rocking robot's heading because of irregular driving surface.
The paper is organized as follow. In the next section, the SLAM based on EKF is briefly reviwed, and then in section 3 two kinds of robot's motion models are compared. Section 4 proposes the method for correcting corrupted robot's heading using another EKF and section 5 provides the simulation results. Conclusion and references are presented in section 6 and 7 respectively.
SLAM based on EKF (ExtendedKalman Filter)
The Extended Kalman Filter
The basic Kalman filter is limited to a linear assumption. However, most non-trivial systems are non-linear. The non-linearity can be associated either with the process model or with the observation model or with both. Robot's process model and observation model are nonlinear. So they need linearization by using the EKF. In other words, state transitions and measurements are rarely linear in practice. For example, a robot that moves with constant translational and rotational velocity typically moves on a circular trajectory, which can not be described by linear state transitions. This observation, along with the assumption of unimodal beliefs, renders plain kalman filters, as discussed so far, inapplicable to all but the most trivial robotics problem.
Here, X(k),U(k),V(k) are the state vector, control input, process noise respectively. T is a control time, and w
R
and w
L
stand for anglar velocity of robot wheels.
Here, M(k) is a measurement nosie, θ means robot's heading.
Equation (2) is a motion model of general differential type robot. The function f can be used to compute the predicted state from the previous estimate and similarly the function h of equation (3) can be used to compute the predicted measurement from the predicted state. However, f and h cannot be applied to the covariance directly. Instead a matrix of partial derivatives (the jacobian) is computed. At each timestep the Jacobian is evaluated with current predicted states. These matrices can be used in the Kalman filter equations. This process essentially linearizes the non-linear function around the current estimate.

Differential two wheel type robot

Measurement model
The each step of extended kalman filter is as follows, Prediction step :
Here, Q(k) is a covariance of process nise, F(k) stands for state transition metrix through partial derivative. G(k) means the control input model which is applied to the control vector.
Correction step :
where H(k) is the observation model which maps the true state space into the observed space and R(k) means the covariance of measurement noise.
The extended kalman filter is a recursive estimator. This means that only the estimated state from the previous time step and the current measurement are needed to compute the estimate for the current state. In contrast to batch estimation techniques, no history of observations and/or estimates is required. It is unusual in being purely a time domain filter; most filters (for example, a low-pass filter) are formulated in the frequency domain and then transformed back to the time domain for implementation.
In what follows, the notation
The dominant approach to the SLAM problem was introduced in a seminal paper by Smith and Cheeseman in 1986, and first developed into an implemented system by Moutarlier and Chatila. This approach uses the Extended Kalman Filter (EKF) to estimate the posterior over robot pose and maps. The EKF approximates the SLAM posterior as a highdimensional Gaussian over all features in the map and the robot pose.
Maps, in EKF SLAM, are featured-based. They are composed of point landmarks. For computational reasons, the number of point landmarks is usually small. Further, the EKF approach tends to work well the less ambiguous the landmarks are. For this reason, EKF SLAM requires significant engineering of features detectors, using sometimes artificial beacons as features. In this simulation, we assume that there are four beacons as artificial landmarks and robot can recognize the identification of landmark. The algorithm of EKF SLAM is described Table 1.
Algorithm of the EKF SLAM
Algorithm of the EKF SLAM
In case of general two wheels differential type, a motion model can be described as equation (2). But a motion model of robot using caterpillar can not be made like equation (2). So we parameterize the velocity of caterpillar through real experiment in this simulation. This method makes error more large. New motion model is equation (12).

Caterpillar type robot model
As see equation (12), the parameter of the control input changes to the velocity of caterpillar using encoder signal. But we have difficulty to estimate robot pose because uncertainty of motion model becomes more larger. So we propose to correct robot's heading by using one more extended kalman filter.
Robot's heading is corrupted by its environment (surface). As stated in section 1, a robot has to estimate its pose, then the robot can build map. To correct robot's heading, we assume that the state vector is θ, and robot can correct its heading through measure absolute heading by using a gyro. So SLAM algorithm can change as follow.
Algorithm of the EKF SLAM added correction
Algorithm of the EKF SLAM added correction
Simulations implemented three kinds of methods. The first is that the robot estimated own position by only odometry data. The second, the robot implemented SLAM based on the EKF, at last the simulation that is applied correction algorithm was conducted.
In Fig. 4, the green line is reference robot's path, the black line stands for real robot's trajectory. The red triangle and blue triangle are estimated robot pose and reference robot pose.

Estimate robot's position by only odometry
As you can see, when robot estimates own position by only odometry, the result is really exorbitant. Because odometry error is not only accumulated, but the robot's heading is also corrupted by arough surface.
Fig. 5 shows error between the referece robot's heading and estimated robot's heading.

Graph of robot's heading error (only odometry)
Fig. 6 is the result that the robot implements SLAM based on the EKF. Compare with Fig. 4, the robot can correct own position through measurement of landmarks.

SLAM based on EKF
Because of landmarks, the robot corrects its pose, the heading error decrease by maximum 0.05 radian/sec to −0.03 radian/sec.
Fig. 8 is the result of SLAM based on EKF after the heading error is corrected by using one more EKF. In this simulation, the robot corrects its heading constantly by measure of the landmark.

Graph of robot's heading error (SLAM based on EKF)

Correct heading using one more EKF
In Fig. 9, the robot's heading error is more reduced compare with Fig. 7. Through three kinds of simulation results, the feasibility of this paper's proposal was verified. The EKF to correct robot's heading results more exact SLAM.

Graph of robot's heading error(correction heading by one more EKF)
This paper introduced supplmentary EKF application to correct robot's heading that is corrupted when the caterpillar type robot drives on a rough surface road. As comparing with three kinds of simulations, driving by only odometry data, implementation of SLAM without correcting heading and SLAM applying the proposal, this paper's proposal is proved. When the robot moves by only odometry data, the robot can not follow reference path due to accumulate odometry error and irregular surface. In case of SLAM based on EKF, it corrects odometry error through measure landmasrks, but it is not able to follow reference trajectory because of rough surface. As the robot conducts supplementary EKF for revising heading error, it can implement more accurate SLAM compare with upper two simulations.
However it requires more complex computation quantity than computational complexity of SLAM based on EKF, O(N2), because it use additional EKF to correct its heading (here, N is the number of landmarks).
Futuer work is to reduce computational complexity, through experiment using real robot, proposal will have to be proved whether it is applicable or not in real environment.
