
人工智能Python&OpenCV
文章平均质量分 72
Python语言和人工智能相关框架算法和OpenCV图像处理算法
keneyr
一个兴趣广泛/想成为大佬 且 未遂的二道小贩子
展开
-
形态学图像处理之边界提取与跟踪
边界提取要在二值图像中提取物体的边界,容易想到的一个方法是将所有物体内部的点删除(置为背景色)。具体地说,可以逐行扫描图像,如果发现一个黑点的8个邻域都是黑点,则该点为内部点,在目标图像中将它删除。实际上这相当于采用一个3*3的结构元素对原图进行腐蚀,使得只有那些8个邻域都有黑点的内部点被保留,再用原图像减去腐蚀后的图像,恰好删除了这些内部点,留下了边界像素。这过程如下图所示。示例演示利用OpenCV实现上面边界提取的功能。#include<open...转载 2021-03-27 16:54:26 · 1993 阅读 · 0 评论 -
四连通与八连通
四连通与八连通所谓四连通区域或四邻域,是指对应像素位置的上、下、左、右,是紧邻的位置。共4个方向,所以称之为四连通区域,又叫四邻域。所谓八连通区域或八邻域,是指对应位置的上、下、左、右、左上、右上、左下、右下,是紧邻的位置和斜向相邻的位置。共8个方向,所以称之为8连通区域或八邻域。八连通则定义为:对每一个值为1的点若其八连通有一个点的值也为1,那么这两个点就归为一个物体。从8连通的定义公式可以看到,其为N4四连通并上右下、右上、左下、左上四点,即四连通...转载 2021-03-27 09:54:07 · 5292 阅读 · 0 评论 -
OpenPose的18和25关节点对应顺序
OpenPose的18和25关节点对应顺序1、18点模型对应位置:// {0, “Nose”},// {1, “Neck”},// {2, “RShoulder”},// {3, “RElbow”},// {4, “RWrist”},// {5, “LShoulder”},// {6, “LElbow”},// {7, “LWrist”},// {8, “RHip”},// {9, “RKnee”},// {10, “RAnkle”},// {11, “LHip”},// {转载 2021-02-23 15:23:42 · 5085 阅读 · 0 评论 -
BP神经网络进阶-MINIST分类
BP神经网络进阶前言在BP神经网络原理探索一文中,只是介绍了简单的回归,并给出简单的回归代码。这次要涉及到BP神经网络的分类问题,以在博客园中上蹿下跳异常活泼的MINIST数据集分类为练手~MINIST数据集大多数示例使用手写数字的MNIST数据集。该数据集包含60,000个用于训练的示例和10,000个用于测试的示例。这些数字已经过尺寸标准化并位于图像中心,图像是固定大小(28x28像素),其值为0到1。为简单起见,每个图像都被平展并转换为784(28 * 28)个特征的一维numpy数组。注原创 2021-02-13 09:46:02 · 4500 阅读 · 2 评论 -
BP神经网络原理探索
前言本博讲述BP神经网络的原理,并给出一个小项目的练手手~原理稳住别怕,我们上来先定义了三层网络,输入层(第0层),隐藏层(第1层),输出层(第二层)。并且每个结点没有偏置(有偏置原理完全一样),激活函数为sigmod函数(不同的激活函数,求导不同),符号说明如下:对应网络如下:能看懂吗?看不懂出门左转先把神经元这些最最最最基本东西的概念看一遍再拐回来…其中对应的矩阵表示如下:X=Z0=[0.359]X=Z_0=\begin{bmatrix} 0.35 \\ 9 \end{bmatrix原创 2021-02-12 17:15:05 · 603 阅读 · 0 评论 -
行为识别数据集汇总
行为识别数据集汇总The KTH Dataset(2004)KTH数据集于2004 年的发布,是计算机视觉领域的一个里程碑。此后,许多新的数据库陆续发布。数据库包括在 4个不同场景下 25 个人完成的 6 类动作(walking, jogging, running,boxing, hand waving and hand clapping)共计 2391个视频样本,是当时拍摄的最大的人体动作数据库,它使得采用同样的输入数据对不同算法的性能作系统的评估成为可能。数据库的视频样本中包含了尺度变化、 衣着变化转载 2021-01-24 09:58:46 · 3426 阅读 · 1 评论 -
OpenCV中的inRange()
【1】inRange()函数OpenCV中的inRange()函数可实现二值化功能(这点类似threshold()函数),更关键的是可以同时针对多通道进行操作,使用起来非常方便!主要是将在两个阈值内的像素值设置为白色(255),而不在阈值区间内的像素值设置为黑色(0),该功能类似于之间所讲的双阈值化操作。函数原型(C++): void inRange(InputArr...转载 2019-07-11 21:22:10 · 38192 阅读 · 4 评论 -
OpenCV circle()函数
这个函数其实就是画圆:cvCircle(CvArr* img, CvPoint center, int radius, CvScalar color, int thickness=1, int lineType=8, int shift=0)img为源图像指针center为画圆的圆心坐标radius为圆的半径color为设定圆的颜色,规则根据B(蓝)G(绿)R(红)thic...原创 2019-07-11 00:03:44 · 33928 阅读 · 4 评论 -
opencv灰度图at<uchar>(i, j)显示不出来--乱码
如果你也是单通道灰度图的话,和我一样的情况的话,记得转成intint(mat.at<uchar>(i, j)原创 2019-05-22 17:12:07 · 1630 阅读 · 0 评论 -
模式识别之Shape Context---利用Shape Context进行形状识别
本文主要是形状轮廓匹配中的ShapeContext算法。本文属于转载。原文讲的够好了。原文:https://www.cnblogs.com/pengkunfan/p/4433510.html什么是Shape Context Shape Context是一个用于形状识别的,非常经典的特征(一串便于计算机处理的数字)提取方法,它由Serge Belongie和Jitendra ...转载 2019-05-20 22:48:18 · 2331 阅读 · 0 评论 -
OpenCV3.x+cmake+win+vs
今天在使用opencv3.4版本的内部特征点算法的时候,竟然提醒我黑人问号脸??????什么cpp,怎么调用opencv内部的函数还会特么出问题呢、还偏偏出在Compute()函数调用的时候。搜了搜博客,竟然是opencv需要cmake?纳尼?为什么需要cmake?cmake有啥用?为什么需要Cmake你有没有发现,调用opencv的时候想要查看他们的cpp文件,都找不到。顶多...原创 2019-04-19 19:42:19 · 233 阅读 · 0 评论 -
OpenCV进行图像相似度对比的几种办法:PSNR/感知哈希/计算特征点
本文转载自:OpenCV进行图像相似度对比的几种办法一、PSNR峰值信噪比PSNR(Peak Signal to Noise Ratio),一种全参考的图像质量评价指标。原理简介https://en.wikipedia.org/wiki/Peak_signal-to-noise_ratioPSNR是最普遍和使用最为广泛的一种图像客观评价指标,然而它是基于对应像素点间的误差,即基...转载 2019-04-21 00:06:05 · 1982 阅读 · 0 评论 -
Opencv创建纯色图
Mat类的创建:方法一:通过读入一张图像,直接转换为Mat对象Mat image = imread("test.jpg");其中imread()方法需要传入String类型的值,一般都是图像文件路径。方法二:使用无参数构造函数,创建Mat对象Mat image = Mat();image.create(4, 4, CV_8UC3);此刻表示创建一个4x4...原创 2019-04-15 15:29:27 · 22744 阅读 · 0 评论 -
opencv3.4.0+vs2013+win10配置
垃圾记性,必须做个笔记。。。软件版本和系统:opencv3.4.0 、visual studio2013、win10 64位下载完opencv以后,解压。读者自行搜索相关资源下载吧。。配置环境变量,如下:打开vs,新建项目。。。然后好了,项目摆出了,右键点击属性然后是库目录然后是链接器然后就可以写出基本程序测验了。。。中间有很多波折。。忘了。。。。有一个可以用属性表的,比较方便,给出该大神的博客链...原创 2018-05-03 22:49:10 · 1410 阅读 · 0 评论 -
python opencv矩形框并切割
本博不具有普适性。https://blog.youkuaiyun.com/loovelj/article/details/78739790https://blog.youkuaiyun.com/wsp_1138886114/article/details/82945328pencv阈值https://blog.youkuaiyun.com/a19990412/article/details/81172426htt...原创 2019-10-23 18:00:58 · 3977 阅读 · 2 评论 -
在python3,opencv3下无法打开摄像头读取视频问题
在Anaconda3环境下装了conda opencv,结果自动装了3.1.0然后就能打开摄像头,但是读取不了视频。妈的,害我搞了半天,还以为是自己程序的问题。。结果竟然是版本的问题:然后我还不想自己cmake,所以又想偷懒,想直接在conda下安装,所以步骤是这样的,参考这篇博客:https://blog.youkuaiyun.com/xrinosvip/article/details...原创 2019-05-15 01:17:06 · 4491 阅读 · 0 评论 -
pdb调试
python调试一个很好的工具pdbimport pdb; pdb.set_trace();pdb常用命令:n:执行下一行 s:执行下一行,如果有函数,会进入函数体 c:让程序正常运行,直到遇到断点 p:打印某个变量 !:感叹号后面跟一个语句,可以直接改变某个变量 h:帮助 l:列出当前将要运行的代码块 b:设置断点,后面跟想要设置断点的行数 cl:清除所有的断点 j...原创 2019-01-04 17:48:30 · 838 阅读 · 0 评论 -
Python实战---抓取淘宝美食
系统:win10,Spyder3,MySQL话不多说,先上代码:# -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.ui import WebDriverWaitfrom seleniu...原创 2018-02-19 10:21:57 · 976 阅读 · 1 评论 -
Spyder+selenium+chrome之初学者配置
这里的Spyder是Anaconda3下的,系统win10.首先下载chrome驱动chromedriver.exe。找了好久终于在csdn上找到一个资源,然后下载zip文件,解压得到exe。把该exe文件放入chrome的路径下,比如本人的路径是C:\Program Files (x86)\Google\Chrome\Application,在高级系统环境设置的path里面加入这个路径,如图:然...原创 2018-02-12 11:54:17 · 6209 阅读 · 2 评论 -
Python实战---抓取猫眼电影TOP100
话不多说,直接上代码:# -*- coding: utf-8 -*-import requestsfrom requests import RequestExceptionimport reimport json#from multiprocessing import Pooldef get_one_page(url): headers={ '原创 2018-02-02 22:30:57 · 669 阅读 · 0 评论 -
Python实战---抓取头条网街拍美图
啊哈哈哈哈~今天成功的完成了抓取头条网街拍美图的小任务。虽然看的是网易云课堂的老师的讲解,但是里面还是有自己的思考滴!现记录如下:系统:windows10、Spyder~为什么我不用Ubuntu16,pycharm了呢。因为我的Ubuntu本本网坏掉了,如果能修好的话,我一定针对那个问题发个博。不过话外:Anaconda真的是好好用啊~强大、轻盈、美丽、优雅~最终结果,抓取头条的街拍美图,原创 2018-02-01 21:22:31 · 424 阅读 · 0 评论 -
Python实战--抓取拉勾网招聘信息
近两日,在网易云课堂上看了一个抓取拉勾网招聘信息的视频教程。学习颇多,以此记录。系统:Ubuntu16.04、Pycharm2017、python3.5+、Google Chrome。抓取的是拉勾网有关python的招聘信息的关键词。效果如图:下面是学习步骤以及心得记录:一、引入库需要导入的外接库是requests库和beautifulSoup库。这两个库都是爬虫里非常原创 2018-01-29 18:05:55 · 1604 阅读 · 0 评论 -
行为识别数据集汇总
1. The KTH Dataset(2004)KTH数据集于2004 年的发布,是计算机视觉领域的一个里程碑。此后,许多新的数据库陆续发布。数据库包括在 4个不同场景下 25 个人完成的 6 类动作(walking, jogging, running,boxing, hand waving and hand clapping)共计 2391个视频样本,是当时拍摄的最大的人体动作数据库,它使得...转载 2019-11-12 15:16:43 · 1551 阅读 · 0 评论 -
epoch、batch、training step(iteration)的区别
(1)iteration:表示1次迭代(也叫training step),每次迭代更新1次网络结构的参数;(2)batch-size:1次迭代所使用的样本量;(3)epoch:1个epoch表示过了1遍训练集中的所有样本。值得注意的是,在深度学习领域中,常用带mini-batch的随机梯度下降算法(Stochastic Gradient Descent, SGD)训练深层结构,它有一个...转载 2019-10-25 16:52:10 · 4685 阅读 · 1 评论 -
python2中的unicode()函数在python3中会报错: python2中的unicode()函数在python3中会报错:NameError: name 'unicode' is not
There is no such name in Python 3, no. You are trying to run Python 2 code in Python 3. In Python 3,unicodehas been renamed tostr.翻译过来就是:Python 3中没有这样的名字,没有。 您正在尝试在Python 3中运行Python 2代码。在Python 3...转载 2019-10-25 16:00:54 · 2586 阅读 · 0 评论 -
输出重定向之python2和python3的区别
python语句支持输出重定向到文件里,与shell类似使用“>>”来重定向输出。python2:logfile = open('mylog.txt', 'a')print >> logfile, 'Fatal error: invalid input'logfile.close()#mylog.txtFatal error: invalid i...转载 2019-10-20 13:19:31 · 273 阅读 · 0 评论 -
python中出现IndentationError:unindent does not match any outer indentation level错误
本博属转载:https://blog.youkuaiyun.com/u010412719/article/details/47089473今天在网上copy的一段代码,代码很简单,每行看起来该缩进的都缩进了,运行的时候出现了如下错误:【解决过程】1.对于此错误,最常见的原因是,的确没有缩进。根据错误提示的行数,去代码中看了下,看起来没有什么问题呀,都有缩进,而且语法也没有错误呀。2....转载 2019-05-29 22:16:11 · 7126 阅读 · 2 评论 -
UserWarning: invalid index of a 0-dim tensor
将pytorch更新到0.4.0最新版后对0.3.1版本代码会有如下警告,它在提醒用户下个版本这将成为一个错误1.[python]view plaincopyUserWarning:invalidindexofa0-dimtensor.ThiswillbeanerrorinPyTorch0.5.Usetensor.item()toconverta...转载 2019-05-16 19:57:56 · 265 阅读 · 0 评论 -
CUDA error:out of memory
今天在运行程序的时候,一直跟我报这个错误,说我CUDA内存不足。调试了很久,最后发现竟然是这样·····刚开始我怀疑是服务器上的显卡被人用了,但是当我mvidia-smi的时候发现3块GPU都没人用。。那这个问题显然是不可能了。那为何会这样呢?又有人说是TensorFlow和Pytorch的版本冲突。???我并没有搞到TensorFlow啊最后参考了该帖子:http:...原创 2019-05-16 16:27:33 · 32973 阅读 · 3 评论 -
Pytorch并行处理机制
本文属转载,原文地址:https://www.jianshu.com/p/9e36e5e36638?utm_source=oschina-appPytorch 的多 GPU 处理接口是 torch.nn.DataParallel(module, device_ids),其中 module 参数是所要执行的模型,而 device_ids 则是指定并行的 GPU id 列表。而其并行处理机...转载 2019-05-15 10:55:29 · 2914 阅读 · 0 评论 -
理解numpy mean(axis=?)
就是为了记载下来防止忘记,没什么技术含量。其实就是求平均值。参考博客:http://www.cnblogs.com/ymjyqsx/p/6495450.html>>X = np.float32(12,32,34,54)>>print X[12.32.34.54]>>print X.mean(axis=0)33.0>>print X...原创 2019-02-21 20:45:01 · 11789 阅读 · 1 评论 -
理解np.expand_dims()和np.delete()
主要是为了记在博客上让自己不忘掉,倒是没有什么技术含量。这个函数顾名思义就是扩展维度的。参考博客讲的很详细了,这里附上我的小实验:https://blog.youkuaiyun.com/qq_16949707/article/details/53418912expand_dims(a, axis)就是在axis的那一个轴上把数据加上去,这个数据在axis这个轴的0位置。 例如原本为一维的2个数据...原创 2019-02-21 20:10:32 · 3228 阅读 · 0 评论 -
MNIST-Tensorflow新手教程
在TensorFlow中文社区学习的帖子,好久没写博客了,这个教程非常适合新手学习,附上链接如下:http://www.tensorfly.cn/tfdoc/tutorials/mnist_pros.htmlMNIST是一个数字识别的数据集,笔记本一直是win10,就用spyder跑了一下,感觉很好。第一次的代码仿佛helloworld一样拥有新生儿纯洁的面孔,期间也出了很多莫名其妙的bu...原创 2018-08-19 22:39:48 · 894 阅读 · 0 评论