openCV图像变换

简介: 笔记

一. 边缘检测


1.实现步骤:
  1 消除噪声 ,使用高斯平滑滤波器卷积降噪。
  2 计算梯度幅值和反向
  3 非极大值抑制
  4 阈值

2.Canny边缘检测:Canny()函数

c++:
  void Canny(InputArray image,OutputArray edges, double threshold1,
  double threshold2,int apertureSize = 3,bool L2gradient = flase)
1.第一个参数,输入的图像
2. 第二个参数,输出的图像
3. 第三个参数,阈值1
4. 第四个参数,阈值2
5. 第五个参数,Sobel算子的孔径大小,默认为3
6. 第六个参数,一个计算图像梯度幅值的标识,某类为false

3.程序实例

#include<opencv2/opencv.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<opencv2/imgproc/imgproc.hpp>
using namespace cv;
int main(void)
{
  Mat src = imread("1.jpg");
  Mat dst,src1=src.clone();
  Mat edge,gray,edge1;
  dst.create(src1.size(),src1.type());
  cvtColor(src1,gray,COLOR_BGR2GRAY);   //转换成灰度图片
  blur(gray,edge,Size(3,3); //降噪
  Canny(edge, edge1,3,9,3);
  dst = Scalar::all(0);   // 将所有元素都设置为0
  src1.copyTo(dst,edge);
  imshow("B",dst);
  waitKey(0);
  return 0;
}

二. sobel算子


  1. 计算过程
    1 分别在x和y两个方向求导
    2 在图像的每一点,结合以上两个求出近似梯度
  2. Sobel算子:Sobel()函数
c++ :
void Sobel(InputArray src,OutputArray dst,int ddepth,int dx,int dy,int ksize=3,
double scale=1,double delta = 0,int borderType=BORDER_DEFAULT);
1. 第一个参数:输入的图片
2. 第二个参数:输出的图片
3. 第三个参数:输出图像的深度
4. 第四个参数:int类型dx,x方向上的差分阶数
5. 第五个参数:int类型dy,y方向上的差分阶数
6. 第六个参数:int类型的ksize,默认为3,表示Sobel核的大小,必须取1,3,5,7
7. 第七个参数:double类型的scale,计算时的缩放因子
8. 第八个参数:double类型的delta,表示偏移值。
9. 第九个参数:边界模式,默认为BORDER_DEFAULT

3.程序实例

#include<opencv2/opencv.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<opencv2/imgproc/imgproc.hpp>
using namespace cv;
int main(void)
{
  Mat grad_x,grad_y;
  Mat abs_grad_x,abs_grad_y,dst;
  Mat src = imread("1.jpg");
  imshow("AA",src);
    // 计算x方向的梯度
  Sobel(src,grad_x,CV_16S,1,0,3,1,1,BORDER_DEFAULT);
  convertScaleAbs(grad_x,abs_grad_x);
  imshow("BB",abs_grad_x);
  // 计算y方向的梯度。
  Sobel(src,grad_y,CV_16S,0,1,3,1,1,BORDER_DEFAULT);
  convertScaleAbs(grad_y,abs_grad_y);
  imshow("CC",abs_grad_y);
  waitkey(0);
  return 0;
}


三. 拉普斯拉变换


  1. 1.Laplaceian()函数
c++:
void Laplaceian(InputArray src,OutputArray dst,int ddepth,int ksize=1,
double scale=1,double delta=0,intborderType=BORDER_DEFAULT);
1. 第一个参数:输入的图片
2. 第二个参数:输出的图片
3. 第三个参数:目标图像的深度
4. 第四个参数:计算二阶导数的滤波器的孔径尺寸
5. 第五个参数:缩放因子
6. 第六个参数:偏移值
7. 第七个参数:边界模式

2.程序实例

#include<opencv2/opencv.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<opencv2/imgproc/imgproc.hpp>
using namespace cv;
int main(void)
{
  Mat src,src1,src_gray,dst,abs_gray;
  src = imread("1.jpg");
  GaussianBlur(src,src1,Size(3,3),0,0,BORDER_DEFAULT);
  cvtColor(src1,src_gray,COLOR_RGB2GRAY);
  Laplaceian(src_gray,dst,CV_16S,3,1,0,BORDER_DEFAULT);
  convertScaleAbs(dst,abs_dst);
  imshow("A",abs_dst);
  waitKey(0);
  return 0;
}

三. scharr滤波器


使用Scharr滤波器分别计算x或y方向的图像差分。

c++:
void Scharr(InputArray src,OutputArray dst,int ddepth,int dx,int dy,
double scale=1,double delta=0,intborderType = BORDER_DEFAULT);
1. 第一个参数:输入图像
2. 第二个参数:输出图像
3. 第三个参数:输出图像深度
4. 第四、五个参数:计算x,y方向的梯度
5. 第六个参数:缩放因子
6. 第七个参数:偏移值
7. 第八个参数:边界模式

2.程序实例

#include<opencv2/opencv.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<opencv2/imgproc/imgproc.hpp>
using namespace cv;
int main(void)
{
  Mat grad_x,grad_y;
  Mat abs_grad_x,abs_grad_y,dst;
  Mat src = imread("1.jpg");
  Scharr(src,grad_x,CV_16S,1,0,1,0,BORDER_DEFAULT);
  convertScaleAbs(grad_x,abs_grad_x);
  imshow("A",abs_grad_x);
  Scharr(src,grad_y,CV_16S,0,1,1,0,BORDER_DEFAULT);
  convertScaleAbs(grad_y,abs_grad_y);
  imshow("B",abs_grad_y);
  waitKey(0);
  return 0;
}

公众号:FPGA之旅


目录
相关文章
|
1月前
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
310 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
2月前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
47 4
|
2月前
|
存储 计算机视觉
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
本文介绍了使用OpenCV进行图像读取、显示和存储的基本操作,以及如何绘制直线、圆形、矩形和文本等几何图形的方法。
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
|
3月前
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
WK
|
3月前
|
编解码 计算机视觉 Python
如何在OpenCV中进行图像转换
在OpenCV中,图像转换涉及颜色空间变换、大小调整及类型转换等操作。常用函数如`cvtColor`可实现BGR到RGB、灰度图或HSV的转换;`resize`则用于调整图像分辨率。此外,通过`astype`或`convertScaleAbs`可改变图像数据类型。对于复杂的几何变换,如仿射或透视变换,则可利用`warpAffine`和`warpPerspective`函数实现。这些技术为图像处理提供了强大的工具。
WK
108 1
|
5月前
|
计算机视觉
opencv之形态变换
opencv之形态变换
|
5月前
|
算法 计算机视觉
【Qt&OpenCV 图像的感兴趣区域ROI】
【Qt&OpenCV 图像的感兴趣区域ROI】
164 1
|
5月前
|
运维 算法 计算机视觉
【Qt&OpenCV 图像的模板匹配 matchTemplate/minMaxLoc】
【Qt&OpenCV 图像的模板匹配 matchTemplate/minMaxLoc】
76 1
|
5月前
|
存储 编解码 算法
【Qt&OpenCV 检测图像中的线/圆/轮廓 HoughLinesP/HoughCircles/findContours&drawContours】
【Qt&OpenCV 检测图像中的线/圆/轮廓 HoughLinesP/HoughCircles/findContours&drawContours】
89 0
|
4月前
|
机器学习/深度学习 XML 计算机视觉
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。