⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ma.java

📁 EclipseTrader is a stock exchange analysis system, featuring shares pricing watch, intraday and hi
💻 JAVA
字号:
/* * Copyright (c) 2004-2006 Marco Maccaferri and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: *     Stefan S. Stratigakos - original qtstalker code *     Marco Maccaferri - initial API and implementation */package net.sourceforge.eclipsetrader.trading.alerts;import net.sourceforge.eclipsetrader.core.db.BarData;/** * Moving Average */public class MA{    public static final int SMA = 0;    public static final int EMA = 1;    public static final int WMA = 2;    public static final int Wilder = 3;    public static double getMA(BarData in, int field, int type, int period)    {        double ma = 0;        if (period < 1 || period >= in.size())            return ma;                double data[] = new double[period + 1];        int index = in.size() - period - 1;        for (int i = 0; i < data.length; i++, index++)        {            switch(field)            {                case BarData.OPEN:                    data[i] = in.getOpen(index);                    break;                case BarData.HIGH:                    data[i] = in.getHigh(index);                    break;                case BarData.LOW:                    data[i] = in.getLow(index);                    break;                case BarData.CLOSE:                    data[i] = in.getClose(index);                    break;            }        }        switch (type)        {            case SMA:                ma = getSMA(data, period);                break;            case EMA:                ma = getEMA(data, period);                break;            case WMA:                ma = getWMA(data, period);                break;            case Wilder:                ma = getWilderMA(data, period);                break;        }        return ma;    }    public static double getEMA(double[] data, int period)    {        double result = 0;        if (period < 1 || period >= data.length)            return result;        double smoother = 2.0 / (period + 1);        double t = 0;        int loop;        for (loop = 0; loop < period; loop++)            t = t + data[loop];        double yesterday = t / period;        result = yesterday;        for (; loop < data.length; loop++)        {            double t1 = (smoother * (data[loop] - yesterday)) + yesterday;            yesterday = t1;            result = t1;        }                return result;    }    public static double getSMA(double[] data, int period)    {        double result = 0;        if (period < 1 || period >= data.length)            return result;        // create the circular buffer and its running total        double[] values = new double[period];        double total = 0.0;        // fill buffer first time around, keeping its running total        int loop = -1;        while (++loop < period)        {            double val = data[loop];            total += val;            values[loop] = val;        }        // buffer filled with first period values, output first sma value        result = total / period;        // loop over the rest, each time replacing oldest value in buffer        --loop;        while (++loop < data.length)        {            int index = loop % period;            double newval = data[loop];            total += newval;            total -= values[index];            values[index] = newval;            result = total / period;        }        return result;    }    public static double getWMA(double[] data, int period)    {        double result = 0;        if (period < 1 || period >= data.length)            return result;        int loop;        for (loop = period - 1; loop < data.length; loop++)        {            int loop2;            int weight;            int divider;            double total;            for (loop2 = period - 1, weight = 1, divider = 0, total = 0; loop2 >= 0; loop2--, weight++)            {                total = total + (data[loop - loop2] * weight);                divider = divider + weight;            }            result = total / divider;        }        return result;    }    public static double getWilderMA(double[] data, int period)    {        double result = 0;        if (period < 1 || period >= data.length)            return result;        double t = 0;        int loop;        for (loop = 0; loop < period; loop++)            t = t + data[loop];        double yesterday = t / period;        result = yesterday;        for (; loop < data.length; loop++)        {            double t1 = (yesterday * (period - 1) + data[loop]) / period;            yesterday = t1;            result = t1;        }        return result;    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -