Commit 34c1c8e6 authored by Sebastien Robin's avatar Sebastien Robin

PartJobShop: very simple order in GUI have now successfull simulation run

All the display of results needs to be reviewed
parent e53c6727
...@@ -8,15 +8,17 @@ from datetime import datetime ...@@ -8,15 +8,17 @@ from datetime import datetime
from dream.simulation.GUI import ACO from dream.simulation.GUI import ACO
from dream.simulation.GUI.Default import schema from dream.simulation.GUI.Default import schema
MACHINE_TYPE_SET = set(["Dream.MachineManagedJob"])
class Simulation(ACO.Simulation): class Simulation(ACO.Simulation):
def getConfigurationDict(self): def getConfigurationDict(self):
conf = ACO.Simulation.getConfigurationDict(self) conf = ACO.Simulation.getConfigurationDict(self)
conf["Dream-MachineJobShop"] = { conf["Dream-MachineManagedJob"] = {
"property_list": [ "property_list": [
schema["processingTime"], schema["processingTime"],
schema["failures"] schema["failures"]
], ],
"_class": 'Dream.MachineJobShop', "_class": 'Dream.MachineManagedJob',
"name": 'Machine' "name": 'Machine'
} }
conf["Dream-QueueManagedJob"] = { conf["Dream-QueueManagedJob"] = {
...@@ -41,6 +43,10 @@ class Simulation(ACO.Simulation): ...@@ -41,6 +43,10 @@ class Simulation(ACO.Simulation):
"_class": 'Dream.ExitJobShop', "_class": 'Dream.ExitJobShop',
"name": 'Exit' "name": 'Exit'
} }
conf["Dream-Operator"] = {
"_class": 'Dream.Operator',
"name": 'Operator'
}
conf["Dream-OrderDecomposition"] = { conf["Dream-OrderDecomposition"] = {
"_class": 'Dream.OrderDecomposition', "_class": 'Dream.OrderDecomposition',
"name": 'Decompo' "name": 'Decompo'
...@@ -58,10 +64,44 @@ class Simulation(ACO.Simulation): ...@@ -58,10 +64,44 @@ class Simulation(ACO.Simulation):
conf.pop('Dream-Exit') conf.pop('Dream-Exit')
return conf return conf
def getMachineNameSet(self, step_name):
"""
Give list of machines given a particular step name. For example
if step_name is "CAM", it will return ["CAM1", "CAM2"]
"""
machine_name_set = set()
for machine_name in self.data["nodes"].keys():
if machine_name.startswith(step_name):
machine_name_set.add(machine_name)
print "getMachineNameSet, %r : %r" % (step_name, machine_name_set)
return machine_name_set
def getNotMachineNodePredecessorList(self, step_name):
"""
Give the list of all predecessors that are not of type machine
For example, for step_name "CAM", it may return "QCAM"
"""
predecessor_list = []
machine_name_set = self.getMachineNameSet(step_name)
for edge in self.data["edges"].values():
print "getNotMachineNodePredecessorList, edge[1]: %r" % edge[1]
if edge[1] in machine_name_set:
predecessor_step = edge[0]
if predecessor_step in predecessor_list:
continue
if not self.data["nodes"][predecessor_step]["_class"] in MACHINE_TYPE_SET:
predecessor_list = [predecessor_step] + predecessor_list
predecessor_list = [x for x in self.getNotMachineNodePredecessorList(predecessor_step) \
if x not in predecessor_list] + predecessor_list
print "getNotMachineNodePredecessorList, %r : %r" % (step_name, predecessor_list)
# XXX We have to returned an ordered list
return predecessor_list
def _preprocess(self, in_data): def _preprocess(self, in_data):
""" Set the WIP in queue from spreadsheet data. """ Set the WIP in queue from spreadsheet data.
""" """
data = copy(in_data) data = copy(in_data)
self.data = data
now = datetime.now() now = datetime.now()
if data['general']['currentDate']: if data['general']['currentDate']:
...@@ -71,40 +111,96 @@ class Simulation(ACO.Simulation): ...@@ -71,40 +111,96 @@ class Simulation(ACO.Simulation):
# Data is presented as follow, with first line the order, then only parts of this order # Data is presented as follow, with first line the order, then only parts of this order
# Order ID | Due Date | Priority | Project Manager | Parts | Part Type | Sequence | Processing Time | Electrodes needed # Order ID | Due Date | Priority | Project Manager | Parts | Part Type | Sequence | Processing Time | Electrodes needed
# Order 1 | 2013/02/15 | 1 | PM1 | P1 | type1 | Mach1-Mach2 | 3-5 | # Order 1 | 2013/02/15 | 1 | PM1 | P1 | type1 | Mach1-Mach2 | 3-5 |
wip_dict = {} # | | | | P2 | type2 | Mach2-Mach3 | 4-7 |
wip_list = []
print "wip part data : %r" % (data['wip_part_spreadsheet'],) print "wip part data : %r" % (data['wip_part_spreadsheet'],)
for value_list in data['wip_part_spreadsheet']: i = 0
wip_part_spreadsheet_length = len(data['wip_part_spreadsheet'])
while i < wip_part_spreadsheet_length:
value_list = data['wip_part_spreadsheet'][i]
print "first value_list: %r" % (value_list,) print "first value_list: %r" % (value_list,)
if value_list[0] == 'Order ID' or not value_list[4]: if value_list[0] == 'Order ID' or not value_list[4]:
i += 1
continue continue
print "still there after first continue" print "still there after first continue"
order_dict = {}
wip_list.append(order_dict)
order_id, due_date, priority, project_manager, part, part_type,\ order_id, due_date, priority, project_manager, part, part_type,\
sequence_list, processing_time_list, electrode_needed = value_list sequence_list, processing_time_list, electrode_needed = value_list
due_date = (datetime.strptime(due_date, '%Y/%m/%d') - now).days due_date = (datetime.strptime(due_date, '%Y/%m/%d') - now).days
sequence_list = sequence_list.split('-') sequence_list = sequence_list.split('-')
processing_time_list = processing_time_list.split('-') processing_time_list = processing_time_list.split('-')
wip_dict.setdefault(sequence_list[0], []).append( order_dict["_class"] = "Dream.Order"
{ order_dict["id"] = order_id
"_class": "Dream.Job", order_dict["manager"] = project_manager
"id": value_list[1], order_dict["name"] = order_id
"name": value_list[0], # XXX can we do better than this ?
"dueDate": dueDate, order_dict["route"] = [
"route": [ {
{ "stationIdsList": [
"processingTime": { "QStart"
"distributionType": "Fixed", ],
"mean": processing_time_list[i], "stepNumber": "0"
}, },
"stationIdsList": sequence_list[i].split(','), {
"stepNumber": i "processingTime": {
} for i in xrange(len(sequence_list))] "distributionType": "Fixed",
} "mean": "1"
) },
for node_id in data['nodes'].keys(): "setupTime": {
if node_id in wip_dict: "setupDistribution": "Fixed",
data['nodes'][node_id]['wip'] = wip_dict[node_id] "setupMean": "0.5"
},
"stationIdsList": [
"CAD1",
"CAD2"
],
"stepNumber": "1"
}
]
i += 1
component_list = []
if i < wip_part_spreadsheet_length:
while data['wip_part_spreadsheet'][i][0] == None:
value_list = data['wip_part_spreadsheet'][i]
if value_list[4] == None:
break
order_id, due_date, priority, project_manager, part, part_type,\
sequence_list, processing_time_list, electrode_needed = value_list
sequence_list = sequence_list.split('-')
processing_time_list = processing_time_list.split('-')
component_dict = {}
component_dict["_class"] = "Dream.OrderComponent"
component_dict["componentType"] = part_type
component_dict["id"] = "%i" % i
component_dict["name"] = part
component_list.append(component_dict)
route_list = []
route_counter = 0
for j, sequence_step in enumerate(sequence_list):
for predecessor_step in self.getNotMachineNodePredecessorList(sequence_step):
route = {"stationIdsList": [predecessor_step],
"stepNumber": "%i" % route_counter
}
route_list.append(route)
route_counter += 1
route = {"stationIdsList": list(self.getMachineNameSet(sequence_step)),
"stepNumber": "%i" % route_counter,
"processingTime": {"distributionType": "Fixed",
"mean": "%i" % int(processing_time_list[j])},
"setupTime": {"setupDistribution": "Fixed",
"setupMean": "0.5"}, # XXX hardcoded value
}
route_list.append(route)
route_counter += 1
component_dict["route"] = route_list
i+=1
order_dict["componentsList"] = component_list
data["nodes"]["QStart"]["wip"] = wip_list
del(data['wip_part_spreadsheet']) del(data['wip_part_spreadsheet'])
from pprint import pprint
print pprint(data)
return data return data
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment