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

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

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

  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. yarn serve 开启项目服务失败 assets emit different content to the same filename

    error: answer: 删除public的文件,重新 yarn serve :

  2. (系列七).net8 Aop切面编程

    说明 该文章是属于OverallAuth2.0系列文章,每周更新一篇该系列文章(从0到1完成系统开发). 该系统文章,我会尽量说的非常详细,做到不管新手.老手都能看懂. 说明:OverallAuth2 ...

  3. 云原生爱好者周刊:GitHub 官方文档终于开源了!

    云原生一周动态要闻: API 在 Kubernetes 1.22 中被删除 ContainIQ 公开发布 - Kubernetes 本地实时监控! Sophos 收购 Capsule8 开源项目推荐 ...

  4. 云原生爱好者周刊:VMware Tanzu 社区办发布,无任何限制!

    云原生一周动态要闻: VMware Tanzu 推出社区版 Kubernetes Cluster API 1.0 版已生产就绪 Linkerd 2.11 发布 Cartografos 工作组推出云原生 ...

  5. Lambda表达式、方法引用、算法、正则表达式

    文章目录 1.Lambda表达式 1.1 Lambda表达式基本使用 1.2 Lambda表达式省略规则 2.JDK8新特性(方法引用) 2.1 静态方法引用 2.2 实例方法引用 2.3 特定类型的 ...

  6. TrueNAS关闭5357端口

    sockstat -4l 查看监听5357端口进程的ID. 用kill -9 PID 干掉进程.

  7. RAC:无训练持续扩展,基于检索的目标检测器 | ECCV'24

    来源:晓飞的算法工程笔记 公众号,转载请注明出处 论文: Online Learning via Memory: Retrieval-Augmented Detector Adaptation 论文地 ...

  8. 题解:CF1776L Controllers

    CF1776L Controllers 题解 分析 先把题目形式化.设 \(n\) 次加减中有 \(x\) 个加,\(y\) 个减,其中 \(a\) 加了 \(u\) 次,减了 \(v\) 次,显然 ...

  9. Codeforces Round 971 (Div. 4) E 题解析

    # E题 Klee's SUPER DUPER LARGE Array!!! 题目描述 思路: 对于这道题,首先观察到题目求的是最小可能值,而且数据的范围是1e9范围,所以首先可以考虑的方法就是O(l ...

  10. git pull发现有ahead of xx commits问题如何解决

    git pull 的时候发现有提示你ahead of xx commits 这个时候怎么办呢? 直接一句话定位到远程最新分支 git reset --hard origin/分支名称