Canny Edge Detection Shaders

Total Page:16

File Type:pdf, Size:1020Kb

Canny Edge Detection Shaders GPU Accelerated Feature Algorithms for Mobile Devices A thesis submitted to the Auckland University of Technology, In fulfilment of the requirements for the degree of Doctor of Philosophy (PhD) Seth George Hall School of Computing and Mathematical Sciences March 2014 Primary Supervisor: Dr. Andrew Ensor Secondary Supervisor: Dr. Roy Davies Table of Contents List of Figures ........................................................................................................................... 5 List of Tables ............................................................................................................................ 7 Attestation of Authorship ........................................................................................................ 8 Acknowledgements ................................................................................................................... 9 Abstract ................................................................................................................................... 10 Chapter 1 Introduction .......................................................................................................... 11 Chapter 2 Literature Review ................................................................................................ 22 2.1 : Augmented Reality ................................................................................................... 22 2.2 : Mobile Smartphone Platforms Overview ................................................................. 24 2.3 : Computer Vision: ..................................................................................................... 28 2.3.1 : Fiducial Markers ................................................................................................ 29 2.3.2 : Feature Detection ............................................................................................... 30 2.3.3 : Image Convolutions ........................................................................................... 31 2.3.4 : Canny Edge Detection ....................................................................................... 32 2.3.5 : FAST.................................................................................................................. 34 2.3.6 : SIFT ................................................................................................................... 35 2.3.7 : SURF ................................................................................................................. 36 2.3.8 : Lucas Kanade..................................................................................................... 36 2.4 : General Purpose Computing on the GPU: ............................................................... 38 2.4.1 : GPU programming and Shaders: ....................................................................... 38 2.4.2 GPU based feature descriptors ............................................................................. 43 2.5 : Cluster Analysis ....................................................................................................... 44 2.5.1 : DBSCAN ........................................................................................................... 45 2.5.2 : K-means Clustering ........................................................................................... 46 2.6 : Location Based Services .......................................................................................... 47 2 | Page 2.7 : Existing Computer Vision and MAR Applications: ................................................ 49 2.8 Significance for Mobile Augmented Reality .............................................................. 51 Chapter 3 GPU Based Canny Edge Detection ..................................................................... 53 3.1 : Image Analysis on Mobile Devices ......................................................................... 54 3.2 : Canny Shader Implementation ................................................................................. 57 3.2.1 : CPU side setup ................................................................................................... 58 3.2.2 : Gaussian Smoothing Steps ................................................................................ 59 3.2.3 : Sobel XY Steps .................................................................................................. 59 3.2.4 : Non-Maximal Suppression & Double Threshold Steps .................................... 59 3.2.5 : Weak and Strong Pixel Tests ............................................................................. 60 Chapter 4 Performance Comparison of Canny Edge Detection on Mobile Platforms ... 62 4.1 Mobile Performance Results ...................................................................................... 62 4.2 Results Discussion ...................................................................................................... 65 Chapter 5 GPU-based Feature point detection ................................................................... 67 5.1 Feature Detection and Description ............................................................................. 67 5.2 : GPU FAST implementation ..................................................................................... 69 5.3 : ColourFAST Feature Point Detection Implementation ............................................ 71 5.3.1 : CPU Side Setup and Android Camera Capture ................................................. 72 5.3.2 : Colour Conversion ............................................................................................. 73 5.3.3 : Smoothing .......................................................................................................... 74 5.3.4 : Half Bresenham and Feature Strength Calculation ........................................... 74 5.3.5 Feature Direction Calculation .............................................................................. 76 5.4 ColourFAST Results and Comparison to FAST ........................................................ 78 Chapter 6 GPU-based Feature Tracking ............................................................................. 83 6.1 : GPU-based Lucas Kanade implementation .............................................................. 84 6.2 : ColourFAST Feature Search implementation .......................................................... 85 6.2.1 Feature Point Difference Calculation .................................................................. 87 3 | Page 6.2.2 : Two-Step Hierarchical Approach ...................................................................... 87 6.2.3 Feature Blending .................................................................................................. 88 6.3 Results and Comparison with Lucas-Kanade ............................................................. 89 6.3.1 : Frame rate throughput tests ............................................................................... 89 6.3.2 : Tracking accuracy tests...................................................................................... 90 6.3.3 : Feature value repeatability tests......................................................................... 93 Chapter 7 Cluster Analysis & GPU-based Feature Discovery .......................................... 98 7.1 : GPU Feature Discovery Implementation ................................................................. 98 7.2 : Point Clustering ...................................................................................................... 101 7.3 : Results and Testing ................................................................................................ 105 7.4 : Future Work ........................................................................................................... 107 Chapter 8 GPU-based Object Recognition ........................................................................ 109 8.1 : Object Recognition and Feature Descriptions ........................................................ 109 8.2 : GPU-based Object Recognition version 1.............................................................. 110 8.3 : GPU Based Object Recognition Version 2 ............................................................ 114 8.4 : Results and testing .................................................................................................. 116 8.4.1 : Match Accuracy test ........................................................................................ 116 8.4.2 : Match Speed Test ............................................................................................ 122 8.5 : Future Work ........................................................................................................... 124 Chapter 9 Conclusion .......................................................................................................... 126 Appendix A: Canny Edge Detection Shaders .................................................................... 129 Appendix B: ColourFAST Feature Detection Shaders .................................................... 132 Appendix C: ColourFAST Feature Tracking Shaders .................................................... 134 Appendix D: Feature Discovery Shader ............................................................................ 137 Appendix E: ColourFAST Object Recognition Shaders .................................................. 138 References ............................................................................................................................
Recommended publications
  • Hough Transform, Descriptors Tammy Riklin Raviv Electrical and Computer Engineering Ben-Gurion University of the Negev Hough Transform
    DIGITAL IMAGE PROCESSING Lecture 7 Hough transform, descriptors Tammy Riklin Raviv Electrical and Computer Engineering Ben-Gurion University of the Negev Hough transform y m x b y m 3 5 3 3 2 2 3 7 11 10 4 3 2 3 1 4 5 2 2 1 0 1 3 3 x b Slide from S. Savarese Hough transform Issues: • Parameter space [m,b] is unbounded. • Vertical lines have infinite gradient. Use a polar representation for the parameter space Hough space r y r q x q x cosq + ysinq = r Slide from S. Savarese Hough Transform Each point votes for a complete family of potential lines: Each pencil of lines sweeps out a sinusoid in Their intersection provides the desired line equation. Hough transform - experiments r q Image features ρ,ϴ model parameter histogram Slide from S. Savarese Hough transform - experiments Noisy data Image features ρ,ϴ model parameter histogram Need to adjust grid size or smooth Slide from S. Savarese Hough transform - experiments Image features ρ,ϴ model parameter histogram Issue: spurious peaks due to uniform noise Slide from S. Savarese Hough Transform Algorithm 1. Image à Canny 2. Canny à Hough votes 3. Hough votes à Edges Find peaks and post-process Hough transform example http://ostatic.com/files/images/ss_hough.jpg Incorporating image gradients • Recall: when we detect an edge point, we also know its gradient direction • But this means that the line is uniquely determined! • Modified Hough transform: for each edge point (x,y) θ = gradient orientation at (x,y) ρ = x cos θ + y sin θ H(θ, ρ) = H(θ, ρ) + 1 end Finding lines using Hough transform
    [Show full text]
  • A PERFORMANCE EVALUATION of LOCAL DESCRIPTORS 1 a Performance Evaluation of Local Descriptors
    MIKOLAJCZYK AND SCHMID: A PERFORMANCE EVALUATION OF LOCAL DESCRIPTORS 1 A performance evaluation of local descriptors Krystian Mikolajczyk and Cordelia Schmid Dept. of Engineering Science INRIA Rhone-Alpesˆ University of Oxford 655, av. de l'Europe Oxford, OX1 3PJ 38330 Montbonnot United Kingdom France [email protected] [email protected] Abstract In this paper we compare the performance of descriptors computed for local interest regions, as for example extracted by the Harris-Affine detector [32]. Many different descriptors have been proposed in the literature. However, it is unclear which descriptors are more appropriate and how their performance depends on the interest region detector. The descriptors should be distinctive and at the same time robust to changes in viewing conditions as well as to errors of the detector. Our evaluation uses as criterion recall with respect to precision and is carried out for different image transformations. We compare shape context [3], steerable filters [12], PCA-SIFT [19], differential invariants [20], spin images [21], SIFT [26], complex filters [37], moment invariants [43], and cross-correlation for different types of interest regions. We also propose an extension of the SIFT descriptor, and show that it outperforms the original method. Furthermore, we observe that the ranking of the descriptors is mostly independent of the interest region detector and that the SIFT based descriptors perform best. Moments and steerable filters show the best performance among the low dimensional descriptors. Index Terms Local descriptors, interest points, interest regions, invariance, matching, recognition. I. INTRODUCTION Local photometric descriptors computed for interest regions have proved to be very successful in applications such as wide baseline matching [37, 42], object recognition [10, 25], texture Corresponding author is K.
    [Show full text]
  • 1 Introduction
    1: Introduction Ahmad Humayun 1 Introduction z A pixel is not a square (or rectangular). It is simply a point sample. There are cases where the contributions to a pixel can be modeled, in a low order way, by a little square, but not ever the pixel itself. The sampling theorem tells us that we can reconstruct a continuous entity from such a discrete entity using an appropriate reconstruction filter - for example a truncated Gaussian. z Cameras approximated by pinhole cameras. When pinhole too big - many directions averaged to blur the image. When pinhole too small - diffraction effects blur the image. z A lens system is there in a camera to correct for the many optical aberrations - they are basically aberrations when light from one point of an object does not converge into a single point after passing through the lens system. Optical aberrations fall into 2 categories: monochromatic (caused by the geometry of the lens and occur both when light is reflected and when it is refracted - like pincushion etc.); and chromatic (Chromatic aberrations are caused by dispersion, the variation of a lens's refractive index with wavelength). Lenses are essentially help remove the shortfalls of a pinhole camera i.e. how to admit more light and increase the resolution of the imaging system at the same time. With a simple lens, much more light can be bought into sharp focus. Different problems with lens systems: 1. Spherical aberration - A perfect lens focuses all incoming rays to a point on the optic axis. A real lens with spherical surfaces suffers from spherical aberration: it focuses rays more tightly if they enter it far from the optic axis than if they enter closer to the axis.
    [Show full text]
  • Detection and Evaluation Methods for Local Image and Video Features Julian Stottinger¨
    Technical Report CVL-TR-4 Detection and Evaluation Methods for Local Image and Video Features Julian Stottinger¨ Computer Vision Lab Institute of Computer Aided Automation Vienna University of Technology 2. Marz¨ 2011 Abstract In computer vision, local image descriptors computed in areas around salient interest points are the state-of-the-art in visual matching. This technical report aims at finding more stable and more informative interest points in the domain of images and videos. The research interest is the development of relevant evaluation methods for visual mat- ching approaches. The contribution of this work lies on one hand in the introduction of new features to the computer vision community. On the other hand, there is a strong demand for valid evaluation methods and approaches gaining new insights for general recognition tasks. This work presents research in the detection of local features both in the spatial (“2D” or image) domain as well for spatio-temporal (“3D” or video) features. For state-of-the-art classification the extraction of discriminative interest points has an impact on the final classification performance. It is crucial to find which interest points are of use in a specific task. One question is for example whether it is possible to reduce the number of interest points extracted while still obtaining state-of-the-art image retrieval or object recognition results. This would gain a significant reduction in processing time and would possibly allow for new applications e.g. in the domain of mobile computing. Therefore, the work investigates different corner detection approaches and evaluates their repeatability under varying alterations.
    [Show full text]
  • Local Descriptors
    Local descriptors SIFT (Scale Invariant Feature Transform) descriptor • SIFT keypoints at locaon xy and scale σ have been obtained according to a procedure that guarantees illuminaon and scale invance. By assigning a consistent orientaon, the SIFT keypoint descriptor can be also orientaon invariant. • SIFT descriptor is therefore obtained from the following steps: – Determine locaon and scale by maximizing DoG in scale and in space (i.e. find the blurred image of closest scale) – Sample the points around the keypoint and use the keypoint local orientaon as the dominant gradient direc;on. Use this scale and orientaon to make all further computaons invariant to scale and rotaon (i.e. rotate the gradients and coordinates by the dominant orientaon) – Separate the region around the keypoint into subregions and compute a 8-bin gradient orientaon histogram of each subregion weigthing samples with a σ = 1.5 Gaussian SIFT aggregaon window • In order to derive a descriptor for the keypoint region we could sample intensi;es around the keypoint, but they are sensi;ve to ligh;ng changes and to slight errors in x, y, θ. In order to make keypoint es;mate more reliable, it is usually preferable to use a larger aggregaon window (i.e. the Gaussian kernel size) than the detec;on window. The SIFT descriptor is hence obtained from thresholded image gradients sampled over a 16x16 array of locaons in the neighbourhood of the detected keypoint, using the level of the Gaussian pyramid at which the keypoint was detected. For each 4x4 region samples they are accumulated into a gradient orientaon histogram with 8 sampled orientaons.
    [Show full text]
  • Local Feature Detectors and Descriptors Overview
    CS 6350 – COMPUTER VISION Local Feature Detectors and Descriptors Overview • Local invariant features • Keypoint localization - Hessian detector - Harris corner detector • Scale Invariant region detection - Laplacian of Gaussian (LOG) detector - Difference of Gaussian (DOG) detector • Local feature descriptor - Scale Invariant Feature Transform (SIFT) - Gradient Localization Oriented Histogram (GLOH) • Examples of other local feature descriptors Motivation • Global feature from the whole image is often not desirable • Instead match local regions which are prominent to the object or scene in the image. • Application Area - Object detection - Image matching - Image stitching Requirements of a local feature • Repetitive : Detect the same points independently in each image. • Invariant to translation, rotation, scale. • Invariant to affine transformation. • Invariant to presence of noise, blur etc. • Locality :Robust to occlusion, clutter and illumination change. • Distinctiveness : The region should contain “interesting” structure. • Quantity : There should be enough points to represent the image. • Time efficient. Others preferable (but not a must): o Disturbances, attacks, o Noise o Image blur o Discretization errors o Compression artifacts o Deviations from the mathematical model (non-linearities, non-planarities, etc.) o Intra-class variations General approach + + + 1. Find the interest points. + + 2. Consider the region + ( ) around each keypoint. local descriptor 3. Compute a local descriptor from the region and normalize the feature.
    [Show full text]
  • Interest Point Detectors and Descriptors for IR Images
    DEGREE PROJECT, IN COMPUTER SCIENCE , SECOND LEVEL STOCKHOLM, SWEDEN 2015 Interest Point Detectors and Descriptors for IR Images AN EVALUATION OF COMMON DETECTORS AND DESCRIPTORS ON IR IMAGES JOHAN JOHANSSON KTH ROYAL INSTITUTE OF TECHNOLOGY SCHOOL OF COMPUTER SCIENCE AND COMMUNICATION (CSC) Interest Point Detectors and Descriptors for IR Images An Evaluation of Common Detectors and Descriptors on IR Images JOHAN JOHANSSON Master’s Thesis at CSC Supervisors: Martin Solli, FLIR Systems Atsuto Maki Examiner: Stefan Carlsson Abstract Interest point detectors and descriptors are the basis of many applications within computer vision. In the selection of which methods to use in an application, it is of great in- terest to know their performance against possible changes to the appearance of the content in an image. Many studies have been completed in the field on visual images while the performance on infrared images is not as charted. This degree project, conducted at FLIR Systems, pro- vides a performance evaluation of detectors and descriptors on infrared images. Three evaluations steps are performed. The first evaluates the performance of detectors; the sec- ond descriptors; and the third combinations of detectors and descriptors. We find that best performance is obtained by Hessian- Affine with LIOP and the binary combination of ORB de- tector and BRISK descriptor to be a good alternative with comparable results but with increased computational effi- ciency by two orders of magnitude. Referat Detektorer och deskriptorer för extrempunkter i IR-bilder Detektorer och deskriptorer är grundpelare till många ap- plikationer inom datorseende. Vid valet av metod till en specifik tillämpning är det av stort intresse att veta hur de presterar mot möjliga förändringar i hur innehållet i en bild framträder.
    [Show full text]
  • Keypoint Extraction and Selection for Object Recognition
    7-1 MVA2009 IAPR Conference on Machine Vision Applications, May 20-22, 2009, Yokohama, JAPAN Keypoint extraction and selection for object recognition Maja Rudinac Boris Lenseigne Pieter Jonker Delft Biorobotics Laboratory, Department of BioMechanical Engineering Delft University of Technology, 2628 CD, Delft, The Netherlands { m.rudinac, b.a.j.lenseigne, p.p.jonker}@tudelft.nl Abstract the method for selecting the most representative points in the scene. In order to gain as much information as possi- In order to improve the performance of affine invariant ble, we decided to combine different keypoint extraction detectors, approaches that combine different keypoint methods for detecting the object and then to reduce the extraction methods can be found in literature. However, number of found keypoints using an independent measure such a combining has two major drawbacks: a high com- for information content. This reduction is performed for putational cost in matching similar objects, and a large two reasons: to keep the most discriminative points, and number of false positives because only a relatively small to speed up the matching. For creating the object models, subset of those keypoints is really discriminative. In this the most representative keypoints are then described us- paper we propose a method to overcome these limitations: ing SIFT [1] and GLOH [6] descriptors. This paper is First we combine different keypoint extractors in order to organized as follows: chapter 2 gives a short overview of obtain a large set of possible interest points for a given related work. The detailed explanation of our approach object. Then, a two step filtering approach is applied: and the test results are presented in chapters 3-5.
    [Show full text]
  • Features • Harris Corner Detector • SIFT Features •Extensions • Applications
    Outline •Features • Harris corner detector • SIFT Features •Extensions • Applications Digital Visual Effects Yung-Yu Chuang with slides by Trevor Darrell Cordelia Schmid, David Lowe, Darya Frolova, Denis Simakov, Robert Collins and Jiwon Kim Features • Also known as interesting points, salient points or keypoints. Points that you can easily point out their correspondences in multiple images using only local information. Features ? Desired properties for features Applications • Distinctive: a single feature can be correctly • Object or scene recognition matched with high probability. • Structure from motion • Invariant: invariant to scale, rotation, affine, •Stereo illumination and noise for robust matching • Motion tracking across a substantial range of affine distortion, viewpoint change and so on. That is, it is •… repeatable. Components • Feature detection locates where they are • Feature description describes what they are • Feature matching decides whether two are the same one Harris corner detector Moravec corner detector (1980) Moravec corner detector • We should easily recognize the point by looking through a small window • Shifting a window in any direction should give a large change in intensity flat Moravec corner detector Moravec corner detector flat flat edge Moravec corner detector Moravec corner detector Change of intensity for the shift [u,v]: E(u,v) w(x, y)I(x u, y v) I(x, y) 2 x, y window shifted intensity function intensity corner flat edge Four shifts: (u,v) = (1,0), (1,1), (0,1), (-1, 1) isolated point Look for local maxima in min{E} Problems of Moravec detector Harris corner detector • Noisy response due to a binary window function Noisy response due to a binary window function • Only a set of shifts at every 45 degree is Use a Gaussian function considered • Only minimum of E is taken into account Harris corner detector (1988) solves these problems.
    [Show full text]
  • Rotation Invariant Histogram Features for Object Detection and Tracking in Aerial Imagery
    ROTATION INVARIANT HISTOGRAM FEATURES FOR OBJECT DETECTION AND TRACKING IN AERIAL IMAGERY Dissertation Submitted to The School of Engineering of the UNIVERSITY OF DAYTON In Partial Fulfillment of the Requirements for The Degree of Doctor of Philosophy in Electrical Engineering By Alex Mathew UNIVERSITY OF DAYTON Dayton, Ohio May, 2014 ROTATION INVARIANT HISTOGRAM FEATURES FOR OBJECT DETECTION AND TRACKING IN AERIAL IMAGERY Name: Mathew, Alex APPROVED BY: Vijayan K. Asari, Ph.D. Keigo Hirakawa, Ph.D. Advisor Committee Chairman Committee Member Professor, Department of Electrical and Assistant Professor, Department of Computer Engineering Electrical and Computer Engineering Raul´ Ordo´nez,˜ Ph.D Youssef N. Raffoul, Ph.D Committee Member Committee Member Associate Professor, Department of Professor, Department of Mathematics Electrical and Computer Engineering John G. Weber, Ph.D. Tony E. Saliba, Ph.D. Associate Dean Dean, School of Engineering School of Engineering & Wilke Distinguished Professor ii c Copyright by Alex Mathew All rights reserved 2014 ABSTRACT ROTATION INVARIANT HISTOGRAM FEATURES FOR OBJECT DETECTION AND TRACKING IN AERIAL IMAGERY Name: Mathew, Alex University of Dayton Advisor: Dr. Vijayan K. Asari Object detection and tracking in imagery captured by aerial systems are becoming increasingly important in computer vision research. In aerial imagery, objects can appear in any orientation, vary- ing sizes and in different lighting conditions. Due to the exponential growth in sensor technology, increasing size and resolution of aerial imagery are becoming a challenge for real-time computation. A rotation invariant feature extraction technique for detecting and tracking objects in aerial imagery is presented in this dissertation. Rotation invariance in the feature representation is addressed by considering concentric circular regions centered at visually salient locations of the object.
    [Show full text]
  • SIFTSIFT -- Thethe Scalescale Invariantinvariant Featurefeature Transformtransform
    SIFTSIFT -- TheThe ScaleScale InvariantInvariant FeatureFeature TransformTransform Distinctive image features from scale-invariant keypoints. David G. Lowe, International Journal of Computer Vision, 60, 2 (2004), pp. 91-110 Presented by Ofir Pele. Based upon slides from: - Sebastian Thrun and Jana Košecká - Neeraj Kumar Correspondence ■ Fundamental to many of the core vision problems – Recognition – Motion tracking – Multiview geometry ■ Local features are the key Images from: M. Brown and D. G. Lowe. Recognising Panoramas. In Proceedings of the the International Conference on Computer Vision (ICCV2003 ( Local Features: Detectors & Descriptors Detected Descriptors Interest Points/Regions <0 12 31 0 0 23 …> <5 0 0 11 37 15 …> <14 21 10 0 3 22 …> Ideal Interest Points/Regions ■ Lots of them ■ Repeatable ■ Representative orientation/scale ■ Fast to extract and match SIFT Overview Detector 1. Find Scale-Space Extrema 2. Keypoint Localization & Filtering – Improve keypoints and throw out bad ones 3. Orientation Assignment – Remove effects of rotation and scale 4. Create descriptor – Using histograms of orientations Descriptor SIFT Overview Detector 1.1. FindFind Scale-SpaceScale-Space ExtremaExtrema 2. Keypoint Localization & Filtering – Improve keypoints and throw out bad ones 3. Orientation Assignment – Remove effects of rotation and scale 4. Create descriptor – Using histograms of orientations Descriptor Scale Space ■ Need to find ‘characteristic scale’ for feature ■ Scale-Space: Continuous function of scale σ – Only reasonable kernel is
    [Show full text]
  • Speeded-Up Robust Features (SURF)
    Speeded-Up Robust Features (SURF) Herbert Bay a , Andreas Ess a , Tinne Tuytelaars b , and Luc Van Gool a;b aETH Zurich, BIWI Sternwartstrasse 7 CH-8092 Zurich Switzerland bK. U. Leuven, ESAT-PSI Kasteelpark Arenberg 10 B-3001 Leuven Belgium Abstract This article presents a novel scale- and rotation-invariant detector and descriptor, coined SURF (Speeded-Up Robust Features). SURF approximates or even outperforms previously proposed schemes with respect to repeatability, distinctiveness, and robustness, yet can be computed and compared much faster. This is achieved by relying on integral images for image convolutions; by building on the strengths of the leading existing detectors and descriptors (specifically, using a Hessian matrix-based measure for the detector, and a distribution-based descriptor); and by simplifying these methods to the essential. This leads to a combination of novel detection, description, and matching steps. The paper encompasses a detailed description of the detector and descriptor and then explores the effect of the most important parameters. We conclude the article with SURF's application to two challenging, yet converse goals: camera calibration as a special case of image registration, and object recognition. Our experiments underline SURF's usefulness in a broad range of topics in computer vision. Key words: interest points, local features, feature description, camera calibration, object recognition PACS: 1. Introduction between the vectors, e.g. the Mahalanobis or Euclidean dis- tance. The dimension of the descriptor has a direct impact The task of finding point correspondences between two on the time this takes, and less dimensions are desirable for images of the same scene or object is part of many computer fast interest point matching.
    [Show full text]