国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表
主站蜘蛛池模板: 泰安市| 西畴县| 积石山| 阆中市| 德格县| 荥阳市| 正宁县| 涟源市| 故城县| 临沧市| 张家川| 会泽县| 尚志市| 普陀区| 福泉市| 荆门市| 汪清县| 彩票| 阿合奇县| 弥渡县| 仪陇县| 红桥区| 静宁县| 上饶市| 绥阳县| 乡宁县| 哈巴河县| 雅安市| 永安市| 峨眉山市| 南通市| 淅川县| 于都县| 色达县| 岳普湖县| 庐江县| 杨浦区| 安乡县| 南靖县| 蓝山县| 郸城县|