zoukankan      html  css  js  c++  java
  • 计算OBV(On-Balance Volume,净额成交量或叫能量潮指标)

    (1) 把BHP数据分别加载到收盘价和成交量的数组中:
    c, v=np.loadtxt('BHP.csv', delimiter=',', usecols=(6, 7), unpack=True)
    为了判断计算中成交量前的正负号,我们先使用diff函数计算收盘价的变化量。diff函数可以
    计算数组中两个连续元素的差值,并返回一个由这些差值组成的数组:
    change = np.diff(c)
    print "Change", change
    收盘价差值的计算结果如下:
    Change [ 1.92 -1.08 -1.26 0.63 -1.54 -0.28 0.25 -0.6 2.15 0.69 -1.33 1.16
    1.59 -0.26 -1.29 -0.13 -2.12 -3.91 1.28 -0.57 -2.07 -2.07 2.5 1.18
    -0.88 1.31 1.24 -0.59]


    (2) NumPy中的sign函数可以返回数组中每个元素的正负符号,数组元素为负时返回-1,为
    正时返回1,否则返回0。对change数组使用sign函数:
    signs = np.sign(change)
    print "Signs", signs
    change数组中各元素的正负符号如下所示:
    Signs [ 1. -1. -1. 1. -1. -1. 1. -1. 1. 1. -1. 1. 1. -1. -1. -1. -1. -1. -1. -1. -1.
    1. 1. 1. -1. 1. 1. -1.]
    另外,我们也可以使用piecewise函数来获取数组元素的正负。顾名思义,piecewise①函
    数可以分段给定取值。使用合适的返回值和对应的条件调用该函数:
    pieces = np.piecewise(change, [change < 0, change > 0], [-1, 1])
    print "Pieces", pieces
    再次输出数组元素的正负,结果如下:
    Pieces [ 1. -1. -1. 1. -1. -1. 1. -1. 1. 1. -1. 1. 1. -1. -1. -1. -1. -1. -1. -1. -1.
    1. 1. 1. -1. 1. 1. -1.]

    (3) OBV值的计算依赖于前一日的收盘价,所以在我们的例子中无法计算首日的OBV值:
    print "On balance volume", v[1:] * signs
    计算结果如下:
    [2620800. -2461300. -3270900. 2650200. -4667300. -5359800. 7768400.
    -4799100. 3448300. 4719800. -3898900. 3727700. 3379400. -2463900.
    -3590900. -3805000. -3271700. -5507800. 2996800. -3434800. -5008300.
    -7809799. 3947100. 3809700. 3098200. -3500200. 4285600. 3918800.
    -3632200.]

     1 import numpy as np
     2 c, v=np.loadtxt('BHP.csv', delimiter=',', usecols=(6, 7), unpack=True)
     3 change = np.diff(c)
     4 print "Change", change
     5 signs = np.sign(change)
     6 print "Signs", signs
     7 pieces = np.piecewise(change, [change < 0, change > 0], [-1, 1])
     8 print "Pieces", pieces
     9 print "Arrays equal?", np.array_equal(signs, pieces)
    10 print "On balance volume", v[1:] * signs

     文章来源:《Numpy学习指南》

  • 相关阅读:
    UED
    内容分发网络CDN(互联网技术)
    分布式系统基础架构
    十六进制后按高低位分开(转)
    Kafka.net使用编程入门(二)
    Storm集成Kafka应用的开发
    .net 框架
    .NET 的 WebSocket 开发包比较(转)
    ASP.NET Web API上实现 Web Socket
    Scrapyd部署爬虫
  • 原文地址:https://www.cnblogs.com/zhangshuwen/p/7017074.html
Copyright © 2011-2022 走看看