计算布林带

简介: 计算布林带# coding: utf-8# 作者:Wizard import numpy as npfrom matplotlib import pyplot as pltimport sys# 获取数据# 因为没找到数据源,所以直接随机生成了series = np.

计算布林带

# coding: utf-8
# 作者:Wizard <github.com/wizardforcel>

import numpy as np
from matplotlib import pyplot as plt
import sys

# 获取数据
# 因为没找到数据源,所以直接随机生成了
series = np.random.rand(100) * 10 + 10
ser_len = len(series)

# 获取窗口大小,默认为 5
win_sz = 5 if len(sys.argv) < 2 else sys.argv[1]
print u'窗口大小: ', win_sz

# 计算权重,sma_weight 为简单滑动
# ema_weight 为指数滑动
sma_weight = np.ones(win_sz).astype(float) / win_sz
ema_weight = np.exp(np.linspace(-1, 0, win_sz))
ema_weight /= ema_weight.sum()


# 手动计算简单/指数滑动平均,以及滑动标准差
# 滑动平均就是当天和前 N - 1 天的(加权)均值
# 其中 N 是窗口大小,标准差与之类似
sma = []
ema = []
mstd = []

for i in xrange(win_sz - 1, ser_len):

    ser_range = series[i - (win_sz - 1): i + 1]
    avg = (ser_range * sma_weight).sum()
    sma.append(avg)
    avg = (ser_range * ema_weight).sum()
    ema.append(avg)

    std = ser_range.std()
    mstd.append(std)

sma = np.asarray(sma)
mstd = np.asarray(mstd)

# 上布林带是简单滑动均值加上两个滑动标准差
# 下布林带是简单滑动均值减去两个滑动标准差
upper = sma + 2 * mstd
lower = sma - 2 * mstd

# 要注意横轴从 N - 1 开始
ser_slice = series[win_sz - 1:]
x = np.arange(win_sz - 1, ser_len)
print 'x: ', x[:5]

# 绘制函数
plt.plot(x, ser_slice, 'b', label='series')
print u'序列: ', ser_slice[:5]
plt.plot(x, sma, 'g', label='sma')
print u'简单滑动均值: ', sma[:5]
plt.plot(x, ema, 'r', label='ema')
print u'指数滑动均值: ', ema[:5]

plt.plot(x, upper, 'grey', label='upper bolling')
plt.plot(x, lower, 'grey', label='lower bolling')

plt.legend()
plt.show()

相关文章
|
3月前
|
算法
联想算法题-石头剪刀布
联想算法题-石头剪刀布
39 0
|
9月前
小游戏(猜数字、剪刀石头布) 2021-01-03
小游戏(猜数字、剪刀石头布) 2021-01-03
|
9月前
|
机器学习/深度学习 人工智能 自然语言处理
【每周一坑】三国演义中谁的存在感最强 +【解答】暴力计算圆周率
当然,精确统计是比较复杂的,比如同样是刘备,可以是 刘备、玄德、刘豫州、刘皇叔、使君、先主、备,而同样的 主公、丞相、将军 这些称谓在不同语境下指的又是不同的人。这里我们就只粗略算个大概即可,统计哪些个名字出现次数最多。你可以尽量让结果更接近实际值。
|
4月前
|
存储 JavaScript 索引
基于 HTML+CSS+JS 的石头剪刀布游戏
基于 HTML+CSS+JS 的石头剪刀布游戏
78 0
|
7月前
|
算法
石头剪刀布 L1-044 稳赢 15分
石头剪刀布 L1-044 稳赢 15分
|
7月前
|
弹性计算 数据安全/隐私保护 Python
石头剪刀布
本场景介绍如何在阿里云ECS环境下用Python实现一款人机对战小游戏:石头剪刀布。
288 0
|
8月前
[普及练习场] 生活大爆炸版石头剪刀布
[普及练习场] 生活大爆炸版石头剪刀布
115 0
|
8月前
|
Shell
脚本编写 剪刀 、 石头、布游戏
脚本编写 剪刀 、 石头、布游戏
86 1
|
测试技术 Python
PTA 1018 锤子剪刀布 (20 分)
大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示
123 0
|
Java
Java锤子剪刀布大家应该都会玩“锤子剪刀布”的游戏: 现给出两人的交锋记录,请统计双方的胜、平、负次数,并且给出双方分别出什么手势的胜算最大。
Java锤子剪刀布大家应该都会玩“锤子剪刀布”的游戏: 现给出两人的交锋记录,请统计双方的胜、平、负次数,并且给出双方分别出什么手势的胜算最大。
142 0

热门文章

最新文章

相关实验场景

更多