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

📄 normal.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: Normal Distribution</p>
 * <p>Description: Normal distribution data structure</p>
 * 
 * @author Bertoli Marco
 *         Date: 7-lug-2005
 *         Time: 17.46.19
 */
public class Normal extends Distribution {
    /**
     * Construct a new Normal Distribution
     */
    public Normal() {
        super("Normal",
                "jmt.engine.random.Normal",
                "jmt.engine.random.NormalPar",
                "Normal distribution");
        hasMean = true;
        hasC = true;
    }

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

        // Sets parameter standardDeviation
        parameters[1] = new Distribution.Parameter("standardDeviation",
                "\u03C3",
                Double.class,
                new Double(1));
        // Checks value of standardDeviation must be greater then 0
        parameters[1].setValueChecker(new Distribution.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("Normal");
    }

    /**
     * Returns this distribution's short description
     * @return distribution's short description
     */
    public String toString() {
        return "norm(" +
                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) {
        // sigma = c^2*mean^2
        // Backups old parameters to restore them upon a false result
        Object oldm = getParameter("mean").getValue();
        Object olds = getParameter("standardDeviation").getValue();
        if (getParameter("mean").setValue(new Double(mean)) &&
                getParameter("standardDeviation").setValue(new Double(c*c*mean*mean))) {
            this.mean = mean;
            this.c = c;
        }
        else {
            getParameter("mean").setValue(oldm);
            getParameter("standardDeviation").setValue(olds);
        }
    }

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

⌨️ 快捷键说明

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