Python 实现股票指标计算——DMA

DMA (Deviation Moving Average) - 平均差

1 公式

DMA = 收盘价N1日简单平均 - 收盘价N2日简单平均

AMA = M日DMA简单平均

2 数据准备

我们以科创50指数 000688 为例,指数开始日期为2019-12-31,数据格式如下:

3 计算过程

def calculate_dma(df: pd.DataFrame, N1=10, N2=50, M=6):
    """
    计算两种不同周期的移动平均线差值 (DMA) 及其移动平均线 (DMA MA)。

    参数:
    df (pd.DataFrame): 包含至少 'close' 列的DataFrame,代表每日收盘价。
    N1 (int): 第一个用于计算DMA的简单移动平均线 (SMA) 的时间窗口大小,默认为10。
    N2 (int): 第二个用于计算DMA的简单移动平均线 (SMA) 的时间窗口大小,默认为50。
    M (int): 用于计算DMA MA的时间窗口大小,默认为6。

    返回:
    pd.DataFrame: 包含 DMA 和 DMA MA 值的DataFrame。
    """

    # 创建一个df的副本以避免修改原始数据
    data = df.copy()

    # 计算 N1 和 N2 天的简单移动平均线 (SMA),然后计算差值作为 DMA
    dma = data['close'].rolling(window=N1).mean() - data['close'].rolling(window=N2).mean()

    # 计算 DMA 的移动平均线 (DMA MA),使用窗口大小 M
    madma = dma.rolling(window=M).mean()

    # 将计算出的 DMA 和 DMA MA 添加到 DataFrame
    data['dma'] = dma
    data['madma'] = madma

    # 返回包含所有计算出指标的 DataFrame
    return data

4 注意事项

参数N1=10,N2=50,M=6时,计算结果与东方财富软件中一致

雪球无此指标

你的身份是高级编程技术专家,精通各类编程语言,能对编程过程中的各类问题进行分析和解答。我的问题是【使用Python构建回测系统测试选股代码的有效性?用2018-2024年全A股周期回测验证此代码选股逻辑的准确性和胜率,评估月胜率达到多少?评估有效信号准确率达到多少?】,同时此代码还有什么可提升的空间,提出可行性的优化建议和方案,如何选到选股胜率达到月胜率提高至75%以上,有效信号准确率95%以上,选到资金持续流入,股票市场情绪启动,盘中异动启动主升浪的股票,及日线盘中预警选股和盘后选股。请帮我检查并改正错误点补全正确代码,优化选股逻辑和参数计算关系和信号触发条件,并替换为通达信支持的函数,生成优化后完整代码。我的原始代码如下:【{——智能估值体系V8——} DYNPETTM:=IF(FINANCE(33)>2.5E8 AND FINANCE(1)>1.2E8, CLOSE/MAX(FINANCE(33)/FINANCE(1),0.82*IF(INBLOCK('沪深300'),1.12,1)), 999); PB_RATE:=IF(FINANCE(34)>0.68*VOL_REGIME_NEW/0.028 AND CLOSE>4.2, CLOSE/(FINANCE(34)*0.78 + FINANCE(34,1)*0.22*EXP(-0.18*VOL_REGIME_NEW)), 999); PEG_VAL:=DYNPETTM/MAX((FINANCE(54)/FINANCE(54,1)*100-100),0.68*VOL_REGIME_NEW/0.028); {——分形波动率V8——} VOL_REGIME_NEW:=DMA(STD(C,89)/MA(C,89)*SQRT(144),34)*(1+0.18*SIN(2*3.1416*BARSLAST(CROSS(VOL_REGIME,0.02))/55)); VAR_PERIOD:=IF(VOL_REGIME_NEW<0.012,233, IF(VOL_REGIME_NEW<0.028*EXP(-0.12*HSL),144, IF(VOL_REGIME_NEW<0.055*MA(C,21)/MA(C,55),55,34))); FAST_LEN:=BARSLAST(CROSS(VOL_REGIME_NEW,0.025*HSL))+21; SLOW_LEN:=CEILING(VAR_PERIOD*(1.618-IF(VOL_REGIME_NEW>0.15,0.22*VOL_REGIME_NEW,0.06))); {——九维情绪引擎V9——} MARKET_SENTI:=EMA(ADVANCE/DECLINE,13)*0.42*IF(C>MA(C,233),1.18,0.88) + EMA(AMOUNT/REF(AMOUNT,5),13)*0.32*POW(VOL_REGIME_NEW,0.5) + EMA((HSL-REF(HSL,8))/REF(HSL,8),21)*0.18*IF(CAPITAL>8E9,1.22,1) + EMA(LARGE_INFLOW(3)/FINVALUE(0),8)*0.08*IF(WEEKDAY==5,1.12,1) + 0.18*(IF(LARGE_ORDER(2)>REF(LARGE_ORDER(2),8)*1.28,1,0)); HOT_INDEX:=SMA(SUM(IF(C>DYNAINFO(58)*1.028,V/FINVALUE(7)*100,0),21)/ MA(V,21)*2.28,13,1)*IF(CAPITAL>8E9,1.22,1)*IF(HSL>3,1.18,0.92); {——资金流验证V8——} CAPITAL_INFLOW_NEW:=SUM(LARGE_INFLOW(3),13)/SUM(LARGE_INFLOW(3),55)>MAX(0.92,0.8+0.12*VOL_REGIME_NEW) AND SUM(IF(C>O*1.028 AND C>MA(C,21),V,0),13)/SUM(V,13)>0.82*IF(MONTH_TREND,1.12,1) AND (AMOUNT-REF(AMOUNT,13))/REF(AMOUNT,13)>0.42*EXP(0.08*WEEK_MACD) AND EVERY(LARGE_ORDER(2)>0.72,8) AND CHIPSDIFF(8,21)>0.32*VOL_REGIME_NEW/0.028 AND HKHOLDDIFF(5)>0.08*IF(INBLOCK('港股通'),1.22,1); {——信号合成V9——} FINAL_SIGNAL:=TREND_CONFIRM AND (MONTH_TREND*0.32 + WEEK_MACD>REF(WEEK_MACD,5)*1.88*0.28 + DAY_BREAK*0.22 + MIN30_BREAK*0.18 + (MARKET_SENTI>4.8)*0.15 + (HOT_INDEX>3.8)*0.12 + (PEG_VAL<0.48)*0.18 + (DYNPETTM<8.2)*0.15 + CAPITAL_INFLOW_NEW*0.28)>=0.92*IF(VOL_REGIME_NEW>0.05,1.08,1) AND BARSLAST(FINAL_SIGNAL)>MAX(89,SLOW_LEN) AND INDUSTRY_BETA(C,IND_NAME,144)<0.88; {——智能止损V6——} STOP_LOSS:=C<EMA(L,21)*0.92*IF(VOL_REGIME_NEW>0.15,0.95,1) OR (V>MA(V,89)*8.2 AND C<OPEN*0.968) OR VOL_REGIME_NEW>0.15 AND C<EMA(C,55)*0.88*IF(WEEKDAY>3,0.92,1);】:
最新发布
04-02
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值