Python 量化投资(一):滑动均值、布林带、MACD、RSI、KDJ、OBV

简介: Python 量化投资(一):滑动均值、布林带、MACD、RSI、KDJ、OBV

滑动均值和标准差

为了更好利用向量化来加速,滑动窗口使用np.lib.stride_tricks.sliding_window_view(x, win)提取,它会返回所有x[i]开头并且长度为win的数组的数组。

def rolling(x, win):
    r = np.lib.stride_tricks.sliding_window_view(x, win)
    pad = np.zeros([len(x) - len(r), win]) * np.nan
    return np.vstack([pad, r])
def rolling_mean(x, win):
    return rolling(x, win).mean(-1)
def rolling_std(x, win):
    return rolling(x, win).std(-1)

布林带

def bollinger(close, win=10, nstd=2):
    means = rolling_mean(close, win)
  stds = rolling_std(close, win)
  upper = means + nstd * stds
  lower = means - nstd * stds
  return upper, means, lower

指数滑动均值

这是原始实现:

# 计算指数平滑 
# y[i] = alpha * x[i] + (1 - alpha) * y[i - 1]
def exp_smooth_naive(x, alpha):
    y = x.copy()
    for i in range(1, len(y)):
    y[i] = y[i] * alpha + y[i - 1] * (1 - alpha)
  return y

原始公式是递归的,需要改成通项才能向量化,这是推导过程:

y[0] = x[0] = init
y[t] = alpha * x[t]  + (1-alpha) * y[t-1]
     = alpha * x[t]  + (1-alpha) * alpha * x[t-1] + (1-alpha) ** 2 * y[t-2]
   = alpha * x[t]  + (1-alpha) * alpha * x[t-1] + ... + (1-alpha)** t * init
   = alpha * x[t]  + (1-alpha) * alpha * x[t-1] + ... + alpha * (1-alpha)** t * init + (1 - alpha) ** (t + 1) * init
   = Σ(alpha * (1 - alpha) ** i * x[t-i]; i: 0 -> t) + (1 - alpha) ** (t + 1) * init
corr[i] = alpha * (1-alpha) ** i
supl[t] = (1 - alpha) ** (t + 1) * init 
y[t] = Σ(corr[i] * x(t-i); i: 0 -> t) + supl[t]
y = conv(corr, x) + supl

这就完成了向量化,因为 NumPy 或者 PyTorch 都针对卷积做了特殊优化。

def exp_smooth_vec(x, alpha):
  init, n = x[0], len(x)
  corr =  alpha * (1 - alpha) ** np.arange(0, n)
  supl = (1 - alpha) ** (np.arange(0, n) + 1) * init
  y = np.convolve(corr, x, 'full')[:n] + supl
  return y
exp_smooth = exp_smooth_vec
def rolling_ema(x, win):
    x = np.asarray(x)
    alpha = 2 / (win + 1.0)
  return exp_smooth(x, alpha)

MACD

def macd(close, fast_win=12, slow_win=26, sig_win=9):
  fast = rolling_ema(close, fast_win)
  slow = rolling_ema(close, slow_win)
  dif = fast - slow
  dea = rolling_ema(dif, sig_win)
  macd_ = dif - dea * 2
  return macd_, dif, dea

RSI

def rsi(close, win=3):
  change = np.diff(close)
  up = np.where(change > 0, change, 0)
  down = np.where(change < 0, change, 0)
  sum_up = rolling(up, win).sum(-1)
  sum_down = rolling(down, win).sum(-1)
  eps = 1e-12
  rs = sum_up / (sum_down + eps)
  rsi_ = 100 - 100 / (1 + rs)
  return np.hstack([[np.nan], rsi_])

KDJ

def kdj(close, low, high, n=9):
  hn = rolling(high, n).max(-1)
  ln = rolling(low, n).min(-1)
  rsv = (close - ln) / (hn - ln) * 100
  rsv = [x for x in rsv if not np.isnan(x)]
  rsv = np.hstack([[50], rsv])
  k = exp_smooth(rsv, 2/3)
  d = exp_smooth(k, 2/3)
  j = 3 * k - 2 * d
  pad = [np.nan] * (len(close) - len(k))
  k = np.hstack([pad, k])
  d = np.hstack([pad, d])
  j = np.hstack([pad, j])
  return k, d, j

OBV

def obv(close, vol):
  change = np.diff(close)
  sig = np.hstack([[1], np.sign(change)])
  obv_ = np.cumsum(vol * sig)
  return obv_
相关文章
|
1月前
|
数据可视化 算法 数据挖掘
Python量化投资实践:基于蒙特卡洛模拟的投资组合风险建模与分析
蒙特卡洛模拟是一种利用重复随机抽样解决确定性问题的计算方法,广泛应用于金融领域的不确定性建模和风险评估。本文介绍如何使用Python和EODHD API获取历史交易数据,通过模拟生成未来价格路径,分析投资风险与收益,包括VaR和CVaR计算,以辅助投资者制定合理决策。
80 15
|
4月前
|
安全 Python
Python量化炒股的获取数据函数—get_industry()
Python量化炒股的获取数据函数—get_industry()
50 3
|
4月前
|
Python
Python量化炒股的获取数据函数—get_security_info()
Python量化炒股的获取数据函数—get_security_info()
49 1
|
4月前
|
Python
Python量化炒股的获取数据函数— get_billboard_list()
Python量化炒股的获取数据函数— get_billboard_list()
59 0
|
4月前
|
安全 数据库 数据格式
Python量化炒股的获取数据函数—get_fundamentals()
Python量化炒股的获取数据函数—get_fundamentals()
91 0
|
1月前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
1月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
1月前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
116 80
|
2月前
|
存储 索引 Python
Python编程数据结构的深入理解
深入理解 Python 中的数据结构是提高编程能力的重要途径。通过合理选择和使用数据结构,可以提高程序的效率和质量
162 59
|
23天前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
40 14