计算机视觉之可做什么
1、计算机视觉的应用
计算机视觉在我们生活中已经有了很广泛的应用,在我们可见、不可见;可感知、不可感知的地方,深深地影响了我们的生活、生产方式。
- 日常生活:美颜相机、火车站刷脸进站、线上办理业务的身份认证、自动驾驶等等
- 医学领域:医学影像分析、疾病筛查、病理学图像分析、药物研发、皮肤病检测、运动和康复治疗等等。
- 工业领域:质量与缺陷检测、自动化生产线和机器人、自动化物流和仓储管理、尺寸测量、几何分析、包装和标签识别、安全与安防监控、3D视觉等等。
- 农业领域:作物监测与健康分析、精准农业(精准施肥、灌溉)、杂草识别与自动除草、果实成熟度检测与自动采摘、牲畜监测与健康管理、种子质量检测、产量预测等等。
- 城市治理:智能交通管理、公共安全与安防监控、人群管理与公共秩序维护、智能停车管理、智能建筑与社区管理、智慧零售与城市商业管理等等。
- 商业领域:智能零售、客户行为分析、人脸支付、个性化广告、虚拟试衣和增强现实购物、商品监控与库存管理、防盗与安全监控、自动化物流与供应链管理、电子商务中的视觉搜索、品牌保护与假货识别、数字人等等。
计算机视觉在我们社会各方面都有深入的应用,各种名词眼花缭乱,让人应接不暇,看起来让人找不到头绪,这些眼花缭乱的应用都是由计算机视觉一些基础任务组成:图像分类、目标检测、目标分割、图像生成、视觉多模态,这些基础任务最基本的原理都是一样的:数值回归。
2、视觉基础任务
2.1 图像分类
图像分类是根据图像中的内容把类别标签分配给图像。比如我们生活中的刷脸就有一个步骤是图像分类,即把类别标签分给人脸。
图像分类是怎么做的呢?图像在计算机中是一堆数据,不同内容的数据不一样,直观经验是直接对比这些数据距离的远近,也就是这些数据的相似程度,但是图像是矩形的,目标不可能正好也是矩形的,也就是说图像中有背景,而且同一类目标的会存在外观上的差别,比如颜色;即使同一个目标的也可能存在柔性变化、姿态变化。比如下图鸟的图片,鸟有正对摄像机,有侧对摄像机的;有的鸟嘴张开了,有的闭着的;有的头歪着,有的正的,有的背景时天空,有的背景时地面,等等这些因素都会影响算法的分类准确性。因此需要能获取能描述目标本质的特征,而不是看起来的特征,比如人有两条腿和两条胳膊,不能因为某个人少了一条就说不是人。




因此,首先让要分类的标签内容占据图像的主要部分,尽量减少背景的影响;然后利用一定手段获取图像特征,使得获取的特征具有一定抗干扰能力,如抗光照变化,柔性目标外形变化等等;最后利用分类器将图像划分到某一个类中。
2.2 目标检测
目标检测是从图像中把所需要的目标定位出来,并给出类别标签。目标检测中包含了两个部分:找到目标位置和确定目标的类别(即分类)。位置一般用矩形框表示,如下图所示。
目标检测是在一张完整的图像中,把占图像比较小的目标识别和定位出来。目标检测里的分类不是整张图的分类,而是图像中某个区域的分类,确定这块区域的标签信息。
我们人定位识别某个目标是一个非常自然而且似乎是一起完成的,对我们人来说似乎是非常具象的。图像在计算机里是一堆数字,虽然我们知道这些数字表示图像,但是如果把这些数字给我们看,我们是无法知道里面有什么的。那计算机怎么定位识别目标的呢?这些数字经过显示器能让我们区分不同的目标,表明这些数字是有规律的,并且数字之间存在一定的关联,才使得人能够看明白里面的内容。
2.3 目标分割
目标分割和目标检测有些类似,都是确定某个区域的像素是否属于某个目标类别;不同的是目标分割确定图像哪些像素属于目标,是像素级别的判别,理想情况下,目标分割不包含背景的像素。目标分割中包含了两个部分:确定像素是否属于目标以及目标的类别(即分类)。目标分割相对于目标检测来说,更加定准定位目标。如下图所示,矩形框是目标检测的结果,斑马上透明色是目标分割的结果,分割精细的描述了目标的边界。
2.4图像/视频生成
图像/视频生成是根据一定的输入而生成图像/视频。图像生成相对来说比较简单,应用比较广。可以文生图,也可以图生图。文生图很多人都不陌生,很多人在工作中直接会用到;图生图就是要输入图像,生成另一幅图像,像老图像修复、灰度图像上色、美颜、超分等等都可以看作是图生图。下图是在文生图网站上生成的图,我给的文本是高原草原风光,但是生成的图完全不符合,这也说明视觉算法很多时候也会失灵的。
2.5视觉多模态
视觉多模态是最近几年才火爆的,输入是视觉和其他的数据(如文本、语音等),不同的模型可以完成不同的任务,如生成、检测、图像描述等等。下图是智谱AI的CogVLM论文里的实验图,给模型一张图,一个prompt,模型根据这两个条件来生成对应的描述。视觉多模态还有一个应用:开放词汇,目标是让模型学习对应目标的图像、词汇,从而让模型能基于新的目标词汇在图像中找出/判断目标。
3、视觉算法演变
3.1 黎明前黑暗——深度学习之前的方法
早期的特征是人通过观察和数学上的推导获取的特征,再利用一些数学上的一些原理定义分类器,从而实现对目标的分类。这时期的算法在实验室条件,也就是严格控制环境条件下能取得不错的效果,但是基本上无法推广使用。这阶段主要方法haar+adaboost、HoG+SVM、LBP、PCA等等。
3.2 黎明——深度学习方法
我们现在处于黎明时期。这个时期,深度学习方法使得视觉算法获得了一定的社会应用,但是在有些时候也会出错,但是要么人可以忍受,要么用于辅助人的工作。不管怎样,是真的可以用了。这阶段的算法结构基础是卷积神经网络和Transformer。
3.3 未来
视觉算法未来会是什么样,现在无法预测,但是未来算法的数据基础很可能现在已经完善了,只是尚未到其爆发的时候。
4、总结
视觉算法已经获得了很多的应用,不仅仅是传统的分类、分割、检测获得应用,多模态大模型也逐步在各种场景有应用。
但是算法在应用中会遇到很多问题,这些问题归根到底主要是成本问题。因为算法在应用中是一个系统,而不仅仅是算法,系统其他部分也需要占用资源。如果为了追求效果而把算法模型做的很大,需要的资源就很多,这样成本就很高,特别是GPU资源。有的算法集成到低端的端侧芯片里,这些单薄的芯片里,不仅仅要运行算法,还有其他的业务需要运行,导致资源异常紧张,导致这个的主要原因就是成本。因为成本高了,愿意付费的用户就少了,企业可能入不敷出,所以为了保证企业生存,企业需要平衡各方面的因素。
相关文章:

计算机视觉之可做什么
1、计算机视觉的应用 计算机视觉在我们生活中已经有了很广泛的应用,在我们可见、不可见;可感知、不可感知的地方,深深地影响了我们的生活、生产方式。 日常生活:美颜相机、火车站刷脸进站、线上办理业务的身份认证、自动驾驶等等…...

观察者模式的思考
观察者模式由来 观察者模式(Observer Pattern)是一种行为型设计模式,它的起源可以追溯到20世纪90年代初,由设计模式四人帮(Erich Gamma, Richard Helm, Ralph Johnson 和 John Vlissides)在其著作《设计模…...

ORACLE SELECT INTO 赋值为空,抛出 NO DATA FOUND 异常
例子: DECLARE ORDER_NUM VARCHAR2(20); BEGIN SELECT S.ORDER_NUM INTO ORDER_NUM FROM SALES_ORDER S WHERE S.ID122344; DBMS_OUTPUT.PUT_LINE(单号: || ORDER_NUM); END; 在查询结果为空的情况下,以上代码会报错:未找到任何数据 解决方…...
GPT提示词
参考 提示词大全: GPT提示词大全(中英文双语)持续更新 提示词.com...

Redis协议详解及其异步应用
目录 一、Redis Pipeline(管道)概述优点使用场景工作原理Pipeline 的基本操作步骤C 示例(使用 [hiredis](https://github.com/redis/hiredis) 库) 二、Redis 事务概述事务的前提事务特征(ACID 分析)WATCH 命…...
LeetCode213:打家劫舍II
题目链接:213. 打家劫舍 II - 力扣(LeetCode) 代码如下 class Solution { public:int rob(vector<int>& nums) {if(nums.size() 0) return 0;if(nums.size() 1) return nums[0];if(nums.size() 2) return max(nums[0…...

linux一二三章那些是重点呢
第一章 静态库动态库的区别 什么是库 库文件是计算机上的一类文件,可以简单的把库文件看成一种代码仓库,它提供给使用者一些可以直接 拿来用的变量、函数或类。 如何制作 静态动态库 静态库: GCC 进行链接时,会把静态库中代码打…...
C语言中的程序入口:超越main函数的探索
在C语言中,尽管main函数是标准程序的默认入口点,但借助编译器特性和链接器选项,我们可以指定其他函数作为程序的入口。GCC编译器通过-e选项,允许我们将任何符合签名的函数作为程序的入口。这一特性可以用于特定的实验需求、特定系…...
《面试之MQ篇》
《面试之MQ篇》 1. 为什么要使用MQ 首先,面试官问的第一个问题或者说是逼问的一个问题:“为什么要使用MQ”其实面试官问这个问题就是想考察你MQ的特性,这个时候呢,我们必须要答出三点:解耦、异步、削峰。 1. 解耦 1. 传统系统…...

Git 分支操作-开发规范
一、背景 在实际开发中,一般在主分支的基础上单独创建一个新的分支进行开发,最后合并到master分支,而不是直接在master分支进行开发。 二、新建分支 1、初始状态,local为本地分支,remote为远程分支 2、单击 “Remot…...
JSONArray根据指定字段去重
JSONArray dataList new JSONArray();这儿省略dataList 加数据的过程 dataList new JSONArray(dataList.stream().distinct().collect(Collectors.toList())); Set<String> timestamps new HashSet<>();根据时间字段去重 dataList dataList.stream().map(obj -…...
线程有哪几种状态? 分别说明从一种状态到另一种状态转变有哪些方式?
在 Java 中,线程的生命周期管理通过不同的状态来跟踪。一个线程在其生命周期中可以处于多种状态,不同的状态之间会通过特定的事件发生转变。以下是 Java 线程的几种状态及其之间的转移方式: 1. 线程的状态 1.1 NEW(新建状态&…...
自注意力机制self-attention中的KV 缓存
在自注意力机制中,KV 缓存(Key-Value Caching)主要用于加速模型在推理阶段的计算,尤其是在处理长序列或者生成任务(如文本生成)时,这种缓存机制可以显著提高效率。 1. KV 缓存的背景 在 Trans…...
前端库--nanoid(轻量级的uuid)
文章目录 定义:生成方式:现实使用:NanoID 只有 108 个字节那么大NanoID更安全NanoID它既快速又紧凑 使用步骤1.安装nanoid包2.引入使用3.使用4.自定义字母 定义: UUID 是 通用唯一识别码(Universally Unique Identifierÿ…...
计算机基础-什么是网络端口?
网络端口可以想象成一个大型公寓楼的邮箱。每个公寓楼(这里指的是一个计算机或服务器)有很多个邮箱(即网络端口),每个邮箱都有一个独一无二的编号(端口号)。当一封信(网络数据包&…...

力扣动态规划基础版(斐波那契类型)
70. 爬楼梯https://leetcode.cn/problems/climbing-stairs/ 70.爬楼梯 方法一 动态规划 考虑转移方程和边界条件: f(x) f(x -1) f(x - 2);f(1) 1;f&…...

Java重修笔记 InetAddress 类和 Socket 类
InetAddress 类相关方法 1. 获取本机 InetAddress 对象:getLocalHost public static InetAddress getLocalHost() throws UnknownHostException 返回值:本地主机的名字和地址 异常:UnknownHostException - 如果本地主机名无法解析成地址 2…...

秋招突击——8/6——万得数据面试总结
文章目录 引言正文面经整理一1、讲一下java的多态,重载,重写的概念,区别2、说一下Java的数组,链表的结构,优缺点3、创建java线程的方式有哪些,具体说说4、创建线程池呢、每个参数的意义5、通过那几种方式保…...

STM32定时器
目录 STM32定时器概述 STM32基本定时器 基本定时器的功能 STM32基本定时器的寄存器 STM32通用定时器 STM32定时器HAL库函数 STM32定时器概述 从本质上讲定时器就是“数字电路”课程中学过的计数器(Counter),它像“闹钟”一样忠实地为处…...
第七课 Vue中的v-for遍历指令
Vue中的v-for遍历指令 v-for用于对象遍历(数组/JSON),渲染数据列表 基础示例: <div id"app"><ul><li v-for"val in arr">{{val}}</li></ul></div><script>new V…...

XML Group端口详解
在XML数据映射过程中,经常需要对数据进行分组聚合操作。例如,当处理包含多个物料明细的XML文件时,可能需要将相同物料号的明细归为一组,或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码,增加了开…...
R语言AI模型部署方案:精准离线运行详解
R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...

为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?
在建筑行业,项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升,传统的管理模式已经难以满足现代工程的需求。过去,许多企业依赖手工记录、口头沟通和分散的信息管理,导致效率低下、成本失控、风险频发。例如&#…...

2.Vue编写一个app
1.src中重要的组成 1.1main.ts // 引入createApp用于创建应用 import { createApp } from "vue"; // 引用App根组件 import App from ./App.vue;createApp(App).mount(#app)1.2 App.vue 其中要写三种标签 <template> <!--html--> </template>…...

【Zephyr 系列 10】实战项目:打造一个蓝牙传感器终端 + 网关系统(完整架构与全栈实现)
🧠关键词:Zephyr、BLE、终端、网关、广播、连接、传感器、数据采集、低功耗、系统集成 📌目标读者:希望基于 Zephyr 构建 BLE 系统架构、实现终端与网关协作、具备产品交付能力的开发者 📊篇幅字数:约 5200 字 ✨ 项目总览 在物联网实际项目中,**“终端 + 网关”**是…...

mac:大模型系列测试
0 MAC 前几天经过学生优惠以及国补17K入手了mac studio,然后这两天亲自测试其模型行运用能力如何,是否支持微调、推理速度等能力。下面进入正文。 1 mac 与 unsloth 按照下面的进行安装以及测试,是可以跑通文章里面的代码。训练速度也是很快的。 注意…...

VisualXML全新升级 | 新增数据库编辑功能
VisualXML是一个功能强大的网络总线设计工具,专注于简化汽车电子系统中复杂的网络数据设计操作。它支持多种主流总线网络格式的数据编辑(如DBC、LDF、ARXML、HEX等),并能够基于Excel表格的方式生成和转换多种数据库文件。由此&…...

PH热榜 | 2025-06-08
1. Thiings 标语:一套超过1900个免费AI生成的3D图标集合 介绍:Thiings是一个不断扩展的免费AI生成3D图标库,目前已有超过1900个图标。你可以按照主题浏览,生成自己的图标,或者下载整个图标集。所有图标都可以在个人或…...

Mysql故障排插与环境优化
前置知识点 最上层是一些客户端和连接服务,包含本 sock 通信和大多数jiyukehuduan/服务端工具实现的TCP/IP通信。主要完成一些简介处理、授权认证、及相关的安全方案等。在该层上引入了线程池的概念,为通过安全认证接入的客户端提供线程。同样在该层上可…...

内窥镜检查中基于提示的息肉分割|文献速递-深度学习医疗AI最新文献
Title 题目 Prompt-based polyp segmentation during endoscopy 内窥镜检查中基于提示的息肉分割 01 文献速递介绍 以下是对这段英文内容的中文翻译: ### 胃肠道癌症的发病率呈上升趋势,且有年轻化倾向(Bray等人,2018&#x…...