Извлечение блоков, входов и выходов из отсканированной диаграммы симулинктаC++

Программы на C++. Форум разработчиков
Ответить Пред. темаСлед. тема
Anonymous
 Извлечение блоков, входов и выходов из отсканированной диаграммы симулинкта

Сообщение Anonymous »

Я работаю над программным обеспечением распознавания , которое занимает сканируемое диаграмму Simulink (in .png/.jpeg формат) в качестве ввода и извлекает структурированную информацию о блоках, их входах и выходе. Цель состоит в том, чтобы сгенерировать электронную таблицу Excel , которая будет использоваться внутренним генератором Code Cod C. /> [*] Назначить уникальные имена к блокам того же типа, с подчинением суффикса с номером.
  • Пример: первый bbang block → bbang1 , второй bbang block → bbang2 , lec. /> < /li>
    обнаружение и входы на метку /выходы < /strong>:

    Если ввод /вывод блока имеет буквенно -цифровой label < /strong>, его следует использовать.BlockName_INPUTn
    (для входов)
  • BlockName_OUTPUTn (для выходов)
[*] Пример: 4th вывод из 2nd logicarray

обнаружение соединений между блоками :
  • Если выход block подключается к вводу другого блока без метки , если он должен быть записан с использованием linkto . Hwins3 (без метки), выход GRT2 должен быть:
    linkTo(HWINS3_INPUT1)
  • Если A метка присутствует на стрелке, сама метка следует использовать в качестве выходного имени. Формат)
    Каждый block должен быть записан следующим образом в таблице Excel:
    • Первая строка: name
    • Вторая строка: number numbers, следовал входные лабил /> третья строка: Количество выходов, за которыми следуют выходные метки

    Пример вывода для блока:

    LOGICARRAY2
    2, INPUT_A, INPUT_B
    1, linkTo(HWINS3_INPUT1)

    Challenge
  • Как я могу извлечь и распознавать блоки, входные данные, выходы и соединения из Сканированные рекомендации по доходам ? соответствие шаблонов) для точного обнаружения и классификации блоков? Пробовал использование соответствия шаблонов ... не работает на данный момент
Какой бы лучший подход для достижения этого в c ++ ? Любые предложения или идеи были бы очень оценены! #include
#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
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C++»