Предполагается, что программное обеспечение для распознавания:
- идентифицировать базовые блоки с помощью отсканированного изображения и уникальные названия на блок-номера. />
- Пример: первый bbang block → bbang1 , второй bbang block → bbang2 и т. Д.
. />
- Как я могу извлечь и распознавать блоки из отсканированной диаграммы симулики ? Пробовал использование соответствия шаблонов ... не работает на данный момент
#include
#include
#include
#include
namespace fs = std::filesystem;
using namespace cv;
using namespace std;
// Non-Maximum Suppression (NMS)
void nonMaxSuppression(vector& detectedRegions, double overlapThreshold) {
vector indices;
sort(detectedRegions.begin(), detectedRegions.end(), [](const Rect& a, const Rect& b) {
return a.area() > b.area();
});
for (size_t i = 0; i < detectedRegions.size(); ++i) {
bool keep = true;
for (size_t j = 0; j < i; ++j) {
float intersectionArea = (detectedRegions & detectedRegions[j]).area();
float unionArea = detectedRegions.area() + detectedRegions[j].area() - intersectionArea;
if ((intersectionArea / unionArea) > overlapThreshold) {
keep = false;
break;
}
}
if (keep) {
indices.push_back(i);
}
}
vector filteredDetections;
for (int index : indices) {
filteredDetections.push_back(detectedRegions[index]);
}
detectedRegions = filteredDetections;
}
// template matching
void detectBlocks(const string& diagramPath, const string& templateFolder, ofstream& outputFile) {
Mat inputImage = imread(diagramPath, IMREAD_GRAYSCALE);
if (inputImage.empty()) {
cout
Подробнее здесь: https://stackoverflow.com/questions/794 ... nk-diagram