Python 实现 ATR 指标计算(真实波幅):股票技术分析的利器系列(10)

Python 实现 ATR 指标计算(真实波幅):股票技术分析的利器系列(10)

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


介绍

ATR(真实波幅)是一种技术指标,用于衡量市场波动性的程度

优点缺点
提供波动性度量,有助于风险管理和交易决策ATR本身不提供买卖信号,需要结合其他指标使用
简单易懂,计算方法清晰对于极端行情,ATR可能无法准确反映实际波动
可适用于不同市场和时间周期信号滞后,因为ATR是基于历史数据计算的
可以帮助设定止损和止盈水平
可以作为确定交易仓位大小的参考

先看看官方介绍:

ATR(真实波幅)
用法
今日振幅、今日最高与昨收差价、今日最低与昨收差价中的最大值,为真实波幅,求真实波幅的N日移动平均
参数:N为天数,一般取14

算法解释

MTR:MAX(MAX((HIGH-LOW),ABS(REF(CLOSE,1)-HIGH)),ABS(REF(CLOSE,1)-LOW));
ATR:MA(MTR,N);
  1. Mean True Range (MTR):

    MTR代表的是平均真实波幅,它是真实波幅(TR)的移动平均值。TR是用来度量单个交易周期内的价格波动性的指标,其计算方法是当日最高价和最低价之间的差值,当日最高价和前一个交易日的收盘价之间的差值,以及当日最低价和前一个交易日的收盘价之间的差值中的最大值。MTR通过对TR进行移动平均来平滑价格波动性的波动,因此提供了更稳定的参考。

  2. Average True Range (ATR):

    ATR也是用来衡量价格波动性的指标,但它直接计算了一段时间内的平均波幅。与MTR不同,ATR并没有对真实波幅进行平均化处理,而是直接计算了一定时期内的TR的平均值。ATR通常用于确定价格波动性的程度,例如,较大的ATR值表示市场波动较大,而较小的ATR值表示市场波动较小。

代码

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

核心代码

# 计算 ATR
def calculate_atr(df, n=14):# 计算真实范围(True Range)df['HL'] = df['HIGH'] - df['LOW']df['HC'] = abs(df['CLOSE'].shift(1) - df['HIGH'])df['LC'] = abs(df['CLOSE'].shift(1) - df['LOW'])df['MTR'] = df[['HL', 'HC', 'LC']].max(axis=1)# 计算ATRdf['ATR'] = df['MTR'].rolling(window=n).mean()return df.drop(['HL', 'HC', 'LC'], axis=1)

df['HL'] = df['HIGH'] - df['LOW']: 这一行计算了每个交易周期内的价格范围,即当日最高价和最低价之间的差值,结果保存在DataFrame的新列’HL’中。

df['HC'] = abs(df['CLOSE'].shift(1) - df['HIGH']): 这一行计算了当日最高价与前一个交易日收盘价之间的价差的绝对值,结果保存在DataFrame的新列’HC’中。shift(1)函数将CLOSE列向上偏移一个位置,以便与前一个交易日的CLOSE值进行计算。

df['LC'] = abs(df['CLOSE'].shift(1) - df['LOW']): 这一行计算了当日最低价与前一个交易日收盘价之间的价差的绝对值,结果保存在DataFrame的新列’LC’中。

df['MTR'] = df[['HL', 'HC', 'LC']].max(axis=1): 这一行计算了每个交易周期内的真实范围(Mean True Range)。它取了之前计算的’HL’、'HC’和’LC’列的最大值,结果保存在DataFrame的新列’MTR’中。max(axis=1)表示沿着每一行取最大值。

df['ATR'] = df['MTR'].rolling(window=n).mean(): 这一行计算了ATR(Average True Range)。它对MTR列进行滚动平均,使用了窗口大小为’n’的移动窗口。结果保存在DataFrame的新列’ATR’中。这里假设变量’n’已经在代码中定义并赋值。

完整代码

import pandas as pdimport a_get_data# 计算 ATR
def calculate_atr(df, n=14):# 计算真实范围(True Range)df['HL'] = df['HIGH'] - df['LOW']df['HC'] = abs(df['CLOSE'].shift(1) - df['HIGH'])df['LC'] = abs(df['CLOSE'].shift(1) - df['LOW'])df['MTR'] = df[['HL', 'HC', 'LC']].max(axis=1)# 计算ATRdf['ATR'] = df['MTR'].rolling(window=n).mean()return df.drop(['HL', 'HC', 'LC'], axis=1)data = {'CLOSE': 填每日收盘的数据,'HIGH': 填每日最高的数据,'LOW': 填每日最低的数据'OPEN': 填每日开盘的数据
}df = pd.DataFrame(data)# 计算ATR
df = calculate_atr(df)print(df)

在这里插入图片描述

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

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

相关文章

Windows+Yolo3-darknet训练自己数据集并测试

WindowsYolo3-darknet训练自己的数据集并测试 一、首要条件 Windows 7下配置好VS2015OPENCV3.4.2YOLO3CUDA10.0CUDNN7.5生成darknet.exe。具体配置可参考我的博客:https://blog.csdn.net/wszswllnzn_/article/details/100760477 二.制作数据集 1、方法1 使用软件la…

ELK介绍以及搭建

基础环境 hostnamectl set-hostname els01 hostnamectl set-hostname els02 hostnamectl set-hostname els03 hostnamectl set-hostname kbased -i s/SELINUXenforcing/SELINUXdisabled/ /etc/selinux/config systemctl stop firewalld & systemctl disable firewalld# 安…

家政小程序开发,引领家庭服务新时代的科技革命

随着科技的飞速发展,人们的生活方式正在发生深刻的变化。其中,家政服务作为日常生活的重要组成部分,也在经历着一场由小程序技术引领的科技革命。本文将探讨家政小程序的发展趋势、功能特点以及对家庭服务的深远影响。 一、家政小程序的发展…

IDEA创建java项目

1. 创建单个项目 1.1 点击New Project 刚安装好会进入下面的创建页面,选择直接New Project创建新项目。 如果后续打开IDEA,并且上次的项目存在,则会打默认开上次的项目,此时可以选择File -> New->Project创建新项目。 …

一文带你解决如何设置Redis临时密码和永久密码

💟💟前言 ​ 友友们大家好,我是你们的小王同学😗😗 今天给大家打来的是 一文带你解决如何设置Redis临时密码和永久密码 希望能给大家带来有用的知识 觉得小王写的不错的话麻烦动动小手 点赞👍 收藏⭐ 评论&…

Echarts与后台(mongoose)交互

Echarts引入地址可参考 echarts组件引入 <template><div><div id"main" style"width: 600px;height:400px;"></div></div> </template><script setup> import { onMounted, ref } from vue; import * as echa…

Siamfc论文中文翻译(详细!)

Fully-Convolutional Siamese Networks for Object Tracking 用于对象跟踪的Siamese网络 说明 建议对照siamfc&#xff08;2021版&#xff09;原文阅读&#xff0c;翻译软件翻译出来的效果不好&#xff0c;整体阅读体验不佳&#xff0c;所以我对译文重新进行了整理&#xff0…

Kafka:kafka的主从模式和故障切换 ②

一、Kafka整体架构图 二、Kafka原题回答 Kafka集群有主从模式吗&#xff1f; Kafka集群实际上并没有严格意义上的主从模式。Kafka的设计是基于分布式的&#xff0c;每个Topic都会切分为多个Partition&#xff0c;每个Partition都有一个Leader和多个Follower。 所有的读写操作…

开源分子对接程序rDock的安装及使用流程

欢迎浏览我的CSND博客&#xff01; Blockbuater_drug …点击进入 前言 本文介绍开源分子对接程序rDock在Linux Ubuntu 22.04系统上的conda安装、编译安装过程及程序使用流程。 一、rDock是什么&#xff1f; rDock来源 rDock是一个快速、多功能的开源对接程序&#xff0c;可用…

每日OJ题_牛客OR59_字符串中找出连续最长的数字串

目录 牛客OR59 字符串中找出连续最长的数字串 解析代码 牛客OR59 字符串中找出连续最长的数字串 字符串中找出连续最长的数字串_牛客题霸_牛客网 解析代码 #include <iostream> #include <cctype> using namespace std; int main() {string str, tmp "&q…

Python奇幻之旅(从入门到入狱基础篇)——面向对象进阶篇(下)

目录 引言 3. 面向对象高级和应用 3.1. 继承【补充】 3.1.1. mro和c3算法 c3算法 一句话搞定继承关系 3.1.2. py2和py3区别 3.3. 异常处理 3.3.1. 异常细分 3.3.2. 自定义异常&抛出异常 3.3.3. 特殊的finally 3.4. 反射 3.4.1. 一些皆对象 3.4.2. import_modu…

Sora是什么?

文章目录 前言Sora是什么&#xff1f;功能特色优点 缺点Sora模型的工作原理如何使用Sora模型Sora模型的应用场景Sora模型带来的问题虚假信息版权问题 后记 前言 Sora是美国人工智能研究公司OpenAI发布的一款令人惊叹的人工智能文生成视频大模型。近年来&#xff0c;人工智能技…

Web性能优化-详细讲解与实用方法-MDN文档学习笔记

Web性能优化 查看更多学习笔记&#xff1a;GitHub&#xff1a;LoveEmiliaForever MDN中文官网 性能优良的网站能够提高访问者留存和用户满意度&#xff0c;减少客户端和服务器之间传输的数据量可降低各方的成本 不同的业务目标和用户需求需要不同的性能度量&#xff0c;要提高…

总是显得不在乎

愫 - 林玉英 词&#xff1a;灵漪 曲&#xff1a;孙建平 是否我对你 总是显得不在乎 是否我眼神 总有几许淡漠 如果冷漠不在乎 是分离的理由 我该含笑让你走 还是含泪挥手 你给我的爱 仿佛总是太多 你给我的情 仿佛也是太过 因为过多的感情 是沉重的负荷 让我不…

Linux Android USB gadget(从设备驱动)

Linux Android USB gadget 一:Linux usb gadget 与 Android Composite Gadget二:原生方式和Android方式如何配置函数调用逻辑内核配置原生驱动android驱动三:mass_storage配置虚拟化U盘四:遍历usb设备五:adb usb判断usb设备为adb获取adb配置信息adb设备序列号发送与接收《Linux…

二十七、图像的均值模糊操作

项目功能实现&#xff1a;对一张图片进行均值模糊操作 按照之前的博文结构来&#xff0c;这里就不在赘述了 更多的图像模糊操作原理可参考博文&#xff1a;七、模糊操作&#xff0c;里面有详细原理讲解&#xff0c;只不过代码是python写的。 一、头文件 blurtest.h #pragma…

为什么Google打算干掉Cookies

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

LVS的工作模式及其原理

1、LVS 介绍 &#xff08;1&#xff09;LVS 是Linux Virtual Server的简称&#xff0c;也就是 Linux 虚拟服务器, 是一个由章文嵩博士发起的自由软件项目&#xff0c;它的官方站点是www.linuxvirtualserver.org。现在LVS已经是 Linux标准内核的一部分&#xff0c;因此性能较高…

林浩然与杨凌芸的Java泛型历险记:从类型安全到代码简洁,一场浪漫的编程革命

林浩然与杨凌芸的Java泛型历险记&#xff1a;从类型安全到代码简洁&#xff0c;一场浪漫的编程革命 Lin Haoran and Yang Lingyun’s Java Generics Adventure: A Romantic Programming Revolution from Type Safety to Code Simplicity 在那片充满逻辑与智慧的Java大陆上&…

123 Linux C++ 系统编程2 Linux 上安装卸载程序三种方法,linux 下解压缩命令 tar介绍。kill命令,top命令,umask 命令

一 通过命令和网络直接安装 sudo apt-get update sudo apt-get update 的工作就是将自己本地 ubutun的软件列表和 aliyun 的软件列表对比&#xff0c;如不一样&#xff0c;则更新。 sudo apt-get install 软件名 真正的安装 那么这里就有一个问题了&#xff0c; 怎么从aliy…