histogramdata.java

来自「OperaMasks是一种基于J2EE的Web开发技术」· Java 代码 · 共 97 行

JAVA
97
字号
/*
 * $Id: HistogramData.java,v 1.2 2008/07/25 10:13:08 libin Exp $
 *
 * Copyright (C) 2006 Operamasks Community.
 * Copyright (C) 2000-2006 Apusic Systems, Inc.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program. If not, see http://www.gnu.org/licenses.
 */

package demo.graph;

import javax.faces.model.ArrayDataModel;
import java.util.Random;

import org.operamasks.faces.annotation.ManagedBean;
import org.operamasks.faces.annotation.ManagedBeanScope;

@ManagedBean(scope=ManagedBeanScope.REQUEST)
public class HistogramData extends ArrayDataModel
{
    private double min;
    private double max;
    private double mean;
    private double std;

    public HistogramData() {
        this(1000);
    }

    public HistogramData(int numRows) {
        createData(numRows);
    }

    public void randomize() {
        createData(1000);
    }

    private void createData(int numRows) {
        // create random data
        Random random = new Random();
        Double[] data = new Double[numRows];
        double offset = random.nextInt(6) + 2;
        for (int i = 0; i < numRows; i++) {
            data[i] = random.nextGaussian() + offset;
        }
        setWrappedData(data);

        // compute mean and std
        min = max = data[0];
        double sum = 0.0;
        for (int i = 0; i < numRows; i++) {
            sum += data[i];
            min = Math.min(min, data[i]);
            max = Math.max(max, data[i]);
        }
        this.mean = sum / numRows;

        sum = 0.0;
        for (int i = 0; i < numRows; i++) {
            sum += (data[i] - this.mean) * (data[i] - this.mean);
        }
        this.std = Math.sqrt(sum / numRows);
    }

    public double getMin() {
        return min;
    }

    public double getMax() {
        return max;
    }

    public double getMean() {
        return mean;
    }

    public double getStd() {
        return std;
    }

    public double normalDistribution(double x) {
        return Math.exp(-1.0 * (x-mean)*(x-mean) / (2*std*std))
             / Math.sqrt(2*Math.PI*std*std);
    }
}

⌨️ 快捷键说明

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