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

news2024/12/23 10:34:17

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

    • 介绍
      • 算法解释:
        • 优势:
        • 劣势:
    • 代码
      • rolling函数介绍
      • 核心代码
        • 计算 EMV
    • 完整代码


介绍

先看看官方介绍:

EMV(简易波动指标)
用法
1.EMV 由下往上穿越0 轴时,视为中期买进信号;
2.EMV 由上往下穿越0 轴时,视为中期卖出信号;
3.EMV 的平均线穿越0 轴,产生假信号的机会较少;
4.当ADX 低于±DI时,本指标失去效用;
5.须长期使用EMV指标才能获得最佳利润。

算法解释:

VOLUME:=MA(VOL,N)/VOL;
MID:=100*(HIGH+LOW-REF(HIGH+LOW,1))/(HIGH+LOW);
EMV:MA(MID*VOLUME*(HIGH-LOW)/MA(HIGH-LOW,N),N);
MAEMV:MA(EMV,M);
优势:
优势描述
清晰的信号EMV提供了明确的买入和卖出信号,当指标由下往上穿越0轴时,视为中期买进信号,由上往下穿越0轴时,视为中期卖出信号,使投资者能够更容易地进行决策。
较少的假信号EMV的平均线穿越0轴时,产生假信号的机会较少,这增加了指标的可靠性,帮助投资者避免不必要的交易。
相对简单EMV指标相对简单,易于理解和应用,对于初学者或喜欢简单交易策略的投资者来说,是一种较为友好的指标。
劣势:
劣势描述
依赖其他指标当ADX低于±DI时,EMV指标失去效用,因此投资者在使用EMV指标时可能需要结合其他指标进行综合分析,降低失误的风险。
单一性即使EMV提供了明确的买卖信号,但它仍然是一种单一的指标,可能无法完全覆盖市场的全部信息,投资者仍需谨慎考虑其他因素。
需长期使用虽然提到了须长期使用EMV指标才能获得最佳利润,但这也意味着需要一定的时间来验证该指标的有效性,对于短期交易者可能不够实用。

代码

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

核心代码

计算 EMV

EMV(简易波动指标)是一种用于中期买卖信号的技术指标,通过观察其与0轴的交叉以及平均线的运动,提供清晰的交易信号。

def calculate_EMV(v_df, n, m):
    """
    计算EMV指标
    
    参数:
    v_df: pandas.DataFrame,包含股票数据的DataFrame
    n: int,窗口大小
    m: int,平滑窗口大小
    
    返回:
    无,结果直接存储在输入的DataFrame中
    """
    # 计算VOLUME
    v_df['MA_VOL'] = v_df['VOL'].rolling(window=n).mean()
    v_df['VOLUME'] = v_df['MA_VOL'] / v_df['VOL']

    # 计算MID
    v_df['MID'] = 100 * (v_df['HIGH'] + v_df['LOW'] - v_df['HIGH'].shift(1) - v_df['LOW'].shift(1)) / (
            v_df['HIGH'] + v_df['LOW'])

    # 计算EMV
    v_df['HL_MA'] = v_df['HIGH'] - v_df['LOW']
    v_df['MA_HL'] = v_df['HL_MA'].rolling(window=n).mean()
    v_df['EMV'] = v_df['MID'] * v_df['VOLUME'] * v_df['HL_MA'] / v_df['MA_HL']
    v_df['EMV'] = v_df['EMV'].rolling(window=n).mean()

    # 计算MAEMV
    v_df['MAEMV'] = v_df['EMV'].rolling(window=m).mean()

完整代码

这里完整代码中的data部分,阔以通过下面资源文件下载,或者留下邮箱等发送。:

https://download.csdn.net/download/qq_36051316/88896567

在这里插入图片描述

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,包含EMV指标的DataFrame
    day_index: int,要检查的日期索引,默认为最后一天
    
    返回:
    str,表示信号的字符串,可能为"买入信号"、"卖出信号"或"无信号"
    """
    latest_data = v_df['EMV'].iloc[day_index]
    latest_data2 = v_df['EMV'].iloc[-1 + day_index]
    signal = "无信号"
    if latest_data > 0 >= latest_data2:
        signal = "买入信号"
    elif latest_data < 0 <= latest_data2:
        signal = "卖出信号"
    return signal

def calculate_EMV(v_df, n, m):
    """
    计算EMV指标
    
    参数:
    v_df: pandas.DataFrame,包含股票数据的DataFrame
    n: int,窗口大小
    m: int,平滑窗口大小
    
    返回:
    无,结果直接存储在输入的DataFrame中
    """
    # 计算VOLUME
    v_df['MA_VOL'] = v_df['VOL'].rolling(window=n).mean()
    v_df['VOLUME'] = v_df['MA_VOL'] / v_df['VOL']

    # 计算MID
    v_df['MID'] = 100 * (v_df['HIGH'] + v_df['LOW'] - v_df['HIGH'].shift(1) - v_df['LOW'].shift(1)) / (
            v_df['HIGH'] + v_df['LOW'])

    # 计算EMV
    v_df['HL_MA'] = v_df['HIGH'] - v_df['LOW']
    v_df['MA_HL'] = v_df['HL_MA'].rolling(window=n).mean()
    v_df['EMV'] = v_df['MID'] * v_df['VOLUME'] * v_df['HL_MA'] / v_df['MA_HL']
    v_df['EMV'] = v_df['EMV'].rolling(window=n).mean()

    # 计算MAEMV
    v_df['MAEMV'] = v_df['EMV'].rolling(window=m).mean()

N = 14
M = 9

calculate_EMV(df, N, M)

# 输出信号
latest_signal = check_signal(df, -1)
print(latest_signal)

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL 多表查询 连接查询 内连接

介绍 内连接查询是两张表中交集的部分 连接模式 隐式内连接 SELECT 字段列表 FROM 表1,表2 WHERE 条件显式内连接 SELECT 字段列表 FROM 表1 [INNER] JOIN 表2 ON 连接条件案例 有两张表一个表为学生表&#xff0c;另一个表为班级表&#xff0c;现在需要查询学生时候在查…

【Excel PDF 系列】EasyExcel + iText 库实现 Excel 转换 PDF

你知道的越多&#xff0c;你不知道的越多 点赞再看&#xff0c;养成习惯 如果您有疑问或者见解&#xff0c;欢迎指教&#xff1a; 企鹅&#xff1a;869192208 文章目录 前言转换前后效果引入 pom 配置代码实现定义 ExcelDataVo 对象主方法EasyExcel 监听器 前言 最近遇到生成 …

【Java程序员面试专栏 算法思维】六 高频面试算法题:动态规划

一轮的算法训练完成后,对相关的题目有了一个初步理解了,接下来进行专题训练,以下这些题目就是汇总的高频题目,本篇主要聊聊回溯算法,主要就是排列组合问题,所以放到一篇Blog中集中练习 题目关键字解题思路时间空间零钱兑换动态规划+双重循环dp[i]表示兑换金额为i元的最少…

基于springboot+vue的中医慢性病食疗系统

后端语言&#xff1a;java 框架&#xff1a;springboot/ssm 数据库&#xff1a;mysql5.7 数据库工具&#xff1a;Navicat 前端技术&#xff1a;vue.jsElementUi 开发工具 idea/eclipse/都可以为设计一个安全便捷&#xff0c;并且使用户更好获取中医药膳慢性病食疗平台&#xf…

Mamba与MoE架构强强联合,Mamba-MoE高效提升LLM计算效率和可扩展性

论文题目&#xff1a; MoE-Mamba: Efficient Selective State Space Models with Mixture of Experts 论文链接&#xff1a; https://arxiv.org/abs/2401.04081 代码仓库&#xff1a; GitHub - llm-random/llm-random 作为大型语言模型&#xff08;LLM&#xff09;基础架构的后…

腾讯云优惠代金券领取的3个渠道入口,不看后悔!

腾讯云代金券领取渠道有哪些&#xff1f;腾讯云官网可以领取、官方媒体账号可以领取代金券、完成任务可以领取代金券&#xff0c;大家也可以在腾讯云百科蹲守代金券&#xff0c;因为腾讯云代金券领取渠道比较分散&#xff0c;腾讯云百科txybk.com专注汇总优惠代金券领取页面&am…

华为数通方向HCIP-DataCom H12-821题库(多选题:01-20)

第01题 如图BGP下有如下配置,下面哪些描述是错误的? [HUAWEI-bgp] timer keepalive 30 hold 90 [HUAWEI-bgp] peer 1.1.1.2 timer keepalive 10 hold 30A、Timer 取最小值,所以最终结果是 peer1.1.1.2 的 timer值取 keepalive 10 hold 30 B、Peer 配置优先,所以最终结果是…

【Maven】Maven 基础教程(三):build、profile

《Maven 基础教程》系列&#xff0c;包含以下 3 篇文章&#xff1a; Maven 基础教程&#xff08;一&#xff09;&#xff1a;基础介绍、开发环境配置Maven 基础教程&#xff08;二&#xff09;&#xff1a;Maven 的使用Maven 基础教程&#xff08;三&#xff09;&#xff1a;b…

开源视频转码器HandBrake

什么是 HandBrake &#xff1f; HandBrake 是一款适用于 Linux、Mac 和 Windows的开源视频转码器。HandBrake 可以处理大多数常见的视频文件和格式&#xff0c;包括消费者和专业摄像机创建的文件、手机和平板电脑等移动设备的文件、游戏和计算机屏幕录制的文件&#xff0c;以及…

【数据结构】实现栈

大家好&#xff0c;我是苏貝&#xff0c;本篇博客带大家了解栈&#xff0c;如果你觉得我写的还不错的话&#xff0c;可以给我一个赞&#x1f44d;吗&#xff0c;感谢❤️ 目录 一 .栈的概念及结构二 .栈的实现栈的结构体初始化销毁栈顶插入栈顶删除显示栈顶元素是否为空栈的大…

Android 签名机制

V1是内部文件单个签 但是增加apk文件目录下面随意增加文件并不会有影响,它只关心meta-info文件 mf汇总清单的各个文件sha256 V2 整个APK文件,按文件进行hash 那么便不能随便在这里面增加文件了,增加了签名分块&#xff08;不然签名信息存哪里&#xff09;这里涉及一个文件概念 …

记录一次架构优化处理性能从3千->3万

0.背景 优化Kafka消费入Es&#xff0c;适配600台设备上报数据&#xff0c;吞吐量到达2万每秒 1.环境配置 2.压测工具 3.未优化之前的消费逻辑 4.优化之后的消费流程 5.多线程多ESclient 6.修改ES配置&#xff0c;增加kafka分区&#xff0c;增加线程&#xff0c;提升吞吐量 7.…

DiskMirror-spring-boot-starter 技术|

DiskMirror-spring-boot-starter 技术 diskMirror 实现了 SpringBoot 的 starter 能够集成到 SpringBoot 中。 DiskMirror 的 starter&#xff0c;通过引入此类&#xff0c;可以直接实现 diskMirror 在 SpringBoot 中的自动配置&#xff0c;接下来我们将使用案例逐步的演示 d…

【多线程】CAS详解

目录 &#x1f334;什么是 CAS&#x1f338;CAS 伪代码 &#x1f38d;CAS 是怎么实现的&#x1f340;CAS 有哪些应⽤&#x1f338;实现原子类&#x1f338;实现自旋锁 &#x1f333;CAS 的 ABA 问题&#x1f338;**什么是 ABA 问题**&#xff1f;&#x1f338;ABA 问题引来的 B…

挑战30天学完Python:Day24 统计分析

&#x1f389; 本系列为Python基础学习&#xff0c;原稿来源于 30-Days-Of-Python 英文项目&#xff0c;大奇主要是对其本地化翻译、逐条验证和补充&#xff0c;想通过30天完成正儿八经的系统化实践。此系列适合零基础同学&#xff0c;或仅了解Python一点知识&#xff0c;但又没…

Docker之数据卷

文章目录 一、什么是数据卷二、自定义镜像 一、什么是数据卷 1.1Docker 数据管理 在生产环境中使用 Docker &#xff0c;往往需要对数据进行持久化&#xff0c;或者需要在多个容器之间进行 数据共享&#xff0c;这必然涉及容器的数据管理操作 1.2操作 将宿主机的目录与容器的目…

【解决(几乎)任何机器学习问题】:交叉验证

在上⼀章中&#xff0c;我们没有建⽴任何模型。原因很简单&#xff0c;在创建任何⼀种机器学习模型之前&#xff0c;我们必须知道什么是交叉检验&#xff0c;以及如何根据数据集选择最佳交叉检验数据集。 那么&#xff0c;什么是 交叉检验 &#xff0c;我们为什么要关注它&…

交友社交软件开发-php交友聊天系统-

为了开发一个高效的交友系统&#xff0c;需要一个完善的信息管理和筛选机制。这个系统应该能够根据用户的个人信息、兴趣爱好、价值观等标准进行筛选&#xff0c;并向用户提供符合他们要求心仪的人的信息。为了实现这个目标&#xff0c;系统可以利用人工智能技术&#xff0c;分…

Docker使用数据卷自定义镜像Dockerfile

文章目录 一、数据卷二、Dockerfile自定义centos 一、数据卷 数据卷(Data Volumes)是一个可供一个或多个容器使用的特殊目录&#xff0c;它将主机操作系统目录直接映射进容器&#xff0c;它可以提供很多有用的特性&#xff1a; 1.数据卷 可以在容器之间共享和重用 2.对数据卷的…

Python调用ChatGPT API使用国内中转key 修改接口教程

大家好&#xff0c;我是淘小白~ 有的客户使用4.0的apikey ,直接使用官方直连的apikey消费很高&#xff0c;有一位客户一个月要消费2万&#xff0c;想使用4.0中转的apikey&#xff0c;使用中转的apikey 需要修改官方的openai库&#xff0c;下面具体说下。 1、首先确保安装的op…