【情感识别】基于改近最近邻实现语音情感分类识别含Matlab源码

本文介绍了K近邻算法的基本思想,包括训练阶段的离散化存储和分类阶段的决策过程。并通过Matlab代码展示了如何计算短时特征用于语音情感识别。通过实例阐述了如何在实际场景中运用该算法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 简介

K近邻(K-NearestNeighbor,KNN)算 法是 一种基于实例的统计学习方法,其基本思想是在多维空间Rn中,对于一个待分类样本x,根据距离找到与未知样本最近邻的k个训练样本点,然后根据这k个近邻样本点的类别决定待分类样本的类别.K近邻算法的具体实现包括两 个 阶 段.

(1)训练阶段:对 训 练 样 本 进 行 离 散 化,读 取 和 存 储;

(2)分类阶段:首先对于待分类的样本,计算它与其他的训练样本的欧式距离.选择其中距离最近的K个样本.并查看这K个近邻的分类标记,根 据多 数 表 决原则确定待测样本的类别.重复以上步骤直至所有待分类的样本分类结束.

2 部分代码

function[A,E,Z] =TimePara(y)y_length=length(y);                                   %声音信号的长度Ny=512;                                                    %短时帧长frame_all=floor((y_length-(Ny/2))/(Ny/2));       y2_sound=y(1:(frame_all+1)*(Ny/2));    y3=reshape(y2_sound,(Ny/2),[]);    y4=[y3(:,1:frame_all);y3(:,2:(frame_all+1))];%%%%%%加hamming窗win_h=hamming(Ny);      %win_y=y_sound.*win_h;for i=1:(frame_all)                                         A_y(i)=sum(abs(y4(:,i).*win_h));                            %计算短时幅值    E_y(i)=sum((y4(:,i).*win_h).*(y4(:,i).*win_h));             %计算短时能量        Z_y(i)=sum(abs(sign(y4(2:80,i))-sign(y4(1:79,i))))/2;      %计算短时过零率endA=mean(A_y);E=mean(E_y);Z=mean(Z_y);figure(3);plot(y);grid on;xlabel('样本数');title('语音信号时域波形');figure(4);plot(A_y,'*r');hold on;plot(Z_y,'^g');hold on;plot(E_y,'sb');grid on;xlabel('帧数');title('短时幅值,过零率,能量');legend('幅值','过零率','能量');

3 仿真结果

4 参考文献

[1]龚灵杰, 袁家政, 刘宏哲. 基于加权最近邻的语音情感识别方法[C]// 中国计算机用户协会网络应用分会2017年第二十一届网络新技术与应用年会论文集. 2017.

博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

部分理论引用网络文献,若有侵权联系博主删除。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

matlab科研助手

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值