CV基础(图像预处理)_图像cv-程序员宅基地

技术标签: 计算机视觉  

文章目录

CV基础

1.课程概述

1.1 计算机视觉的研究理论和应用

(1)模拟人类视觉的优越能力
(2)弥补人类视觉的缺陷

1.2 主要研究维度

•语义感知(semantic)

•几何属性(Geometry)
在这里插入图片描述

Tips

(1)神经网络不断增加层数一定会导致过拟合
(2)工业领域没有大量样本之前需要数据增强方式去获取数据
(3) OpenCL•URL: http://opencv.org/
(4)Caffe•函数库:http://caffe.berkeleyvision.org
(5)Torch(PyTorch)•函数库:URL: https://torch.ch(http://pytorch.org/)
(6)Tensorflow:https://www.tensorflow.org/
(7)Keras:兼容 Theano 和 Tensorflow 的深度学习高级包, https://keras.io

tensorflow基础

1.使用图 (graph) 来表示计算任务.
2. 在被称之为 会话 (Session) 的上下文 (context) 中执行图.
3. 使用 张量(tensor) 表示数据.
4. 通过 变量 (Variable) 维护状态.
5. 使用 feed 和 fetch 可以为任意的操作赋值或者从其中获取数据

图像预处理

1.颜色空间和图片处理

1.1彩色的三要素

亮度:即人眼对光的明亮程度的感受。
色调:人眼能看到的颜色种类,与光的波长有关
饱和度:颜色深浅程度。与各种颜色混入白光的比例有关。
以上 色调 + 饱和度 = 色度

1.2.基本颜色空间(常用的四种颜色空间)

1.2.1 RGB颜色空间

RGB彩色空间利用相加混合法将三个彩色分量按照不同的比例叠加,最终就可以在屏幕中显现出各种颜色。
在这里插入图片描述
任意的彩色光F都有一个配色的公式:F = r[R]+g[G]+b[B]
式中r,g,b为系数,r+g+b=1。故,知其二便可唯一确定色调。

此外对于一个像素颜色值的表示可以是(B,G,R)
取值范围:[0, 255] 或者[0.0, 1.0]

1.2.2CMY(K)颜色空间

•减法混色,印刷
•4通道
•Cyan通道•Magenta通道•Yellow通道•Key通道
一个像素颜色值:(c, m, y, k)
•取值范围•[0, 255]•[0.0, 1.0]
在这里插入图片描述

1.2.3 HSV颜色空间

在这里插入图片描述

1.2.4 CIE-XYZ颜色空间

在这里插入图片描述

1.3 图片存储原理

(1)分成三个通道然后去保存:
RGB三通道彩色图:图片转成3维矩阵([0,255])
(2)把图片灰度化存储:
单通道灰度图:亮度信息([0,255])
** Gray=Rx0.3+Gx0.59+Bx0.11**

常见的存储的格式有:bmp, jpg, png, tiff, gif, pcx, tga, exif, fpx, svg, psd, cdr, pcd, dxf, ufo, eps, ai, raw, WMF, webp等

2 图像处理

2.1 空间域处理-点运算(HE、CLAHE)

2.1.1 特征提取方法

通过直方图对图片数据/特征分布进行统计,包括以下特征:
•灰度、颜色
•梯度/边缘、形状、纹理
•局部特征点、视觉词汇

直方图

•区间(bin)----如上图区间就是5
•具有一定的统计或物理意义
•一种数据或特征的代表
•需要预定义或基于数据进行学习
•数值是一种统计量:概率、频数

所以实际上直方图就是对数据空间(bin)进行量化

2.1.2 HE(直方图均衡化)

定义:利用图像直方图对对比度进行调整的方法。
均衡化的基本思想是:尽量使得每个灰度级的像素数量相等。即不存在大片的相似像素,提高图像的对比度。

从下图的对比上看HE的实质上是对图像进行非线性拉伸,重新分配各个灰度单位中的像素点数量,使一定灰度范围像素点数量的值大致相等:
在这里插入图片描述进行HE操作以后,值变化不大,但是被拉开了:
在这里插入图片描述

(1)作用:直方图均衡化通常用来增加许多图像的局部对比度,尤其是当图像的有用数据的对比度相当接近的时候。
直方图均衡化以后,亮度可以更好地在直方图上分布。这样就可以用于增强局部的对比度而不影响整体的对比度,直方图均衡化通过有效地扩展常用的亮度来实现这种功能。

(2)缺点:无法处理图片中明显亮或者明显暗的部分,而且拉伸后有些灰度级可能不被映射到,造成图像观感上的颗粒感。

2.1.3 AHE(自适应直方图均衡)

对于图片中明显亮或者明显暗的部分,

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_41036272/article/details/122351610

智能推荐

深度学习与智能故障诊断学习笔记(三)——RNN与LSTM推导详解_深度学习 故障诊断-程序员宅基地

文章浏览阅读3.2k次,点赞7次,收藏38次。1.RNN1.1网络结构标准神经网络的输入输出在不同例子中可能有不同的长度,在学习中并不共享从不同位置上学到的特征。因为标准神经网络的训练集是稳定的,即所有的特征域表达的内容是同一性质的,一旦交换位置,就需要重新学习。故障诊断和健康管理属于带有时间序列的任务场景,在进行学习时参数量巨大,标准神经网络无法体现出时序上的前因后果,所以引入循环神经网络。如图所示为RNN循环神经网络的单元。其中为当前输入,为前一个状态,b为偏置项,tanh为激活函数,用于学习非线性部分。当前输入和前一个状态分别乘以_深度学习 故障诊断

026求总数问题_计算题目总数的代码-程序员宅基地

文章浏览阅读771次。026求总数问题1.题目2.代码3.个人见解4.输出结果截图1.题目集邮爱好者把所有的邮票存放在三个集邮册中,在A册内存放全部的十分之二,在B册内存放不知是全部的七分之几,在C册内存放303张邮票,问这位集邮爱好者集邮总数是多少?以及每册中各有多少邮票?2.代码#include<stdio.h>int main(void){ int a, b, c, x, su..._计算题目总数的代码

webGL创建旋转动画三角形_webgl 三角形 动画-程序员宅基地

文章浏览阅读237次。test.html<!doctype html><html lang="en"> <head> <meta charset="utf-8"> <title>WebGL Demo</title> <link rel="stylesheet" href="./webgl.css" type="text/css"> <script src="https://cdnjs.cloudfla_webgl 三角形 动画

python查询数据库语句大全_sql:查询语句大全-程序员宅基地

文章浏览阅读1.6k次。一、mysql查看数据库:SHOW DATABASES;创建数据库:CREATE DATABASE db_name;使用数据库:USE db_name;删除数据库:DROP DATABASE db_name;创建表:CREATE TABLE table_name(id TINYINT UNSIGNED NOT NULL AUTO_INCREMENT, --id值,无符号、非空、递增——唯一性,可做..._python数据库查询语句

10分钟学会python写游戏脚本!Python其实很简单_手游刷初始号的脚本怎么写-程序员宅基地

文章浏览阅读3.5k次,点赞3次,收藏51次。最近在玩儿公主连结,之前也玩儿过阴阳师这样的游戏,这样的游戏都会有个初始号这样的东西,或者说是可以肝的东西。当然,作为一名程序员,肝这种东西完全可以用写代码的方式帮我们自动完成。游戏脚本其实并不高深,最简单的体验方法就是下载一个Airtest了,直接截几个图片,写几层代码,就可以按照自己的逻辑玩儿游戏了。当然,本篇文章不是要讲Airtest这个怎么用,而是用原始的python+opencv来实现上面的操作。_手游刷初始号的脚本怎么写

CAD绿色版教程-程序员宅基地

文章浏览阅读10次。CAD绿色版下载地址百度网盘CAD完全卸载

随便推点

共存Python2.7和python3.4_v2库支持的python版本为2.7和3.4及以上版-程序员宅基地

文章浏览阅读415次。多版本Python共存[支持使用pip安装包] 有时特殊需要会要用到高版本的Python, 但是系统自带的版本又是很多其他工具依赖的, 不能随意更新。 所以就会考虑安装另一个版本的python环境, 然后需要用到这个版本时就在脚本头部指明 #/usr/bin/env python2.7 这样。## 下载要安装的 Python版本源码包(我用的是 2.7 版本)wget ‘http:_v2库支持的python版本为2.7和3.4及以上版

Linux 系统下 Python 的安装 详细步骤_python linus如何安装-程序员宅基地

文章浏览阅读1.4k次。Linux 系统下 Python 的安装一.安装环境准备centos7系统Python 安装包:官网地址:https://www.python.org/downloads/(速度不是一般的慢)镜像网址:http://npm.taobao.org/mirrors/python/ (速度较快)二.安装步骤1.将安装包从本地上传到远程服务器(可选用SSH工具)2.解压缩 (文件名可直接输入首字母按tab键)解压完成如图所示3.进入文件夹,输入 ./configure --prefix_python linus如何安装

代码点与代码单元和Unicode相关的UTF_代码的ut ui-程序员宅基地

文章浏览阅读1k次。java字符串由char序列组成,char数据类型是一个采用UTF-16编码表示Unicode代码点的代码单元,大多数的常用Unicode字符使用一个代码单元就可以表示,而辅助字符需要一对代码单元来表示,length方法返回的是采用UTF-16编码表示的给定字符串所需要的代码单元的数量,要想得到真实的长度即代码点的数量可以调用xxx.codePointCount(0,xxx.length())方法_代码的ut ui

JDK1.6在LINUX下的安装配置-程序员宅基地

文章浏览阅读63次。JDK1.6在LINUX下的安装是如何进行的呢,让我们开始我们的演示:Ubuntu Linux下jdk的安装与配置1.JDK1.6安装准备从sun公司网站www.sun.com下载linux版本的jdk,我下载的版本是JDK 6 Update 7,地址http://java.sun.com/javase/downloads/index.jspjdk-6u7-linux-i586..._jdk1.6在linux下是不是解开就能用

幅频响应 matlab画法,MATLAB环境下频率响应曲线的绘制方法.pdf-程序员宅基地

文章浏览阅读2.6k次。MATLAB环境下频率响应曲线的绘制方法黄 伟, 聂 东 , 陈英俊(广东肇庆学院电子信息工程系,肇庆526061)频域分析提供了一种简单有效的途径。关t词:MATLAB;Bode图;Nyquist图;Nichoh图前言 表示方法即为系统的频域分析方法。在频域分析M艄露AB作为一种高性能软件和编程语言,Nich..._肇庆学院 陈英俊

凸二次规划问题 库函数_c语言有二次规划函数吗-程序员宅基地

文章浏览阅读959次。#encoding: utf-8'''python 解决 凸二次规划问题 首先转换成标准型 1/2 * X^T * P *X + q ^ T * X限制条件 G * X <= h A * X = bx1 = (3,3), x2 = (4, 3) x3 = (1,1), 其中 x1 x2是正例, 求最大间隔分离 超平面'''import numpyf..._c语言有二次规划函数吗

推荐文章

热门文章

相关标签