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

📄 simulator.java

📁 drools 一个开放源码的规则引擎
💻 JAVA
字号:
package org.drools.spring.examples.jiahvac.sim;

/*
 * Copyright 2005 (C) The Werken Company. All Rights Reserved.
 *
 * Redistribution and use of this software and associated documentation
 * ("Software"), with or without modification, are permitted provided that the
 * following conditions are met:
 *
 * 1. Redistributions of source code must retain copyright statements and
 * notices. Redistributions must also contain a copy of this document.
 *
 * 2. Redistributions in binary form must reproduce the above copyright notice,
 * this list of conditions and the following disclaimer in the documentation
 * and/or other materials provided with the distribution.
 *
 * 3. The name "drools" must not be used to endorse or promote products derived
 * from this Software without prior written permission of The Werken Company.
 * For written permission, please contact bob@werken.com.
 *
 * 4. Products derived from this Software may not be called "drools" nor may
 * "drools" appear in their names without prior written permission of The Werken
 * Company. "drools" is a registered trademark of The Werken Company.
 *
 * 5. Due credit should be given to The Werken Company.
 * (http://drools.werken.com/).
 *
 * THIS SOFTWARE IS PROVIDED BY THE WERKEN COMPANY AND CONTRIBUTORS ``AS IS''
 * AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED. IN NO EVENT SHALL THE WERKEN COMPANY OR ITS CONTRIBUTORS BE
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 *
 */



import org.drools.spring.examples.jiahvac.model.Floor;
import org.drools.spring.examples.jiahvac.model.HeatPump;
import org.drools.spring.examples.jiahvac.model.Vent;

public class Simulator implements Runnable {

    private final double RATE = 0.01;
    private final double HOT = 100;
    private final double COLD = 50;
    
    private SimFloor[] floors;
    private SimHeatPump[] heatPumps;
    private double outdoorTempurature = 90;

    public Simulator(int numOfFloors, double initialTempuratureReading, Vent.State initialVentState) {
        if (numOfFloors % 3 != 0) {
            throw new RuntimeException("numOfFloors must be divisible by 3");
        }
        buildFloors(numOfFloors, initialTempuratureReading, initialVentState);
        buildHeatPumps();
        new Thread(this).start();
    }
    
    private void buildFloors(int numOfFloors, double initialTempuratureReading, Vent.State initialVentState) {
        floors = new SimFloor[numOfFloors];
        for (int i = 0; i < numOfFloors; i++) {
            floors[i] = new SimFloor(i);
            
            SimThermometer thermometer = new SimThermometer(floors[i]);
            thermometer.setReading(initialTempuratureReading);
            floors[i].setThermometer(thermometer);
            
            SimVent vent = new SimVent(floors[i]);
            vent.setState(initialVentState);
            floors[i].setVent(vent);
        }
    }
    
    private void buildHeatPumps() {
        int numHeatPumps = floors.length / 3;
        heatPumps = new SimHeatPump[numHeatPumps];
        
        int floorNumber = 0;
        for (int i = 0; i < numHeatPumps; i++) {
            SimFloor[] servicedFloors = new SimFloor[] {
                    floors[floorNumber++],
                    floors[floorNumber++],
                    floors[floorNumber++]
            };
            heatPumps[i] = new SimHeatPump(i, servicedFloors);
            
            servicedFloors[0].setHeatPump(heatPumps[i]);
            servicedFloors[1].setHeatPump(heatPumps[i]);
            servicedFloors[2].setHeatPump(heatPumps[i]);
        }
    }
    
    public void run() {
        for (int i = 0; i < floors.length; i++) {
            SimThermometer thermometer = floors[i].getThermometer();
            Vent vent = floors[i].getVent();
            HeatPump pump = floors[i].getHeatPump();
            
            double temperature = thermometer.getReading();
            temperature += leakage( temperature );            
            
            switch (pump.getState()) {
            case HEATING:
                temperature += heatingTempuratureDelta( vent, temperature ); 
                break;
            case COOLING:
                temperature += coolingTempuratureDelta( vent, temperature ); 
                break;
            case OFF:
                temperature += offTempuratureDelta( i );
                break;
            }
            
            thermometer.setReading(temperature);
        }
    }

    private double coolingTempuratureDelta(Vent vent, double temperature) {
        return (COLD - temperature) * RATE * vent.getState().getValue();
    }

    private double heatingTempuratureDelta(Vent vent, double temperature) {
        return (HOT - temperature) * RATE * vent.getState().getValue();
    }

    private double offTempuratureDelta(int i) {
        return (i + 1 ) * 0.005;
    }

    private double leakage(double temperature) {
        return (outdoorTempurature - temperature) * RATE / 2;
    }

    public Floor[] getFloors() {
        return floors;
    }
    
    public HeatPump[] getHeatPumps() {
        return heatPumps;
    }
    
    public void setOutdoorTempurature(double tempurature) {
        this.outdoorTempurature = tempurature;
    }
    
    public double getOutdoorTempurature() {
        return outdoorTempurature;
    }
}

⌨️ 快捷键说明

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