股票MA算法(Java实现)

public class MAUtils {
    private void test(int dayCount) {
        //算法公式:MA(C,X)=(X1+X2+…+XX)/X.
        //MA(C,1)=C/1=1(这里C=1,X=1);
        //MA(C,2)=(1+2)/2=1.5;
        //MA(C,3)=(1+2+3)/3=2;
        //MA(C,4)=(1+2+3+4)/4=2.5;
        //MA(C,5)=(1+2+3+4+5)/5=3.
        List<Data> dataList = new ArrayList<>();
        for (int i = 0; i < dayCount; i++) {
            Data data = new Data();
            data.setClosePrice(i + 1);
            data.setOpenPrice(i + 1);
            dataList.add(data);
        }

        List<Double> maResults = new ArrayList<>();
        for (int days = 0; days < dayCount; days++) {
            double sum = 0;
            for (int dataIdx = 0; dataIdx < dataList.size(); dataIdx++) {
                if (dataIdx > days) {
                    break;
                }
                sum += dataList.get(dataIdx).getOpenPrice();
            }
            maResults.add(sum / (days + 1));
        }
        System.out.println("=============");
        System.out.println(maResults);
    }

    public static void main(String[] args) {
        new MAUtils().test(5);
    }

    class Data {
        Data() {

        }

        double closePrice;
        double openPrice;

        public double getClosePrice() {
            return closePrice;
        }

        public void setClosePrice(double closePrice) {
            this.closePrice = closePrice;
        }

        public double getOpenPrice() {
            return openPrice;
        }

        public void setOpenPrice(double openPrice) {
            this.openPrice = openPrice;
        }

        @Override
        public String toString() {
            return "Data{" +
                    "closePrice=" + closePrice +
                    ", openPrice=" + openPrice +
                    '}';
        }
    }

注:自行BigDecimal处理

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
BBI指标是一种基于多条不同周期的移动平均线组合的技术分析指标,其计算公式如下: BBI = (MA3 + MA6 + MA12 + MA24) / 4 其中,MA3表示3日移动平均线,MA6表示6日移动平均线,MA12表示12日移动平均线,MA24表示24日移动平均线。 下面是用Java实现BBI指标的算法代码: ```java public class BBI { public static double[] calculate(int[] prices) { int n = prices.length; double[] ma3 = new double[n]; double[] ma6 = new double[n]; double[] ma12 = new double[n]; double[] ma24 = new double[n]; double[] bbi = new double[n]; // 计算3日、6日、12日、24日移动平均线 for (int i = 0; i < n; i++) { if (i >= 2) { ma3[i] = (prices[i] + prices[i-1] + prices[i-2]) / 3.0; } if (i >= 5) { ma6[i] = (prices[i] + prices[i-1] + prices[i-2] + prices[i-3] + prices[i-4] + prices[i-5]) / 6.0; } if (i >= 11) { ma12[i] = (prices[i] + prices[i-1] + prices[i-2] + prices[i-3] + prices[i-4] + prices[i-5] + prices[i-6] + prices[i-7] + prices[i-8] + prices[i-9] + prices[i-10]) / 12.0; } if (i >= 23) { ma24[i] = (prices[i] + prices[i-1] + prices[i-2] + prices[i-3] + prices[i-4] + prices[i-5] + prices[i-6] + prices[i-7] + prices[i-8] + prices[i-9] + prices[i-10] + prices[i-11] + prices[i-12] + prices[i-13] + prices[i-14] + prices[i-15] + prices[i-16] + prices[i-17] + prices[i-18] + prices[i-19] + prices[i-20] + prices[i-21] + prices[i-22]) / 24.0; } } // 计算BBI指标 for (int i = 0; i < n; i++) { bbi[i] = (ma3[i] + ma6[i] + ma12[i] + ma24[i]) / 4.0; } return bbi; } } ``` 以上代码实现了BBI指标的计算,可以将股票的价格数据传入该算法中,即可得到对应的BBI指标值数组。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值