Skip to content

Latest commit

 

History

History
executable file
·
145 lines (113 loc) · 12.5 KB

README.md

File metadata and controls

executable file
·
145 lines (113 loc) · 12.5 KB

simulation

This project implements a cellular automata simulator.

Names:

  • Mariusz Derezinski-Choo
  • Tyler Jang
  • Thomas Quintanilla

Timeline

Start Date: 01/26/20

Finish Date: 02/09/29

Hours Spent: 80

Primary Roles

Tyler

Tyler worked on the Controller part of the project. He implemented the XML parsers, and designed the XML structure so that the XMLs could be converted to a Simulation and a Style. Tyler worked on the logic behind the methods to start, stop, and step through the simulation. The central components of this work are in SimulationControl.

Thomas

Thomas worked on developing the various different types of cells and Grids for the Model. This was accomplished by adding several subclasses to the abstract Cell and Grid classes in the model. The structured use of inheritance allows for different Grid types to be easily instantiated in Controller depending on the file uploaded.

Mariusz

Mariusz worked on rendering the various elements of the GUI for the View, and connecting them to the Controller via the use of EventHandlers and ChangeListeners. He constructed generic listeners in the Controller that could be added to the graphics elements once they were rendered. The appearance of the elements were styled with the use of css.

Resources Used

Spike Simulation for XML parsing and enumerated types

Game Of Life for Conway's Game of Life specification

Percolation for Percolation algorithm

Segregation for Segregation specification

Wa-Tor World for Predator-Prey specification

Fire Spreading for fire specification

Rock-Paper-Scissors for Rock-Paper-Scissors algorithm

XML Parsing for XML parsing

XML Writing for writing to XML files

Running the Program

Main class: Main.java

Creates an instance of SimulationControl.java on start, which in turn creates ConfigParser.java, StyleParser.java, ApplicationView.java, and Grid.java instances to build the simulation.

Data files needed:

An XML fitting the format for a Simulation type. For examples, see:

  • Fire1.xml: a basic Fire simulation with all values specified
  • Fire2.xml: a basic Fire simulation with some values specified
  • Fire3.xml: a basic Fire simulation with random values
  • Fire4.xml: a basic Fire simulation with parametrized random values
  • GameOfLife1.xml: a basic Game of Life simulation with all values specified
  • GameOfLife2.xml: a basic Game of Life simulation with some values specified
  • GameOfLife3.xml: a basic Game of Life simulation with random values
  • GameOfLife4.xml: a basic Game of Life simulation with parametrized random values for a hexagonal grid
  • GameOfLife5.xml: a basic Game of Life simulation with all values specified for a hexagonal grid
  • Percolation1.xml: a basic Percolation simulation with all values specified
  • Percolation2.xml: a basic Percolation simulation with some values specified
  • Percolation3.xml: a basic Percolation simulation with random values
  • Percolation4.xml: a basic Percolation simulation with parametrized random values
  • PredatorPrey1.xml: a basic Predator-Prey simulation with all values specified
  • PredatorPrey2.xml: a basic Predator-Prey simulation with some values specified
  • PredatorPrey3.xml: a basic Predator-Prey simulation with random values
  • PredatorPrey4.xml: a basic Predator-Prey simulation with parametrized random values
  • RockPaperScissors1.xml: a basic Rock-Paper-Scissors simulation with all values specified
  • RockPaperScissors2.xml: a basic Rock-Paper-Scissors simulation with some values specified
  • RockPaperScissors3.xml: a basic Rock-Paper-Scissors simulation with random values
  • RockPaperScissors4.xml: a basic Rock-Paper-Scissors simulation with parametrized random values
  • Segregation1.xml: a basic Segregation simulation with all values specified
  • Segregation2.xml: a basic Segregation simulation with some values specified
  • Segregation3.xml: a basic Segregation simulation with random values
  • Segregation4.xml: a basic Segregation simulation with parametrized random values

In creating the XML configuration files, it is also important to know what not to include. The following XML files exhibit problems that may arise:

  • BadFire.xml: The grid_type attribute is outside the normal bounds of 0-3. It defaults to 3. The rate is also much larger than the allowed 1-10, so it defaults to 5. Lastly, an extraneous field called "dummy" is included, but ignored in the configuration process.
  • BadGameOfLife.xml: The grid is incomplete and also includes extraneous values. These are ignored, and any missing cells default to a value of 0.
  • BadPredatorPrey.xml: The title attribute contains a misspelling, but is understood to be PredatorPrey. Additional extraneous fields are also ignored.
  • TerriblePercolation.xml: The file contains irredeemable errors with double values across several attributes. This prompts the user to fix the error or choose a new configuration file.

Additional required resource files (in the Resources Root) include:

  • English.properties: A properties specifying language-dependent Strings for all XML-related and displayable contexts.
  • ImageBundle: A Java class containing a bundle of image files for use in the project. Only images specified here may be accessed from Styling.xml.
  • Styling.xml: An XML file containing style configuration for each simulation type, including outlines, sizing, and what the cells should be filled with (images or colors).
  • style.css: A css file that contains styling information for the various NOdes Features implemented:

This project implements a basic user interface in which XML configuration files can be specified to control parameters of five different simulations:

  • Fire: A cell may either be empty, tree, or burning. If a tree's neighbor is burning, it has a chance, catch, of catching fire. Burning cells turn to empty after one turn.
  • Game Of Life: A cell may either be dead or alive. If a live cell has 0-1 or 4-8 live neighbors, it dies. If a dead cell has three live neighbors, it will become alive.
  • Percolation: A cell may either be closed, opened, or filled. If a cell is opened and has a filled neighbor on top of it, it will become filled on the next turn.
  • Predator-Prey: A cell may either be empty, fish, or shark. If a shark has been alive shark_starve turns, it will die. If a shark has been alive shark_breed turns, it will spawn another shark. If a fish has been alive fish_breed turns, it will spawn another shark. If a shark is near a fish, it will move toward the fish. If a shark is neighboring a fish, the fish will die and become empty.
  • Rock-Paper-Scissors: A cell may either be rock, paper, or scissors. Per the traditional game, rock beats scissors, scissors beats paper, and paper beats rock in a transitive loop. If a cell loses multiple times in a row, it will be replaced by the type that defeated it.
  • Segregation: A cell may either be empty, A, or B. If a cell is A or B, and less than threshold % of its neighbors are of the same type, it will move to a random empty space on the next turn.

XML files must adhere to the different simulation types' settings, but allow for "all", "some", "random," and "parametrized random" cell specifications.

In addition to specifying a configuration file, the user interface allows for the frame rate to be changed. It displays the grid and a log of any potential error messages.

This front end is made possible by a back end implementation of Grid, in which Cells update based on fixed rules regarding their neighbors.

Additional features include:

  • XMLWriting: The user may save the current configuration and grid states to an XML file that can be loaded later in data/.
  • Hexagonal Cells: The user may configure simulations with hexagonal cells.
  • Cell Images: The user may opt for cells to be filled with images instead of colors.
  • Scrolling: The user may scroll to reach cells outside the main viewing area.
  • Live Graph: The user is presented with a live graph showing the distributions of different states over the lifetime of the simulation.
  • Edges: Based on the input XML files, the user can choose whether a simulation will have fixed, toroidal, or PacMan-style edges.

Notes/Assumptions

Assumptions or Simplifications:

  • Different simulations all share the same default cell color scheme (red = 1, blue = 2, black = 0/empty).
  • Each cell has access to its neighboring cells so that calculating the next state for each cell would be easier to handle.
  • Assumptions for simulation rules:
    • Fire: each burning neighbor of a not burning tree cell has a set % chance to spread the fire to the cell. The rule description was vague on whether this probability is only checked once no matter how many neighbors are burning or if its checked per neighbor.
    • PredatorPrey: A fish who meets breeding threshold but cannot reproduce due to neighboring cells being occupied will reproduce any step after where an adjacent cell is free.
    • PredatorPrey: It is interpreted when the rules state "After eating or moving" that a shark can not do both.
    • Segregation: Randomly moving unsatisfied cells will eventually balance out.
  • the window is not resizeable
  • the positioning of the UI components can not be modified by the configuration files (with the exception of the Cells, of course)

Interesting data files: * The 3rd data file for each simulation type creates a 30x30 grid of cells with a random state for each cell. So it's interesting to see patterns that occur when run multiple times.

Extra credit: The XML reader can take in different reading types. If the type is all, then every cell type and state is specified within the XML file. If the type is some, then some cells are specified and others are set to 0. If the type is random, then all cells are randomly generated. If the type is parametrized random, then all cells are randomly generated based on fixed rules.

A live line graph was generated to display state distributions over time.

GUI design choices

  • We opted to have all of the GUI in one window as we felt it was a more streamlined appearance and also made everything must easier to keep track of in the View as it was all in one Scene
  • A BorderPane is a clear choice for the Parent node as it's children's locations match with our original idea of having a console at the bottom, a dashboard on the left, and the grid in the middle
  • This also means that each component (console, dashboard, and grid) had clear separation

Impressions

Overall the project maintains good separation of Model, View, and Controller. The Model stores the details of the Grid without understanding any of the implementation behind viewing, loading, and running the simulations. That job is handled by the Controller. Meanwhile, View, dislays the Grid without worrying about how each state is calculated. This allows for each component to be developed separately by different developers. Model makes use of inheritance to define different types of Grids and Cells, which would allow for future rules to be easy added to the application. View makes use of EventHandlers and ChangeListeners to bind actions performed by the user on the GUI to logic in the Controller. This abstracts away from the Controller, and means the graphic elements can be rendered in whatever manner, as long as they are compatible with the listeners provided. Controller makes use of Exceptions, such as the custom-made ConfigParser, to handle bad input cased by illegal actions taken by the user. This information is logged to the ApplicationView console, and allows for error messages to be displayed to the user. This lets the user correct their behavior while simulatneously ensuring that bad input does not crash the program.