ESN-Autoencoder可视化时间序列

ESN-Autoencoder可视化时间序列

这篇论文是发表在neurocomputing上的Model-Coupled Autoencoder for Time Series Visualisation,提出了通过结合Echo State Network (ESN)和Autoencoder来可视化时间序列的方法。可视化是将不同种类的时序数据映射(压缩)到低维(如二维)空间上,同一类的距离近,而不同类的距离远。
文章提出的序列降维方法分为两个阶段:

  1. 用ESN训练每一个序列,得到对应的输出层权重(readout weights),这个权重作为序列的表达;
  2. 对第一步得到的权重用一个Autoencoder降维,得到二维的表达

序列经过12降维后的就可以用一个二维图展示出来。
在介绍方法之前,需要先解释ESN,Autoencoder等:

1. 预备知识

Echo State Networks

ESN是一个循环神经网络rnn,由三个基本的组件组成:输入层,内部稀疏连接的循环层(called the reservoir, 蓄水池,水库),输出层。一般的结构如图:

ESN

用D,N,L分别表示三个层的神经元个数,输入层到中间层的权重表示为Win,中间层的内部连接权重为N*N的Wres,中间层到输出层Wout。其中权重Win和Wres是随机初始化的,固定的,不训练的,只有最后一层的Wout需要训练。

Formula


这里的z(t)应该改为z(t+1)才对。
x(t)就是echo state,保存了当前状态和过去的信息(记忆)。
与RNN对比:

  1. ESN是对输入的一个高维的投射,来捕捉输入的动态信息,有证明其类似于一个核函数的作用;
  2. reservoir是核心,一般100-1000维,内部是稀疏连接,且权重是不需要训练的;
  3. 输出是对中间state的线性变换,权重Wout可以很容易计算出来。

权重初始化

  1. Win:均匀分布 [-IS, IS]
  2. Wres: 具体如图

    α是非零的概率,表示这个循环连接是稀疏的。
    其中提到了ESN的一个很重要的性质Echo State Property,好像是指echo state具有短时记忆的作用。

权重计算

考虑一个简单情况,去掉输入层到输出层的连接,fout函数取线性函数,可得:



我们把x(t)用矩阵表示:X (大小为T*N,T为数据个数,N为中间层神经元个数),y(t) 用向量y (大小为T)表示,则我们可以得到loss函数:


对w求导,导数=0,得


如果加上正则项


可以看出,w权重的求解简单,不需要梯度下降等的方法。
更加具体的ESN可以参考article

确定性的ESN(Deterministically Constructed ESN)

原始的ESN的权重是随机初始化的,为了避免随机性,就有了确定性的ESN。

  1. 输入权重Win为v或者-v,v是大于0的随机数,正负号是随机的。
  2. reservoir的内部连接是确定的,即神经元i+1连i, 1连N。权重就是W_i+1,i=u,W_1,N = u,u>0, 其他权重为0。用图表示为:


    determined ESN

Autoencoder

自编码器学习的是从输入x到输出也为x(identical map),分为编码器encoder和解码器decoder。encoder将x映射到想要的编码(维数Q),decoder将编码转换为原来的输入。



优化目标:最小化reconstruction mse:



最简单编码器可以是一个三层的只有一个隐含层神经网络,中间层为编码层。其他AE有sequence to sequence(lstm),VAE等。

2. 论文提出的模型 (Model Formulation)

论文提出的方法有两个阶段:一是将时序用ESN得到Wout表示(后面用w表示),二是对w进行降维,可视化。

Embedding time series in the space of readout weights

Deterministic ESN 对所有序列用输出层权重w表示,注意embedding时对于不同序列D-ESN是固定参数,D, v, u。
w能很好的表达序列的特征,捕捉关于序列y的重要信息,好的预测y的能力,同时具有时移不变性(time-shift invariance 即不随时间变化),能适应不同长度的序列。
为了得到预测能力最好的固定的reservoir,论文对v, u取十个候选值 [10^-2, ..., 1.0],一共100中组合,做如下操作:

  1. 将所有序列y分为两半,得ytrain和ytest
  2. 根据上面提到的权重计算方法得到每个序列对应的w
  3. 算测试误差



    最后选择具有最小测试误差的参数,另外参数D, μ也是这样取最优的。

ESN-coupled Autoencoder

序列用w表达后,需要将w进行降维才能可视化,所以使用Autoencoder的方法降维。
直接的做法就是f(w) -> w,最小化


这种重构误差测量的是L2范数。一个更好的表示重构误差是在序列空间中测量,将重构得到近似w' 使用Xw'=y'得到对应的序列y'。新的目标函数为

可以理解为是另外一个loss函数,更容易优化。这里对重构的w'没有限制,是不是会让w'偏离原来的w呢?从实验结果看是不会的,其实应该是对于Xw=y只有一个最优值w,这样w'会向着一个w趋近,而这个目标函数是会比前一个函数更容易优化,减少了重构的误差。

Data Projection

训练得到Autoencoder后,将w投射到二维z。至此,我们将序列从y到w,再从w到z的低维表达。

二值序列

前面针对的序列都是连续,这一部分讲了如何将ESN应用到二值序列中,y(t) in {0, 1}。
ESN:



y(t)-0.5是因为函数h是tanh函数。输出使用了sigmoid函数,表示输出1的概率,后面就可以用交叉熵来算loss:



Autoencoder的loss:

放大因子 Magnification Factors

这个有些地方不懂,大概意思是每个点z(空间V)会有一个对应w=f_dec(z)。假定观测y是包含高斯噪声的,则得到概率分布p(y; f_dec(z)):


放大倍数应该是指在V空间中的距离Δz与对应的概率模型p(y;w)间的距离的放大的倍数。然后里面的计算方法没有看懂 -. -!
直观理解就是z的改变对所表示的y的分布的改变有多大

3. 实验

数据集

  • NARMA
  • Cauchy: 柯西分布
  • X-ray
  • Wind:不同地方的风速数据
  • Textual data(符号):三种不同语言的文本,用01表示文字,得到三种序列。

降维算法

  • PCA
  • t-SNE
  • Standard AE
  • ESN-AE
    AE的层数没有给出,只给了编码器和解码器的隐藏层H=10,权重正则系数v=1。

实验结果

可视化结果


image.png

可以看出ESN-AE能较好的降维表示,能更好的区分不同类。(如果我们对序列降维后进行聚类,可以得到更好的聚类结果)

重构误差

4. 总结

论文提出的ESN-coupled AE方法将序列用ESN的w表示,然后再用ESN-AE对w降维。降维后的可视化展示了这个方法能较好的区分开不同类。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容