// 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 <assert.h> #include <stdlib.h> #include"fast.h"
#define Compare(X, Y) ((X)>=(Y))
xy* aom_nonmax_suppression(const xy* corners, constint* scores, int num_corners, int** ret_scores, int* ret_num_nonmax)
{ int num_nonmax=0; int last_row; int* row_start; int i, j;
xy* ret_nonmax; int* nonmax_scores; constint sz = (int)num_corners;
/*Point above points (roughly) to the pixel above the one of interest, if there
is a feature there.*/ int point_above = 0; int point_below = 0;
/* Find where each row begins (the corners are output in raster scan order). A beginning of -1 signifies
that there are no corners on that row. */
last_row = corners[num_corners-1].y;
row_start = (int*)malloc((last_row+1)*sizeof(int)); if(!row_start)
{
free(ret_nonmax);
free(nonmax_scores); return 0;
}
/*Check above (if there is a valid row above)*/ if(pos.y > 0 && row_start[pos.y - 1] != -1)
{ /*Make sure that current point_above is one
row above.*/ if(corners[point_above].y < pos.y - 1)
point_above = row_start[pos.y-1];
/*Make point_above point to the first of the pixels above the current point,
if it exists.*/ for(; corners[point_above].y < pos.y && corners[point_above].x < pos.x - 1; point_above++)
{}
for(j=point_above; corners[j].y < pos.y && corners[j].x <= pos.x + 1; j++)
{ int x = corners[j].x; if( (x == pos.x - 1 || x ==pos.x || x == pos.x+1) && Compare(scores[j], score)) goto cont;
}
/* Make point below point to one of the pixels belowthe current point, if it
exists.*/ for(; point_below < sz && corners[point_below].y == pos.y+1 && corners[point_below].x < pos.x - 1; point_below++)
{}
for(j=point_below; j < sz && corners[j].y == pos.y+1 && corners[j].x <= pos.x + 1; j++)
{ int x = corners[j].x; if( (x == pos.x - 1 || x ==pos.x || x == pos.x+1) && Compare(scores[j],score)) goto cont;
}
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.