source: DCWoRMS/trunk/src/test/article/recs/plugins/energy/AmdNodeEEP.java @ 656

Revision 656, 1.4 KB checked in by wojtekp, 12 years ago (diff)
  • Property svn:mime-type set to text/plain
Line 
1package test.article.recs.plugins.energy;
2
3import java.io.FileNotFoundException;
4import java.io.IOException;
5
6import schedframe.resources.computing.ComputingNode;
7import schedframe.resources.computing.ComputingResource;
8import schedframe.resources.computing.Processor;
9import schedframe.resources.computing.profiles.energy.EnergyEvent;
10import schedframe.scheduling.manager.tasks.JobRegistry;
11
12public class AmdNodeEEP extends RecsNodeBaseEEP {
13
14        public double estimatePowerConsumption(EnergyEvent event, JobRegistry jobRegistry,
15                        ComputingResource resource) {
16                double powerConsumption = 0;
17                ComputingNode node = (ComputingNode) resource;
18                for(Processor cpu: node.getProcessors()){
19                        try{
20                                powerConsumption = powerConsumption + cpu.getPowerInterface().getRecentPowerUsage().getValue();
21                        } catch (Exception e){
22                               
23                        }
24                }
25                try {
26                        powerConsumption = powerConsumption + node.getPowerInterface().getPowerConsumption(node.getPowerInterface().getPowerState());
27                } catch (NoSuchFieldException e) {
28                }
29
30               
31                try {
32                        if(jobRegistry.getRunningTasks().size()>0)
33                        powerConsumption = powerConsumption + getMeasuredPower(createQuery(jobRegistry.getRunningTasks().get(0)));
34                } catch (FileNotFoundException e) {
35                        // TODO Auto-generated catch block
36                        e.printStackTrace();
37                } catch (IOException e) {
38                        // TODO Auto-generated catch block
39                        e.printStackTrace();
40                }
41                return powerConsumption;
42        }
43
44}
Note: See TracBrowser for help on using the repository browser.