OPENCV(0-1之0.1)

OPENCV-0.1

  • 学习安排
  • 计算机视觉简介
    • 是什么?
    • 应用领域
    • 基础概念
  • OpenCV简介
    • 历史背景和主要贡献者
    • 支持的语言和平台
    • 主要模块和功能
  • 安装(windows_python)
    • pip安装
    • 验证安装(记得安装jupyter)
  • 第一个OpenCV程序
  • 实践练习

官方文档

学习安排

  1. 计算机视觉简介

目标:了解计算机视觉是如何使计算机“看”到并理解图像和视频的。
学习内容

  1. 计算机视觉的定义和应用领域,比如自动驾驶、安防监控、医学图像处理等。
  2. 基础概念,包括图像识别、物体检测、图像分割、场景重建等。
  1. OpenCV简介

目标:了解OpenCV库的历史、特点和能为你的项目带来什么优势。
学习内容

  1. OpenCV的历史背景和主要贡献者。
  2. OpenCV支持的语言和平台。
  3. OpenCV库的主要模块和功能。
  1. 安装OpenCV

目标:在你的操作系统上安装OpenCV,并配置好开发环境。
学习内容

  1. 在Windows上安装OpenCV
  1. 第一个OpenCV程序

目标:学会使用OpenCV读取、显示和保存图像。
学习内容

  1. 使用cv2.imread()函数读取图像。
  2. 使用cv2.imshow()函数显示图像。
  3. 使用cv2.imwrite()函数保存图像。
  4. 了解图像的基本属性,如大小、类型和像素值。
  1. 实践练习
  1. 读取并显示图像:选择一张图像,使用OpenCV读取并显示出来。
  2. 图像转换:将读取的图像转换为灰度图,并显示。
  3. 保存图像:将转换后的灰度图保存到你的磁盘上。

计算机视觉简介

是什么?

计算机视觉是一门研究如何使机器“看”的科学。更具体地说,它是指用摄像机和计算机代替人眼对目标进行识别、跟踪和测量的技术,进而对这些信息进行处理,使计算机能够进一步处理、理解和解释视觉世界。

应用领域

自动驾驶:利用计算机视觉来识别道路上的车辆、行人、交通标志等,实现自动驾驶汽车的导航和安全。
安防监控:通过监控视频来检测异常行为、识别特定人群,提高安全防护效率。
医学图像处理:分析X光片、MRI等医学图像,帮助诊断疾病、规划治疗方案。
零售:在零售行业中,计算机视觉技术可以用于顾客行为分析、智能结账系统等。
增强现实(AR)和虚拟现实(VR):通过理解和解释用户的视觉环境,增强或创建全新的虚拟体验。

基础概念

图像识别:从图像中识别一个或多个特定对象的过程。这是计算机视觉中最基本的任务之一,比如识别照片中的人脸。
物体检测:不仅识别图像中的对象,还确定它们在图像中的位置。通常表现为定位框或边界框。
图像分割:将图像细分为多个部分或对象的过程。目的是简化或改变图像的表现形式,使其更容易分析。
场景重建:通过分析图像或视频序列来重建三维场景的过程。这在自动驾驶、机器人导航等领域非常重要。

OpenCV简介

历史背景和主要贡献者

历史背景:OpenCV最初由Intel在1999年启动,并在2000年首次公开发布。该项目的目的是提供一个通用的基础设施,能够加速计算机视觉的应用开发过程,并推动该领域内的商业应用和学术研究。Gary Bradski是OpenCV项目的创始人之一。
主要贡献者:自诞生以来,OpenCV已经吸引了全球数千名开发者的贡献。虽然最初由Intel支持,但后来也得到了其他公司和组织的支持,包括Google、NVIDIA、AMD等,它现在是由一个非营利组织——OpenCV.org负责维护和发展。

支持的语言和平台

支持的语言:OpenCV最初是用C++编写的,提供了良好的C++接口。随着项目的发展,它现在也提供了Python、Java和MATLAB等语言的接口,这使得它可以轻松地被集成到各种应用中。
支持的平台:OpenCV可以在多种操作系统上运行,包括Windows、Linux、Mac OS X、甚至在移动平台如Android和iOS上也有良好支持。

主要模块和功能

核心功能(Core functionality):基本数据结构,绘图函数,数组操作等。
图像处理(Imgproc):图像滤波,图像变换,颜色空间转换等。
图像分析(Imgcodecs):读写图像,图像编码等。
视频分析(Video):运动估计,背景减法等。
特征检测和描述(Features2D):关键点检测,描述符提取等。
摄像头标定和3D重建(Calib3d):立体视觉,摄像头标定等。
机器学习(ML):SVM,决策树,神经网络等。
深度学习(Dnn):支持多种深度学习框架,如TensorFlow、Torch/PyTorch等。
等其他模块

安装(windows_python)

pip安装

前提是安装好python环境。
python:官网下载
anaconda:官网下载
tips:记得勾选添加环境变量。
在终端命令行中执行以下语句

pip install opencv-python

如下图所示(包含创建、切换conda环境):
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

验证安装(记得安装jupyter)

代码:

import cv2

# 打印OpenCV版本
print(cv2.__version__)

# 尝试打开摄像头
cap = cv2.VideoCapture(0)
if not cap.isOpened():
    print("无法打开摄像头")
else:
    print("摄像头已就绪")
    cap.release()

结果(记得打开摄像头权限,这里未打开):
在这里插入图片描述

第一个OpenCV程序

代码

import cv2

# 读取图像
image = cv2.imread('../image.jpg')  # 读取图片
# 打印图像的基本属性
print(f'Width: {image.shape[1]} pixels')
print(f'Height: {image.shape[0]} pixels')
print(f'Channels: {image.shape[2]}')
# 显示图像
cv2.imshow('Image', image)
cv2.waitKey(0)  # 等待任意键盘按键
cv2.destroyAllWindows()  # 关闭所有OpenCV窗口

# 保存图像
cv2.imwrite('image_copy.jpg', image)  # 保存图像的路径

结果
在这里插入图片描述

实践练习

import cv2

# 图像路径
image_path = '../image.jpg'

# 读取图像
image = cv2.imread(image_path)

# 检查图像是否正确加载
if image is None:
    print("Error: 图像未加载,请检查路径。")
else:
    # 转换图像为灰度图
    gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

    # 显示原图
    cv2.imshow('Original Image', image)
    # cv2.waitKey(0)  # 等待按键
    # cv2.destroyAllWindows()  # 关闭窗口

    # 显示灰度图
    cv2.imshow('Grayscale Image', gray_image)
    cv2.waitKey(0)  # 等待按键
    cv2.destroyAllWindows()  # 关闭窗口

    # 保存灰度图到磁盘
    save_path = 'gray_image.jpg'
    cv2.imwrite(save_path, gray_image)
    print(f"灰度图已保存到 {save_path}")

结果
在这里插入图片描述
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【LeetCode】升级打怪之路 Day 21:二叉树的最近公共祖先(LCA)问题

今日题目: 236. 二叉树的最近公共祖先1644. 二叉树的最近公共祖先 II235. 二叉搜索树的最近公共祖先 目录 LCA 问题LC 236. 二叉树的最近公共祖先 【classic】LC 1644. 二叉树的最近公共祖先 II 【稍有难度】LC 235. 二叉搜索树的最近公共祖先 ⭐⭐⭐ 今天做了几道有…

一文弄清池化层(pooling)的作用

池化层的本质是一个下采样,数据经过卷积之后,维度会越来越高,在特征图没有较大改变的情况下,参数量却上涨的很快,造成模型的训练困难和过拟合现象,所以将池化层置于连续的卷积层之间,以压缩数据量和参数以减少过度拟合,对卷积层输出的特征图进行特征选择。池化层的具体操作是将…

考虑功率均分与电压频率的事件触发分布式二次控制MATLAB模型

微❤关注“电气仔推送”获得资料(专享优惠) 模型简介 此模型是在《基于事件触发机制的孤岛微电网二次电压与频率协同控制MATLAB仿真模型》上进一步创作的,之前的模型只考虑了二次电压与频率控制,并没有考虑均分这一项点。 因此…

【考研数学】打基础用张宇《30讲》还是武忠祥《基础篇》?

基础课不太可能所有的东西全都覆盖,还是先搭起一个知识框架,然后不断的填充和完善。 所以不必太过于在意少一些东西,我们不可能一口吃成胖子,基础知识肯定不会遗漏的,只可能一些技巧不到位。 从自己的情况考虑&#…

前端Vue列表组件 list组件:实现高效数据展示与交互

前端Vue列表组件 list组件:实现高效数据展示与交互 摘要:在前端开发中,列表组件是展示数据的重要手段。本文将介绍如何使用Vue.js构建一个高效、可复用的列表组件,并探讨其在实际项目中的应用。 效果图如下: 一、引言…

DETR Doesn’t Need Multi-Scale or Locality Design

论文名称:PlainDetr 发表时间:ICCV2023 开源代码 作者及组织: Yutong Lin,Yuhui Yuan等,来自西安交大,微软亚洲研究院。 前言 自Detr以来,后续paper的改进的方向:主要是将归纳偏置重新又引入进…

如何在群晖用Docker本地搭建Vocechat聊天服务并无公网ip远程交流协作

文章目录 1. 拉取Vocechat2. 运行Vocechat3. 本地局域网访问4. 群晖安装Cpolar5. 配置公网地址6. 公网访问小结 7. 固定公网地址 如何拥有自己的一个聊天软件服务? 本例介绍一个自己本地即可搭建的聊天工具,不仅轻量,占用小,且功能也停强大,它就是Vocechat. Vocechat是一套支持…

前端之用html做一个用户登陆界面

用户登陆界面 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>用户注册页面</title></head> <body><form action"https://www.baidu.com" method"post">…

C语言函数—关于静态库

具体的函数声明和定义请参考上一篇文章 如果我们成为了库的开发者&#xff0c;要卖给别人C语言库&#xff0c;该怎么办呢&#xff1f; A不会写减法&#xff0c;想找你买一个函数 但是&#xff0c;他给的太少了&#xff0c;你不想把源码卖给他 那怎么办呢&#xff1f; 首先&…

如何使用vue定义组件之——父组件调用子组件数据

首先&#xff0c;准备父子容器&#xff1a; <div class"container"><my-father></my-father><my-father></my-father><my-father></my-father><!-- 此处无法调用子组件&#xff0c;子组件必须依赖于父组件进行展示 --&…

windows的vmdk文件转qcow2运行蓝屏

背景 使用qemu-img将做好的vmware虚拟机转为qcow2到gns3中运行&#xff0c;Linux、Win7、Win10都没出现蓝屏&#xff0c;但Win XP却在开机时蓝屏了&#xff0c;错误代码&#xff1a;0x0000007B 解决方案 最终在proxmox上找到方案&#xff1a;https://pve.proxmox.com/wiki/Ad…

什么是架构?架构设计原则是哪些?什么是设计模式?设计模式有哪些?

什么是架构?架构设计原则是哪些?什么是设计模式?设计模式有哪些? 架构的本质 架构本身是一种抽象的、来自建筑学的体系结构,其在企业及IT系统中被广泛应用。 架构的本质是对事物复杂性的管理,是对一个企业、一个公司、一个系统复杂的内部关系进行结构化、体系化的抽象,…

【42 Pandas+Pyecharts | 某瓣电影Top250数据分析可视化】

文章目录 &#x1f3f3;️‍&#x1f308; 1. 导入模块&#x1f3f3;️‍&#x1f308; 2. Pandas数据处理2.1 读取数据2.2 查看数据信息2.3 查看数据描述信息2.4 将中国地区语言修改为中文 &#x1f3f3;️‍&#x1f308; 3. Pyecharts数据可视化3.1 各年份上映电影数量3.2 电…

【数据库-黑马笔记】基础-SQL

本文参考b站黑马数据库视频,总结详细全面的笔记 ,可结合视频观看1~26集 MYSQL 的基础知识框架如下 目录 一、MYSQL概述 1、数据库相关概念 2、MYSQL的安装及启动 二、SQL 1、DDL【Data Defination】 2、DML【Data Manipulation】 ①、插入 ②、更新和删除 3、 DQL【Data…

基于Java+SpringBoot+vue+element实现婚纱摄影网系统

基于JavaSpringBootvueelement实现婚纱摄影网系统 &#x1f345; 作者主页 央顺技术团队 &#x1f345; 欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; &#x1f345; 文末获取源码联系方式 &#x1f4dd; 文章目录 基于JavaSpringBootvueelement实现婚纱摄影网系统前言介…

深度学习进阶:揭秘强化学习原理,实战应用全解析!

作为机器学习领域的一大分支&#xff0c;强化学习以其独特的学习方式吸引了众多研究者和实践者的目光。强化学习&#xff0c;顾名思义&#xff0c;是通过不断地强化与环境的交互来优化决策策略。在这个过程中&#xff0c;智能体通过试错&#xff0c;根据环境给出的奖励信号来调…

反无人机电子护栏:原理、算法及简单实现

随着无人机技术的快速发展&#xff0c;其在航拍、农业、物流等领域的应用日益广泛。然而&#xff0c;无人机的不规范使用也带来了安全隐患&#xff0c;如侵犯隐私、干扰航空秩序等。为了有效管理无人机&#xff0c;反无人机电子护栏技术应运而生。 目录 一、反无人机电子护栏…

《OWASP TOP10漏洞》

0x01 弱口令 产生原因 与个人习惯和安全意识相关&#xff0c;为了避免忘记密码&#xff0c;使用一个非常容易记住 的密码&#xff0c;或者是直接采用系统的默认密码等。 危害 通过弱口令&#xff0c;攻击者可以进入后台修改资料&#xff0c;进入金融系统盗取钱财&#xff0…

现代化的轻量级Redis桌面客户端Tiny RDM

​欢迎光临我的博客查看最新文章: https://river106.cn 1、简介 Tiny RDM&#xff08;全称&#xff1a;Tiny Redis Desktop Manager&#xff09;是一个界面现代化的轻量级Redis桌面客户端&#xff0c;支持Linux、Mac和Windows。它专为开发和运维人员设计&#xff0c;使得与Red…

电脑音频显示红叉怎么办?这里提供四种方法

前言 如果你在系统托盘中看到音量图标上的红色X,则表示你无法使用音频设备。即使音频设备未被禁用,当你运行音频设备疑难解答时,仍然会看到此错误。 你的电脑将显示已安装高清音频设备,但当你将鼠标悬停在图标上时,它将显示未安装音频输出设备。这是一个非常奇怪的问题,…