diff --git a/tools/cooja/java/se/sics/cooja/interfaces/Battery.java b/tools/cooja/java/se/sics/cooja/interfaces/Battery.java index b13949d84..b20c92b5a 100644 --- a/tools/cooja/java/se/sics/cooja/interfaces/Battery.java +++ b/tools/cooja/java/se/sics/cooja/interfaces/Battery.java @@ -26,7 +26,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: Battery.java,v 1.5 2008/10/28 12:30:48 fros4943 Exp $ + * $Id: Battery.java,v 1.6 2008/10/28 13:28:35 fros4943 Exp $ */ package se.sics.cooja.interfaces; @@ -44,33 +44,33 @@ import se.sics.cooja.*; *

* This Battery updates energy after each mote tick: * the energy consumption of each interface is summed up. - * In addtion, the energy used by the CPU (depends on mote state) is - * detracted each tick. + * In addition, the Battery adds the CPU energy. *

* - * This observable notifies every tick (!). + * This observable notifies every tick (relatively time-consuming). * - * When energy left is below 0 the mote is dead. + * When the energy left is below 0 the mote is dead. * * @see MoteInterface - * @see MoteInterface#energyConsumptionPerTick() + * @see MoteInterface#energyConsumption() * * @author Fredrik Österlind */ @ClassDescription("Battery") public class Battery extends MoteInterface implements PolledAfterAllTicks { + private static Logger logger = Logger.getLogger(Battery.class); /** * Approximate energy consumption of a mote's CPU in active mode (mA). ESB * measured energy consumption is 1.49 mA. */ - public final double ENERGY_CONSUMPTION_AWAKE_mA; + public final double CPU_ENERGY_CONSUMPTION_AWAKE_mA; /** * Approximate energy consumption of a mote's CPU in low power mode (mA). ESB * measured energy consumption is 1.34 mA. */ - public final double ENERGY_CONSUMPTION_LPM_mA; + public final double CPU_ENERGY_CONSUMPTION_LPM_mA; /** * Initial energy of battery in milli coulomb (mQ). ESB mote: 3 regular AA @@ -79,46 +79,39 @@ public class Battery extends MoteInterface implements PolledAfterAllTicks { */ public final double INITIAL_ENERGY; - private double energyConsumptionLPMPerTick = -1.0; - private double energyConsumptionAwakePerTick = -1.0; - private Mote mote = null; - private static Logger logger = Logger.getLogger(Battery.class); - private double myEnergy; + private double cpuEnergyConsumptionLPMPerMs; + private double cpuEnergyConsumptionAwakePerMs; + private boolean hasInfiniteEnergy; - private double lastEnergyConsumption = 0; + + private double cpuEnergyConsumption = 0; + + private double totalEnergyConsumption = 0; /** * Creates a new battery connected to given mote. * + * @param mote Mote + * + * @see #energyConsumption * @see #INITIAL_ENERGY - * @param mote - * Mote holding battery */ public Battery(Mote mote) { - // Read class configurations of this mote type - ENERGY_CONSUMPTION_AWAKE_mA = mote.getType().getConfig() - .getDoubleValue(Battery.class, "CPU_AWAKE_mA"); - ENERGY_CONSUMPTION_LPM_mA = mote.getType().getConfig().getDoubleValue( - Battery.class, "CPU_LPM_mA"); - INITIAL_ENERGY = mote.getType().getConfig().getDoubleValue( - Battery.class, "INITIAL_ENERGY_mQ"); - hasInfiniteEnergy = mote.getType().getConfig().getBooleanValue( - Battery.class, "INFINITE_ENERGY_bool"); + /* Read configuration */ + CPU_ENERGY_CONSUMPTION_AWAKE_mA = mote.getType().getConfig().getDoubleValue(Battery.class, "CPU_AWAKE_mA"); + CPU_ENERGY_CONSUMPTION_LPM_mA = mote.getType().getConfig().getDoubleValue(Battery.class, "CPU_LPM_mA"); + INITIAL_ENERGY = mote.getType().getConfig().getDoubleValue(Battery.class, "INITIAL_ENERGY_mQ"); + hasInfiniteEnergy = mote.getType().getConfig().getBooleanValue(Battery.class, "INFINITE_ENERGY_bool"); - if (energyConsumptionAwakePerTick < 0) { - energyConsumptionAwakePerTick = ENERGY_CONSUMPTION_AWAKE_mA * 0.001; - energyConsumptionLPMPerTick = ENERGY_CONSUMPTION_LPM_mA * 0.001; - } + cpuEnergyConsumptionAwakePerMs = CPU_ENERGY_CONSUMPTION_AWAKE_mA * 0.001; /* TODO Voltage */ + cpuEnergyConsumptionLPMPerMs = CPU_ENERGY_CONSUMPTION_LPM_mA * 0.001; /* TODO Voltage */ this.mote = mote; - myEnergy = INITIAL_ENERGY; } public void doActionsAfterTick() { - lastEnergyConsumption = 0; - // If infinite energy, do nothing if (hasInfiniteEnergy) { return; @@ -129,22 +122,24 @@ public class Battery extends MoteInterface implements PolledAfterAllTicks { return; } - double totalEnergyConsumption = 0.0; - - totalEnergyConsumption += energyConsumptionLPMPerTick; - for (MoteInterface intf : mote.getInterfaces().getInterfaces()) { - totalEnergyConsumption += intf.energyConsumptionPerTick(); + if (mote.getState() == Mote.State.ACTIVE) { + cpuEnergyConsumption += cpuEnergyConsumptionLPMPerMs; + } else { + cpuEnergyConsumption += cpuEnergyConsumptionAwakePerMs; } - decreaseEnergy(totalEnergyConsumption); - lastEnergyConsumption += totalEnergyConsumption; + totalEnergyConsumption = cpuEnergyConsumption; + for (MoteInterface intf : mote.getInterfaces().getInterfaces()) { + totalEnergyConsumption += intf.energyConsumption(); + } - // Check if we are out of energy - if (getCurrentEnergy() <= 0.0) { - setChanged(); - notifyObservers(); + /* Check if we are out of energy */ + if (getEnergyConsumption() > INITIAL_ENERGY) { mote.setState(Mote.State.DEAD); } + + setChanged(); + notifyObservers(); } /** @@ -172,49 +167,52 @@ public class Battery extends MoteInterface implements PolledAfterAllTicks { } /** - * @return Current energy left + * @return Current energy consumption */ - public double getCurrentEnergy() { - return myEnergy; + public double getEnergyConsumption() { + return totalEnergyConsumption; } - private void decreaseEnergy(double consumption) { - if (!hasInfiniteEnergy) { - myEnergy -= consumption; - setChanged(); - notifyObservers(); - } + /** + * @return Energy left ratio + */ + public double getEnergyLeftRatio() { + return ((getInitialEnergy() - getEnergyConsumption()) / getInitialEnergy()); } public JPanel getInterfaceVisualizer() { // Battery energy left JPanel panel = new JPanel(); panel.setLayout(new BoxLayout(panel, BoxLayout.Y_AXIS)); + final JLabel initialLabel = new JLabel(""); final JLabel energyLabel = new JLabel(""); - final JLabel energyPercentLabel = new JLabel(""); + final JLabel leftLabel = new JLabel(""); if (hasInfiniteEnergy()) { - energyLabel.setText("INFINITE"); - energyPercentLabel.setText(""); + initialLabel.setText("[infinite energy]"); + energyLabel.setText(""); + leftLabel.setText(""); } else { - energyLabel.setText("Energy left (mQ) = " + getCurrentEnergy()); - energyPercentLabel.setText("Energy left (%) = " - + (getCurrentEnergy() / getInitialEnergy() * 100) + "%"); + initialLabel.setText("Total energy (mQ): " + getInitialEnergy()); + energyLabel.setText("Consumed energy (mQ): " + getEnergyConsumption()); + leftLabel.setText("Energy left (%): " + (getEnergyLeftRatio() * 100)); } + panel.add(initialLabel); panel.add(energyLabel); - panel.add(energyPercentLabel); + panel.add(leftLabel); Observer observer; this.addObserver(observer = new Observer() { public void update(Observable obs, Object obj) { if (hasInfiniteEnergy()) { - energyLabel.setText("INFINITE"); - energyPercentLabel.setText(""); + initialLabel.setText("[infinite energy]"); + energyLabel.setText(""); + leftLabel.setText(""); } else { - energyLabel.setText("Energy left (mQ) = " + getCurrentEnergy()); - energyPercentLabel.setText("Energy left (%) = " - + (getCurrentEnergy() / getInitialEnergy() * 100) + "%"); + initialLabel.setText("Total energy (mQ): " + getInitialEnergy()); + energyLabel.setText("Consumed energy (mQ): " + getEnergyConsumption()); + leftLabel.setText("Energy left (%): " + (getEnergyLeftRatio() * 100)); } } }); @@ -235,15 +233,10 @@ public class Battery extends MoteInterface implements PolledAfterAllTicks { this.deleteObserver(observer); } - public double energyConsumptionPerTick() { - // The battery itself does not require any power. + public double energyConsumption() { return 0.0; } - public double getLastTotalEnergyConsumption() { - return lastEnergyConsumption; - } - public Collection getConfigXML() { Vector config = new Vector(); Element element;