Class HardSoftScore
- java.lang.Object
- 
- org.optaplanner.core.api.score.AbstractScore<HardSoftScore>
- 
- org.optaplanner.core.api.score.buildin.hardsoft.HardSoftScore
 
 
- 
- All Implemented Interfaces:
- Serializable,- Comparable<HardSoftScore>,- Score<HardSoftScore>
 
 public final class HardSoftScore extends AbstractScore<HardSoftScore> ThisScoreis based on 2 levels of int constraints: hard and soft. Hard constraints have priority over soft constraints. Hard constraints determine feasibility.This class is immutable. - See Also:
- Score, Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description static HardSoftScoreONE_HARDstatic HardSoftScoreONE_SOFTstatic HardSoftScoreZERO- 
Fields inherited from class org.optaplanner.core.api.score.AbstractScoreINIT_LABEL, initScore
 
- 
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description HardSoftScoreadd(HardSoftScore addend)Returns a Score whose value is (this + addend).intcompareTo(HardSoftScore other)HardSoftScoredivide(double divisor)Returns a Score whose value is (this / divisor).booleanequals(Object o)intgetHardScore()The total of the broken negative hard constraints and fulfilled positive hard constraints.intgetSoftScore()The total of the broken negative soft constraints and fulfilled positive soft constraints.inthashCode()booleanisFeasible()APlanningSolutionis feasible if it has no broken hard constraints andScore.isSolutionInitialized()is true.HardSoftScoremultiply(double multiplicand)Returns a Score whose value is (this * multiplicand).HardSoftScorenegate()Returns a Score whose value is (- this).static HardSoftScoreof(int hardScore, int softScore)static HardSoftScoreofHard(int hardScore)static HardSoftScoreofSoft(int softScore)static HardSoftScoreofUninitialized(int initScore, int hardScore, int softScore)static HardSoftScoreparseScore(String scoreString)HardSoftScorepower(double exponent)Returns a Score whose value is (this ^ exponent).HardSoftScoresubtract(HardSoftScore subtrahend)Returns a Score whose value is (this - subtrahend).Number[]toLevelNumbers()Returns an array of numbers representing the Score.StringtoShortString()LikeObject.toString(), but trims score levels which have a zero weight.StringtoString()HardSoftScorewithInitScore(int newInitScore)For example0hard/-8softwith-7returns-7init/0hard/-8soft.HardSoftScorezero()Returns a Score, all levels of which are zero.- 
Methods inherited from class org.optaplanner.core.api.score.AbstractScorebuildScorePattern, buildShortString, getInitPrefix, getInitScore, isSolutionInitialized, parseInitScore, parseLevelAsBigDecimal, parseLevelAsInt, parseLevelAsLong, parseScoreTokens
 
- 
 
- 
- 
- 
Field Detail- 
ZEROpublic static final HardSoftScore ZERO 
 - 
ONE_HARDpublic static final HardSoftScore ONE_HARD 
 - 
ONE_SOFTpublic static final HardSoftScore ONE_SOFT 
 
- 
 - 
Method Detail- 
parseScorepublic static HardSoftScore parseScore(String scoreString) 
 - 
ofUninitializedpublic static HardSoftScore ofUninitialized(int initScore, int hardScore, int softScore) 
 - 
ofpublic static HardSoftScore of(int hardScore, int softScore) 
 - 
ofHardpublic static HardSoftScore ofHard(int hardScore) 
 - 
ofSoftpublic static HardSoftScore ofSoft(int softScore) 
 - 
getHardScorepublic int getHardScore() The total of the broken negative hard constraints and fulfilled positive hard constraints. Their weight is included in the total. The hard score is usually a negative number because most use cases only have negative constraints.- Returns:
- higher is better, usually negative, 0 if no hard constraints are broken/fulfilled
 
 - 
getSoftScorepublic int getSoftScore() The total of the broken negative soft constraints and fulfilled positive soft constraints. Their weight is included in the total. The soft score is usually a negative number because most use cases only have negative constraints.In a normal score comparison, the soft score is irrelevant if the 2 scores don't have the same hard score. - Returns:
- higher is better, usually negative, 0 if no soft constraints are broken/fulfilled
 
 - 
withInitScorepublic HardSoftScore withInitScore(int newInitScore) Description copied from interface:ScoreFor example0hard/-8softwith-7returns-7init/0hard/-8soft.- Parameters:
- newInitScore- always negative (except in statistical calculations), 0 if all planning variables are initialized
- Returns:
- equals score except that Score.getInitScore()is set tonewInitScore
 
 - 
isFeasiblepublic boolean isFeasible() Description copied from interface:ScoreAPlanningSolutionis feasible if it has no broken hard constraints andScore.isSolutionInitialized()is true. Simple scores (SimpleScore,SimpleLongScore,SimpleBigDecimalScore) are always feasible, if theirScore.getInitScore()is 0.- Returns:
- true if the hard score is 0 or higher and the Score.getInitScore()is 0.
 
 - 
addpublic HardSoftScore add(HardSoftScore addend) Description copied from interface:ScoreReturns a Score whose value is (this + addend).- Parameters:
- addend- value to be added to this Score
- Returns:
- this + addend
 
 - 
subtractpublic HardSoftScore subtract(HardSoftScore subtrahend) Description copied from interface:ScoreReturns a Score whose value is (this - subtrahend).- Parameters:
- subtrahend- value to be subtracted from this Score
- Returns:
- this - subtrahend, rounded as necessary
 
 - 
multiplypublic HardSoftScore multiply(double multiplicand) Description copied from interface:ScoreReturns a Score whose value is (this * multiplicand). When rounding is needed, it should be floored (as defined byMath.floor(double)).If the implementation has a scale/precision, then the unspecified scale/precision of the double multiplicand should have no impact on the returned scale/precision. - Parameters:
- multiplicand- value to be multiplied by this Score.
- Returns:
- this * multiplicand
 
 - 
dividepublic HardSoftScore divide(double divisor) Description copied from interface:ScoreReturns a Score whose value is (this / divisor). When rounding is needed, it should be floored (as defined byMath.floor(double)).If the implementation has a scale/precision, then the unspecified scale/precision of the double divisor should have no impact on the returned scale/precision. - Parameters:
- divisor- value by which this Score is to be divided
- Returns:
- this / divisor
 
 - 
powerpublic HardSoftScore power(double exponent) Description copied from interface:ScoreReturns a Score whose value is (this ^ exponent). When rounding is needed, it should be floored (as defined byMath.floor(double)).If the implementation has a scale/precision, then the unspecified scale/precision of the double exponent should have no impact on the returned scale/precision. - Parameters:
- exponent- value by which this Score is to be powered
- Returns:
- this ^ exponent
 
 - 
negatepublic HardSoftScore negate() Description copied from interface:ScoreReturns a Score whose value is (- this).- Returns:
- - this
 
 - 
zeropublic HardSoftScore zero() Description copied from interface:ScoreReturns a Score, all levels of which are zero.- Returns:
- never null
 
 - 
toLevelNumberspublic Number[] toLevelNumbers() Description copied from interface:ScoreReturns an array of numbers representing the Score. Each number represents 1 score level. A greater score level uses a lower array index than a lesser score level.When rounding is needed, each rounding should be floored (as defined by Math.floor(double)). The length of the returned array must be stable for a specificScoreimplementation.For example: -0hard/-7softreturnsnew int{-0, -7}The level numbers do not contain the Score.getInitScore(). For example:-3init/-0hard/-7softalso returnsnew int{-0, -7}- Returns:
- never null
- See Also:
- ScoreDefinition.fromLevelNumbers(int, Number[])
 
 - 
compareTopublic int compareTo(HardSoftScore other) 
 - 
toShortStringpublic String toShortString() Description copied from interface:ScoreLikeObject.toString(), but trims score levels which have a zero weight. For example 0hard/-258soft returns -258soft.Do not use this format to persist information as text, use Object.toString()instead, so it can be parsed reliably.- Returns:
- never null
 
 
- 
 
-