# -*- coding: utf-8 -*-
"""
author: zengbin93
email: zeng_bin8888@163.com
create_dt: 2022/1/24 15:01
describe: 常用技术分析指标
"""
import numpy as np
[docs]def SMA(close: np.array, timeperiod=5):
"""简单移动平均
https://baike.baidu.com/item/%E7%A7%BB%E5%8A%A8%E5%B9%B3%E5%9D%87%E7%BA%BF/217887
:param close: np.array
收盘价序列
:param timeperiod: int
均线参数
:return: np.array
"""
res = []
for i in range(len(close)):
if i < timeperiod:
seq = close[0: i+1]
else:
seq = close[i - timeperiod + 1: i + 1]
res.append(seq.mean())
return np.array(res, dtype=np.double).round(4)
[docs]def EMA(close: np.array, timeperiod=5):
"""
https://baike.baidu.com/item/EMA/12646151
:param close: np.array
收盘价序列
:param timeperiod: int
均线参数
:return: np.array
"""
res = []
for i in range(len(close)):
if i < 1:
res.append(close[i])
else:
ema = (2 * close[i] + res[i-1] * (timeperiod-1)) / (timeperiod+1)
res.append(ema)
return np.array(res, dtype=np.double).round(4)
[docs]def MACD(close: np.array, fastperiod=12, slowperiod=26, signalperiod=9):
"""MACD 异同移动平均线
https://baike.baidu.com/item/MACD%E6%8C%87%E6%A0%87/6271283
:param close: np.array
收盘价序列
:param fastperiod: int
快周期,默认值 12
:param slowperiod: int
慢周期,默认值 26
:param signalperiod: int
信号周期,默认值 9
:return: (np.array, np.array, np.array)
diff, dea, macd
"""
ema12 = EMA(close, timeperiod=fastperiod)
ema26 = EMA(close, timeperiod=slowperiod)
diff = ema12 - ema26
dea = EMA(diff, timeperiod=signalperiod)
macd = (diff - dea) * 2
return diff.round(4), dea.round(4), macd.round(4)
[docs]def KDJ(close: np.array, high: np.array, low: np.array):
"""
:param close: 收盘价序列
:param high: 最高价序列
:param low: 最低价序列
:return:
"""
n = 9
hv = []
lv = []
for i in range(len(close)):
if i < n:
h_ = high[0: i+1]
l_ = low[0: i+1]
else:
h_ = high[i - n + 1: i + 1]
l_ = low[i - n + 1: i + 1]
hv.append(max(h_))
lv.append(min(l_))
hv = np.around(hv, decimals=2)
lv = np.around(lv, decimals=2)
rsv = np.where(hv == lv, 0, (close - lv) / (hv - lv) * 100)
k = []
d = []
j = []
for i in range(len(rsv)):
if i < n:
k_ = rsv[i]
d_ = k_
else:
k_ = (2 / 3) * k[i-1] + (1 / 3) * rsv[i]
d_ = (2 / 3) * d[i-1] + (1 / 3) * k_
k.append(k_)
d.append(d_)
j.append(3 * k_ - 2 * d_)
k = np.array(k, dtype=np.double)
d = np.array(d, dtype=np.double)
j = np.array(j, dtype=np.double)
return k.round(4), d.round(4), j.round(4)
[docs]def RSQ(close: [np.array, list]) -> float:
"""拟合优度 R Square
:param close: 收盘价序列
:return:
"""
x = list(range(len(close)))
y = np.array(close)
x_squred_sum = sum([x1 * x1 for x1 in x])
xy_product_sum = sum([x[i] * y[i] for i in range(len(x))])
num = len(x)
x_sum = sum(x)
y_sum = sum(y)
delta = float(num * x_squred_sum - x_sum * x_sum)
if delta == 0:
return 0
y_intercept = (1 / delta) * (x_squred_sum * y_sum - x_sum * xy_product_sum)
slope = (1 / delta) * (num * xy_product_sum - x_sum * y_sum)
y_mean = np.mean(y)
ss_tot = sum([(y1 - y_mean) * (y1 - y_mean) for y1 in y]) + 0.00001
ss_err = sum([(y[i] - slope * x[i] - y_intercept) * (y[i] - slope * x[i] - y_intercept) for i in range(len(x))])
rsq = 1 - ss_err / ss_tot
return round(rsq, 4)