Шакирова Есения. Технология TBB. Выделение ребер на изображении с использованием оператора Собеля. Вариант 27#1285
Merged
allnes merged 7 commits intoMay 28, 2026
Conversation
Codecov Report✅ All modified and coverable lines are covered by tests. Additional details and impacted files@@ Coverage Diff @@
## master #1285 +/- ##
==========================================
- Coverage 83.04% 82.84% -0.20%
==========================================
Files 901 934 +33
Lines 53044 55738 +2694
Branches 22119 23164 +1045
==========================================
+ Hits 44050 46178 +2128
- Misses 6237 6733 +496
- Partials 2757 2827 +70 ☔ View full report in Codecov by Sentry. 🚀 New features to boost your workflow:
|
…ользованием оператора Собеля. Вариант 27 (learning-process#103) * laba is ready * laba is ready * laba is ready * laba is ready * laba is ready * laba is ready
2ea73a7 to
54cba6f
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Описание
width * height. Требуется применить оператор Собеля для выделения ребер на изображении.using InType = ImgContainer, гдеImgContainerсодержит ширину, высоту и вектор пикселей в диапазоне[0, 255]. Входное изображение может быть как полутоновым(grayscale), так и цветным — цветные изображения форматов.pngавтоматически преобразуются в полутоновые по формуле0.299*R + 0.587*G + 0.114*B. Также поддерживается задание изображения в виде текстовой матрицы.txt, где первая строка содержит размеры, а далее следуют значения пикселей.using OutType = std::vector<int>, где каждый элемент — магнитуда градиента в диапазоне[0, 255].Intel TBBоператора Собеля для обнаружения ребер на изображении. Для каждого внутреннего пикселя изображения вычисляется свёртка с двумя развёрнутыми ядрами Собеля размером3×3: горизонтальнымGxи вертикальнымGy. На основе полученных значений вычисляется магнитуда градиента по быстрому целочисленному приближению(max(|Gx|, |Gy|) * 123 + min(|Gx|, |Gy|) * 51) >> 7, которая ограничивается диапазоном[0, 255]и записывается в выходной вектор. Внешний цикл по строкам изображения распараллелен с помощьюtbb::parallel_forсtbb::blocked_range<int>и размером зерна8строк, что обеспечивает эффективную балансировку нагрузки через механизм work-stealing планировщика TBB. Внутри лямбды используются сырые указатели на строки изображения (prev,curr,next), вычисляемые один раз за строку, что улучшает локальность кэша и позволяет компилятору выполнить автовекторизацию. Граничные пиксели изображения остаются нулевыми, так как для них невозможно применить полное ядро3×3. Поддерживается загрузка изображений форматов.png,.jpg,.bmpчерез библиотекуstb_image, а также текстового формата.txt.Чек-лист
<фамилия>_<первая_буква_имени>_<короткое_название_задачи>clang-formatлокально в моем форке (нет ошибок форматирования)clang-tidyлокально в моем форке (нет предупреждений/ошибок)(например,
nesterov_a_vector_sum), а не вmasterдостоверными