声明:看到研究非常细致深入的文章,转载到我的博客园,以便学习和研究。

(转载自聚宽的大象咖啡)

本文参考了如下相关文贴:

  1. 【量化缠论】之分型、笔、线段识别
    1.1. 在该帖的基础上将线段和调整后的k线绘制在一张图中;
    1.2. 添加了中枢判断,并和调整后的k线绘制在一张图中;
  2. 《MACD背离》技术研究对MACD底背离策略改写的改写——30秒极速版
    2.1. 在大牛的基础上对不同类型的背离做了点皮毛分析;

本文以TCL集团(000100)11月6日至10日的30分钟级别,以及华润三九(000999)2017年行情为例介绍总体实现。

绘制k线图

函数get_k_series(security, start_date, end_date, n=30)获取k线序列,默认为30分钟级别。plot_k_series(k_data)函数绘制k线图。TCL集团(000100)11月6日至10日的30分钟级别的k线图绘制如下。

数绘制k线图。TCL集团(000100)11月6日至10日的30分钟级别的k线图绘制如下。

分型、笔、线段

分型是笔的节点,笔相互连接构成线段。分型是通过所考察的级别k线相互关系判断的。关于分型的具体定义截取《缠论》相关章节如下。

图1,第二K线高点是相邻三K线高点中最高的,而低点也是相邻三K线低点中最高的,定义其为顶分型;图2,第二K线低点是相邻三K线低点中最低的,而高点也是相邻三K线高点中最低的,定义为底分型。顶分型的最高点叫该分型的顶,底分型的最低点叫该分型的底。

两个相邻的顶和底之间构成一笔,所谓笔,就是顶和底之间的其他波动,都可以忽略不算,但注意,一定是相邻的顶和底,隔了几个就不是了。而所谓的线段,就是至少由三笔组成。但这里有一个细微的地方要分清楚,因为结合律是必须遵守的,像图3,顶和底之间必须共用一个K线,这就违反结合律了,所以这不算一笔,而图4,就光是顶和底了,中间没有其他K线,一般来说,也最好不算一笔,而图5,是一笔的最基本的图形,顶和底之间还有一根K线。在实际分析中,都必须要求顶和底之间都至少有一K线当成一笔的最基本要求。

当然,实际图形里,有些复杂的关系会出现,就是相邻两K线可以出现如图6这种包含关系,也就是一K线的高低点全在另一K线的范围里,这种情况下,可以这样处理,在向上时,把两K线的最高点当高点,而两K线低点中的较高者当成低点,这样就把两K线合并成一新的K线;反之,当向下时,把两K线的最低点当低点,而两K线高点中的较低者当成高点,这样就把两K线合并成一新的K线。经过这样的处理,所有K线图都可以处理成没有包含关系的图形。而图7,就给出了经过以上处理,没有包含关系的图形中,三相邻K线之间可能组合的一个完全分类,其中的二、四,就是分别是顶分型和底分型,一可以叫上升K线,三可以叫下降K线。所以,上升的一笔,由结合律,就一定是底分型+上升K线+顶分型;下降的一笔,就是顶分型+下降K线+底分型。注意,这里的上升、下降K线,不一定都是3根,可以无数根,只要一直保持这定义就可以。当然,简单的,也可以是1、2根,这只要不违反结合律和定义就可以。至于图8,就是线段的最基本形态,而图9,就是线段破坏,也就是两线段组合的其中一种形态。

如上所述,在实现的过程中,k线的包含关系会影响顶分型和底分型的判断。因此需要首先调整k线的包含关系以便于判断顶分型和底分型。具体调整规则如下:

k线向右包含:

  1. 如果是上升趋势,取更高的最低价;
  2. 如果是下降趋势,取更低的最高价;

k线向左包含:

  1. 如果是上升趋势,取更高的最高价;
  2. 如果是下降趋势,取更低的最低价;

调整过程由函数adjust_by_cintainment(k_data)实现。调整之后的TCL集团(000100)11月6日至10日的30分钟级别的k线图绘制如下:

调整之后的k线之间没有绝对的包含关系,这样容易寻找分型。分型的判断标准如下:

分型判断(并非严格的分型):

  1. 底分型,下降趋势中的第一个最低价抬升;
  2. 顶分型,上升趋势中的第一个最高价回落;
  3. 底分型之后必为顶分型;顶分型之后必为底分型;
  4. 分型之间至少有3根k线;

另外,由于起止点不构成分型,这样线段两端就是空白的。为了美观起见,起止点这里采用第一根和最后一根k线的二分位作为线段的起止点。

通过上面的方法得到分型以及起止点,对应的函数是get_fx(adjusted_k_data)。有了分型就可以连成笔,并进一步将笔连成线段。绘制函数是plot_lines(ax, fx_plot, fx_offset)。绘制效果如下:

中枢判断

缠论中的中枢满足如下条件:

  1. 必须在一个完整的走势类型中(至少3笔);
  2. 价格范围是最小的最高价,以及最大的最低价;

根据上述条件,实现中枢判断函数,对应到get_pivot(fx_plot, fx_offset, fx_observe)。输入中的fx_observe为观测的分型位置,函数返回这个位置前面最近的一个中枢区间。

比如,输入是上图中咖啡色处的分型点位,那么函数输出这个分型位置前面最近的中枢。中枢绘制函数是plot_pivot(ax, pivot_date_interval, pivot_price_interval)。绘制效果如下:

可以看到,目前30分钟图上股价处于最近的中枢上方,如果下跌不进入中枢区就会形成第三类买点(这个第三类买点在本周没有出现)。第三类买点需要动量分析。下文介绍MACD背离的判断实现。

MACD背离判断

MACD背离根据不同人的使用习惯有以下几种类型(以顶背离为例):

  1. 驼峰背离:股价创新高,MACD红柱没有创新高(左图);
  2. 面积背离:股价创新高,MACD红柱面积没有扩大(中图);
  3. 快慢线背离:股价创新高,快慢线死叉点位没有创新高(右图3);

上述三类背离以快慢线背离最为准确,并且计算效率最高。因此本文实现快慢线背离。实现函数为check_deviating(scode, fastperiod=11, slowperiod=26, signalperiod=9)。该函数判断日线级别的背离。判断规则如下:

底背离判断:
最近的收盘价快慢线金叉,与上一次金叉相比,金叉点位提高,dif提高,收盘价下跌;

顶背离判断:
最近的收盘价快慢线死叉,与上一次死叉相比,死叉点位下降,dif下降,收盘价上升;

以华润三九(000999)为例,2017年以来日线级别的背离判断如下:

可以看出以快慢线背离进行判断,买点靠右,卖点靠左,因而风险较小。不过个股也容易出现不有效的情况。背离的判断对于指数更加有效。所以我也会尝试在ETF指数上用背离策略,看看效果如何。

总结

上述实现没有仔细推敲,代码也显得凌乱,个人水平也十分有限。往大神们批评指正!

龙哥量化:缠论的笔、线段、中枢以及MACD背离分析实现的更多相关文章

  1. 龙哥库塔法or欧拉法求解微分方程matlab实现

    举例:分别用欧拉法和龙哥库塔法求解下面的微分方程 我们知道的欧拉法(Euler)"思想是用先前的差商近似代替倒数",直白一些的编程说法即:f(i+1)=f(i)+h*f(x,y)其 ...

  2. 杨恒说李的算法好-我问你听谁说的-龙哥说的(java中常见的List就2个)(list放入的是原子元素)

    1.List中常用的 方法集合: 函数原型 ******************************************* ********************************** ...

  3. 声笔飞码GB2312单字效率分析

    -----------------------声笔飞码强字方式单字效率分析-------------------------- 2   keys: 567       items, 381900209 ...

  4. hdu-4507 吉哥系列故事——恨7不成妻 数位DP 状态转移分析/极限取模

    http://acm.hdu.edu.cn/showproblem.php?pid=4507 求[L,R]中不满足任意条件的数的平方和mod 1e9+7. 条件: 1.整数中某一位是7:2.整数的每一 ...

  5. 东哥讲义2 - 基于TCP,UDP协议的攻击,分析与防护

    TCP SYN FLOOD 攻击 正常的TCP三次握手过程: 处于SYN FLOOD攻击状态时的三次握手过程: 查看示例:x_syn.c文件,一个实现了自定义mac,ip,tcp头部的syn floo ...

  6. python做量化交易干货分享

    http://www.newsmth.NET/nForum/#!article/Python/128763 最近程序化交易很热,量化也是我很感兴趣的一块. 国内量化交易的平台有几家,我个人比较喜欢用的 ...

  7. SAP成都研究院许聚龙:Hello, Coresystems!

    Jerry的前一篇文章<SAP成都研究院数字创新空间沟通S/4HANA和C/4HANA的智能服务演示视频和Coresystems分享预告>已经提到,接下来会由SAP成都研究院数字创新空间的 ...

  8. 2019 Multi-University Training Contest 7 - 1006 - Snowy Smile - 线段树

    http://acm.hdu.edu.cn/showproblem.php?pid=6638 偷学一波潘哥的二维离散化和线段树维护最大子段和. 思路是枚举上下边界,但是不需要从左到右用最大子段和dp. ...

  9. POJ——3264线段树

    题目: 输入两个数(m,n),m表示牛的头数,n表示查询的个数.查询时输入两个数(x,y),表示查询范围的起始值和终止值,查询结果是,这个区间内牛重量的最大值减去牛重量的最小值,数量级为1000,00 ...

  10. 简单几何(线段相交) POJ 2653 Pick-up sticks

    题目传送门 题意:就是小时候玩的一种游戏,问有多少线段盖在最上面 分析:简单线段相交,队列维护当前最上的线段 /******************************************** ...

随机推荐

  1. 001 C#配置多个版本Swagger说明

    1. AddSwaggerGen AddSwaggerGen 是配置多个版本的swagger的关键 Path.Combine 当前项目运行的路径 UseSwaggerUI 主要分为 2 步骤  : 1 ...

  2. kotlin更多语言结构——>This表达式

    This表达式 为了表示当前的 接收者 我们使用 this 表达式: - 在类的成员中,this指的是该类的当前对象. - 在扩展函数或者带有接收者的函数字面值中,this 表示在点左侧传递的 接收者 ...

  3. select语句

    SELECT语句可以从表中选择数据 SELECT <列名1>,<列名2> as "aaa" FROM <表名>; 查询两列数据SELECT * ...

  4. 王树森Attention与Self-Attention学习笔记

    目录 Seq2Seq + Attention Attention的原理 方法一(Used in the original paper) 方法二(more popular,the same to Tra ...

  5. 云电脑玩游戏挑选标准,ToDesk实测体验

    大家玩游戏还在攒机吗?与其花费时间精力在组装游戏电脑上,不如用上最近兴起的云电脑软件.无需额外配备硬件设备,旧电脑原地变身成高性能电脑,随时随地享受游戏乐趣. 但市面上众多的云电脑软件,该怎么选择才能 ...

  6. AI五子棋_07 落子点四周棋形获取

    AI五子棋 第七步 恭喜你到达第七步! 到这一步,你对战场环境就有了充分的了解.下面我们准备打造机器大脑了.你可能已经有你自己的想法了,不过别着急,先跟着我的思路做.我会提示你解决一些基本的问题. 棋 ...

  7. DP 详解

    DP 概述 DP(Dynamic programming,全称动态规划),是一种基于分治,将原问题分解为简单子问题求解复杂问题的方法. 动态规划的耗时往往远少于朴素(爆搜)解法. 动态规划 and 递 ...

  8. 国内SRC信息收集

    SRC之信息收集 前言: ​ 关于SRC信息收集不在于工具是否全面,工具固然重要,它们能帮我们节省大量的时间收集资产,但不是说我们一定要用到所有工具,收集到某个SRC的所有资产才罢休.资产总会有遗漏, ...

  9. Problem K. Master of Sequence(二分)

    Problem K. Master of Sequence(二分) 补补题,人太菜了,一个题解看了两个小时才看明白(当然也可能是比赛的时候这个题完全不知道怎么下手qwq) 题目链接:http://ac ...

  10. 2023NOIP A层联测23 T2 涂鸦

    2023NOIP A层联测23 T2 涂鸦 模拟赛一道博弈,剩下仨全期望,我: 思路 其实我也不是很会 考虑设 \(f_{mst}\),为 \(n*m\) 个格被压成一个二进制 \(mst\),转移到 ...