Class OptimizationProblem
java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractSet<E>
java.util.HashSet<OptProbElement>
org.tweetyproject.math.opt.problem.GeneralConstraintSatisfactionProblem
org.tweetyproject.math.opt.problem.ConstraintSatisfactionProblem
org.tweetyproject.math.opt.problem.OptimizationProblem
- All Implemented Interfaces:
- Serializable,- Cloneable,- Iterable<OptProbElement>,- Collection<OptProbElement>,- Set<OptProbElement>
This class models a general optimization problem.
- Author:
- Matthias Thimm
- See Also:
- 
Field SummaryFields
- 
Constructor SummaryConstructorsConstructorDescriptionCreates an empty optimization problem.OptimizationProblem(int type) Creates an empty optimization problem of the given type.
- 
Method SummaryModifier and TypeMethodDescriptionclone()voidThis method collapses all associative operations appearing in the target function and the constraints, e.g.Converts the this optimization problem into a string in the commonly used CPLEX LP-format for mixed integer linear programming.Converts the this optimization problem into a string in the commonly used LP-format for mixed integer linear programming.Returns all minimums appearing in this problem.Returns the target function of this problem.intgetType()Returns the type of this problem.Returns all variables of this problem.booleanisLinear()Checks whether every constraint of this problem is linear.booleanChecks whether this problem uses no minimum function.booleanChecks whether the target function is linear.voidResolves all occurrences of absolute values "abs(X)" by replacing "abs(X)" by a new variable "TMPABS" adding constraints "TMPABS - X>= 0" and "TMPABS + X >= 0" (yielding "TMPABS <= abs(X)") introducing a new variable "TMPABSB" adding constraints "X+PENALTY*TMPABSB - TMPABS >= 0" and "-X-TMPABSB*PENALTY - TMPABS >= -PENALTY" (yielding "TMPABS >= abs(X)") adding constraints "TMPABSB<=1"voidResolves all occurrences of maximums by substituting a maximum "max{a,b}" by "0.5 a + 0.5 b + abs(a-b)".voidResolves all occurrences of minimums by substituting a minimum "min{a,b}" by "0.5 a + 0.5 b - abs(a-b)".voidsetPenalty(int penalty) Sets the penalty for violated minimum.voidsetTargetFunction(Term targetFunction) Sets the target function of this problem.voidsetType(int type) Sets the type of this problem, either OptimizationProblem.MINIMIZE or OptimizationProblem.MAXIMIZE.toString()Methods inherited from class org.tweetyproject.math.opt.problem.ConstraintSatisfactionProblemisInteger, toNormalizedFormMethods inherited from class java.util.HashSetadd, clear, contains, isEmpty, iterator, remove, size, spliterator, toArray, toArrayMethods inherited from class java.util.AbstractSetequals, hashCode, removeAllMethods inherited from class java.util.AbstractCollectionaddAll, containsAll, retainAllMethods inherited from interface java.util.CollectionparallelStream, removeIf, stream, toArray
- 
Field Details- 
EPSILONpublic static final double EPSILONSome value to represent a very small number- See Also:
 
- 
MINIMIZEpublic static final int MINIMIZEStatic constant for the type "minimization"- See Also:
 
- 
MAXIMIZEpublic static final int MAXIMIZEStatic constant for the type "maximization"- See Also:
 
 
- 
- 
Constructor Details- 
OptimizationProblempublic OptimizationProblem()Creates an empty optimization problem.
- 
OptimizationProblempublic OptimizationProblem(int type) Creates an empty optimization problem of the given type.- Parameters:
- type- the type of the problem; either OptimizationProblem.MINIMIZE or OptimizationProblem.MAXIMIZE.
 
 
- 
- 
Method Details- 
setTargetFunctionSets the target function of this problem.- Parameters:
- targetFunction- a term.
 
- 
isTargetLinearpublic boolean isTargetLinear()Checks whether the target function is linear.- Returns:
- "true" if the target function is linear.
 
- 
isLinearpublic boolean isLinear()Description copied from class:ConstraintSatisfactionProblemChecks whether every constraint of this problem is linear.- Overrides:
- isLinearin class- ConstraintSatisfactionProblem
- Returns:
- "true" if every constraint of this problem is linear.
 
- 
isMinimumFreepublic boolean isMinimumFree()Description copied from class:ConstraintSatisfactionProblemChecks whether this problem uses no minimum function.- Overrides:
- isMinimumFreein class- ConstraintSatisfactionProblem
- Returns:
- "true" if this problem uses no minimum function.
 
- 
resolveMinimumspublic void resolveMinimums()Description copied from class:ConstraintSatisfactionProblemResolves all occurrences of minimums by substituting a minimum "min{a,b}" by "0.5 a + 0.5 b - abs(a-b)".- Overrides:
- resolveMinimumsin class- ConstraintSatisfactionProblem
 
- 
resolveMaximumspublic void resolveMaximums()Description copied from class:ConstraintSatisfactionProblemResolves all occurrences of maximums by substituting a maximum "max{a,b}" by "0.5 a + 0.5 b + abs(a-b)".- Overrides:
- resolveMaximumsin class- ConstraintSatisfactionProblem
 
- 
resolveAbsoluteValuespublic void resolveAbsoluteValues()Resolves all occurrences of absolute values "abs(X)" by- replacing "abs(X)" by a new variable "TMPABS"
- adding constraints "TMPABS - X>= 0" and "TMPABS + X >= 0" (yielding "TMPABS <= abs(X)")
- introducing a new variable "TMPABSB"
- adding constraints "X+PENALTY*TMPABSB - TMPABS >= 0" and "-X-TMPABSB*PENALTY - TMPABS >= -PENALTY" (yielding "TMPABS >= abs(X)")
- adding constraints "TMPABSB<=1"
 
- 
convertToLpFormatConverts the this optimization problem into a string in the commonly used LP-format for mixed integer linear programming.- Returns:
- A string representing this problem in LP-format
 
- 
convertToCplexLpFormatConverts the this optimization problem into a string in the commonly used CPLEX LP-format for mixed integer linear programming.- Returns:
- A string representing this problem in CPLEX LP-format
 
- 
getVariablesDescription copied from class:ConstraintSatisfactionProblemReturns all variables of this problem.- Overrides:
- getVariablesin class- ConstraintSatisfactionProblem
- Returns:
- all variables of this problem.
 
- 
getMinimumsDescription copied from class:ConstraintSatisfactionProblemReturns all minimums appearing in this problem.- Overrides:
- getMinimumsin class- ConstraintSatisfactionProblem
- Returns:
- all minimums appearing in this problem.
 
- 
collapseAssociativeOperationspublic void collapseAssociativeOperations()Description copied from class:ConstraintSatisfactionProblemThis method collapses all associative operations appearing in the target function and the constraints, e.g. every min{min{a,b},c} becomes min{a,b,c}- Overrides:
- collapseAssociativeOperationsin class- ConstraintSatisfactionProblem
 
- 
setTypepublic void setType(int type) Sets the type of this problem, either OptimizationProblem.MINIMIZE or OptimizationProblem.MAXIMIZE.- Parameters:
- type- the type of this problem.
 
- 
setPenaltypublic void setPenalty(int penalty) Sets the penalty for violated minimum.- Parameters:
- penalty- some penalty
 
- 
getTypepublic int getType()Returns the type of this problem.- Returns:
- the type of this problem.
 
- 
getTargetFunctionReturns the target function of this problem.- Returns:
- the target function of this problem.
 
- 
toString- Overrides:
- toStringin class- ConstraintSatisfactionProblem
 
- 
clone- Overrides:
- clonein class- ConstraintSatisfactionProblem
 
 
-