首页 > 其他分享 >m基于HMM和博弈模型的LSTM互联网情感词性分类识别matlab仿真

m基于HMM和博弈模型的LSTM互联网情感词性分类识别matlab仿真

时间:2023-04-06 15:34:22浏览次数:56  
标签:词性 end 预测 传播 HMM 情感 zeros matlab LSTM

1.算法描述

        传统的情感分析研究大多立足于解决主观性文本的情感分类问题, 面向复杂交互式文本的情感演化分析却力所不逮. 本文以天涯论坛短文本中文在线评论为研究对象, 首先提出一种高效的情感计算框架捕捉在线评论所蕴含的情感倾向; 然后将情感计算和博弈论相结合提出情感演化预测算法, 以混合纳什均衡策略作为交互行为的预测结果; 最后在大规模评论数据集上, 验证了情感计算框架的有效性和情感演化预测算法的准确性.

 

       在社交网络中,情感传播与信息传播类似。第一,信息传播的研究主体是信息,信息中包含着各种各样的情境,情感传播的研究主体是情感,情感蕴含着丰富多样的类型。第二,情感的传播依赖于信息的传播,所以情感的生命周期同样经历着:潜伏期-爆发期-蔓延期-衰退期。第三,信息传播存在着相互竞争,情感传播存在着相互影响。近年来,网络情感传播研究吸引了信息管理、传播学、心理学、社会学、公共管理等不同领域的学者参与,是一个跨学科研究领域。情感的传播涉及到个体认知、情感、行为多重作用,只有深入理解社会学理论,准确把握情感动力学机制,才能对情感传播进行深入有效的研究。

 

(1)基于个性特质分类的情感波动度量方法研究。由于个性特质的差异,对于相同事物个体情绪表达的强弱、类型也有所差异。通过分析个体的性格特征,了解个体情感的基线水平,才能准确理解不同情感信息对个体的影响,进而准确分析个体情感对群体情感波动产生的影响。

 

(2)基于行为预测的情感动力学模型研究。情感产生于个体与其环境交互的过程之中,节点对环境中不同元素的认知与态度的产生变化时,其行为也相应地发生改变。蕴含情感的行为也不断影响了节点,以及节点对环境因素的认知。行为与情感相互作用,行为的演化刺激情感的演化,从而影响了情感传播的方向。行为预测是情感传播预测的基础,可以保证情感传播预测的逻辑性、合理性,再综合考虑个体情感基线的同时,即可提高情感传播预测的精度。

 

(3)基于博弈论的竞争性情感传播模型研究。在情感传播网络中,个体对于信息传播的决策依赖于利益的博弈,利益的最大化是节点信息与情感扩散的主要动力。与在社交网络信息量爆炸式增长,信息呈现并发式传播,信息间的相互作用同样影响着信息的传播。在相对积极的环境中,信息间的合作关系帮助信息传播,同时也促进情感的扩散。在相对消极的环境中,信息间的竞争关系,抑制了劣势信息的传播,同时也抑制的情感的蔓延。个体决策的博弈以及信息相互的竞争,成就了信息的爆发与情感的蔓延。基于博弈论的竞争的情感传播模型是现实的拓展,研究竞争与博弈共存的传播模型,可以健全情感传播机制,提高情感传播的预测精度。

 

       长短期记忆网络(LSTM,Long Short-Term Memory)是一种时间循环神经网络,是为了解决一般的RNN(循环神经网络)存在的长期依赖问题而专门设计出来的,所有的RNN都具有一种重复神经网络模块的链式形式。在标准RNN中,这个重复的结构模块只有一个非常简单的结构,例如一个tanh层。

 

        长短期记忆网络(Long-Short Term Memory,LSTM)论文首次发表于1997年。由于独特的设计结构,LSTM适合于处理和预测时间序列中间隔和延迟非常长的重要事件。LSTM的表现通常比时间递归神经网络及隐马尔科夫模型(HMM)更好,比如用在不分段连续手写识别上。2009年,用LSTM构建的人工神经网络模型赢得过ICDAR手写识别比赛冠军。LSTM还普遍用于自主语音识别,2013年运用TIMIT自然演讲数据库达成17.7%错误率的纪录。作为非线性模型,LSTM可作为复杂的非线性单元用于构造更大型深度神经网络。

 

       LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为它可以记忆不定时间长度的数值,区块中有一个gate能够决定input是否重要到能被记住及能不能被输出output。图1底下是四个S函数单元,最左边函数依情况可能成为区块的input,右边三个会经过gate决定input是否能传入区块,左边第二个为input gate,如果这里产出近似于零,将把这里的值挡住,不会进到下一层。左边第三个是forget gate,当这产生值近似于零,将把区块里记住的值忘掉。第四个也就是最右边的input为output gate,他可以决定在区块记忆中的input是否能输出 。LSTM有很多个版本,其中一个重要的版本是GRU(Gated Recurrent Unit),根据谷歌的测试表明,LSTM中最重要的是Forget gate,其次是Input gate,最次是Output gate。

 

 

 

 

       电力系统负荷预测是指充分考虑历史的系统负荷、经济状况、气象条件和社会事件等因素的影响,对未来一段时间的系统负荷做出预测。负荷预测是电力系统规划与调度的一项重要内容。短期(两周以内)预测是电网内部机组启停、调度和运营计划制定的基础;中期(未来数月)预测可为保障企业生产和社会生活用电,合理安排电网的运营与检修决策提供支持;长期(未来数年)预测可为电网改造、扩建等计划的制定提供参考,以提高电力系统的经济效益和社会效益。复杂多变的气象条件和社会事件等不确定因素都会对电力系统负荷造成一定的影响,使得传统负荷预测模型的应用存在一定的局限性。同时,随着电力系统负荷结构的多元化,也使得模型应用的效果有所降低,因此电力系统负荷预测问题亟待进一步研究。

        电力负荷预测是一种典型的时间序列回归预测任务。电力负荷预测是保证电力供需平衡的基础,并为电网、电源的规划建设以及电网企业、电网使用者的经营决策提供信息和依据。负荷预测分为长期、中期、短期和超短期负荷预测,预测对象包括系统负荷和母线负荷,由电网企业负责组织编制。大用户应根据有关规定,按时报送其主要接装容量和年、月用电量预测及日用电负荷变化过程。

 

LSTM通过以下公式进行更新权值矩阵和偏置参数等网络信息:

 

 

 

 

 

 

2.仿真效果预览

matlab2022a仿真结果如下:

 

 

 

 

 

 

 

 

 

 

 

 

 

 

3.MATLAB核心程序

 

function [Mu,LL]=func_hmm(X,T,K,Iteration,tol)
 
p   = length(X(1,:));
N   = length(X(:,1));
N   = N/T;
Cov = diag(diag(cov(X)));
Mu  = randn(K,p)*sqrtm(Cov)+ones(K,1)*mean(X);
Pi  = rand(1,K);
Pi  = Pi/sum(Pi);
 
P   = rand(K);
P   = rdiv(P,rst_sum(P));
 
LL  = [];
lik = 0;
 
alpha = zeros(T,K);
beta  = zeros(T,K);
gamma = zeros(T,K);
 
 
B=zeros(T,K);
k1=(2*pi)^(-p/2);
 
for ij=1:Iteration
    ij
    Gamma   = [];
    Gammasum= zeros(1,K);
    Scale   = zeros(T,1);
    Xi      = zeros(T-1,K*K);
    for n=1:N
        iCov = inv(Cov);
        k2   = k1/sqrt(det(Cov));
        for i=1:T
            for l=1:K
                d       = Mu(l,:)-X((n-1)*T+i,:);
                B(i,l)  = k2*exp(-0.5*d*iCov*d');
            end;
        end;
    
    scale     = zeros(T,1);
    alpha(1,:)= Pi.*B(1,:);
    scale(1)  = sum(alpha(1,:));
    alpha(1,:)= alpha(1,:)/scale(1);
    for i=2:T
        alpha(i,:) = (alpha(i-1,:)*P).*B(i,:);
        scale(i)   = sum(alpha(i,:));
        alpha(i,:) = alpha(i,:)/scale(i);
    end;
    
    beta(T,:) = ones(1,K)/scale(T);
    for i=T-1:-1:1
        beta(i,:) = (beta(i+1,:).*B(i+1,:))*(P')/scale(i); 
    end;
    
    gamma    = (alpha.*beta); 
    gamma    = rdiv(gamma,rst_sum(gamma));
    gammasum = sum(gamma);
    xi       = zeros(T-1,K*K);
    for i=1:T-1
        t       = P.*( alpha(i,:)' * (beta(i+1,:).*B(i+1,:)));
        xi(i,:) = t(:)'/sum(t(:));
    end;
    
    Scale    = Scale+log(scale);
    Gamma    = [Gamma; gamma];
    Gammasum = Gammasum+gammasum;
    Xi       = Xi+xi;
  end;
  Mu =zeros(K,p);
  Mu = Gamma'*X;
  Mu = rdiv(Mu,Gammasum');
  sxi= rst_sum(Xi')';
  sxi= reshape(sxi,K,K);
  P  = rdiv(sxi,rst_sum(sxi));
 
  Pi = zeros(1,K);
  for i=1:N
      Pi=Pi+Gamma((i-1)*T+1,:);
  end
  Pi=Pi/N;
  Cov=zeros(p,p);
  for l=1:K
      d=(X-ones(T*N,1)*Mu(l,:));
      Cov=Cov+rprod(d,Gamma(:,l))'*d;
  end;
  Cov=Cov/(sum(Gammasum));
  
  oldlik = lik;
  lik    = sum(Scale);
  LL     = [LL lik/T];
 
end
end
function Z=rst_sum(X)
Z=zeros(size(X(:,1)));
for i=1:length(X(1,:))
  Z=Z+X(:,i);
end
end
function Z=rdiv(X,Y)
 
Z=zeros(size(X));
for i=1:length(X(1,:))
    Z(:,i)=X(:,i)./Y;
end
end
function Z=rprod(X,Y)
[n m]=size(X);
 
Z=X.*(Y*ones(1,m));
end

  

标签:词性,end,预测,传播,HMM,情感,zeros,matlab,LSTM
From: https://www.cnblogs.com/51matlab/p/17292895.html

相关文章

  • 自动驾驶-预瞄-Pure pursuit纯跟踪算法-MATLAB实现
    有空把引入、逻辑、原理介绍给写了,目前先给大家看看代码。将来写大概会分成这么几块:汽车运动学自行车模型跟踪算法主流模型及特点纯跟踪算法原理推导代码介绍代码原创,来之不易,请勿不注明转载。喜欢点个赞吧!网上许多代码都跑不起来hhclc;clear;%------------formroa......
  • c++实现Matlab矩阵Matrix类(实矩阵Matrix、复矩阵CMatrix)
    全栈工程师开发手册(作者:栾鹏)matlab2c动态链接库下载matlab库函数大全matlab2c基础教程matlab2c开发全解教程开发注意事项:1、目前matlab2c对矩阵的实现仅包含实数型、复数型数据。实数型矩阵使用Matrix定义,复数型矩阵使用CMatrix定义。2、实数矩阵元素int、float元素类型会自动......
  • 一维CNN,二维CNN以及三维CNN的训练模型matlab仿真
    1.算法描述卷积神经网络(ConvolutionalNeuralNetworks,CNN)是一类包含卷积计算且具有深度结构的前馈神经网络(FeedforwardNeuralNetworks),是深度学习(deeplearning)的代表算法之一。卷积神经网络具有表征学习(representationlearning)能力,能够按其阶层结构对输入信息进行平移不变......
  • m基于多核学习支持向量机MKLSVM的数据预测分类算法matlab仿真
    1.算法描述        20世纪60年代Vapnik等人提出了统计学习理论。基于该理论,于90年代给出了一种新的学习方法——支持向量机。该方法显著优点为根据结构风险最小化归纳准则,有效地避免了过学习、维数灾难和局部极小等传统机器学习中存在的弊端,且在小样本情况下仍然具有......
  • m基于多核学习支持向量机MKLSVM的数据预测分类算法matlab仿真
    1.算法描述20世纪60年代Vapnik等人提出了统计学习理论。基于该理论,于90年代给出了一种新的学习方法——支持向量机。该方法显著优点为根据结构风险最小化归纳准则,有效地避免了过学习、维数灾难和局部极小等传统机器学习中存在的弊端,且在小样本情况下仍然具有良好的泛化能力,从......
  • 【无人机协同】多无人机协同任务规划模型研究附matlab代码
    ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。......
  • matlab学习笔记7 插值方法与求解微分方程
    插值法拉格朗日插值分段插值由于高次函数往往拟合的情况反而不好,所以用两点之间的直线代替其值进行插值三次样条插值更加光滑,节点处二阶可导代码汇总interp1(x0,y0,x,'cubic')%分段三次多项式插值,第三个参数不写则为普通分段插值interp1(x0,y0,x,'spline')%三次样条插值......
  • 基于mnist手写数字数据库的深度学习网络训练和数字识别matlab仿真
    1.算法描述        MNIST数据集(MixedNationalInstituteofStandardsandTechnologydatabase)是美国国家标准与技术研究院收集整理的大型手写数字数据库,该数据集包含60000 个于训练的样本和10000 个于测试的样本,图像是固定⼤小(28x28像素),每个像素的值为......
  • MATLAB读写excel中指定sheet行列中的数据 and 去除含有NaN的行或者列
    matlab读写excel中指定sheet行列中的数据data=xlsread('data.xlsx','sheet1','c2:c12');xlswrite('newdata.xlsx',newdata,'Sheet1','p2:p12');matlab中去除含有NaN的行或者列b=a(all(~isnan(a),2),:);%删除含有NAN的行b=a(al......
  • 基于LSTM网络的空调功耗数据预测matlab仿真
    1.算法描述       长短期记忆网络(LSTM,LongShort-TermMemory)是一种时间循环神经网络,是为了解决一般的RNN(循环神经网络)存在的长期依赖问题而专门设计出来的,所有的RNN都具有一种重复神经网络模块的链式形式。在标准RNN中,这个重复的结构模块只有一个非常简单的结构,例如一个t......