Search in sources :

Example 1 with WeibullDistribution

use of smile.stat.distribution.WeibullDistribution in project smile by haifengl.

the class WeibullDistributionDemo method stateChanged.

@Override
public void stateChanged(ChangeEvent e) {
    if (e.getSource() == scaleSlider || e.getSource() == shapeSlider) {
        scale = scaleSlider.getValue() / 10.0;
        shape = shapeSlider.getValue();
        if (scale == 0)
            scale = 0.01;
        if (shape == 0)
            shape = 0.01;
        WeibullDistribution dist = new WeibullDistribution(shape, scale);
        double[][] p = new double[100][2];
        double[][] q = new double[100][2];
        for (int i = 0; i < p.length; i++) {
            p[i][0] = i / 20.0;
            p[i][1] = dist.p(p[i][0]);
            q[i][0] = i / 20.0;
            q[i][1] = dist.cdf(p[i][0]);
        }
        pdf.clear();
        pdf.line(p, Line.Style.SOLID, Color.BLUE);
        cdf.clear();
        cdf.line(q, Line.Style.SOLID, Color.BLUE);
        double[] data = new double[500];
        for (int i = 0; i < data.length; i++) {
            data[i] = dist.rand();
        }
        histogram.clear();
        histogram.histogram(data, 20, Color.BLUE);
        qqplot.clear();
        qqplot.add(new QQPlot(data, dist));
        canvas.repaint();
    }
}
Also used : QQPlot(smile.plot.QQPlot) WeibullDistribution(smile.stat.distribution.WeibullDistribution)

Aggregations

QQPlot (smile.plot.QQPlot)1 WeibullDistribution (smile.stat.distribution.WeibullDistribution)1