Python实现DMI工具判断信号:股票技术分析的工具系列(3)

Python实现DMI工具判断信号:股票技术分析的工具系列(3)

    • 介绍
      • 算法解释
    • 代码
      • rolling函数介绍
      • 完整代码


介绍

先看看官方介绍:

DMI (趋向指标)
用法
1.PDI线从下向上突破MDI线,显示有新多头进场,为买进信号;
2.PDI线从上向下跌破MDI线,显示有新空头进场,为卖出信号;
3.ADX值持续高于前一日时,市场行情将维持原趋势;
4.ADX值递减,降到20以下,且横向行进时,市场气氛为盘整;
5.ADX值从上升倾向转为下降时,表明行情即将反转。

算法解释

MTR:= SUM(MAX(MAX(HIGH-LOW,ABS(HIGH-REF(CLOSE,1))),ABS(LOW-REF(CLOSE,1))),N);
HD := HIGH-REF(HIGH,1);
LD := REF(LOW,1)-LOW;
DMP:= SUM(IF(HD>0 AND HD>LD,HD,0),N);
DMM:= SUM(IF(LD>0 AND LD>HD,LD,0),N);
PDI: DMP*100/MTR;
MDI: DMM*100/MTR;
ADX: MA(ABS(MDI-PDI)/(MDI+PDI)*100,M);
ADXR:(ADX+REF(ADX,M))/2;

优势:

优势描述
清晰的买卖信号当PDI线从下向上突破MDI线时,显示有新多头进场,为买进信号;而当PDI线从上向下跌破MDI线时,显示有新空头进场,为卖出信号,提供了明确的交易信号。
确定趋势强度ADX值持续高于前一日时,表明市场行情将维持原趋势,有助于投资者确认趋势的持续性,为持仓决策提供参考。
识别盘整行情当ADX值递减并降到20以下,并且横向行进时,表明市场处于盘整状态,这对于那些偏好在趋势不明朗时选择观望或进行波段交易的投资者是有帮助的。

劣势:

劣势描述
滞后性DMI指标可能会出现滞后现象,尤其是在市场行情急剧变化时,指标可能无法及时反应新的市场趋势,导致错过买卖时机。
假信号尽管DMI指标提供了明确的买卖信号,但在市场波动较大或盘整时,可能会出现假信号,导致交易损失。
需要结合其他指标DMI指标虽然提供了趋势方向和趋势强度的信息,但并不能覆盖市场的所有方面,因此投资者在使用时需要结合其他指标和分析方法进行综合判断。

代码

rolling函数介绍

rolling 函数通常与其他函数(如 meansumstd 等)一起使用,以计算滚动统计量,例如滚动均值、滚动总和等。

以下是 rolling 函数的基本语法:

DataFrame.rolling(window, min_periods=None, center=False, win_type=None, on=None, axis=0, closed=None)
  • window: 用于计算统计量的窗口大小。
  • min_periods: 每个窗口最少需要的非空观测值数量。
  • center: 确定窗口是否居中,默认为 False
  • win_type: 窗口类型,例如 Noneboxcartriang 等,默认为 None
  • on: 在数据帧中执行滚动操作的列,默认为 None,表示对整个数据帧执行操作。
  • axis: 执行滚动操作的轴,默认为 0,表示按列执行操作。
  • closed: 确定窗口的哪一端是闭合的,默认为 None

完整代码

import pandas as pd
import stock_data# 将股票数据存储到字典中
data = {'DATE': stock_data.DATE,'CLOSE': stock_data.CLOSE,'HIGH': stock_data.HIGH,'LOW': stock_data.LOW,'OPEN': stock_data.OPEN,'CHANGE': stock_data.CHANGE,'VOL': stock_data.VOL,'CAPITAL': stock_data.CAPITAL
}df = pd.DataFrame(data)def check_signal(v_df, day_index=-1):"""检查信号参数:v_df: pandas.DataFrame,包含DMI指标的DataFrameday_index: int,要检查的日期索引,默认为最后一天返回:str,表示信号的字符串,可能为"买入信号"、"卖出信号"或"无信号""""# 生成信号signal = "无信号"latest_data_PDI = v_df['PDI'].iloc[day_index]latest_data_PDI2 = v_df['PDI'].iloc[-1 + day_index]latest_data_MDI = v_df['MDI'].iloc[day_index]latest_data_MDI2 = v_df['MDI'].iloc[-1 + day_index]if latest_data_PDI > latest_data_MDI and latest_data_PDI2 <= latest_data_MDI2:signal = "买入信号"elif latest_data_PDI < latest_data_MDI and latest_data_PDI2 >= latest_data_MDI2:signal = "卖出信号"return signaldef DMI(v_df, N, M):"""计算DMI指标参数:v_df: pandas.DataFrame,包含股票数据的DataFrameN: int,计算MTR和移动平均的窗口大小M: int,计算ADX的平滑窗口大小返回:无,结果直接存储在输入的DataFrame中"""# 计算 MTRv_df['HL'] = v_df['HIGH'] - v_df['LOW']v_df['HC'] = abs(v_df['HIGH'] - v_df['CLOSE'].shift(1))v_df['LC'] = abs(v_df['LOW'] - v_df['CLOSE'].shift(1))v_df['MAX1'] = v_df[['HL', 'HC']].max(axis=1)v_df['MAX2'] = v_df[['MAX1', 'LC']].max(axis=1)v_df['MTR'] = v_df['MAX2'].rolling(window=N).sum()# 计算 HDv_df['HD'] = v_df['HIGH'] - v_df['HIGH'].shift(1)# 计算 LDv_df['LD'] = v_df['LOW'].shift(1) - v_df['LOW']# 计算 DMPv_df['DMP'] = df.apply(lambda x: x['HD'] if (x['HD'] > 0 and x['HD'] > x['LD']) else 0, axis=1).rolling(window=N).sum()# 计算 DMMv_df['DMM'] = df.apply(lambda x: x['LD'] if (x['LD'] > 0 and x['LD'] > x['HD']) else 0, axis=1).rolling(window=N).sum()# 计算 PDI、MDI 和 ADXv_df['PDI'] = v_df['DMP'] * 100 / v_df['MTR']v_df['MDI'] = v_df['DMM'] * 100 / v_df['MTR']v_df['DX'] = (v_df['PDI'] - v_df['MDI']).abs() / (v_df['PDI'] + v_df['MDI']) * 100v_df['ADX'] = v_df['DX'].rolling(window=M).mean()# 计算 ADXRv_df['ADXR'] = (v_df['ADX'] + v_df['ADX'].shift(M)) / 2# 删除中间计算用的列df.drop(['LOW', 'HL', 'HC', 'LC', 'MAX1', 'MAX2', 'HD', 'LD', 'DX'], axis=1, inplace=True)DMI(df, 14, 6)
print(check_signal(df, day_index=-1))

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/506565.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

喀秋莎软件如何编辑视频 Camtasia2023软件下载 电脑录屏剪辑软件推荐 Camtasia安装教程 微课视频制作方法 课件制作投屏软件

现在市面上的课件录制软件很多&#xff0c;许多人都听说过Camtasia&#xff0c;它是TechSmith旗下的一套专业屏幕录制软件&#xff0c;同时包含Camtasia录像器、Camtasia编辑器、Camtasia菜单制作器、Camtasia剧场、Camtasia播放器和Screencast的内置功能。 今天我们就来介绍如…

精准唇语同步:Wav2Lip 引领视频技术前沿 | 开源日报 No.188

Rudrabha/Wav2Lip Stars: 8.4k License: NOASSERTION Wav2Lip 是一个准确地在野外进行视频唇语同步的项目。 该项目的主要功能、关键特性和核心优势包括&#xff1a; 可以高精度地将视频与任何目标语音进行唇语同步适用于任何身份、声音和语言&#xff0c;也适用于 CGI 面孔和…

B树系列(详解)

目录 一、B-树 二、B树 三、B*树 四、时间复杂度 五、Mysql与B树系列 一、B-树 首先再说B树的性质以及其他的之前&#xff0c;先要说一声&#xff0c;好多人都把这个树叫B减树&#xff0c;其实不是&#xff0c;他就叫B树&#xff0c;至于原因我觉的没必要再这个名字上纠结…

基于Springboot的同城上门喂遛宠物系统(有报告)。Javaee项目,springboot项目。

演示视频&#xff1a; 基于Springboot的同城上门喂遛宠物系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系…

React Developer Tools带你掌握9个React组件调试技巧,十分钟学会

React Developer Tools 是 React 官方推出的开发者插件&#xff0c;可以毫不夸张的说&#xff0c;它在我们日常组件开发中&#xff0c;对于组件属性以及文件定位&#xff0c;props 排查等等场景都扮演者至关重要的角色&#xff1b;毋庸置疑&#xff0c;熟练使用React Developer…

Window下编写的sh文件在Linux/Docker中无法使用

Window下编写的sh文件在Linux/Docker中无法使用 一、sh文件目的1.1 初始状态1.2 目的 二、过程与异常2.1 首先获取标准ubuntu20.04 - 正常2.2 启动ubuntu20.04容器 - 正常2.3 执行windows下写的preInstall文件 - 报错 三、检查和处理3.1 评估异常3.2 处理异常3.3 调整后运行测试…

使用 frp 实现 windows 远程

前提条件&#xff1a; 拥有一台公网 ip 的服务器&#xff1b; 被远程控制的 windows 系统为专业版&#xff08;家庭版的其它方式没有尝试过&#xff09;&#xff1b; frp 下载包及使用说明 frp release 包的下载网址&#xff1a;https://github.com/fatedier/frp/releases 中…

浅析this指针

浅析this指针 文章目录 浅析this指针前言this指针作用this指针使用注意事项总结 前言 ​ 在面向对象的编程语言中&#xff0c;this指针是一个自引用指针&#xff0c;通常用于指向对象自身。通过这篇文章&#xff0c;我们将探讨this指针的核心特性、应用场景和相关案例。 this指…

[GYCTF2020]EasyThinking --不会编程的崽

看标题就知道&#xff0c;这大概率是关于thinkphp的题目。先尝试错误目录使其报错查看版本号 thinkphp v6.0.0&#xff0c;在网上搜索一下&#xff0c;这个版本有一个任意文件上传漏洞。参考以下文章。 https://blog.csdn.net/god_zzZ/article/details/104275241 先注册一个账…

基于stm32F103的座面声控台灯

1.基本内容&#xff1a; 设计一个放置在桌面使用的台灯&#xff0c;使用220v交流电供电。具备显示屏能够实时显示日期&#xff08;年、月、日和星期&#xff09;&#xff0c;时间&#xff08;小时、分钟、秒&#xff09;和温度&#xff08;摄氏度&#xff09;&#xff1b;能够通…

JAVAEE初阶 JVM(二)

垃圾回收和双亲委派模型 1.双亲委派模型2.垃圾回收机制(1) 识别垃圾1.引用计数2.可达性分析 (2) 销毁垃圾1.标记清除2.复制算法3.标记整理 3.分代回收 1.双亲委派模型 描述了如何查找.class文件的策略. 同时JVM中有专门进行类加载的操作,有一个模块,叫做类加载器. 上述就是为了…

云原生架构技术揭秘:DevOps 技术打破开发运维壁垒,实现持续交付的变革之道

DevOps 是一套将软件开发&#xff08;Development&#xff0c;Dev&#xff09;和系统运维&#xff08;Operations&#xff0c;Ops&#xff09;相结合的实践&#xff0c;旨在缩短应用系统开发生命周期&#xff0c;提供高质量的持续交付。 —— 维基百科 DevOps 0、讲在前面 生…