国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

opencv3/C++圖像濾波實(shí)現(xiàn)方式

2020-01-26 13:22:40
字體:
供稿:網(wǎng)友

圖像濾波在opencv中可以有多種實(shí)現(xiàn)形式

自定義濾波

如使用3×3的掩模:

對(duì)圖像進(jìn)行處理.

使用函數(shù)filter2D()實(shí)現(xiàn)

#include<opencv2/opencv.hpp>using namespace cv;int main(){ //函數(shù)調(diào)用filter2D功能 Mat src,dst; src = imread("E:/image/image/daibola.jpg"); if(!src.data) {  printf("can not load image /n");  return -1; } namedWindow("input", CV_WINDOW_AUTOSIZE); imshow("input", src); src.copyTo(dst); Mat kernel = (Mat_<int>(3,3)<<1,1,1,1,1,-1,-1,-1,-1); double t = (double)getTickCount(); filter2D(src, dst, src.depth(), kernel); std::cout<<((double)getTickCount()-t)/getTickFrequency()<<std::endl; namedWindow("output", CV_WINDOW_AUTOSIZE); imshow("output", dst); printf("%d",src.channels()); waitKey(); return 0;}

通過像素點(diǎn)操作實(shí)現(xiàn)

#include<opencv2/opencv.hpp>using namespace cv;int main(){ Mat src, dst; src = imread("E:/image/image/daibola.jpg"); CV_Assert(src.depth() == CV_8U); if(!src.data) {  printf("can not load image /n");  return -1; } namedWindow("input", CV_WINDOW_AUTOSIZE); imshow("input",src); src.copyTo(dst); for(int row = 1; row<(src.rows - 1); row++) {  const uchar* previous = src.ptr<uchar>(row - 1);  const uchar* current = src.ptr<uchar>(row);  const uchar* next = src.ptr<uchar>(row + 1);  uchar* output = dst.ptr<uchar>(row);  for(int col = src.channels(); col < (src.cols - 1)*src.channels(); col++)  {   *output = saturate_cast<uchar>(1 * current[col] + previous[col] - next[col] + current[col - src.channels()] - current[col + src.channels()]);   output++;  } } namedWindow("output", CV_WINDOW_AUTOSIZE); imshow("output",dst); waitKey(); return 0;}

特定形式濾波

常用的有:

blur(src,dst,Size(5,5));均值濾波

GaussianBlur(src,dst,Size(5,5),11,11);高斯濾波

medianBlur(src,dst,5);中值濾波(應(yīng)對(duì)椒鹽噪聲)

bilateralFilter(src,dst,2,0.5,2,4);雙邊濾波(保留邊緣)

#include<opencv2/opencv.hpp>using namespace cv;int main(){ Mat src, dst; src = imread("E:/image/image/daibola.jpg"); CV_Assert(src.depth() == CV_8U); if(!src.data) {  printf("can not load image /n");  return -1; } namedWindow("input", CV_WINDOW_AUTOSIZE); imshow("input",src); src.copyTo(dst); //均值濾波 blur(src,dst,Size(5,5)); //中值濾波 //medianBlur(src,dst,5); namedWindow("output", CV_WINDOW_AUTOSIZE); imshow("output",dst); waitKey(); return 0;}

以上這篇opencv3/C++圖像濾波實(shí)現(xiàn)方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 富裕县| 潞城市| 波密县| 金湖县| 炎陵县| 长宁县| 大英县| 高清| 米林县| 新化县| 固阳县| 屯昌县| 涿州市| 盐源县| 东乌| 宜州市| 华坪县| 丰都县| 巴塘县| 浑源县| 屯门区| 哈密市| 璧山县| 吴江市| 互助| 绵阳市| 梧州市| 四平市| 吉隆县| 乌兰察布市| 巴彦淖尔市| 保定市| 资中县| 平利县| 清苑县| 雷山县| 晋城| 江油市| 巴里| 阜康市| 荣成市|