: | : | :期货程序化 | :期货程序化研究 | :期货量化学习 | :期货量化 |
返回列表 发帖

[Python源码] 通达信,同花顺中国式SMA指标,EMA指数平均,MACD,RSI的最简python代码实现

[Python源码] 通达信,同花顺中国式SMA指标,EMA指数平均,MACD,RSI的最简python代码实现

通达信,同花顺指标中的中国式SMA,EMA的python实现

同花顺,通达信指标计算有个非常重要的函数SMA,和EMA,下面仅仅用python库panadas和numpy的内置函数实现

  1. import numpy as np; import pandas as pd

  2. def EMA(S,N):     #为了精度 S>4*N  EMA至少需要120周期      
  3.     return pd.Series(S).ewm(span=N, adjust=False).mean().values   

  4. def SMA(S, N, M=1):    #中国式的SMA,至少需要120周期才精确        
  5.     K = pd.Series(S).rolling(N).mean()    #先求出平均值
  6.     for i in range(N+1, len(S)):  K[i] = (M * S[i] + (N -M) * K[i-1]) / N  # 因为要取K[i-1],所以 range(N+1, len(S))        
  7.     return K
复制代码



EMA实现的很成功,pandas内置函数,速度快,SMA需要循环才能实现,不是最优的解决方案,下面采用pandas的内置函数来实现!

  1. def SMA(S, N, M=1):        # 1)高效的方法
  2.     return pd.Series(S).ewm(alpha=M/N, adjust=True).mean().values  

  3. def SMA(S, N, M=1):        # 2)高效写法2
  4.     return pd.Series(S).ewm(com=N-M, adjust=True).mean().values  

  5. def SMA(S, N, M=1):        # 3)高效写法3
  6.     return pd.Series(S).ewm(span=2N/M-1, adjust=True).mean().values  

  7. def SMA(S, N, M=1):        # 4)python2的pandas没有ewm,用ewma实现
  8.     return pd.ewma(S,com=N-M,adjust=True)  

  9. #以上4种写法得到的数值是一样的
复制代码



有了这两个关键函数,就可以用它们构造出MACD指标和RSI指标,代码非常简单

  1. def MACD(CLOSE,SHORT=12,LONG=26,M=9):    # EMA的关系,S取120日,和雪球小数点2位相同
  2.     DIF = EMA(CLOSE,SHORT)-EMA(CLOSE,LONG);  
  3.     DEA = EMA(DIF,M);      MACD=(DIF-DEA)*2
  4.     return DIF,DEA,MACD
  5.    
  6. def RSI(CLOSE, N=24):      
  7.     DIF = CLOSE-REF(CLOSE,1)
  8.     return SMA(MAX(DIF,0), N) / SMA(ABS(DIF), N) * 100   
复制代码



以上函数实现的macd,rsi指标和雪球,同花顺,通达信等软件对照完全一致

论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   1.本站发布源码(包括函数、指标、策略等)均属开放源码,用意在于让使用者学习程序化语法撰写,使用者可以任意修改语法內容并调整参数。仅限用于个人学习使用,请勿转载、滥用,严禁私自连接实盘账户交易
  2.本站发布资讯(包括文章、视频、历史记录、教材、评论、资讯、交易方案等)均系转载自网络主流媒体,内容仅为作者当日个人观点,本网转载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。本网不对该类信息或数据做任何保证。不对您构成任何投资建议,不能依靠信息而取代自身独立判断,不对因使用本篇文章所诉信息或观点等导致的损失承担任何责任。
  3.本站发布资源(包括书籍、杂志、文档、软件等)均从互联网搜索而来,仅供个人免费交流学习,不可用作商业用途,本站不对显示的内容承担任何责任。请在下载后24小时内删除。如果喜欢,请购买正版,谢谢合作!
  4.龙听期货论坛原创文章属本网版权作品,转载须注明来源“龙听期货论坛”,违者本网将保留追究其相关法律责任的权力。本论坛除发布原创文章外,亦致力于优秀财经文章的交流分享,部分文章推送时若未能及时与原作者取得联系并涉及版权问题时,请及时联系删除。联系方式:http://www.qhlt.cn/thread-262-1-1.html
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

very good

TOP

感謝分享

TOP

返回列表