optimize further_point_from_line

This commit is contained in:
scanner 2017-01-20 16:33:54 +01:00
parent fb15d3d5b1
commit 88adc0ba22
2 changed files with 6 additions and 5 deletions

View file

@ -7,6 +7,7 @@ endif(NOT CMAKE_BUILD_TYPE)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -Wall -Werror -pedantic") set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -Wall -Werror -pedantic")
set(CMAKE_CXX_FLAGS_PROFILE "${CMAKE_CXX_FLAGS_DEBUG} -Wall -Werror -pedantic -pg")
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -Wall -Wextra -pedantic -D_DEBUG") set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -Wall -Wextra -pedantic -D_DEBUG")

View file

@ -9,6 +9,9 @@ using namespace cv;
#include "geometry.h" #include "geometry.h"
#define likely(x) __builtin_expect(!!(x), 1)
#define unlikely(x) __builtin_expect(!!(x), 0)
double dist(Point a, Point b) double dist(Point a, Point b)
{ {
return sqrt((double)pow(a.x-b.x,2)+pow(a.y-b.y,2)); return sqrt((double)pow(a.x-b.x,2)+pow(a.y-b.y,2));
@ -115,16 +118,13 @@ cv::Point
further_point_from_line(cv::Vec<double,3> line, std::vector<Point> points) further_point_from_line(cv::Vec<double,3> line, std::vector<Point> points)
{ {
//distance = abs(a*p.x+b*p.y+c) / sqrt(a^2+b^2) //distance = abs(a*p.x+b*p.y+c) / sqrt(a^2+b^2)
double denom = sqrt(line(0)*line(0)+line(1)*line(1));
Point further = points[0]; Point further = points[0];
double maxdist = -1; double maxdist = -1;
std::cout << "--- further" << std::endl;
for(Point p: points) for(Point p: points)
{ {
double numerator = abs(line(0)*p.x + line(1)*p.y + line(2)); double numerator = abs(line(0)*p.x + line(1)*p.y + line(2));
double distance = numerator/denom; if(numerator > maxdist) {
if(distance > maxdist) { maxdist = numerator;
maxdist = distance;
further = p; further = p;
} }
} }