Commit e57d4c28 authored by Davis King's avatar Davis King

Improved an error message.

parent ac83daec
...@@ -167,6 +167,10 @@ namespace dlib ...@@ -167,6 +167,10 @@ namespace dlib
{ {
if (boxes_overlap(mapped_rects[i], mapped_rects[j])) if (boxes_overlap(mapped_rects[i], mapped_rects[j]))
{ {
const double area_overlap = mapped_rects[i].intersect(mapped_rects[j]).area();
const double match_amount = area_overlap/(double)( mapped_rects[i]+mapped_rects[j]).area();
const double overlap_amount = area_overlap/std::min(mapped_rects[i].area(),mapped_rects[j].area());
using namespace std; using namespace std;
ostringstream sout; ostringstream sout;
sout << "An impossible set of object labels was detected. This is happening because "; sout << "An impossible set of object labels was detected. This is happening because ";
...@@ -184,9 +188,8 @@ namespace dlib ...@@ -184,9 +188,8 @@ namespace dlib
sout << "The offending rectangles are:\n"; sout << "The offending rectangles are:\n";
sout << "rect1: "<< mapped_rects[i] << endl; sout << "rect1: "<< mapped_rects[i] << endl;
sout << "rect2: "<< mapped_rects[j] << endl; sout << "rect2: "<< mapped_rects[j] << endl;
sout << "overlap amount: " << sout << "match amount: " << match_amount << endl;
mapped_rects[i].intersect(mapped_rects[j]).area()/(double)( mapped_rects[i]+mapped_rects[j]).area() sout << "overlap amount: " << overlap_amount << endl;
<< endl;
throw dlib::impossible_labeling_error(sout.str()); throw dlib::impossible_labeling_error(sout.str());
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment