This repository has been archived by the owner on Jun 12, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
builder.py
46 lines (42 loc) · 2.1 KB
/
builder.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
##############################################################################
##
## Copyright 2015 Markus Prasser
##
## This file is part of PrSi.
##
## PrSi is free software: you can redistribute it and/or modify
## it under the terms of the GNU General Public License as published by
## the Free Software Foundation, either version 3 of the License, or
## (at your option) any later version.
##
## PrSi is distributed in the hope that it will be useful,
## but WITHOUT ANY WARRANTY; without even the implied warranty of
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
## GNU General Public License for more details.
##
## You should have received a copy of the GNU General Public License
## along with PrSi. If not, see <http://www.gnu.org/licenses/>.
##
##############################################################################
from matrix import Matrix
class Builder:
def __init__( self, argProblemString, argOptions ):
self.options = argOptions
# First load data common to all problems
print( " Builder constructor" )
self.problemItems = argProblemString.rstrip( '\n' ).split( '|' )
# print( self.problemItems )
self.problemName = self.problemItems[0].rpartition( '/' )[ -1 ]
print( " Building {0}-problem: {1}".format( self.options.currentProblemType, self.problemName ) )
# Then load problem specific data or fail, if an unknown problem was given
if self.options.currentProblemType == "QAP":
assert len( self.problemItems ) == 4
self.problemSize = int( self.problemItems[ 1 ] )
self.flowMatrix = Matrix.FromSSV( self.problemItems[ 2 ], self.problemSize, self.problemSize )
# print( self.flowMatrix )
self.distanceMatrix = Matrix.FromSSV( self.problemItems[ 3 ], self.problemSize, self.problemSize )
# print( self.distanceMatrix )
else:
raise ValueError( "Invalid problem type encountered in 'Builder'" )
print( " Problem size: {0}".format( self.problemSize ) )
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4