-
Notifications
You must be signed in to change notification settings - Fork 1
Project Structure
-
Space <- creates space
-
Creature <- something that can live inside the graph space
-
Observer <- an immaterial observer
-
World <- a graph space filled with creatures
-
Time <- allows the world to update in discrete ticks
-
Graphics <- an interface that allows to render a creature on the screen
-
Examples <- a bunch of examples of applications that use this package
- Node - a node in a graph network
- Path - a path in a network
- Plane - a regular plane
- Point - a point
- Direction - possible directions
- PointGenerator - a collection of point sets generators
An creature inside the graph space.
- Move right/left/up/down
- Get the node that the creature is placed in
- Kill
An observer of the graph space. Not placed inside the graph space, but has an associated node which is observed.
- Move right/left/up/down
- Get the node that the creature is placed in
Basically, Set<Node<Creature>>.
Implements time progression and time traveling. When getPast is invoked, a new world line is created. It is possible that two or more time lines would attaint the same state. In this case, they should be merged into one time line.
Time is a graph:
- tick - an abstract method that ticks the world according to specific implementation, preserving the previous world state
- getPast(int ticks) - returns the world state ticks ago
- getFuture(int ticks) - returns the world state ticks in the future
- Keep track of different world lines
Interface that requires implementation of a tile-rendering method. Tiles should be squares of a regular size.
- render()
- getSize()
- Life - a game of life in the graph space
- Dungeon - a dungeon crawler in the graph space
- Wireworld - a wireworld simulation in the graph space