Sensor Noise Rejection Rakshit Allamraju Ben Reish Allan Axelrod Abstract An inaccessible control architecture caused an undesirable influence on a UAV. The encountered noise in the performance was modeled using stochastic methods and a corrective term was implemented on an external controller. Our findings suggest that the sonar noise problem is unconventional may warrant the development of a new methodology. Keywords: Subsumption Architecture,Gaussian Mixture Models,Gaussian Process, Quadcopter, Random Variable 1 Introduction Industrial applications of controlled solutions vary widely in the level of documentation made available to the end-users. In some instances, entire portions of the software for a controlled solution are designed to be inaccessible. This limits the usefulness of purchased controlled solutions to certain niches that may not adequately encompass the scope of an engineering project [8]. In such a case, projects may be delayed until an entirely new controlled solution is purchased, shipped, activated and reprogrammed. However, project delays could result in unacceptable costs; e.g., in emergency response scenarios, and delays in implementation could result in the unnecessary loss of human lives [6, 5]. Additionally, the increasingly aggressive nature of cyber-attacks has posed a serious se- curity and safety concern . In fact, the power, automation and chemical industries have already been the targets of debilitating cyber-attacks [3, 4]. The cyber-warfare arms race has evolved in a costly and overly complicated manner, often involving efforts related to se- curing a network of systems with many accessible input sites. Such efforts typically involve a trade off between operational efficiency and security. In response to the aforementioned issues, we present an augmented control architec- ture that may similarly augment commercial-off-the-shelf (COTS) hardware and potential cyber-warfare targets. The augmented architecture enlists an external sensory system to characterize temporally anomalous or otherwise undesirable behavior to shape the system input signal such that the undesirable aspects of the system behavior are canceled out. In 1 arXiv:1408.6434v1 [stat.AP] 27 Aug 2014 the context of COTS systems, this may allow for systems to operate in more exotic envi- ronments and fulfill a broader range of operational capabilities. For cyber-warefare targets, this solution may allow systems to continue to exhibit desirable performance before, during and after a cyber-attack For the sake of simplicity, we experimentally demonstrate the effectiveness of the aug- mented control architecture in the context of COTS systems. The demonstrated noise re- jection is notably different than what we’ve seen in literature and this report is an initial survey of our investigation. 2 Problem Formulation The objective is to characterize and reduce the undesirable input (noise) introduced into the control input by a lower-level control loop of the subsumption architecture [1] as the UAV hovers about a location in 3-dimensional space. The UAV has an internal controller that uses a sonar apparatus to maintain a preset height of 1 m . An Opti-Track system is used as an external sensor to measure the UAV position during each flight testing episode. The data from the Opti-Track system is received by a Robot Operating System (ROS) client, which contains the higher-level control loop of the subsumption architecture. The ROS client is used to affect the position and orientation of the UAV. Since the default UAV altitude is above the observable range of the Opti-Track, the ROS client altitude controller enforces an alternative steady state altitude of 0 . 5 m . The composite effect on the UAV altitude as it hovers over a uniformly level surface is shown in Figure 1a. The composite effect on the UAV altitude as it hovers over a stepped surface is shown in Figure 1b. The degradation of the composite UAV altitude control in the presence of the stepped surface is significant and undesirable. The approach we have considered for fitting our data are described below. 2.1 Gaussian Mixture Models Gaussian mixture models (GMM’s) are one of the most mature approaches in modeling density estimation of data. GMM’s are parametric probability distributions which are repre- sented as weighted sums of Gaussian component densities. GMM’s are employed for multiple purposes such as color-based tracking and segmentation, classifying color textures in image features [7], and speaker recognition [9]. A GMM can be represented as p ( x | λ ) = M ∑ i =1 w i g i ( x i | μ i , σ i ) (1) GMM’s add a great deal of flexibility for modeling data. If a sufficient numbers of components is allowed, the data can be easily modeled with a high degree of accuracy. One of the main 2 200 400 600 800 1000 1200 −0.5 −0.4 −0.3 −0.2 −0.1 0 Time Z Error (a) ZError -No Building 200 400 600 800 1000 1200 −0.5 −0.4 −0.3 −0.2 −0.1 0 0.1 0.2 0.3 Time Z Error (b) ZError -Building Figure 1: Zerror Comparison abilities of GMM’s is the capability to form smooth approximations to arbitrarily shaped densities. It can be considered as a amalgamation of a uni-modal Gaussian model and a vector quantizer thus enabling us to access characteristics of both. Thus the GMM not only provides a smooth overall distribution fit which is a feature of uni-modal Gaussian, but also details the multi-modal nature of the density modeled by Vector Quantizer. In our current analysis we sought to use Gaussian Mixture Models to model the proba- bility distribution in altitude and thus relate it to the noise generated by the sonar system on the UAV. The presence of the sonar on the controller of the UAV induces a change in altitude which we try to negate using a direct inversion controller. The problem is particularly interesting because the behavior of the sonar signal is not directly observable, due to the design of the UAV. Because of this effect we have a determin- istic sonar sensor and we need to model it as a stochastic system to determine its output. The noise introduced by the presence of a building from the built-in sonar on the UAV is taken as a random variable. This is analogous to the automotive industry using a Gaussian random process for characterization of road surfaces [2]. The automotive work character- ized the shock absorber response of simulated quarter-car models as a random variable [10]. Like the quarter-car model shock absorbers, the UAV does not have knowledge of upcoming disturbances. 3 Experiments and Simulation In our current experimental setup we use an Opti-Track environment as an external position measurement sensor and place a UAV in the Opti-Track environment. The UAV flies in the experimental testbed shown in Figure 2. The testbed area is 16 f t × 12 f t and it is equipped with the Opti-Track motion capture system. The Opti-Track cameras have a 3 Figure 2: Test Bed optical range between 18 in to 433 in , thus allowing an estimated observable volume of 11 f t × 11 f t × 4 f t . The Opti-Track is a set of 10 infra-red cameras, which collect data based on the markers attached to the body. The UAV used in this experiment is the a AR-Drone Parrot 2.0 Quadrotor (UAV), which is controlled by a client program using the Robot Operating System (ROS) and our own external controllers. The UAV is designed to receive velocity commands. The ROS client python script generates the velocity commands and sends the commands to the UAV. The UAV has two sonar sensors on it’s base at a distance of 1 in , which are programmed to maintain the UAV at a default height of 1 meter. A single building is placed at a region close to the center. This region is chosen in order to maintain enduring visibility of the UAV from multiple cameras and prevent the Opti-Track from losing its position. The trajectory of the UAV is designed so that it flies around till it reaches the building and hovers over it until the end of the episodic run. The data is recorded only for those intervals when the UAV is hovering over the building. A Proportional-Derivative (PD) controller written in Python is used as a closed loop position controller which receives data from the Opti-Track and calculates the control com- mands required to maintain the correct position. In the current setup our desired position 4 −0.2 0 0.2 0.4 0.6 0.8 1 1.2 1.4 0 100 200 300 400 500 600 700 800 900 1000 X position X data total Edge Histogram Gaussian fit (a) Hist X −2 −1.5 −1 −0.5 0 0.5 1 1.5 0 100 200 300 400 500 600 700 800 900 1000 Y position Y data total Edge Histogram Gaussian fit (b) Hist Y 0 0.2 0.4 0.6 0.8 1 1.2 1.4 0 0.002 0.004 0.006 0.008 0.01 0.012 Z Position Probability Histogram Gaussian Mixture Model (c) Hist Z Figure 3: Histogram distributions in altitude is 0 . 5 m . In our initial experiments we use our baseline PD controller to fly the desired trajectory without the corrective control. Each time the UAV hovers over the building the sonar detects the loss in altitude and sends a signal to the internal on-board controller causing it to rise to a higher altitude. However, this effect pushes the UAV from the building, causing the sonar to mistake the altitude to be too high and thus sending commands to the on-board controller to decrease the altitude, leading to a rapid drop in altitude. We record the position and attitude data and use it to form a distribution of the position along the Z direction. The distribution along all three directions are given in Figure 3 a,b,c. 4 Solution Our method is to characterize the noise of the sonar and then cancel it out by updating the desired height. This is an offline method at present, but could be taken to an online case. 5 Figure 4: Z Means in each Bin 4.1 Characterization We use recorded data to gain an understanding of the noise. The UAV was initially instructed to hover over a flat (no buildings) surface and the x, y, and z position of the craft was recorded from the Opti-Track data. The UAV was then instructed to hover over a disturbance (the edge of a building) and the x, y, and z position data was again recorded. The data was trimmed to remove obvious outliers as well as takeoff and landing phenomena. The gathered z-data was placed in bins according to the corresponding x and y position. Initially, a polynomial fit of the histogram in Figure 4. was generated in MATLAB as shown in Figure 5. The intent was to use the polynomial fit to generate a corrective control term to eliminate the effects of the sonar. The z-data was also used to train a Gaussian process to locally estimate the expected altitude of the UAV and fit the data onto a surface. 4.2 Cancellation The estimates generated by the polynomial surface and the surface generated by the Gaussian Process were not sufficient to eliminate the sonar noise since the sonar instigated both steep and gradual changes in the altitude of the UAV; i.e., a single surface-estimate of the UAV altitude could not anticipate both sonar modes. A heuristic controller solution was also attempted. The heuristic controller solution resulted in an insufficient improvement in performance; i.e., the sonar noise was not negated. The flat terrain data was subtracted from the disturbed data and that result was used to form the corrective controller command. For a given position in the x-y space, the desired height command was shifted by the expected value of the noise from the sonar in the 6 0.4 0.6 0.8 1 1.2 −1.8 −1.6 −1.4 −1.2 −1 −0.8 −0.6 −0.4 −0.1 0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 X Predictive Mean Y Figure 5: Meansurface quadcopter’s controller. This allowed the sonar to add its noise while not adversely affecting the altitude of the craft. 5 Conclusions We have used a subset of existing tools at our disposal to model the sonar output in terms of the obtained position data. The random interaction of the sonar with the stepped surface caused conventional statistical modeling techniques to generate intractable estimations of the UAV altitude due to the sonar. Our results suggest that the problem of eliminating sonar noise is unconventional, and that may warrant the development of a new methodology. Since the best result was obtained through the heuristic tuning of certain parameters, it is possible that a reinforcement learning approach might be more robust. References [1] R. Brooks, “A robust layered control system for a mobile robot.” [2] C. J. Dodds and J. D. Robson, “The description of road surface roughness,” Journal of Sound and Vibration , vol. 31, no. 2, pp. 175–183, 1973. 7 [3] D. Kundur, X. Feng, S. Liu, T. Zourntos, and K. L. Butler-Purry, “Towards a framework for cyber attack impact analysis of the electric smart grid,” in IEEE Smart Grid Comm . IEEE, October 2010. [4] J. A. Lewis, “Assessing the risks of cyber terrorism, cyber war and other cyber threats,” Center for Strategic and International Studies, Study, 2002. [Online]. Available: www.csis.org [5] R. R. Murphy, “Mobile robots in mine rescue and recovery,” IEEE Robotics and Au- tomation Magazine , vol. 16, pp. 91–103, June 2009. [6] R. R. Murphy and S. Stover, “Rescue robots for mudslides: A descriptive study of the 2005 La Conchita mudslide response,” Journal of Field Robotics , vol. 25, pp. 3–16, Jan 2008. [7] Permuter, “A study of gaussian mixture models of color and texture features for image classification and segmentation.” [8] S. S. R. R. Murphy, J. Kravitz, “Navigational and mission usability in rescue robots,” Journal of the Robotics Society of Japan , vol. 28, pp. 142–146, March 2010. [9] D. Reynolds, “Gaussian mixture models,” MIT Lincoln Laboratory, Tech. Rep., 2009. [10] G. Verros, S. Natsiavas, and C. Papadimitriou, “Design optimization of quarter-car models with passive and semi-active suspensions under random road excitation,” Jour- nal of Vibration and Control , vol. 11, pp. 581–606, 2005. 8