 
 
 
 
 
   
In our conversations about how to design our Hydractinia, we focused on several key questions:
 at each timestep
 at each timestep
 , spawn. If reproducing, check in a random order the von Neumann neighborhood of adjacent cells for one that is empty. The first empty cell found becomes the location of the new agent.
, spawn. If reproducing, check in a random order the von Neumann neighborhood of adjacent cells for one that is empty. The first empty cell found becomes the location of the new agent. 
 ,
, 
 and
 and 
 ). Clearly in this case, the two hostile colonies should not be counted as part of the same colony, yet from the perspective of a member of the neutral colony, they should be. Fundamentally, the problem with counting colony membership arises from the fact that allorecognition is not transitive: if colony A recognizes colony B, and colony B recognizes colony C, then colony A does not necessarily recognize colony C. Because the idea of counting colony size is motivated by the sharing of resources among fused colonies, it was not clear how to resolve a situation in which colonies A shares resources with C via B, yet A and C would not normally share resources. One could potentially simply count all cells with which a cell would recognize directly or indirectly (via any number of intermediaries). However, even this approach is problematic, as one may enough up counting all cells as being part of one super colony despite may on-going internal conflicts! At some point, either arbitrary demarcations must be made, or one must accept the potential that the metric does not truly differentiate colonies in the desired way.
). Clearly in this case, the two hostile colonies should not be counted as part of the same colony, yet from the perspective of a member of the neutral colony, they should be. Fundamentally, the problem with counting colony membership arises from the fact that allorecognition is not transitive: if colony A recognizes colony B, and colony B recognizes colony C, then colony A does not necessarily recognize colony C. Because the idea of counting colony size is motivated by the sharing of resources among fused colonies, it was not clear how to resolve a situation in which colonies A shares resources with C via B, yet A and C would not normally share resources. One could potentially simply count all cells with which a cell would recognize directly or indirectly (via any number of intermediaries). However, even this approach is problematic, as one may enough up counting all cells as being part of one super colony despite may on-going internal conflicts! At some point, either arbitrary demarcations must be made, or one must accept the potential that the metric does not truly differentiate colonies in the desired way.
As such, we decided to attempt to subsume the idea that a larger colony has more resources to devote to fights into other aspects of the model and have local interactions dictate all of the model dynamics rather than a mixture of both global and local properties. As a result, we defined a set of model probability parameters which represented the rules given in the assignment description.
 , the probability that a stolon-stolon or unfused-unfused fight will be won by the aggressor
, the probability that a stolon-stolon or unfused-unfused fight will be won by the aggressor
 , the probability that a stolon-unfused mat fight will be won by the stolon cell
, the probability that a stolon-unfused mat fight will be won by the stolon cell
Unfused mat cells obviously have an advantage over all other colonies. They can fight and, due to the increased reproductive potential that comes with nearby mat cells, reproduce faster. Setting 
 gives the stolon colonies a slight advantage, which is exacerbated by having a larger colony size; however, this advantage should be mitigated by an unfused mat cell colony's greater reproductive rate. Otherwise, our model follows exactly the one described in the assignment.
 gives the stolon colonies a slight advantage, which is exacerbated by having a larger colony size; however, this advantage should be mitigated by an unfused mat cell colony's greater reproductive rate. Otherwise, our model follows exactly the one described in the assignment.
We also defined the following other paramaters for our model:
 , the probability at each time-step that an agent will die. The distribution of lifespans is thus a binomial one centered around
, the probability at each time-step that an agent will die. The distribution of lifespans is thus a binomial one centered around 
![$ E[lifespan]= \frac{1}{P_{death}}$](img16.png) 
 , the base probability of reproducing for any morphological cell type at each time step. A binomial distribution with average
, the base probability of reproducing for any morphological cell type at each time step. A binomial distribution with average 
![$ E[spawn,base]=\frac{1}{P_{spawn,base}}$](img18.png) 
 , the probability added to
, the probability added to 
 for each mat cell within Manhattan distance
 for each mat cell within Manhattan distance  of the spawning agent.
 of the spawning agent.
 , the probability of choosing a random new morphology for the daughter cells when a cell splits
, the probability of choosing a random new morphology for the daughter cells when a cell splits
 , the probability of choosing a random new chromosome (for each of the two) for the daughter cells when a cell splits
, the probability of choosing a random new chromosome (for each of the two) for the daughter cells when a cell splits
For visualization, we used the gd libraries to write color PNG image files of the cell-array at each timestep. Using the unix utility convert, we collapsed the set of image files into a MNG movie file. You can view the movies of the experiments we cite here at http://www.cs.unm.edu/brainsik/cnid/. The hues red, blue and yellow were assigned to the three morphologies, stolon, unfused mat and fused mat respectively. Combinations of saturation and value were used to differentiate the nine different genotypes possible for each of the three colors.
A link to the source code for our Hydractinia model can be found on the main Hydractinia page.
 
 
 
 
