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

📄 pareto.java

📁 一个用于排队系统仿真的开源软件,有非常形象的图象仿真过程!
💻 JAVA
字号:
/**    
  * Copyright (C) 2006, Laboratorio di Valutazione delle Prestazioni - Politecnico di Milano

  * 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 2 of the License, or
  * (at your option) 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, write to the Free Software
  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
  */
  
package jmt.gui.common.distributions;

import jmt.gui.common.resources.ImageLoader;

import javax.swing.*;

/**
 * <p>Title: Pareto Distribution</p>
 * <p>Description: Pareto distribution data structure</p>
 * 
 * @author Bertoli Marco
 *         Date: 28-giu-2005
 *         Time: 10.47.42
 */
public class Pareto extends Distribution{
    /**
     * Construct a new Pareto Distribution
     */
    public Pareto() {
        super("Pareto",
                "jmt.engine.random.Pareto",
                "jmt.engine.random.ParetoPar",
                "Pareto distribution");
        hasMean = true;
        hasC = true;
    }

    /**
     * Used to set parameters of this distribution.
     * @return distribution parameters
     */
    protected Parameter[] setParameters() {
        // Creates parameter array
        Parameter[] parameters = new Parameter[2];
        // Sets parameter alpha
        parameters[0] = new Parameter("alpha",
                "\u03B1",
                Double.class,
                new Double(3));
        // Checks value of alpha must greater or equal then 2
        parameters[0].setValueChecker(new ValueChecker() {
            public boolean checkValue(Object value) {
                Double d = (Double) value;
                if (d.doubleValue() >= 2)
                    return true;
                else
                    return false;
            }
        });

        // Sets parameter k
        parameters[1] = new Parameter("k",
                "k",
                Double.class,
                new Double(1));
        // Checks value of k must be greater then 0
        parameters[1].setValueChecker(new ValueChecker() {
            public boolean checkValue(Object value) {
                Double d = (Double) value;
                if (d.doubleValue() > 0)
                    return true;
                else
                    return false;
            }
        });

        return parameters;
    }

    /**
     * Sets explicative image of this distribution used, together with description, to help the
     * user to understand meaning of parameters.
     * @return explicative image
     */
    protected ImageIcon setImage() {
        return ImageLoader.loadImage("Pareto");
    }

    /**
     * Returns this distribution's short description
     * @return distribution's short description
     */
    public String toString() {
        return "par(" +
                FormatNumber(((Double)parameters[0].getValue()).doubleValue()) +
                "; "+
                FormatNumber(((Double)parameters[1].getValue()).doubleValue()) +
                ")";
    }

    /**
     * Sets the mean for this distribution
     * @param value mean value
     */
    public void setMean(double value) {
        setCM(value, c);
    }

    /**
     * Sets the variation coefficient C for this distribution
     * @param value variation coefficient C value
     */
    public void setC (double value) {
        setCM(mean, value);
    }

    /**
     * Sets Mean and C values
     * @param mean mean value
     * @param c c value
     */
    protected void setCM(double mean, double c) {
        // k = mean - mean /  (1+sqrt(1+1/c^2)) && alpha = 1 + sqrt(1 + 1 / c^2)
        // Backups old parameters to restore them upon a false result
        Object oldk = getParameter("k").getValue();
        Object olda = getParameter("alpha").getValue();
        if (getParameter("k").setValue(new Double(mean - mean / (1 + Math.sqrt(1+1/(c*c))))) &&
                getParameter("alpha").setValue(new Double(1 + Math.sqrt(1 + 1 / (c*c))))) {
            this.mean = mean;
            this.c = c;
        }
        else {
            getParameter("k").setValue(oldk);
            getParameter("alpha").setValue(olda);
        }
    }

    /**
     * This method is called whenever a parameter changes and <code>hasC</code> or
     * <code>hasMean</code> are true
     */
    public void updateCM() {
        double a, k;
        a = ((Double)getParameter("alpha").getValue()).doubleValue();
        k = ((Double)getParameter("k").getValue()).doubleValue();
        mean = a * k / (a - 1);
        c = 1 / Math.sqrt(a * a - 2 * a);
    }                                   
}

⌨️ 快捷键说明

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