【手势识别】SIFT+SVM算法手势识别【含GUI Matlab源码 1789期】

✅博主简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,Matlab项目合作可私信。
🍎个人主页:海神之光
🏆代码获取方式:
海神之光Matlab王者学习之路—代码获取方式
⛳️座右铭:行百里者,半于九十。

更多Matlab仿真内容点击👇
Matlab图像处理(进阶版)
路径规划(Matlab)
神经网络预测与分类(Matlab)
优化求解(Matlab)
语音处理(Matlab)
信号处理(Matlab)
车间调度(Matlab)

⛄一、手势识别简介

1 引言
人机交互技术, 就是利用计算机的输入、输出模块, 用有效的方式实现人与计算机的交流。随着科技的发展, 人们逐渐不满足与传统的输入输出方式, 而是向往通过与计算机直接互动的方式完成人机交互。将手势识别运用到人机交互的方式当中, 不仅完成了与人计算机的互动和交流, 也是一种更加简单、轻松的人机交互方式。

近年来随着人工智能的兴起, 也让手势识别的发展越来越迅速, 手势识别的应用也越来越广泛, 例如利用手势播放PPT、控制电视机等方面逐步呈现在大家面前。

2 算法实现
当前手势识别技术包括个核心部分:手势跟踪、手势分割、特征提取和手势识别。

2.1 基于肤色检测的手势分割
肤色检测, 就是在图像中选取与皮肤颜色相近的像素。其中, 基于颜色的方法, 由于算法简单、实时性高、对形变等具有较强的鲁棒性, 被广泛研究应用。常用的肤色检测算法已经被广泛研究, 例如基于YCrCb颜色空间的肤色检测算法, 该算法将空间中的亮度和色度完全分离开来, 作为两个完全独立的变量, 不会相互混淆。“Y”做为亮度变量, “Cr”和“Cb”分别作为色度的变量。YCrCb颜色空间对颜色的提取和人的眼睛甚是类似, 色彩的分布过渡均匀。YCrCb颜色空间将亮度变量和两个色度变量区分开来, 使得YCrCb颜色空间中对肤色提取和识别将对光线只受到很小很小的影响。通过采集和提取大量的肤色模型, 并将其在YCrCb颜色空间的分布投影到CrCb平面, 发现其在Cr和Cb分量上样本可近似聚合为一个椭圆, 当像素点的色度分量Cb、Cr的值落在椭圆内部或这边界时, 该像素点可以认定为肤色。此方法优点在于彻底分离了色度和亮度, 能够在CrCb平面建立肤色椭圆模型, 表明肤色聚合性好, 并能对颜色空间进行降维处理, 便于计算和应用。利用肤色椭圆模型进行肤色检测, 由于该模型受光线、亮度的影响较小, 其肤色检测效果较好。

2.2 手势跟踪
手势跟踪是动态手势特征提取的前提, 对手势识别系统的效率有重要的影响。手势跟踪获取的是手势位置和运动趋势信息, 是在手势的视频序列中, 利用己获取的信息计算得到的。如何定义和表达运动目标, 直接影响到算法的精度以及鲁棒性, 而算法的实时性则受匹配搜索方法和滤波算法影响。

2.3 基于PCA算法的特征提取
手势图像的特征向量, 由一组描述对象特性的参数组成。如何选择合适的特征参数是手势识别的最关键部分。为了获得较好的特征参数, 在确定出手势位置之后, 需要对该手势的一些基本参数, 如特征的位置、大小以及方向等进行测定, 以保证所用参数的准确性。在提取到这些特征之后, 还要通过大量的训练来进行参数优化。目前, 常用的图像特征包括二值影像、手势形状信息 (区域、轮廓、骨架等) , 手势形状几何属性 (距离、面积、长短、凹凸等) 、指尖等。主成分分析 (Principal Component Analysis) , 简称PCA, 是一种常用的特征提取方法, 它也被称为Karhunen-Loève变换。经过变换后可以有效的降低维数, 又能保留有效的识别信息, 这些有效的信息构成一组特征图像例如PCA一个简易的投影, 假设有很多小方块代表着我们的数据在二维空间中的分布。那我们需要将小方块投影到一条L所在的直线方向, 不仅它保留了原数据的所有信息, 而且还让数据从二维降到了一维。这就是PCA方法的优点。

2.4 基于SVM算法的手势识别
手势识别包括分类和识别两个过程, 是将从图片序列中获得的轨迹 (或点) , 分类到模型参数空间里某个子集, 从而进行识别。因为PCA自身不具有分类能力, 所以通过PCA算法提取特征向量后, 需要利用分类器根据样本的特征向量进行分类处理, 以判别当前手势的含义。分类器的工作分两步:训练和测试。先对样本进行学习, 将样本进行预判别, 将提取的特征向量进行学习和分类, 将类分好后, 再将测试对象经过分类器即可将测试对象进行分类判别, 对于本实验来说, 也就实现了手势识别。支持向量机 (Support Vector Machine, SVM) 是一种二分类模型, 其求解目标在于确定一个分类的超平面, 以最大化特征空间上的间隔。分类超平面的确定只取决于少数的样本信息, 这些关键的样本被称之为支持向量Support Vector, 这也是SVM—支持向量机名称的由来。例如一个简单的两类线性可分的分类。分布着两类数据。一类是正方形所代表的数据, 它们的类别是1, 另一类是圆形所代表的数据, 它们的类别是-1。我们可以从中找到很多条能分隔开这两类数据的线, 支持向量机的目的就是要从这么多的线中找出一条使得两类样本之间的间隔最大的线。

⛄二、部分源代码

function varargout = shibie(varargin)
% SHIBIE MATLAB code for shibie.fig
% SHIBIE, by itself, creates a new SHIBIE or raises the existing
% singleton*.
%
% H = SHIBIE returns the handle to a new SHIBIE or the handle to
% the existing singleton*.
%
% SHIBIE(‘CALLBACK’,hObject,eventData,handles,…) calls the local
% function named CALLBACK in SHIBIE.M with the given input arguments.
%
% SHIBIE(‘Property’,‘Value’,…) creates a new SHIBIE or raises the
% existing singleton*. Starting from the left, property value pairs are
% applied to the GUI before shibie_OpeningFcn gets called. An
% unrecognized property name or invalid value makes property application
% stop. All inputs are passed to shibie_OpeningFcn via varargin.
%
% *See GUI Options on GUIDE’s Tools menu. Choose “GUI allows only one
% instance to run (singleton)”.
%
% See also: GUIDE, GUIDATA, GUIHANDLES

% Edit the above text to modify the response to help shibie

% Last Modified by GUIDE v2.5 13-Oct-2021 00:11:32

% Begin initialization code - DO NOT EDIT
gui_Singleton = 1;
gui_State = struct(‘gui_Name’, mfilename, …
‘gui_Singleton’, gui_Singleton, …
‘gui_OpeningFcn’, @shibie_OpeningFcn, …
‘gui_OutputFcn’, @shibie_OutputFcn, …
‘gui_LayoutFcn’, [] , …
‘gui_Callback’, []);
if nargin && ischar(varargin{1})
gui_State.gui_Callback = str2func(varargin{1});
end

if nargout
[varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:});
else
gui_mainfcn(gui_State, varargin{:});
end
% End initialization code - DO NOT EDIT

% — Executes just before shibie is made visible.
function shibie_OpeningFcn(hObject, eventdata, handles, varargin)
% This function has no output args, see OutputFcn.
% hObject handle to figure
% eventdata reserved - to be defined in a future version of MATLAB
% handles structure with handles and user data (see GUIDATA)
% varargin command line arguments to shibie (see VARARGIN)
%%
set(handles.text3,‘Visible’,‘off’);
set(handles.text4,‘Visible’,‘off’);
set(handles.text5,‘Visible’,‘off’);
set(handles.text8,‘Visible’,‘off’);
set(handles.text1,‘Visible’,‘off’);
set(handles.uipanel4,‘Visible’,‘off’);

% Choose default command line output for shibie
handles.output = hObject;

% Update handles structure
guidata(hObject, handles);

% UIWAIT makes shibie wait for user response (see UIRESUME)
% uiwait(handles.figure1);

% — Outputs from this function are returned to the command line.
function varargout = shibie_OutputFcn(hObject, eventdata, handles)
% varargout cell array for returning output args (see VARARGOUT);
% hObject handle to figure
% eventdata reserved - to be defined in a future version of MATLAB
% handles structure with handles and user data (see GUIDATA)

% Get default command line output from handles structure
varargout{1} = handles.output;

% — Executes on button press in pushbutton1.
function pushbutton1_Callback(hObject, eventdata, handles)
% hObject handle to pushbutton1 (see GCBO)
% eventdata reserved - to be defined in a future version of MATLAB
% handles structure with handles and user data (see GUIDATA)
%%
set(handles.text3,‘Visible’,‘off’);
set(handles.text4,‘Visible’,‘off’);
set(handles.text5,‘Visible’,‘off’);
set(handles.text8,‘Visible’,‘off’);
set(handles.text1,‘Visible’,‘off’);
set(handles.uipanel4,‘Visible’,‘off’);
[Filename,Pathname]=uigetfile(…
{‘.pgm’;'.ppm’},‘选择图片’);
str=[Pathname Filename];
handles.picturepath=str;
guidata(hObject, handles);

if (Filename~=0)
im=imread(str);
axes(handles.axes1);
imshow(im);

else
clear;
end

⛄三、运行结果

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

⛄四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]黄彦铭,宁媛.基于视觉的手势识别算法及应用的研究[J].智能计算机与应用. 2021,11(06)
[2]孙鹏.基于pca+svm算法实现手势识别[J].中国新通信. 2019,21(07)

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除

🍅 仿真咨询
1 各类智能优化算法改进及应用

生产调度、经济调度、装配线调度、充电优化、车间调度、发车优化、水库调度、三维装箱、物流选址、货位优化、公交排班优化、充电桩布局优化、车间布局优化、集装箱船配载优化、水泵组合优化、解医疗资源分配优化、设施布局优化、可视域基站和无人机选址优化

2 机器学习和深度学习方面
卷积神经网络(CNN)、LSTM、支持向量机(SVM)、最小二乘支持向量机(LSSVM)、极限学习机(ELM)、核极限学习机(KELM)、BP、RBF、宽度学习、DBN、RF、RBF、DELM、XGBOOST、TCN实现风电预测、光伏预测、电池寿命预测、辐射源识别、交通流预测、负荷预测、股价预测、PM2.5浓度预测、电池健康状态预测、水体光学参数反演、NLOS信号识别、地铁停车精准预测、变压器故障诊断

3 图像处理方面
图像识别、图像分割、图像检测、图像隐藏、图像配准、图像拼接、图像融合、图像增强、图像压缩感知

4 路径规划方面
旅行商问题(TSP)、车辆路径问题(VRP、MVRP、CVRP、VRPTW等)、无人机三维路径规划、无人机协同、无人机编队、机器人路径规划、栅格地图路径规划、多式联运运输问题、车辆协同无人机路径规划、天线线性阵列分布优化、车间布局优化

5 无人机应用方面
无人机路径规划、无人机控制、无人机编队、无人机协同、无人机任务分配

6 无线传感器定位及布局方面
传感器部署优化、通信协议优化、路由优化、目标定位优化、Dv-Hop定位优化、Leach协议优化、WSN覆盖优化、组播优化、RSSI定位优化

7 信号处理方面
信号识别、信号加密、信号去噪、信号增强、雷达信号处理、信号水印嵌入提取、肌电信号、脑电信号、信号配时优化

8 电力系统方面
微电网优化、无功优化、配电网重构、储能配置

9 元胞自动机方面
交通流 人群疏散 病毒扩散 晶体生长

10 雷达方面
卡尔曼滤波跟踪、航迹关联、航迹融合

  • 19
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值