Package application.model.rules.hrot
Class HROTGenerations
java.lang.Object
application.model.rules.Rule
application.model.rules.RuleFamily
application.model.rules.hrot.BaseHROT
application.model.rules.hrot.HROTGenerations
- All Implemented Interfaces:
ApgtableGeneratable
,MinMaxRuleable
,java.lang.Cloneable
public class HROTGenerations extends BaseHROT implements MinMaxRuleable, ApgtableGeneratable
Implements the HROT Generations rule family
-
Field Summary
Fields inherited from class application.model.rules.hrot.BaseHROT
hrotTransitions, neighbourhood, neighbourhoodRegex, weights
Fields inherited from class application.model.rules.Rule
alternatingPeriod, background, boundedGrid, numStates, readingOrder, tiling
-
Constructor Summary
Constructors Constructor Description HROTGenerations()
Creates a HROT Generations rule with the rule FrogsHROTGenerations(java.lang.String rulestring)
Creates a HROT Generations rule with the given rulestring -
Method Summary
Modifier and Type Method Description boolean
betweenMinMax(RuleFamily minRule, RuleFamily maxRule)
Checks if the current rule is between the given minimum and maximum rulesjava.lang.String
canonise(java.lang.String rulestring)
Canonises the inputted rulestring with the currently loaded parameters.java.lang.Object
clone()
Clones the ruleint
dependsOnNeighbours(int state, int generation, Coordinate coordinate)
If the next state of the cell depends on its neighbours, return -1.protected void
fromRulestring(java.lang.String rulestring)
Loads the rule's parameters from a rulestringRuleDirective[]
generateApgtable()
Generates an apgtable for apgsearch to usejava.lang.String[]
generateComments()
Generates comments that will be placed in the RLE.java.util.HashSet<java.lang.Integer>
getBirth()
The birth conditions of the rule (e.g.java.lang.String
getDescription()
Returns a plain text description of the HROT Generations rule family to be displayed in the Rule Dialogorg.javatuples.Pair<RuleFamily,RuleFamily>
getMinMaxRule(Grid[] grids)
Returns the minimum and maximum rule of the provided evolutionary sequencejava.lang.String[]
getRegex()
The regexes that will match a valid rulestringint[]
getStateWeights()
Gets the state weights of the HROT Generations rulejava.util.HashSet<java.lang.Integer>
getSurvival()
The survival conditions of the rule (e.g.void
loadComments(java.lang.String[] comments)
Loads the weights stored in the comments generated by generateCommentsvoid
randomise(RuleFamily minRule, RuleFamily maxRule)
Randomise the parameters of the current rule to be between minimum and maximum rules Used in CAViewer's rule search programvoid
setBirth(java.util.HashSet<java.lang.Integer> birth)
Sets the birth conditions of the rulevoid
setStateWeights(int[] stateWeights)
Sets the states weights of the rulevoid
setSurvival(java.util.HashSet<java.lang.Integer> survival)
Sets the survival conditions of the ruleint
transitionFunc(int[] neighbours, int cellState, int generations, Coordinate coordinate)
This method represents the transition function of the rulevoid
updateBackground()
Updates the background based on the currently loaded parametersboolean
validMinMax(RuleFamily minRule, RuleFamily maxRule)
Checks if the minimum rule and maximum rules provided are validMethods inherited from class application.model.rules.hrot.BaseHROT
getNeighbourhood, getNeighbourhoodSpecifier, getRuleInfo, getWeights, loadNeighbourhood, setNeighbourhood, setWeights
Methods inherited from class application.model.rules.RuleFamily
equals, getName, getNeighbourList, getRulestring, hashCode, setRulestring, toString
Methods inherited from class application.model.rules.Rule
convertState, getAlternatingPeriod, getBoundedGrid, getColour, getName, getNeighbourhood, getNumStates, getTiling, setBackground, setBoundedGrid, setReadingOrder, step
-
Constructor Details
-
HROTGenerations
public HROTGenerations()Creates a HROT Generations rule with the rule Frogs -
HROTGenerations
public HROTGenerations(java.lang.String rulestring)Creates a HROT Generations rule with the given rulestring- Parameters:
rulestring
- The rulestring of the HROT Generations rule to be created- Throws:
java.lang.IllegalArgumentException
- Thrown if the rulestring is invalid
-
-
Method Details
-
fromRulestring
protected void fromRulestring(java.lang.String rulestring) throws java.lang.IllegalArgumentExceptionLoads the rule's parameters from a rulestring- Specified by:
fromRulestring
in classRuleFamily
- Parameters:
rulestring
- The rulestring of the HROT Generations rule (eg. R1,C3,S1-2,B3-4,NM)- Throws:
java.lang.IllegalArgumentException
- Thrown if an invalid rulestring is passed in
-
canonise
public java.lang.String canonise(java.lang.String rulestring)Canonises the inputted rulestring with the currently loaded parameters.- Specified by:
canonise
in classRuleFamily
- Parameters:
rulestring
- The rulestring to canonised- Returns:
- Canonised rulestring
-
updateBackground
public void updateBackground()Updates the background based on the currently loaded parameters- Overrides:
updateBackground
in classRuleFamily
-
getRegex
public java.lang.String[] getRegex()The regexes that will match a valid rulestring- Specified by:
getRegex
in classRuleFamily
- Returns:
- An array of regexes that will match a valid rulestring
-
getDescription
public java.lang.String getDescription()Returns a plain text description of the HROT Generations rule family to be displayed in the Rule Dialog- Specified by:
getDescription
in classRuleFamily
- Returns:
- Description of the HROT Generations rule family
-
randomise
public void randomise(RuleFamily minRule, RuleFamily maxRule) throws java.lang.IllegalArgumentExceptionRandomise the parameters of the current rule to be between minimum and maximum rules Used in CAViewer's rule search program- Specified by:
randomise
in interfaceMinMaxRuleable
- Parameters:
minRule
- The minimum rule for randomisationmaxRule
- The maximum rule for randomisation- Throws:
java.lang.IllegalArgumentException
- Thrown if the minimum and maximum rules are invalid
-
getMinMaxRule
Returns the minimum and maximum rule of the provided evolutionary sequence- Specified by:
getMinMaxRule
in interfaceMinMaxRuleable
- Parameters:
grids
- An array of grids representing the evolutionary sequence- Returns:
- A pair containing the min rule as the first value and the max rule as the second value
-
betweenMinMax
public boolean betweenMinMax(RuleFamily minRule, RuleFamily maxRule) throws java.lang.IllegalArgumentExceptionChecks if the current rule is between the given minimum and maximum rules- Specified by:
betweenMinMax
in interfaceMinMaxRuleable
- Parameters:
minRule
- The minimum rulemaxRule
- The maximum rule- Returns:
- True if the current rule is between minimum and maximum rules and false if the current rule is not between the minimum and maximum rules
- Throws:
java.lang.IllegalArgumentException
- Thrown if the minimum rule and maximum rule are invalid
-
validMinMax
Checks if the minimum rule and maximum rules provided are valid- Specified by:
validMinMax
in interfaceMinMaxRuleable
- Parameters:
minRule
- The minimum rule to checkmaxRule
- The maximum rule to check- Returns:
- True if the minimum and maximum rules are valid and false if the minimum and maximum rules are not valid
-
generateApgtable
Generates an apgtable for apgsearch to use- Specified by:
generateApgtable
in interfaceApgtableGeneratable
- Returns:
- True if the operation was successful, false otherwise
-
generateComments
public java.lang.String[] generateComments()Generates comments that will be placed in the RLE. These comments represent weights. They are only generated if the neighbourhood specifier is N@ with no additional hex digits- Overrides:
generateComments
in classBaseHROT
- Returns:
- An array of comments each starting with "#R" (eg. {"#R 1 2 3 2 1", "#R 2 4 6 4 2"}). If no additional information needs to be added return null or an empty string array.
-
loadComments
public void loadComments(java.lang.String[] comments)Loads the weights stored in the comments generated by generateComments- Overrides:
loadComments
in classBaseHROT
- Parameters:
comments
- The comments from the RLE (all starting with #R)
-
getBirth
public java.util.HashSet<java.lang.Integer> getBirth()The birth conditions of the rule (e.g. {2, 3})- Returns:
- Birth conditions of the rule
-
getSurvival
public java.util.HashSet<java.lang.Integer> getSurvival()The survival conditions of the rule (e.g. {2, 3})- Returns:
- Survival conditions of the rule
-
getStateWeights
public int[] getStateWeights()Gets the state weights of the HROT Generations rule- Returns:
- State weights of the HROT Generations rule
-
setBirth
public void setBirth(java.util.HashSet<java.lang.Integer> birth)Sets the birth conditions of the rule- Parameters:
birth
- Birth conditions of the rule
-
setSurvival
public void setSurvival(java.util.HashSet<java.lang.Integer> survival)Sets the survival conditions of the rule- Parameters:
survival
- Birth conditions of the rule
-
setStateWeights
public void setStateWeights(int[] stateWeights)Sets the states weights of the rule- Parameters:
stateWeights
- State weights of the rule
-
clone
public java.lang.Object clone()Clones the rule- Specified by:
clone
in classRuleFamily
- Returns:
- Returns a deep copy of the HROT generations rule
-
transitionFunc
Description copied from class:Rule
This method represents the transition function of the rule- Specified by:
transitionFunc
in classRule
- Parameters:
neighbours
- The cell's neighbours in the order of the neighbourhood providedcellState
- The current state of the cellgenerations
- The current generation of the simulationcoordinate
- The coordinate of the cell- Returns:
- The state of the cell in the next generation
-
dependsOnNeighbours
Description copied from class:Rule
If the next state of the cell depends on its neighbours, return -1. If not return the next state of the cell.- Overrides:
dependsOnNeighbours
in classRule
- Parameters:
state
- The current state of the cellgeneration
- The generation of the simulationcoordinate
- The coordinate of the cell- Returns:
- Returns -1 or the next state of the cell
-