1 | package test.stencils.plugins; |
---|
2 | |
---|
3 | import schedframe.resources.computing.Processor; |
---|
4 | import schedframe.resources.computing.profiles.energy.ResourceEvent; |
---|
5 | import schedframe.resources.computing.profiles.energy.power.StandardPowerStateName; |
---|
6 | import schedframe.resources.devices.PhysicalResource; |
---|
7 | import schedframe.scheduling.manager.tasks.JobRegistry; |
---|
8 | import example.energy.BaseEnergyEstimationPlugin; |
---|
9 | |
---|
10 | public class ProcessorEnergyEstimationPlugin extends BaseEnergyEstimationPlugin { |
---|
11 | |
---|
12 | public double estimatePowerConsumption(ResourceEvent event, JobRegistry jobRegistry, |
---|
13 | PhysicalResource resource) { |
---|
14 | |
---|
15 | double processorLoad = 0; |
---|
16 | double powerConsumption = 0; |
---|
17 | Processor proc = (Processor)resource; |
---|
18 | if(resource.getPowerInterface().getPowerState().equals(StandardPowerStateName.OFF)) |
---|
19 | return 0; |
---|
20 | else { |
---|
21 | |
---|
22 | /*double usedFreq = proc.getPowerInterface().getHighestPState().getFrequency(); |
---|
23 | |
---|
24 | JobRegistry jr = new JobRegistryImpl(proc.getFullName()); |
---|
25 | for(ExecTask task: jr.getRunningTasks()){ |
---|
26 | String taskFreqString = task.getCurrentResourceConsumption().getReferenceHardware().get("cpu_maxfreq"); |
---|
27 | double taskFreq = Double.valueOf(taskFreqString); |
---|
28 | if(taskFreq > usedFreq){ |
---|
29 | usedFreq = taskFreq; |
---|
30 | } |
---|
31 | } |
---|
32 | |
---|
33 | processorLoad = proc.getLoadInterface().getRecentUtilization().getValue(); |
---|
34 | //System.out.println(proc.getFullName() + "processorLoad v2: " + processorLoad); |
---|
35 | |
---|
36 | if(processorLoad != 0 && proc.getPowerInterface().getFrequency() != usedFreq) { |
---|
37 | proc.getPowerInterface().setFrequency(usedFreq); |
---|
38 | }*/ |
---|
39 | |
---|
40 | processorLoad = proc.getLoadInterface().getRecentUtilization().getValue(); |
---|
41 | double lowestLoadLevel = 100; |
---|
42 | double highestLoadLevel = 0; |
---|
43 | if(proc.getPowerInterface().getPState().getLoadPowerUsage().containsKey(new Double(processorLoad))){ |
---|
44 | powerConsumption = proc.getPowerInterface().getPState().getLoadPowerUsage().get(new Double(processorLoad)); |
---|
45 | //System.out.println("power from profile: " + powerConsumption); |
---|
46 | } else { |
---|
47 | for(Double load: proc.getPowerInterface().getPState().getLoadPowerUsage().keySet()){ |
---|
48 | if(lowestLoadLevel > load){ |
---|
49 | lowestLoadLevel = load; |
---|
50 | } |
---|
51 | if(highestLoadLevel < load){ |
---|
52 | highestLoadLevel = load; |
---|
53 | } |
---|
54 | } |
---|
55 | if(processorLoad == 0){ |
---|
56 | try{ |
---|
57 | powerConsumption = proc.getPowerInterface().getSupportedPowerStates().get(0).getPowerUsage(); |
---|
58 | //System.out.println("load = 0; power = idle power usage: " + powerConsumption); |
---|
59 | } catch (Exception e){ |
---|
60 | powerConsumption = 0.7 * proc.getPowerInterface().getPState().getLoadPowerUsage().get(new Double(highestLoadLevel)); |
---|
61 | //System.out.println("error load = 0; power = 0.7 max power: " + powerConsumption); |
---|
62 | } |
---|
63 | } else { |
---|
64 | |
---|
65 | double lowerLoadLevel = lowestLoadLevel; |
---|
66 | double higherLoadLevel = highestLoadLevel; |
---|
67 | |
---|
68 | try{ |
---|
69 | |
---|
70 | for(Double load: proc.getPowerInterface().getPState().getLoadPowerUsage().keySet()){ |
---|
71 | if(processorLoad > load){ |
---|
72 | lowerLoadLevel = load; |
---|
73 | } |
---|
74 | else if(processorLoad < load){ |
---|
75 | higherLoadLevel = load; |
---|
76 | break; |
---|
77 | } |
---|
78 | } |
---|
79 | double powerBelow; |
---|
80 | double powerAbove; |
---|
81 | double a; |
---|
82 | double b; |
---|
83 | if(lowerLoadLevel != higherLoadLevel) { |
---|
84 | powerBelow = proc.getPowerInterface().getPState().getLoadPowerUsage().get(lowerLoadLevel); |
---|
85 | powerAbove = proc.getPowerInterface().getPState().getLoadPowerUsage().get(higherLoadLevel); |
---|
86 | a = (powerAbove - powerBelow)/(higherLoadLevel - lowerLoadLevel); |
---|
87 | b = powerAbove - a * higherLoadLevel; |
---|
88 | } else { |
---|
89 | powerBelow = proc.getPowerInterface().getPState().getLoadPowerUsage().get(lowestLoadLevel); |
---|
90 | powerAbove = proc.getPowerInterface().getPState().getLoadPowerUsage().get(highestLoadLevel); |
---|
91 | a = (powerAbove - powerBelow)/(highestLoadLevel - lowestLoadLevel); |
---|
92 | b = powerAbove - a * highestLoadLevel; |
---|
93 | } |
---|
94 | powerConsumption = a * processorLoad + b; |
---|
95 | /*System.out.println("a" +lowestLoadLevel + ";" +highestLoadLevel); |
---|
96 | System.out.println("b" +lowerLoadLevel + ";" +higherLoadLevel); |
---|
97 | System.out.println("c" +powerBelow + ";" +powerAbove); |
---|
98 | System.out.println(resource.getFullName() + "load: " + processorLoad + "linear power estimation " + powerConsumption);*/ |
---|
99 | |
---|
100 | } catch (Exception e){ |
---|
101 | powerConsumption = 0.7 * proc.getPowerInterface().getPState().getLoadPowerUsage().get(new Double(highestLoadLevel)); |
---|
102 | //System.out.println("error; power = 0.7 max power: " + powerConsumption); |
---|
103 | } |
---|
104 | } |
---|
105 | } |
---|
106 | } |
---|
107 | //System.out.println("estimated power consumption: " + powerConsumption); |
---|
108 | return powerConsumption; |
---|
109 | } |
---|
110 | |
---|
111 | } |
---|