org.drools.planner.examples.cloudbalancing.swingui.CloudBalancingPanel Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of drools-planner-examples Show documentation
Show all versions of drools-planner-examples Show documentation
Drools Planner optimizes automated planning by combining metaheuristic search algorithms with rule
engine powered score calculation. This is the drools-planner-examples module which contains examples on how to use
Drools Planner.
/*
* Copyright 2010 JBoss Inc
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.drools.planner.examples.cloudbalancing.swingui;
import java.awt.Color;
import java.awt.GridLayout;
import java.awt.event.ActionEvent;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import javax.swing.AbstractAction;
import javax.swing.GroupLayout;
import javax.swing.JComboBox;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import org.apache.commons.lang.ObjectUtils;
import org.drools.FactHandle;
import org.drools.WorkingMemory;
import org.drools.planner.core.solution.Solution;
import org.drools.planner.core.solution.director.SolutionDirector;
import org.drools.planner.core.solver.ProblemFactChange;
import org.drools.planner.examples.cloudbalancing.domain.CloudAssignment;
import org.drools.planner.examples.cloudbalancing.domain.CloudBalance;
import org.drools.planner.examples.cloudbalancing.domain.CloudComputer;
import org.drools.planner.examples.cloudbalancing.solver.move.CloudComputerChangeMove;
import org.drools.planner.examples.common.swingui.SolutionPanel;
/**
* TODO this code is highly unoptimized
*/
public class CloudBalancingPanel extends SolutionPanel {
public static final Color[] PROCESS_COLORS = {
Color.GREEN, Color.YELLOW, Color.BLUE, Color.RED, Color.CYAN, Color.ORANGE, Color.MAGENTA
};
private JPanel computersPanel;
private CloudComputerPanel unassignedPanel;
private Map cloudComputerToPanelMap;
private Map cloudAssignmentToPanelMap;
public CloudBalancingPanel() {
GroupLayout layout = new GroupLayout(this);
setLayout(layout);
JPanel headerPanel = createHeaderPanel();
JPanel computersPanel = createComputersPanel();
layout.setHorizontalGroup(layout.createParallelGroup()
.addComponent(headerPanel).addComponent(computersPanel));
layout.setVerticalGroup(layout.createSequentialGroup()
.addComponent(headerPanel, GroupLayout.PREFERRED_SIZE, GroupLayout.PREFERRED_SIZE,
GroupLayout.PREFERRED_SIZE)
.addComponent(computersPanel, GroupLayout.PREFERRED_SIZE, GroupLayout.PREFERRED_SIZE,
GroupLayout.PREFERRED_SIZE));
}
private JPanel createHeaderPanel() {
JPanel headerPanel = new JPanel(new GridLayout(0, 5));
JLabel emptyLabel = new JLabel("");
headerPanel.add(emptyLabel);
JLabel cpuPowerLabel = new JLabel("CPU power");
headerPanel.add(cpuPowerLabel);
JLabel memoryLabel = new JLabel("Memory");
headerPanel.add(memoryLabel);
JLabel networkBandwidthLabel = new JLabel("Network bandwidth");
headerPanel.add(networkBandwidthLabel);
JLabel costLabel = new JLabel("Cost");
headerPanel.add(costLabel);
return headerPanel;
}
private JPanel createComputersPanel() {
computersPanel = new JPanel(new GridLayout(0, 1));
unassignedPanel = new CloudComputerPanel(this, null);
computersPanel.add(unassignedPanel);
cloudComputerToPanelMap = new LinkedHashMap();
cloudComputerToPanelMap.put(null, unassignedPanel);
cloudAssignmentToPanelMap = new LinkedHashMap();
return computersPanel;
}
private CloudBalance getCloudBalance() {
return (CloudBalance) solutionBusiness.getSolution();
}
public void resetPanel(Solution solution) {
for (CloudComputerPanel cloudComputerCloudComputerPanel : cloudComputerToPanelMap.values()) {
if (cloudComputerCloudComputerPanel.getCloudComputer() != null) {
computersPanel.remove(cloudComputerCloudComputerPanel);
}
}
cloudComputerToPanelMap.clear();
cloudComputerToPanelMap.put(null, unassignedPanel);
cloudAssignmentToPanelMap.clear();
unassignedPanel.clearCloudAssignments();
updatePanel(solution);
}
@Override
public void updatePanel(Solution solution) {
CloudBalance cloudBalance = (CloudBalance) solution;
Set deadCloudComputerSet = new LinkedHashSet(cloudComputerToPanelMap.keySet());
deadCloudComputerSet.remove(null);
for (CloudComputer cloudComputer : ((CloudBalance) solution).getCloudComputerList()) {
deadCloudComputerSet.remove(cloudComputer);
CloudComputerPanel cloudComputerPanel = cloudComputerToPanelMap.get(cloudComputer);
if (cloudComputerPanel == null) {
cloudComputerPanel = new CloudComputerPanel(this, cloudComputer);
computersPanel.add(cloudComputerPanel);
cloudComputerToPanelMap.put(cloudComputer, cloudComputerPanel);
}
}
Set deadCloudAssignmentSet = new LinkedHashSet(
cloudAssignmentToPanelMap.keySet());
for (CloudAssignment cloudAssignment : cloudBalance.getCloudAssignmentList()) {
deadCloudAssignmentSet.remove(cloudAssignment);
CloudComputerPanel cloudComputerPanel = cloudAssignmentToPanelMap.get(cloudAssignment);
CloudComputer cloudComputer = cloudAssignment.getCloudComputer();
if (cloudComputerPanel != null
&& !ObjectUtils.equals(cloudComputerPanel.getCloudComputer(), cloudComputer)) {
cloudAssignmentToPanelMap.remove(cloudAssignment);
cloudComputerPanel.removeCloudAssignment(cloudAssignment);
cloudComputerPanel = null;
}
if (cloudComputerPanel == null) {
cloudComputerPanel = cloudComputerToPanelMap.get(cloudComputer);
cloudComputerPanel.addCloudAssignment(cloudAssignment);
cloudAssignmentToPanelMap.put(cloudAssignment, cloudComputerPanel);
}
}
for (CloudAssignment deadCloudAssignment : deadCloudAssignmentSet) {
CloudComputerPanel deadCloudComputerPanel = cloudAssignmentToPanelMap.remove(deadCloudAssignment);
deadCloudComputerPanel.removeCloudAssignment(deadCloudAssignment);
}
for (CloudComputer deadCloudComputer : deadCloudComputerSet) {
CloudComputerPanel deadCloudComputerPanel = cloudComputerToPanelMap.remove(deadCloudComputer);
computersPanel.remove(deadCloudComputerPanel);
}
}
public void deleteComputer(final CloudComputer cloudComputer) {
logger.info("Scheduling deleting of computer ({}).", cloudComputer.getLabel());
solutionBusiness.doProblemFactChange(new ProblemFactChange() {
public void doChange(SolutionDirector solutionDirector) {
CloudBalance cloudBalance = (CloudBalance) solutionDirector.getWorkingSolution();
WorkingMemory workingMemory = solutionDirector.getWorkingMemory();
// First remove the planning fact from all planning entities that use it
for (CloudAssignment cloudAssignment : cloudBalance.getCloudAssignmentList()) {
if (ObjectUtils.equals(cloudAssignment.getCloudComputer(), cloudComputer)) {
FactHandle cloudAssignmentHandle = workingMemory.getFactHandle(cloudAssignment);
cloudAssignment.setCloudComputer(null);
workingMemory.retract(cloudAssignmentHandle);
}
}
// Next remove it the planning fact itself
for (Iterator it = cloudBalance.getCloudComputerList().iterator(); it.hasNext(); ) {
CloudComputer workingCloudComputer = it.next();
if (ObjectUtils.equals(workingCloudComputer, cloudComputer)) {
FactHandle cloudComputerHandle = workingMemory.getFactHandle(workingCloudComputer);
workingMemory.retract(cloudComputerHandle);
it.remove(); // remove from list
break;
}
}
}
});
updatePanel(solutionBusiness.getSolution());
}
private class CloudAssignmentAction extends AbstractAction {
private CloudAssignment cloudAssignment;
public CloudAssignmentAction(CloudAssignment cloudAssignment) {
super("=>");
this.cloudAssignment = cloudAssignment;
}
public void actionPerformed(ActionEvent e) {
List cloudComputerList = getCloudBalance().getCloudComputerList();
JComboBox cloudComputerListField = new JComboBox(cloudComputerList.toArray());
cloudComputerListField.setSelectedItem(cloudAssignment.getCloudComputer());
int result = JOptionPane.showConfirmDialog(CloudBalancingPanel.this.getRootPane(), cloudComputerListField,
"Select cloud computer", JOptionPane.OK_CANCEL_OPTION);
if (result == JOptionPane.OK_OPTION) {
CloudComputer toCloudComputer = (CloudComputer) cloudComputerListField.getSelectedItem();
solutionBusiness.doMove(new CloudComputerChangeMove(cloudAssignment, toCloudComputer));
solverAndPersistenceFrame.resetScreen();
}
}
}
}