WeQuant交易策略—EMV
EMV指标策略
简介
EMV(Ease of Movement Value, 简易波动指标),它是由RichardW.ArmJr.根据等量图和压缩图的原理设计而成, 目的是将价格与成交量的变化结合成一个波动指标来反映股价或指数的变动状况。 旨在先于其他投资者买入/卖出。
计算方法(以日为单位举例)
(1) A = (当日最高价 + 当日最低价)/ 2 B = (前日最高价 + 前日最低价)/ 2 C = 当日最高价 – 当日最低价 (2) 当日EM = (A – B ) * C / 当日成交额 (3) EMV = N日内EM的总和
使用方法
当EMV值从下向上穿过零轴时,全仓买入;EMV值从上向下穿过零轴时,全仓卖出。
如果较少的成交量便能推动股价上涨,则EMV数值会升高,相反的,股价下跌时也仅伴随较少的成交量,则EMV数值将降低。另一方面,倘若价格不涨不跌,或者价格的上涨和下跌,都伴随着较大的成交量时,则EMV的数值会趋近于零。
EMV指标曲线大部份集中在0轴下方,这个特征是EMV指标的主要特色,由于股价下跌一般成交量较少,EMV自然位于0轴下方,当成交量放大时,EMV又趋近于零,这可以说明EMV的理论精髓中,无法接受股价在涨升的过程,不断的出现高成交量消耗力气,反而认同徐缓成交的上涨,能够保存一定的元气,促使涨势能走得更远更长。从另外一个角度说,EMV重视移动长久且能产生足够利润的行情。关于EMV和EMV的平均线,两线的交叉并无意义,而是选择以EMV指标平均线跨越0轴为讯号,所产生的交易成果将更令人满意。
优点
EMV的用法十分简单,只要看EMV线穿越零轴这一点即可。而且,较好地运用波动指标EMA不仅可以避免在市场中盲目追涨杀跌,而且还能够发现较好得操作时机。
缺点
EMV指标反应的是价格运行全过程中成交量的动态变化情况。因此,指标对价格的中长期走势更具有警示性。须长期使用EMV指标,才能获得较好的投资效果。想要短期高频操作的同学,最好不要使用EMV作为买卖指标。
代码
# !/usr/bin/env python # -*- coding: utf-8 -*- # 策略代码总共分为三大部分,1)PARAMS变量 2)initialize函数 3)handle_data函数 # 请根据指示阅读。或者直接点击运行回测按钮,进行测试,查看策略效果。 # 策略名称:EMV指标策略 # 策略详细介绍:https://wequant.io/study/strategy.emv.html # 关键词:成交量、捕捉趋势。 # 方法: # 1)通过价格变化以及成交量来捕捉趋势; # 2)在上升趋势买入,在下跌趋势卖出。 # 阅读1,首次阅读可跳过: # PARAMS用于设定程序参数,回测的起始时间、结束时间、滑点误差、初始资金和持仓。 # 可以仿照格式修改,基本都能运行。如果想了解详情请参考新手学堂的API文档。 PARAMS = { "start_time": "2017-02-01 00:00:00", # 回测起始时间 "end_time": "2017-08-01 00:00:00", # 回测结束时间 "slippage": 0.003, # 此处“slippage"包含佣金(千二)+交易滑点(千一) "account_initial": {"huobi_cny_cash": 100000, "huobi_cny_btc": 0}, # 设置账户初始状态 } # 阅读2,遇到不明白的变量可以跳过,需要的时候回来查阅: # initialize函数是两大核心函数之一(另一个是handle_data),用于初始化策略变量。 # 策略变量包含:必填变量,以及非必填(用户自己方便使用)的变量 def initialize(context): # 设置回测频率, 可选:"1m", "5m", "15m", "30m", "60m", "4h", "1d", "1w" context.frequency = "4h" # 设置回测基准, 比特币:"huobi_cny_btc", 莱特币:"huobi_cny_ltc", 以太坊:"huobi_cny_eth" context.benchmark = "huobi_cny_btc" # 设置回测标的, 比特币:"huobi_cny_btc", 莱特币:"huobi_cny_ltc", 以太坊:"huobi_cny_eth" context.security = "huobi_cny_btc" # 设置EMV回看累积时间段 context.user_data.emv_period = 14 # 阅读3,策略核心逻辑: # handle_data函数定义了策略的执行逻辑,按照frequency生成的bar依次读取并执行策略逻辑,直至程序结束。 # handle_data和bar的详细说明,请参考新手学堂的解释文档。 def handle_data(context): # 获取历史数据 hist = context.data.get_price(context.security, count=context.user_data.emv_period + 2, frequency=context.frequency) if len(hist.index) < (context.user_data.emv_period + 2): context.log.warn("bar的数量不足, 等待下一根bar...") return # 每根bar的最高价 high = hist["high"] # 每根bar的最低价 low = hist["low"] # 每根bar的成交量(数量) vol = hist["volume"] close = hist["close"] # 计算EMV a = (high + low) / 2 b = a.shift(1) c = high - low em = (a - b) * c / vol emv = em.rolling(window=context.user_data.emv_period).sum() # 当前bar的EMV值 emv_current = emv[len(emv)-1] # 前一根bar的EMV值 emv_prev = emv[len(emv)-2] context.log.info("当前 EMV = %s; 前一根bar EMV = %s" % (emv_current, emv_prev)) # EMV从下向上穿过零轴,买入信号 if emv_prev <= 0 < emv_current: context.log.info("EMV由下向上穿过0轴,产生买入信号") if context.account.huobi_cny_cash >= HUOBI_CNY_BTC_MIN_ORDER_CASH_AMOUNT: # 有买入信号,且持有现金,则市价单全仓买入 context.log.info("正在买入 %s" % context.security) context.log.info("下单金额为 %s 元" % context.account.huobi_cny_cash) context.order.buy_limit(context.security, quantity=str(context.account.huobi_cny_cash/close[-1]*0.98), price=str(close[-1]*1.02)) else: context.log.info("现金不足,无法下单") # EMV从上向下穿过零轴,卖出信号 elif emv_prev >= 0 > emv_current: context.log.info("EMV由上向下穿过0轴,产生卖出信号") if context.account.huobi_cny_btc >= HUOBI_CNY_BTC_MIN_ORDER_QUANTITY: # 有卖出信号,且持有仓位,则市价单全仓卖出 context.log.info("正在卖出 %s" % context.security) context.log.info("卖出数量为 %s" % context.account.huobi_cny_btc) context.order.sell_limit(context.security, quantity=str(context.account.huobi_cny_btc), price=str(close[-1]*0.98)) else: context.log.info("仓位不足,无法卖出") else: context.log.info("无交易信号,进入下一根bar")
回测
- 参数设置如下:
时间段 | 2017-02-01至2017-08-01 |
回测频率(context.frequency) | 4h |
EMV回看时间窗口 | 5(天) |
股票市场常用的回看时间窗口一般是14天。但是由于数字货币市场自身容易暴涨暴跌的特性,回看时间太长会很难及时对市场的变化做出反应,过于滞后。因此,需要将回看窗口适当调小。大家也可以尝试一下别的时间窗口,看看效果如何。
- 回测结果:
从回测结果中,我们看出EMV指标在捕捉行情上非常有效。几次大幅上涨都有抓住,而在下跌的时候也能比较及时的逃出,锁定收益。
现在,将回看时间调到传统的14天,我们来看一下回测结果:
现在的表现大不如前,几次暴跌都没能反映过来,将大部分收益回吐。所以,在设置指标的参数时,要区分不同产品不同行情,不能无脑照搬。
总结
EMV指标引入了成交量数据,与其他单纯通过价格来计算出的指标,能更有效的反应出一些价格背后所隐藏的东西。在数字货币市场中,EMV指标的回看时间不宜过长,防止在暴涨暴跌中不能及时应对。
WeQuant交易策略—EMV的更多相关文章
- WeQuant交易策略—网格交易
网格交易策略(Grid Trading) 策略介绍 网格策略本质上是一种低吸高抛的策略.标的物价格越低,吸纳的头寸越多:标的物价格越高,卖出的头寸越多.网格策略巧妙地借鉴了日常生活中渔翁撒网扑鱼的思路 ...
- WeQuant交易策略—Dual Thrust
Dual Thrust策略 策略介绍 Dual Thrust是一个趋势跟踪系统,由Michael Chalek在20世纪80年代开发,曾被Future Thruth杂志评为最赚钱的策略之一. Dual ...
- WeQuant交易策略—ATR
ATR(真实波幅均值)策略 策略介绍 ATR(average true range,真实波幅均值),是用来衡量一段时间内价格的真实的平均波动范围,ATR不是一个领先指标,但是它测量最重要的市场参数之一 ...
- WeQuant交易策略—RSI
RSI指标策略 策略介绍 RSI(相对强弱指标),是通过一段时期内的平均收盘上涨和下跌数,计算价格上涨所产生的波动占整个波动的百分比,来分析市场买卖盘的意向和实力. 计算公式(以日为单位举例) RSI ...
- WeQuant交易策略—BOLL
BOLL(布林线指标)策略 简介 BOLL(布林线)指标是技术分析的常用工具之一,由美国股市分析家约翰•布林根据统计学中的标准差原理设计出来的一种非常简单实用的技术分析指标.一般而言,价格的运动总是围 ...
- WeQuant交易策略—KDJ
KDJ随机指标策略策略介绍KDJ指标又叫随机指标,是一种相当新颖.实用的技术分析指标,它起先用于期货市场的分析,后被广泛用于股市的中短期趋势分析,是期货和股票市场上最常用的技术分析工具.随机指标KDJ ...
- WeQuant交易策略—MACD
MACD(指数平滑异同平均线)策略简介MACD指标应该是大家最常见的技术指标,在很多股票.比特币的软件中都是默认显示的.MACD是从双指数移动平均线发展而来的.意义和双移动平均线基本相同,即由快.慢均 ...
- WeQuant交易策略—简单均线
简单双均线策略(Simple Moving Average) 策略介绍简单双均线策略,通过一短一长(一快一慢)两个回看时间窗口收盘价的简单移动平均绘制两条均线,利用均线的交叉来跟踪价格的趋势.这里说的 ...
- WeQuant交易策略—Chaikin A/D
策略名称:AD指标策略 多空双方力量浮标- AD(Chaikin A/D线)策略关键词:ChaikinA/D线.多空对比.AD指标是一种非常流行的平横交易量指标, 用于估定一段时间内该证券累积的资金流 ...
随机推荐
- 解决:Access denied for user 'root'@'localhost' (using password: YES)
症状: 重新安装了MySQL,改变了root的密码,因此,在java代码中修改了某个DatabaseConnectionImpl的DBPASSWORD 在java中写了一些代码测试MySQL的插入和查 ...
- 存储管理器实验——SDRAM
序言:2440有nand和nor两种启动方式,在裸机部分,都是使用的nand启动. 现在,我们想在nand flash启动的时候,通过SRAM访问存储在外设SDRAM中的程序. nand启动,先把前4 ...
- [uboot]Issue list
- 实现cell显示一个删除button
假设想实现滑动cell时,cell右边就能显示一个删除button,则要实现tableview 下边方法: - (void)tableView:(UITableView *)tableView com ...
- Bitmap转灰度字节数组byte[]
工作中遇到图片转灰度数组的须要,经过研究和大神的指导.终于得到例如以下两个方法.能够实现位图转灰度数组 简单的位图转灰度数组就是:得到位图中的每一个像素点,然后依据像素点得到RGB值,最后对RGB值, ...
- mongdb 慢查询
查看mongodb慢查询 赶紧打开服务器爸爸,开慢查询,看下耗时500ms以上的都是些啥: db.setProfilingLevel(2,500) 看下最近的10条具体的慢查询指令: db.syste ...
- SQL Server 2012附加数据库报错
操作系统: win8 数据库:SQL 2012 遇到问题: 以管理员身份登录SQL 2012,附件数据库提示如下错误: 解决办法: 以windows账号登录,附加,成功!
- 时钟.html
<!DOCTYPE html><html charset="utf-8"> <head> <title>时钟</title&g ...
- [android] AndroidManifest.xml - 【 manifest -> permission】
在 API Level 1 时被引入 语法: <permission android:description="string resource" android:icon= ...
- trim() 是什么意思?
这是一个很常见的函数,他的所用是去掉字符序列左边和右边的空格,如字符串str = " ai lafu yo ";str = trim(str); cout << str ...