| // Copyright (c) 2006, 2008 Edward Rosten | 
 | // All rights reserved. | 
 | // | 
 | // Redistribution and use in source and binary forms, with or without | 
 | // modification, are permitted provided that the following conditions | 
 | // are met: | 
 | // | 
 | //  *Redistributions of source code must retain the above copyright | 
 | //   notice, this list of conditions and the following disclaimer. | 
 | // | 
 | //  *Redistributions in binary form must reproduce the above copyright | 
 | //   notice, this list of conditions and the following disclaimer in the | 
 | //   documentation and/or other materials provided with the distribution. | 
 | // | 
 | //  *Neither the name of the University of Cambridge nor the names of | 
 | //   its contributors may be used to endorse or promote products derived | 
 | //   from this software without specific prior written permission. | 
 | // | 
 | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 
 | // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 
 | // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 
 | // A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER | 
 | // OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | 
 | // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 
 | // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | 
 | // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF | 
 | // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | 
 | // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | 
 | // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
 |  | 
 | // clang-format off | 
 | #include <stdlib.h> | 
 | #include "fast.h" | 
 |  | 
 |  | 
 | xy* aom_fast9_detect_nonmax(const byte* im, int xsize, int ysize, int stride, int b, | 
 |                             int** ret_scores, int* ret_num_corners) | 
 | { | 
 |   xy* corners; | 
 |   int num_corners; | 
 |   int* scores; | 
 |   xy* nonmax; | 
 |  | 
 |   corners = aom_fast9_detect(im, xsize, ysize, stride, b, &num_corners); | 
 |   if(!corners) | 
 |   { | 
 |     // Memory allocation failure | 
 |     *ret_num_corners = -1; | 
 |     return NULL; | 
 |   } | 
 |   // num_corners may be zero. | 
 |   scores = aom_fast9_score(im, stride, corners, num_corners, b); | 
 |   if(!scores && num_corners > 0) | 
 |   { | 
 |     // Memory allocation failure | 
 |     free(corners); | 
 |     *ret_num_corners = -1; | 
 |     return NULL; | 
 |   } | 
 |   nonmax = aom_nonmax_suppression(corners, scores, num_corners, ret_scores, ret_num_corners); | 
 |  | 
 |   free(corners); | 
 |   free(scores); | 
 |  | 
 |   return nonmax; | 
 | } | 
 | // clang-format on |