过滤高频数据的微小波动using sas

*
1) 均线化
因为行情的日内高频价格序列波动比较剧烈,看起来也几乎是杂乱无章的,所以我们为
了捕捉趋势需要过滤掉一些干扰的噪声,均线是过滤微小扰动的一种常用的方式,而且也适
合用于捕捉趋势。我们将A 个连续的数据取均值,形成MA(A),在本文所作测试中A 取为
10,下文都称经过均值化的数据位MA(10)。由于采用的原始价格序列是6 秒高频数据,所
以均线化后的数据类似于60 秒价格均值。经过均值化后的价格序列明显平滑了很多,不再像之前6
秒价格序列那样波动剧烈。
*;
proc expand data=six_test out=ma_test
   method =none ;
   convert price=ma_price / transformout=(movave 10);
   convert price=ma2_price / transformout=(movave 50);
   convert price=ma3_price / transformout=(movave 100);
run;

proc sgplot data=ma_test;
  series x=time1 y=ma_price;
  series x=time1 y=price;
run;
*
2) 记录极值点
极值点是局部的高点或者低点,在极值点处股价出现了转折,所以这些点是图形分析的
重要点位,它们包含了重要的信息。判断极值点的方法也比较简单:浏览经过均值化的价格
序列MA(10),如果股价上涨至此,接下来又下跌,那么这个点就是极高值点;如果股价下
跌至此,接下来又出现上涨,那么这个点就是极低值点。这些点利用另外一个数组记录下来,
它们是股价变化的关键点,以备进一步制定策略。
*;
data extreme_test;
   set ma_test;
   dif=dif(ma_price);
   if dif>0 then flag=1;*最后一个1(-1)为极值点;
   else flag=-1;
   retain cnt ;
   if flag^=lag(flag) then cnt+1; 
run;

*
3) 过滤极值附近微小波动
均线用于追踪趋势效果比较好,在形成趋势时能紧跟趋势,虽然略有滞后,但是在于用
高频数据分析中,价格波动较多,均线也就摇摆不定,容易频繁发出交易信号,
高频数据中,很容易出现很多极值点连续出现的情况,这对于分析也是很大的干扰。
所以我们必须对极值附近的点进行滤波。我们滤波的方法是,当股价形成一个极点E 后,比如在接下来
股价波动范围在E 点价位正负0.01 元以内,我们就认为股价过滤微小波动后的趋势
线和E 点没有区别,这样我们就得到了过滤了极值点附近微小波动的均线趋势线filtered。
*;
proc sql;
   create table filtrate_test as
   select *,
          sum(dif) as s_dif 
   from extreme_test
   group by cnt;
quit;
data filtrate_test1;
   set filtrate_test;
   if abs(s_dif)< 0.1 then flag1=-flag;
   else flag1=flag;
   drop flag;
   rename flag1=flag; *新的极值点为flag的第一个和最后一个值;
run; 

你可能感兴趣的:(sql,数据分析,测试,table,图形)