1. 博客:www.jiaopengzi.com

焦棚子的文章目录

请点击下载附件

一、背景

前些日子,有朋友在交流股票RSI用DAX处理的问题,由于RSI股票软件的算法几乎都是需要用到股票从上市第一天开始的所有数据。当期RSI的大小影响因素【close】随着时间往前推,时间越早影响因素会越小(后面会通过公式推导验证该结论),所以往往在计算RSI的时候也不会取从上市到当期的所有数据,对结果不造成绝对的影响。

先看下结果啥样子(其实就是股票软件的样子)

需要说明的是,笔者并非股票行业从业者,本案例目的是分享DAX如何处理RSI,我们不研究RSI如何用。

二、数据源&计算逻辑

1、数据源

2、RSI计算公式

参考(维基百科,如果打不开你懂得):

变形得到(笔者自定义变形,能看懂就好,其中up表示上涨,down表示下跌,ABS表示求绝对值,all表示上涨和下跌)

3、计算逻辑

LC表示昨日【close】

数据源中【diff】=close-LC

如下对6天的EMA做分解计算,

1、Y表示当期EMA结果,

2、在EMA(up)中X=MAX(close-LC,0),

3、在EMA(down)中X=ABS(MIN(close-LC,0)),

4、在EMA(all)中X=ABS(close-LC,0)。


temp

其中X的角标和temp表中的【INDEX】相对应的。
要想计算EMA结果,就需要递归,但在DAX中目前笔者还没有找到办法来处理递归的问题。

于是我们加以思考

将上述表达式分别带入得到:

提一个1/6出来后得到

发现规律了吗?

最终推导得到k天指数平均6天的EMA

说明

这里补充文章最开始说的结论,不难看出,随着k的增加,时间越早值越小,我们带入k=30, =0.00421,和 5/6比起已经可以忽略不计了。所以“当期RSI的大小影响因素【close】随着时间往前推,时间越早影响因素会越小(后面会通过公式推导验证该结论),所以往往在计算RSI的时候也不会取从上市到当期的所有数据,对结果不造成绝对的影响。”

同时我们可以推导得出 天中 天指数平均EMA值

EMA的值可以通过X的迭代得到了,迭代在DAX中就好处理了。

三、上DAX

1、上面的temp表,中间过程便于观察,实际应用中不需要。

  1. temp =
  2. VAR T1 = ADDCOLUMNS (
  3. ALL ( data ),
  4. "INDEX",
  5. VAR DATEAC1 = data[date]
  6. VAR TP =FILTER ( ALL ( data ), data[date] < DATEAC1 )
  7. RETURN
  8. COUNTROWS ( TP )
  9. )
  10. VAR T2 =ADDCOLUMNS (
  11. T1,
  12. "diff",
  13. VAR I = [INDEX] - 1
  14. VAR PRE =CALCULATE ( SUM ( data[close] ), FILTER ( T1, [INDEX] = I ) )
  15. RETURN IF ( PRE = BLANK (), BLANK (), data[close] - PRE )
  16. )
  17. return
  18. T2

2、RSI6,其中N=12,N=24即可求得RSI12、RS24。

  1. RSI6 =
  2. VAR N = 6
  3. VAR BN = ( N - 1 ) / N
  4. VAR DATE_SELECT = MAX ( 'data'[date] )
  5. VAR T1 = ADDCOLUMNS (
  6. ALL ( data ),
  7. "INDEX",
  8. VAR DATEAC1 = data[date]
  9. VAR TP =FILTER ( ALL ( data ), data[date] < DATEAC1 )
  10. RETURN
  11. COUNTROWS ( TP )
  12. )
  13. VAR T2 =ADDCOLUMNS (
  14. T1,
  15. "diff",
  16. VAR I = [INDEX] - 1
  17. VAR PRE =CALCULATE ( SUM ( data[close] ), FILTER ( T1, [INDEX] = I ) )
  18. RETURN IF ( PRE = BLANK (), BLANK (), data[close] - PRE )
  19. )
  20. VAR T3 =FILTER ( T2, [date] <= DATE_SELECT )
  21. VAR K =COUNTROWS ( T3 ) - 1
  22. VAR T4 =ADDCOLUMNS (
  23. T3,
  24. "UP",
  25. VAR X = [diff]
  26. VAR K1 = [INDEX]
  27. RETURN
  28. IF ( X > 0 || X = BLANK (), POWER ( BN, K - K1 ) * X, BLANK () ),
  29. "ALL",
  30. VAR X = [diff]
  31. VAR K1 = [INDEX]
  32. RETURN
  33. IF ( X = BLANK (), BLANK (), POWER ( BN, K - K1 ) * ABS ( X ) )
  34. )
  35. RETURN
  36. ROUND(DIVIDE ( SUMX ( T4, [UP] ), SUMX ( T4, [ALL] ) ) * 100,2)

3、5均线,其中n=10,20,60即可得到10均线、20均线、60均线。

  1. 5均线 =
  2. var n=5
  3. var date1=max('data'[date])
  4. var date2=filter(all('data'[date]),'data'[date]<=date1)
  5. var T=topn(n,date2,'data'[date],DESC)
  6. VAR R=CALCULATE(SUM(data[close]),T)
  7. RETURN
  8. DIVIDE( R,COUNTROWS(T))

四、总结

1、DAX中基本没有难度,就是迭代;

2、主要是数据公式推导后即可迎刃而解;

3、为了更好理解,做了个excel逻辑分解

4、最后验证下我们的计算结果

DAX计算出的RSI结果

股票软件结果(RSI24有一点点差异,主要是软件起始天数或者是小数保留问题,不影响使用。)

5、数据源是通过python的tushare包得到,pbix文件可以当个查询工具使用。

by 焦棚子

焦棚子的文章目录

126_Power BI中使用DAX计算股票RSI及股票均线相关的更多相关文章

  1. 数据可视化之DAX篇(二)Power BI中的度量值和计算列,你搞清楚了吗?

    https://zhuanlan.zhihu.com/p/75462046 对于初学者,总是会把度量值和计算列搞混,我也经常碰到这样的问题,有些星友用文章中的代码总是报错,发给我一看,才知道TA把本来 ...

  2. DAX和Power BI中的参考日期表

    本文使用Power BI模板描述DAX中的引用Date表,可以在Analysis Services模型中使用相同的技术.在Dax Date Template页面下载最新版本的模板. 为什么引用Date ...

  3. 数据可视化之DAX篇(二十七)半累加度量,在Power BI 中轻松处理

    https://zhuanlan.zhihu.com/p/96823622 ​开始半累加的计算之前,我们先看看什么是累加.半累加以及不可累加数据. 在含有大量行的数据表中,各种数据处理语言,包括DAX ...

  4. 以股票RSI指标为例,学习Python发送邮件功能(含RSI指标确定卖点策略)

    本人之前写过若干“给程序员加财商”的系列文,目的是通过股票案例讲述Python知识点,让大家在学习Python的同时还能掌握相关的股票知识,所谓一举两得. 在之前的系列文里,大家能看到K线,均线,成交 ...

  5. --关于null在oracle数据库中是否参与计算,进行验证,

    --关于null在oracle数据库中是否参与计算,进行验证,with td as (select null id,1 name from dual ),td1 as ( select null id ...

  6. R语言作为BI中ETL的工具

    R语言作为BI中ETL的工具,增删改 R语言提供了强大的R_package与各种数据库进行数据交互. 外加其强大数据变换清洗函数,为ETL提供一条方便快捷的道路. RODBC ROracal RMys ...

  7. 数据库SQL语句中根据当前日期计算其他日期小结

    问题描述:我们在写存储过程和函数的时候经常会碰到利用当前日期计算出上周开始日期.结束日期,或者计算上个月的开始日期结束日期等问题.最近写了几个存储过程和函数,其中都涉及到了日期计算问题,在这里简单做一 ...

  8. 第16/24周 SQL Server 2014中的基数计算

    大家好,欢迎回到性能调优培训.上个星期我们讨论在SQL Server里基数计算过程里的一些问题.今天我们继续详细谈下,SQL Server 2014里引入的新基数计算. 新基数计算 SQL Serve ...

  9. Power BI中的QA功能预览

    微软在休斯敦的全球合作伙伴大会上发布了Power BI for Office 365,通过Excel和Office 365中的自服务式商业智能解决方案为信息工作者提供了数据分析以及可视化功能以帮助他们 ...

随机推荐

  1. C++中初始化列表的使用(总结)

    原文链接 https://www.cnblogs.com/dishengAndziyu/p/10906081.html 参考链接:https://www.cnblogs.com/laiqun/p/57 ...

  2. 深入理解ES6之《块级作用域绑定》

    众所周知,js中的var声明存在变量提升机制,因此ESMAScript 6引用了块级作用域来强化对变量生命周期的控制let const 声明不会被提升,有几个需要注意的点1.不能被重复声明 假设作用域 ...

  3. Codepen 每日精选(2018-4-22)

    按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以打开原始页面. 图片切换效果https://codepen.io/AlikinVV/f... 基于 dom 的可换肤的自行 ...

  4. Android设置TextView为不可见

    通常控件的可见与不可见分为三种情况. 第一种    gone         表示不可见并且不占用空间 第二种    visible       表示可见 第三种    invisible    表示 ...

  5. 20220406Java

    记个笔记 字符串操作类中s1.compareTo(s)规则: Compares two strings lexicographically. The comparison is based on th ...

  6. 算法题——Cantor表

    题目介绍 描述 现代数学的著名证明之一是 Georg Cantor 证明了有理数是可枚举的.他是用下面这一张表来证明这一命题的: 1/1, 1/2 , 1/3, 1/4, 1/5, - 2/1, 2/ ...

  7. HTML/CSS+JS制作一个高考倒计时页面

    2020-07-09更新 修复倒计时归零后出现负数的bug 自动切换至下一年日期 ##效果展示 前言 在B站上找视频学习的,勉强搞出来了,写下此篇文章作为笔记,也希望有更多感兴趣的人能够有所收获. ( ...

  8. 第十三届蓝桥杯省赛C/C++ B组

    @(第十三届蓝桥杯省赛C/C++B组) A顺子日期 答案是1478 B顺子日期 答案14(如果012算的话) C刷题统计 数据范围1e18,所以不能直接暴力,先取余,再暴力剩下的 #include&l ...

  9. Go xmas2020 学习笔记 07、Formatted & File I/O

    07-Formatted & File I/O. I/O steams. formatted I/O. fmt functions. file I/O. Practice ① I/O. Alw ...

  10. Spring Authorization Server授权服务器入门

    11月8日Spring官方已经强烈建议使用Spring Authorization Server替换已经过时的Spring Security OAuth2.0,距离Spring Security OA ...