1 Star 0 Fork 1

marlin/Gaussianfilter

forked from 宋佳蓁/Gaussianfilter 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
openmp.cpp 1.46 KB
一键复制 编辑 原始数据 按行查看 历史
宋佳蓁 提交于 2022-07-11 01:03 . 1
#include "openmp.h"
/**
* 按二维高斯函数实现高斯滤波
* @param src
* @param dst
* @param window
*/
void ompGaussianFilter(Mat &src, Mat &dst, Mat window) {
int hh = (window.rows - 1) / 2;
int hw = (window.cols - 1) / 2;
dst = Mat::zeros(src.size(), src.type());
//边界填充
Mat newSrc;
copyMakeBorder(src, newSrc, hh, hh, hw, hw, BORDER_REPLICATE);//边界复制
//高斯滤波
double sum[3] = {0};
#pragma omp parallel for simd num_threads(2) default(none) shared(newSrc, window, hh, hw, dst) private(sum) schedule(dynamic)
for (int i = hh; i < newSrc.rows - hh; ++i) {
for (int j = hw; j < newSrc.cols - hw; ++j) {
sum[0] = 0;
for (int r = -hh; r <= hh; ++r) {
for (int c = -hw; c <= hw; ++c) {
if (newSrc.channels() == 1) {
// sum[0] = sum[0] + newSrc.at<uchar>(i + r, j + c) * window.at<double>(r + hh, c + hw);
sum[0] = sum[0] + newSrc.ptr<uchar>(i + r)[j + c] * window.ptr<double>(r + hh)[c + hw];
}
}
}
for (int k = 0; k < newSrc.channels(); ++k) {
if (sum[k] < 0)
sum[k] = 0;
else if (sum[k] > 255)
sum[k] = 255;
}
if (newSrc.channels() == 1) {
dst.at<uchar>(i - hh, j - hw) = static_cast<uchar>(sum[0]);
}
}
}
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/maxf110415/Gaussianfilter.git
git@gitee.com:maxf110415/Gaussianfilter.git
maxf110415
Gaussianfilter
Gaussianfilter
master

搜索帮助