k线系列目录
查看目录请点击这儿
前言
如果有炒股的同学,想必对于MA、BOLL、MACD等各种K线指标已经很熟悉了。在平时炒股中,技术面分析可全靠这些经典的指标来判断行情趋势。那么今天,我们就来学习一下关于K线指标的一些知识。
或许很多开发者会说,指标这些数据全部都是由后台同学来传送到移动端,然后直接根据数据来绘制相应的指标就可以了。但是,万一前端会修改指标参数呢? 例如这样:
如果每修改一次,就需要告诉后端来实时计算,这样的方式肯定不可能接受。
所以,就需要移动端来计算K线指标。这里提供两种选择:
1、TA-Lib
2、手写指标库
首先看TA-Lib,这个库已经是很久之前的一个股票指标计算库,最新版本是0.4版,支持多平台运行,点击这里可以下载。下载完成以后,直接导入项目中就可以使用。
当然,如果你问有什么缺点没?肯定有,因为TA-Lib是美国的一个开源库,所以在计算时,有可能计算出来的结果与数据供应商提供的不一致。原因有很多种,平滑值不同、乘数不同、公式有差别等等。
所以就说到第二种,自己手写指标库,这样的话,如果计算结果有误差还可以再调整。至于说指标公式,其实有很多地方可以拿:
1、通达信、大智慧、同花顺等主流的PC看盘软件
2、公司内部
3、淘宝购买,网上类似公式网获取
指标
这里为了演示,就直接从通达信PC看盘软件中截取几个指标。如下:
MA指标
首先看第一个指标:MA。
1、公式:
MA(CLOSE, M1)。
2、释义:
‘CLOSE’指收盘价,M1是周期参数,意思是指收盘价在M1周期内的简单移动平均。
3、计算方法:
(CLOSE1+CLOSE2+CLOSE3+…..+CLOSEN)/MN。
其实也就是求N周期内收盘价的平均数。这里假设m1为5,当前点为X,那么这个X点的ma值为
MA5=(Xn−4+Xn−3+Xn−2+Xn−1+Xn)5
那每一个值的ma值都可以依次往前遍历周期数,最后算出平均数。这里要注意当向前遍历时,不足周期数的每个点都直接赋为当前点的收盘价。代码如下:
void getMA(double close[], int length, int m, double ma[])
{
double sum = 0;
for(int idx = length - 1; idx >= 0; idx--)
{
if(idx >= m)
{
for(int jdx=0; jdx<m; jdx++)
{
sum += close[idx-jdx];
}
ma[idx] = sum/m;
sum = 0;
}else
{
ma[idx] = close[idx];
}
}
}
MACD指标
接着来看MACD指标:
1、公式:
DIF: EMA(CLOSE,SHORT)-EMA(CLOSE,LONG);
DEA:EMA(DIF,MID);
MACD:(DIF-DEA)* 2,COLORSTICK。
2、释义:
CLOSE为收盘价,SHORT、LONG、MID为参数
3、EMA的意思为:
EMA(X, N): X的N日指数移动平均
算法为:Y=(X∗2+YL∗(N−1))(N+1)
千万别被公式吓懵逼,其实很简单。一个macd指标包含3个值:DIF、DEA、MACD。DIF值是需要用参数为SHORT时收盘价的EMA值减去参数为LONG时收盘价的EMA值;DEA值是参数为MID时DIF值的EMA值;MACD值就是DIF值与DEA值的差再乘以2。
重点来了,EMA怎么求?算法中Y上面有一个L的意思为前一个求得的Y值,当然,数据的第一个点肯定没有Y值,这里就需要使用一个平滑值来代替。
代码如下:
void getEma(double close[], int length, int N, double ema[])
{
ema[0] = 100;
for(int idx=1; idx<length; idx++)
{
ema[idx] = (close[idx] * 2 + ema[idx-1] * (N-1))/ (N+1);
}
}
KDJ指标
最后来看KDJ指标:
1、公式为:
RSV:=(CLOSE-LLV(LOW,N))/(HHV(HIGH,N)-LLV(LOW,N))*100;
K:SMA(RSV,M1,1);
D:SMA(K,M2,1);
J:3*K-2*D;
2、释义:
CLOSE为收盘价,LOW是最低价,HIGH是最高价, N、M1、M2为参数
3、LLV意思是:
LLV(X, N)求N周期内X值的最小值
4、HHV意思是:
HHV(X, N)求N周期内X值的最大值
5、SMA意思是:
SMA(X, N, M)
求X的N日移动平均,权重为M
算法为:
Y=X∗M+YL∗(N−M)N
KDJ指标包含3个值:K值、D值、J值,要求J值就需要有K、D值,要求D值就需要计算K值,那如何计算K值呢? 看公式就可以得出是求RSV值的M1日移动平均,权重为1。
所以先来求SMA值
void getSma(double X[], int length, int N, int M, double sma[])
{
sma[0] = 100;
for(int idx=1; idx<length; idx++)
{
sma[idx] = (X[idx] * M + sma[idx-1] * (N - M)) / N;
}
}
然后再来看RSV值,算法如下:
LLV(X, N)是求N周期内X值的最小值,HHV(X, N)是求N周期内X值的最大值。
结尾
其实关于K线指标有超级多,上述也只是举了几个简单的例子,权当抛砖引玉。其他的指标,如果想要写的话,可以直接在PC端看盘软件中拿到公式,然后再根据公式编写代码,最后计算求得。
当然,关于K线指标的可讨论点还是非常多的,如果有任何疑问,欢迎随时评论!