python怎么计算图像梯度_opencv python图像梯度实例详解

这篇文章主要介绍了opencv python图像梯度实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

一阶导数与Soble算子

二阶导数与拉普拉斯算子

图像边缘:

Soble算子:

二阶导数:

拉普拉斯算子:

import cv2 as cv

import numpy as np

# 图像梯度(由x,y方向上的偏导数和偏移构成),有一阶导数(sobel算子)和二阶导数(Laplace算子)

# 用于求解图像边缘,一阶的极大值,二阶的零点

# 一阶偏导在图像中为一阶差分,再变成算子(即权值)与图像像素值乘积相加,二阶同理

def sobel_demo(image):

grad_x = cv.Sobel(image, cv.CV_32F, 1, 0) # 采用Scharr边缘更突出

grad_y = cv.Sobel(image, cv.CV_32F, 0, 1)

gradx = cv.convertScaleAbs(grad_x) # 由于算完的图像有正有负,所以对其取绝对值

grady = cv.convertScaleAbs(grad_y)

# 计算两个图像的权值和,dst = src1*alpha + src2*beta + gamma

gradxy = cv.addWeighted(gradx, 0.5, grady, 0.5, 0)

cv.imshow("gradx", gradx)

cv.imshow("grady", grady)

cv.imshow("gradient", gradxy)

def laplace_demo(image): # 二阶导数,边缘更细

dst = cv.Laplacian(image,cv.CV_32F)

lpls = cv.convertScaleAbs(dst)

cv.imshow("laplace_demo", lpls)

def custom_laplace(image):

# 以下算子与上面的Laplace_demo()是一样的,增强采用np.array([[1, 1, 1], [1, -8, 1], [1, 1, 1]])

kernel = np.array([[1, 1, 1], [1, -8, 1], [1, 1, 1]])

dst = cv.filter2D(image, cv.CV_32F, kernel=kernel)

lpls = cv.convertScaleAbs(dst)

cv.imshow("custom_laplace", lpls)

def main():

src = cv.imread("../images/lena.jpg")

cv.imshow("lena",src)

# sobel_demo(src)

laplace_demo(src)

custom_laplace(src)

cv.waitKey(0) # 等有键输入或者1000ms后自动将窗口消除,0表示只用键输入结束窗口

cv.destroyAllWindows() # 关闭所有窗口

if __name__ == '__main__':

main()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

本文标题: opencv python图像梯度实例详解

本文地址: http://www.cppcns.com/jiaoben/python/299473.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/560988.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vector简单应用

输出vector中元素&#xff0c;以及插入删除元素 #include<iostream> #include<vector> using namespace std; template<class T> void printvector(T s,T e)//输出vector元素 {for(; s!e; s)cout<<*s<<" ";cout<<endl; } int …

Linux ct获取本机ip,linux ip命令

ip 是个命令&#xff0c; ip 命令的功能很多&#xff01;基本上它整合了 ifconfig 与 route 这两个命令&#xff0c;不过ip 的功能更强大&#xff01;如果您有兴趣的话&#xff0c;请自行 vi /sbin/ifup 就知道整个 ifup 就是利用 ip这个命令来实现的。下面介绍一下使用方法[ro…

linux errno的作用域,关于比特科技c语言的学习博客(1)

写代码1创建工程2创建路径3创建源文件4写代码写c代码时.c文件是源文件.h是头文件写helloworld时return 0记得中间敲空格 main是主函数从main开始执行也是程序的入口有且仅有一个int是整型的意思main前的int表示main函数调用返回一个整型值void main已经过时#include 包含一个叫…

python o创建文件_Python 文件I/O

模块让你能够有逻辑地组织你的Python代码段。把相关的代码分配到一个 模块里能让你的代码更好用&#xff0c;更易懂。模块也是Python对象&#xff0c;具有随机的名字属性用来绑定或引用。简单地说&#xff0c;模块就是一个保存了Python代码的文件。模块能定义函数&#xff0c;类…

函数对象应用

计算几个数的n次方和 #include<iostream> #include<vector> #include<algorithm> #include<numeric> #include<functional> using namespace std; int sumsquares(int total, int value) {return totalvalue*value; }template<class T>//…

C语言中各字母对应的数值,C语言中字符串与各数值类型之间的转换方法

C语言的算法设计中&#xff0c;经常会需要用到字符串&#xff0c;而由于c语言中字符串并不是一个默认类型&#xff0c;其标准库stdlib设计了很多函数方便我们处理字符串与其他数值类型之间的转换。首先放上一段展示各函数使用的代码&#xff0c;大家也可以copy到自己的机器上运…

web服务面试python_Python面试重点(web篇)

写出常用的bootstrap的样式。导航栏,表单,轮播图,下拉菜单什么是响应式布局&#xff1f;响应式布局就是一个网站能够兼容多个终端,而不是为每个终端做一个特定的版本.优点:灵活性强,能解决多设备显示问题缺点:不兼容所有浏览器,一定程度改变布局结构请通过jQuery发送ajax请求。…

linux下的扑克游戏,linux下多线程扑克游戏框架.doc

linux下多线程扑克游戏框架linux下多线程扑克游戏框架/**rc.c*文件描述&#xff1a;*1)提供了linux下“升级”(北方常见的一种扑克玩法)游戏的框架。*2)库&#xff1a;glibc2.15&#xff1b;编译环境&#xff1a;gcc4.7.2;内核&#xff1a;3.8.4* 3) 编译&#xff1a;gcc -pthr…

python的array如何使用map_你应该了解的JavaScript Array.map()五种用途小结

前言从经典的 for 循环到 forEach() 方法&#xff0c;用于迭代数据集合的各种技术和方法比比皆是。但是现在比较流行的方法是 .map() 方法。.map() 通过指定函数调用一个数组中每一项元素&#xff0c;来创建一个新数组。 .map() 是一种 non-mutating(非变异) 方法&#xff0c;它…

(dp)数字三角形

题目方案1&#xff1a;递归方案二&#xff1a;递推 题目 数字三角形问题。有一个由非负整数组成的三角形&#xff0c;第一行只有一个数&#xff0c;除了最下行 之外每个数的左下方和右下方各有一个数 从第一行的数开始&#xff0c;每次可以往左下或右下走一格&#xff0c;直…

long在C语言中是非法字符吗,C程序设计实践——实验指导

一、课程的总体目标和具体要求总体目标&#xff1a;利用C语言和程序设计方法编制程序&#xff0c;借助计算机解决问题的基本能力。(支撑毕业能力要求1)独立解决文本处理、数学上的一些问题&#xff0c;编写较规范化的代码。(支撑毕业能力要求3)综合运用数学和程序设计方法&…

动规最长上升子序列

#include<iostream> #include<algorithm> using namespace std; #define maxx 101 int a[maxx]; int n; int maxlen[maxx];int main() {int i,j;cin>>n;for(i1;i<n;i){cin>>a[i];//数组a存数maxlen[i]1;//边界条件,每个数最长子序列至少为一}for(i2…

C语言实现一个随机测试加减乘除,编写程序:C语言实现一个随堂测试,能进行加减乘除运算...

//需要导入一个时间头文件&#xff1b;#include//bool类型;long show(){int num1,num2,x;long s;char c;srand((unsigned) time(NULL));//用时间做种子&#xff0c;每次产生的随机序列不同&#xff1b;num1rand()%101;num2rand()%101;xrand()%4;switch(x){case 0:c;snum1num2;b…

前端实现图片悬浮_悬浮图片之上效果实现

其实很简单&#xff0c;就是一个margin-top的问题&#xff0c;但是需要relative的定位方式才能悬在上面。html部分草帽的创新聚集国内外优秀人才&#xff0c; 聚焦新技术及产品研究&#xff0c; 以开放互联的理念&#xff0c; 驱动企业创新发展。实现怎样的创新服务全国品牌用户…

动规最长公共子序列

首先&#xff0c;有俩参数分别是s1,s2&#xff0c;那就要用二维数组. 确定状态maxlen(i,j)&#xff0c;表示s1第i个与s2第j个元素组成的最长公共子序列个数 再找临界状态&#xff1a;maxlen(i,0)0,maxlen(0,j)0 再找状态转移方程&#xff1a; 如果s1第i-1个元素和s2第i-1个…

用c语言程序编写电池管理系统,基于Freescale单片机的电池管理系统设计.doc

摘? 要&#xff1a;为了实现电动汽车电池的实时监控&#xff0c;在研究了锂离子电池特点的基础上&#xff0c;提出了一种用于混合动力汽车的分布式电池管理系统。其中&#xff0c;硬件系统包括电源模块、基于Freescale 系列单片机的主控制模块和子模块、均衡模块以及CAN 总线通…

华为手机解锁码计算工具_华为手机强制解锁工具

《华为解锁助手》是当前唯一一款华为手机强制解锁工具。华为解锁助手也是当前全球首款华为手机解锁工具&#xff0c;由绿豆团队根据华为官方技术规范精心打造&#xff0c;旨在极大简化华为手机的解锁流程并提升解锁效率。清晰的流程设计&#xff0c;手机基本信息只需输入一次就…

深入剖析:Super Jumping! Jumping! Jumping! (动规)

分析&#xff1a; 题意就是&#xff0c;在一个数组里找递增的子序列的最大和&#xff0c;而且子序列元素可以不相邻。 我先上一个错误代码&#xff0c;这是我刚看完题后一分钟就写的&#xff0c;事实上没想象中简单&#xff0c;等会我分析一下错误原因 #include<iostream…

文本导入数据到oracle_oracle导出数据到文本、从文本导入数据

.sqlset line 1000 --设置行的长度set pagesize 0 --输出不换页set feedback off --默认的当一条sql发出的时候&#xff0c;oracle会给一个反馈&#xff0c;比如说创建表的时候&#xff0c;如果成功命令行会返回类似&#xff1a;Table created的反馈,off后…

c语言5版第10章答案,第10章 指 针 参考答案 c语言(1)

10.1 输入3个整数&#xff0c;按由小到大的顺序输出。解&#xff1a;程序如下&#xff1a;(xt10-1.c)#includemain(){ intn1,n2,n3;int *p1,*p2,*p3;printf("Input three integers n1,n2,n3: ");scanf("%d,%d,%d",&n1,&n2,&n3);p1&n1;p2&a…