news 2026/4/23 15:49:43

5年21倍,量化里面超牛的均线:让Python带你玩转KAMA自适应指标!

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
5年21倍,量化里面超牛的均线:让Python带你玩转KAMA自适应指标!
👇我的小册 54章教程:(小白零基础用Python量化股票分析小册),原价299,限时特价2杯咖啡,满100人涨10元。

大家好,我是菜哥

做量化交易的朋友都知道,均线是个好东西,我自己刚开始学量化的时候第一个学的指标就是MA/EMA。但是有很纠结,比如周期设短了,K线稍微动一下就给你发信号,结果十次有八次是假突破;周期设长了,等你反应过来,黄花菜都凉了,最肥的那段行情早跑没影了。

那么有没有一种均线,能在行情火爆的时候反应灵敏,在震荡磨人的时候又能淡定如水?

今天给大家安利一个指标:这个"有眼力见"的指标——KAMA自适应移动平均线

01.啥是KAMA

KAMA的全称是Kaufman's Adaptive Moving Average,中文叫考夫曼自适应移动平均线,是美国量化大师Perry Kaufman在上世纪90年代提出的。

是不是听起来特别牛,它的核心思想特别朴素:市场趋势明显的时候,我就灵敏点;市场来回拉锯的时候,我就钝一点。

听起来是不是很像个聪明人?行情好的时候冲在前面,行情乱的时候躲在后面观望。

KAMA怎么做到这一点的呢?关键在于一个叫"效率比率"(ER)的东西。

效率比率说白了就是:价格真正走了多远,相比它上上下下折腾的总路程,占了多大比例。

下面我用白话说:

假如10天前价格是100,现在是110,涨了10块,这是"净位移"。但这10天里价格可能今天涨2块、明天跌1块、后天又涨3块,折腾来折腾去加起来走了30块,这是"总波动"。那效率比率ER = 10/30 = 0.33。

  • 如果ER接近1,说明价格基本是直线上涨或下跌,趋势强劲

  • 如果ER接近0,说明价格来回拉锯,横盘震荡

咱们用Python算一下这个ER:

有了ER之后,KAMA会根据它来动态调整自己的"敏感度"。ER大的时候跑得快,ER小的时候走得慢,这就是"自适应"的精髓。

02.手把手教你用Python实现KAMA


理论说完了,咱们动手写代码。整个过程分三步:下载数据、计算KAMA、生成交易信号。

第一步:准备数据

我们用yfinance库下载苹果公司(AAPL)2020到2024年的股价数据:

这段代码跑完,你就拿到了苹果股票5年的开盘价、收盘价、成交量等数据。

第二步:计算KAMA

KAMA的计算稍微有点绕,但拆开来看其实不难。核心公式是:

KAMA[今天] = KAMA[昨天] + SC × (价格[今天] - KAMA[昨天])

这里的SC是"平滑常数",它由ER和快慢周期共同决定。ER越大,SC越大,KAMA变化越快;ER越小,SC越小,KAMA变化越慢。

代码里的fast=2和slow=30分别代表快速和慢速EMA的周期,你可以理解为KAMA在这两个极端之间灵活切换。

第三步:生成交易信号

策略逻辑很简单:价格上穿KAMA就买入,下穿就卖出

跑完这段代码,你就能看到5年里一共产生了多少次买入和卖出信号。

03.实战回测:5年21倍的收益是怎么来的


光有信号还不够,咱们得模拟真金白银地买卖,看看最后能赚多少钱。光说不练假把式!前面举例用的苹果的股价,下面我们用特斯拉然后换成AK库来获取数据!

好,假设你有1万美元的本金,每次信号来了就全仓操作(实际交易千万别这么干,这里只是为了演示):

我们抓住取特斯拉的5年的数据来看看效果:

回测代码有200多行,我就不打开了,不然篇幅太长了,简单说就是通过ak下载美股的特斯拉的数据,接着用python写kama指标的,然后去跑这个下载的5年数据进行交易,看看买入和卖出的点位,最后进行打印显示结果并可视化展示。

我们看一下结果:

图上有3根曲线:

深蓝是kama策略的资金曲线

绿色是买入就不动的

红色虚线是初始资金

下面是回测的数据:

回测周期: 2020-01-02 至 2025-12-31

初始资金: $10,000.00

最终资产: $225,211.52

总收益率: 2152.12%

年化收益率: 68.11%

最大回撤: -36.37%

交易次数: 222次

胜率: 27.93%

简单说一下:

买入并不动,大概收益率: 1467.84%(特斯拉还是很猛的)

策略是21.5倍,大概赚超额收益: 684.27%

04.写在最后


KAMA的魅力在于它的"眼力"——知道什么时候该冲,什么时候该稳。

这种自适应的思想在量化交易中非常重要。市场不是一成不变的,一套参数打天下的时代早就过去了。好的策略应该像KAMA一样,能根据市场环境自我调整。

当然,单纯靠一个指标就想稳赚不赔是不现实的。量化路漫漫,我们下一篇再聊!

如果你对量化交易感兴趣,可以看一下我们的入门小册,考虑清楚了,合适了再下手哈!买了之后有我们专门的新手量化交流群可以讨论。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 14:31:04

Qwen3-Reranker-0.6B 实战:提升 RAG 检索效果的简单方法

Qwen3-Reranker-0.6B 实战:提升 RAG 检索效果的简单方法 在构建高质量知识库应用时,你是否遇到过这样的问题:用户问“如何优化MySQL查询性能”,向量检索却返回了大量关于“PostgreSQL索引原理”或“Redis缓存策略”的文档&#xf…

作者头像 李华
网站建设 2026/4/23 12:59:47

科哥开源项目真良心,Emotion2Vec+永久免费使用

科哥开源项目真良心,Emotion2Vec永久免费使用 1. 这不是又一个“玩具模型”,而是能直接落地的语音情感分析系统 你有没有遇到过这些场景? 客服中心想自动识别客户通话中的情绪波动,但商用API按调用次数收费,每月动辄…

作者头像 李华
网站建设 2026/4/16 17:59:53

OFA视觉问答模型镜像:轻松搭建你的第一个多模态AI应用

OFA视觉问答模型镜像:轻松搭建你的第一个多模态AI应用 你有没有试过对着一张图片发问,然后期待AI给出准确回答?比如看到一张咖啡杯的照片,问“这是什么颜色的杯子”,AI立刻答出“白色带蓝色条纹”——这种能力背后&am…

作者头像 李华
网站建设 2026/4/23 12:59:55

Flowise效果展示:实时数据流接入(Kafka)与LLM实时分析能力

Flowise效果展示:实时数据流接入(Kafka)与LLM实时分析能力 1. Flowise是什么:让AI工作流真正“看得见、摸得着” Flowise 不是又一个需要写几十行代码才能跑起来的 LangChain 小样例,而是一个把复杂 AI 工程“拆解成…

作者头像 李华
网站建设 2026/4/22 14:11:16

GTE中文向量模型教程:templates/中HTML表单与后端task_type联动逻辑

GTE中文向量模型教程:templates/中HTML表单与后端task_type联动逻辑 1. 为什么需要理解这个联动逻辑 你可能已经部署好了基于 ModelScope 的 iic/nlp_gte_sentence-embedding_chinese-large 模型 Web 应用,也成功访问了首页,但点下“提交”…

作者头像 李华
网站建设 2026/4/23 14:34:19

Chandra企业AI落地:替代第三方API的私有化聊天服务生产环境部署

Chandra企业AI落地:替代第三方API的私有化聊天服务生产环境部署 1. 为什么企业需要自己的AI聊天服务 你有没有遇到过这样的场景:客服系统想接入智能问答,但每次调用第三方API都要走公网,数据在传输中“裸奔”;内部知…

作者头像 李华