Kotlin OpenCV 图像图像50 Haar 级联分类器模型
Kotlin OpenCV 图像图像50 Haar 级联分类器模型
- 1 OpenCV Haar 级联分类器模型
- 2 Kotlin OpenCV Haar 测试代码
1 OpenCV Haar 级联分类器模型
Haar级联分类器是一种用于对象检测(如人脸检测)的机器学习算法。它由Paul Viola和Michael Jones在2001年提出,通常用于实时检测,因为它速度快且性能良好。
| 基本原理 | 解释 |
|---|---|
| Haar特征 | Haar特征是从图像中提取的简单矩形特征,通过比较相邻区域的像素值来描述图像的局部特征。 常见的Haar特征有边缘特征、线条特征和四边形特征。 每个Haar特征值由区域内像素的加权和计算得到,具体公式为特征值 = 黑色区域像素值总和 - 白色区域像素值总和。 |
| 积分图(Integral Image) | 积分图是一种图像表示方法,方便快速计算矩形区域的像素和。 通过积分图,可以在常数时间内计算任意矩形区域的像素和。 |
| 级联分类器(Cascade Classifier) | 级联分类器由一系列弱分类器(如决策树桩)组成,每个弱分类器使用一个或多个Haar特征进行分类。 弱分类器按顺序排列,每个分类器将图像区域分为正例(目标对象)和负例(非目标对象)。 如果某个区域被认为是负例,则立即停止检测;如果被认为是正例,则继续传递到下一个分类器。 这种级联结构大大提高了检测速度,因为大部分非目标区域在早期就被排除。 |


| 文件夹 | 用途 | 特点 |
|---|---|---|
| lbpcascades | 包含基于局部二值模式 (Local Binary Patterns, LBP) 的级联分类器文件。LBP 是一种有效的纹理特征描述符,在对象检测中表现良好。 | 计算效率高: LBP 特征计算简单,因此在对象检测时速度较快。 鲁棒性: 对光照变化和其他环境变化有较好的鲁棒性。 常用分类器: 人脸检测等。 |
| hogcascades | 包含基于方向梯度直方图 (Histogram of Oriented Gradients, HOG) 特征的级联分类器文件。HOG 特征在检测行人等对象时表现良好。 | 特征描述能力强: HOG 特征能够捕捉对象的形状和外观信息。 高检测精度: 尤其在检测行人方面有较高的精度。 |
| haarcascades_cuda | 包含利用 CUDA 加速的 Haar 特征级联分类器文件。这些分类器利用 GPU 进行加速计算,提高检测速度。 类似于 haarcascades 文件夹中的文件,是加速版本。 | 高性能: 利用 GPU 的并行计算能力,大幅提升检测速度。 需要支持 CUDA 的 GPU: 需要系统安装 CUDA 并支持相应的 GPU 硬件。 |
| haarcascades | 包含基于 Haar 特征的级联分类器文件。这是 OpenCV 中最常用的对象检测分类器之一。 | 历史悠久: Haar 级联分类器是最早用于人脸检测的算法之一。 计算复杂度适中: 相比 LBP 更复杂,但特征描述能力也更强。 广泛应用: 用于人脸、眼睛、微笑等对象的检测。 |
haarcascades_cuda 和 haarcascades 文件的主要区别在于它们是否利用 CUDA 加速进行对象检测。
| haarcascades/haarcascades_cuda 文件夹 | 用途 |
|---|---|
| haarcascade_eye.xml | 用于检测人眼。 |
| haarcascade_eye_tree_eyeglasses.xml | 用于检测戴眼镜的人眼。 |
| haarcascade_frontalcatface.xml | 用于检测猫的正面脸部。 |
| haarcascade_frontalcatface_extended.xml | 用于检测猫的正面脸部(扩展版本)。 |
| haarcascade_frontalface_alt.xml | 用于检测人脸的另一个版本。 |
| haarcascade_frontalface_alt2.xml | 用于检测人脸的另一个替代版本。 |
| haarcascade_frontalface_alt_tree.xml | 用于检测人脸的另一个替代版本(树状结构)。 |
| haarcascade_frontalface_default.xml | 用于检测人脸的默认版本。 |
| haarcascade_fullbody.xml | 用于检测人体的完整体。 |
| haarcascade_lefteye_2splits.xml | 用于检测左眼(两部分)。 |
| haarcascade_license_plate_rus_16stages.xml | 用于检测俄罗斯车牌(16阶段)。 |
| haarcascade_lowerbody.xml | 用于检测人体的下半身。 |
| haarcascade_profileface.xml | 用于检测人脸的侧面(侧脸)。 |
| haarcascade_righteye_2splits.xml | 用于检测右眼(两部分)。 |
| haarcascade_russian_plate_number.xml | 用于检测俄罗斯车牌号码。 |
| haarcascade_smile.xml | 用于检测微笑。 |
| haarcascade_upperbody.xml | 用于检测人体的上半身。 |
| hogcascades文件夹 | 用途 |
|---|---|
| hogcascade_pedestrians.xml | 用于在图像或视频中检测行人。 |
| lbpcascades文件夹 | 用途 |
|---|---|
| lbpcascade_frontalcatface.xml | 用于检测猫的正面脸部。 |
| lbpcascade_frontalface.xml | 用于检测人脸的正面部分。 |
| lbpcascade_frontalface_improved.xml | 用于检测人脸的正面部分,改进版本。 |
| lbpcascade_profileface.xml | 用于检测人脸的侧面部分。 |
| lbpcascade_silverware.xml | 用于检测银器(如刀、叉、勺等餐具)。 |
2 Kotlin OpenCV Haar 测试代码
package com.xu.com.xu.imageimport org.opencv.core.MatOfRect
import org.opencv.core.Point
import org.opencv.core.Scalar
import org.opencv.highgui.HighGui
import org.opencv.imgcodecs.Imgcodecs
import org.opencv.imgproc.Imgproc
import org.opencv.objdetect.CascadeClassifier
import java.io.File
import java.util.*object FaceDetect {init {val os = System.getProperty("os.name")val type = System.getProperty("sun.arch.data.model")if (os.uppercase(Locale.getDefault()).contains("WINDOWS")) {val lib = if (type.endsWith("64")) {File("lib\\opencv\\x64\\" + System.mapLibraryName("opencv_java4100"))} else {File("lib\\opencv\\x86\\" + System.mapLibraryName("opencv_java4100"))}System.load(lib.absolutePath)}}@JvmStaticfun main(args: Array<String>) {face()}private fun face() {val facebook = CascadeClassifier("lib/opencv/data/haarcascades/haarcascade_frontalface_alt2.xml")val image = Imgcodecs.imread("C:\\Users\\hyacinth\\Desktop\\1.png")val face = MatOfRect()facebook.detectMultiScale(image, face)val reacts = face.toArray()println("匹配到 " + reacts.size + " 个人脸")for (i in reacts.indices) {Imgproc.rectangle(image,Point(reacts[i].x.toDouble(), reacts[i].y.toDouble()),Point((reacts[i].x + reacts[i].width).toDouble(), (reacts[i].y + reacts[i].height).toDouble()),Scalar(0.0, 0.0, 255.0), 2)Imgproc.putText(image,i.toString(),Point(reacts[i].x.toDouble(), reacts[i].y.toDouble()),Imgproc.FONT_HERSHEY_SCRIPT_SIMPLEX,1.0,Scalar(0.0, 0.0, 255.0),2,Imgproc.LINE_AA,false)}HighGui.imshow("人脸识别", image)HighGui.waitKey(0)}}

相关文章:
Kotlin OpenCV 图像图像50 Haar 级联分类器模型
Kotlin OpenCV 图像图像50 Haar 级联分类器模型 1 OpenCV Haar 级联分类器模型2 Kotlin OpenCV Haar 测试代码 1 OpenCV Haar 级联分类器模型 Haar级联分类器是一种用于对象检测(如人脸检测)的机器学习算法。它由Paul Viola和Michael Jones在2001年提出…...
嗖嗖移动业务大厅(Java版)
首先对此项目说明一下,我只完成了项目的基本需求,另外增加了一个用户反馈的功能,但是可能项目中间使用嗖嗖这个功能还有一些需要完善的地方,或者还有一些小bug,就当给大家参考一下了,希望谅解。代码我也上传…...
hcia复习笔记
一、OSI 七层模型 应用层:为应用程序提供服务,如文件传输、电子邮件等。 表示层:数据格式转换、加密解密、压缩解压缩。 会话层:建立、维护和管理会话。 传输层:提供端到端的可靠或不可靠的数据传输服务࿰…...
pycharm中安装、使用扩展工具,以QT Designer为例
pycharm中安装、使用扩展工具,以QT Designer为例 第一步,下载QT Designer安装包。找到QT Designer.exe所在位置,复制路径 第二步,打开Pycharm,选择Setting,找到扩展工具(External Tools…...
【Rust光年纪】Rust语言实用库汇总:从机器翻译到全文搜索引擎
优秀的Rust语言库探索:机器翻译、音频编解码和全文搜索引擎 前言 Rust语言在近年来迅速崛起,成为了一种备受欢迎的系统级编程语言。随着其生态系统的不断丰富,涌现出了许多优秀的库和工具。本文将重点介绍几个用于Rust语言的重要库…...
学习笔记 - 二极管的参数与选型
二极管 普通二极管: 1N4148(高频开关二极管) 整流二极管: 1N4007 1A 1000V1N5408 3A 1000V 肖特基二极管 (白线边为阴极) SS14 SS34 SS54 常见肖特基二极管参数 快恢复二极管 FR107 FR207 FR307 UF4007 可以用快恢复二…...
PMP--冲刺--易混概念
文章目录 十大知识领域一、整合管理项目管理计划与项目文件的区分: 二、范围管理三、进度管理赶工与快速跟进的区分:赶工增加资源,以最小的成本代价来压缩进度工期;快速跟进,将正常情况下按顺序进行的活动或阶段改为至…...
Resolving Maven dependencies
Maven是一种项目管理和构建工具,通常用于Java项目。这个过程包括下载项目所需的所有外部库和插件,并将它们添加到项目的构建路径中。具体来说,它正在处理名为“AAS_byBasyx”的项目或模块的依赖项。这种任务通常在你打开一个新的Maven项目或更…...
【Spring】SSM框架整合Spring和SpringMVC
目录 1.项目结构 2.项目的pom.xml文件 3.spring.xml和springMVC配置文件 4.database.properties和mybatis.xml配置文件 5. 代码编写 6.测试整合结果 1.项目结构 首先创建一个名为ssm_pro的Mavew项目,然后再在主目录和资源目录下,创建如下所示的结…...
优维2024年中思考:大模型赋予新一代运维的“非产品性”启示
近年来,人工智能在各个行业的应用大幅增加,人工智能技术取得重大进步的领域之一是IT运维。 去年四季度,优维科技敏锐地提出“新一代运维核心系统提供商”的战略新定位,决定将“DevOps及运维”回归到“运维”本身,但我…...
【中药网络药理学】筛选细胞衰老和预后相关基因(附分类代码和画图代码)
1、衰老相关基因 从HAGR和msigdb数据获取细胞衰老相关基因,将两者取交集后构建基因蛋白互作网络 HAGR数据库 该库本身提供了下载链接,我在下载后对其进行了清洗 msigdb数据库 以"aging"作为关键词,Search Filters中collection…...
华为的流程体系
缘由 2010年,华为销售额为1850亿元,其中国际市场占65%,净利润238亿元。当时,公司员工达11万人,公司处理合同达5万多个,290万个订单,大量的工作是手工处理,没有统一的流程支持&#…...
算法——长度最小的子数组209 对比代码随想录题解中对于result取值为Integer.MAX_VALUE的思考
具体解题过程可看代码随想录,我主要是对于为什么result也就是子数组和初始化要为Integer.MAX_VALUE有一个疑惑,为什么不是其他值,经过思考后我发现: 情况一:如果result为负数的话是不符合数组长度取值的一个规范的。 情况二&…...
图像处理案例03
HOGSVM数字识别 1 . 步骤2 . 代码 1 . 步骤 读入数据,把数据划分为训练集和测试集用hog提取特征用SVM训练数据测试、评价模型保存模型加载模型,应用模型 2 . 代码 import os import cv2 import sklearn import numpy as np from skimage.feature impo…...
【Kubernetes】k8s集群中kubectl的陈述式资源管理
目录 一.k8s集群资源管理方式分类 1.陈述式资源管理方式 2.声明式资源管理方式 二.陈述式资源管理方法 三.kubectl命令 四.项目生命周期 1.创建 kubectl create命令 2.发布 kubectl expose命令 3.更新 kubectl set 4.回滚 kubectl rollout 5.删除 k…...
串---顺序串实现
顺序串详解 本文档将详细介绍顺序串的基本概念、实现原理及其在 C 语言中的具体应用。通过本指南,读者将了解如何使用顺序串进行各种字符串操作。 1. 什么是顺序串? 顺序串是一种用于存储字符串的数据结构,它使用一组连续的内存空间来保存…...
吴恩达机器学习WEEK2
COURSE1 WEEK2 多维特征 在线性回归中,往往特征不止一个,而是具有多维特征 例如,在预测房价的例子中,我们知道更多的信息: x 1 x_1 x1:房屋的面积 x 2 x_2 x2:卧室的数目 x 3 x_3 x3&a…...
yield and generator in python
首先,假设大家都对于pytyhon的List comprehension的使用有了一定经验(它可以用于list,set,和dict哦) 不熟悉的参考介绍: Comprehending Python’s Comprehensions – dbader.org generator generator是哦…...
spring原理(自学第六天)
Aware 接口及 InitializingBean 接口 今天将会学到Aware 接口及 InitializingBean 接口 我们可以先了解他们的作用: 1. Aware 接口用于注入一些与容器相关信息, 例如 a. BeanNameAware 注入 bean 的名字 b. BeanFactoryAware 注入…...
案例分享—国外优秀ui设计作品赏析
国外UI设计创意迭出,融合多元文化元素,以极简风搭配动态交互,打造沉浸式体验,色彩运用大胆前卫,引领界面设计新风尚 同时注重用户体验的深度挖掘,通过个性化定制与智能算法结合,让界面不仅美观且…...
Janus-1.3B:1.3B参数解锁多模态理解生成新可能
Janus-1.3B:1.3B参数解锁多模态理解生成新可能 【免费下载链接】Janus-1.3B Janus-1.3B:新一代统一多模态模型,独特的自回归框架实现视觉编码解耦,提升多模态理解与生成的灵活性,性能超越传统模型。基于DeepSeek-LLM-1…...
企业信息化一站式方案,开启高效管理新时代
企业信息化一站式方案,提升核心竞争力在当今数字化时代,企业面临着日益激烈的市场竞争,如何提升核心竞争力成为企业发展的关键。企业信息化一站式方案应运而生,为企业提供了全面、高效、便捷的解决方案,帮助企业实现数…...
用1/100成本,Tacore要让企业告别“软件定制”时代
商业化未满20天,签约20家企业,ARR预估120万。一位零基础企业主通过Tacore在7天内独立完成了百人规模公司的CRM系统,成本仅为传统的1/100,效率提升1000倍。 这是Tacore的故事——一个为AI彻底重构底层的OPC超级个体创业团队&#x…...
MOS管技术详解:从基础到工程应用
MOS管技术详解:从基础原理到工程应用1. MOS管基础概念与分类1.1 场效应管基本类型场效应管(FET)主要分为两大类型:结型场效应管(JFET):Junction Field-Effect Transistor金属氧化物半导体场效应管(MOSFET):Metal-Oxide-Semiconduc…...
为什么你的Polars清洗比Pandas还慢?3步定位CPU缓存未对齐、SIMD未启用、线程池饥饿这3大隐形杀手
第一章:Polars 2.0 大规模数据清洗技巧 性能调优指南Polars 2.0 引入了全新的执行引擎与内存管理机制,显著提升了大规模数据清洗场景下的吞吐量与低延迟响应能力。相比 Pandas,其在 10GB 数据集上的列式过滤、字符串标准化与缺失值插补操作平…...
STM32栈空间溢出处理与优化技术
STM32栈空间溢出处理技术解析1. 栈空间溢出问题概述在STM32嵌入式开发中,函数内部定义的局部变量存储在栈空间中。STM32的启动文件中预定义了栈空间大小,当局部变量占用空间超过预设栈大小时,虽然编译过程不会报错,但运行时可能出…...
远程调试革新性实践:Chrome DevTools App全方位技术指南
远程调试革新性实践:Chrome DevTools App全方位技术指南 【免费下载链接】chrome-devtools-app Chrome DevTools packaged as an app via Electron 项目地址: https://gitcode.com/gh_mirrors/ch/chrome-devtools-app 一、远程调试的核心价值:突破…...
【农业AI实战权威指南】:Python图像识别精度提升7大关键瓶颈与2024最新调优方案
第一章:农业AI图像识别精度提升的底层逻辑与行业挑战农业AI图像识别并非简单套用通用计算机视觉模型,其精度瓶颈根植于农田场景特有的物理复杂性与数据稀缺性。光照剧烈变化、作物生长阶段连续演化、病斑形态微小且易与阴影/污渍混淆,导致传统…...
Langflow场景化部署指南:为不同用户定制的安装方案
Langflow场景化部署指南:为不同用户定制的安装方案 【免费下载链接】langflow ⛓️ Langflow 是 LangChain 的用户界面,使用 react-flow 设计,旨在提供一种轻松实验和原型设计流程的方式。 项目地址: https://gitcode.com/GitHub_Trending/…...
Au新手入门指南:从零开始掌握音频编辑基础
1. 认识Adobe Audition:你的第一把音频手术刀 第一次打开Adobe Audition(简称Au)时,满屏的波形图和专业术语可能会让你头皮发麻。别担心,这就像第一次拿手术刀的外科实习生——工具看起来很专业,但基础操作…...
